linux tcp默认报文分片,深入理解TCP/IP协议的实现之ip分片(基于linux1.2.13)

本文详细探讨了Linux系统中TCP/IP协议的IP分片过程。通过分析ip_fragment函数,阐述了当数据包超过以太网MTU限制时,如何在IP层进行分片,并介绍了分片的主要逻辑,包括新内存的申请、数据复制以及IP报文字段的修改。此外,解释了IP_DF标志与ICMP Frag_Needed响应的关联。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上次分析了ip分片重组,这次分析一下ip分片。首先我们要先了解为什么需要分片。比如在以太网中,使用CSMA/CD协议(由网卡实现),他规定了一个链路层数据包(不包括mac头,但是这一版内核实现的时候是包括了mac头的大小)的最大值(MTU)和最小值。所以如果上层的包大于这个阈值就需要被分片。而分片和组包的实现是在ip层。我们看一下具体的逻辑。ip分片的逻辑在ip_fragment函数里实现。

void ip_fragment(

struct sock *sk,

struct sk_buff *skb,

struct device *dev,

int is_frag

)

定义的一些变量。

struct iphdr *iph;

unsigned char *raw;

unsigned char *ptr;

struct sk_buff *skb2;

int left, mtu, hlen, len;

int offset;

unsigned long flags;

// mac首地址

raw = skb->data;

// ip头首地址,hard_header_len为mac头大小

iph = (struct iphdr *) (raw + dev->hard_header_len);

skb->ip_hdr = iph;

// ip头的大小,不包括数据部分

hlen = 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值