免费获取
|
论文天下网
|
原创毕业论文
|
论文范文
|
论文下载
|
计算机论文
|
论文降重
|
论文排版
|
外文翻译
|
免费论文
|
开题报告
|
心得体会
|
全站搜索
当前位置:
论文天下网
->
免费论文
->
电子通信
IP协议设计实现—重装模块(三)
_dst.s_addr&&ip->ip_p==fp->ipq_p) goto found;
found: /*调整ip_len*/
ip->ip_len-=heln; /*有更多分片就创建ip_mff,并将偏移量*/ ((struct ipasfrag *)ip)->ip_mff&=~1;/ *转换成字节*/
if(ip->ip_off&IP_MF) ((struct ipasfrag *) ip)->ipf_mff |=1;
ip->ip_off<<=3;
if(((struct ipasfrag *) ip)->ipf_mff&1||ip->ip_off)
ipstat.ips_fragments++;
/*如果此数据报有更多的分片或者这不是第一个分片,就试图重
*装,调用 ip_reass函数,如果成功,就继续*/
ip=ip_reass((struct ipasfrag *)ip,fp);
if(ip==0) goto next;
ipstat.ips_reassembled++;
m=dtom(ip);
}else if(fp) ip_freef(fp);
}else ip->ip_len-=hlen;
}
ip_reass函数实现:
struct ip *
struct ipasfrag *ip;
struct ipq *fp;
ip_reass(ip,fp)
{ struct mbuf *m=dtom(ip);
struct ipasfrag *q;
struct mbuf *t;
int hlen=ip->ip_hl<<2;/*
int i,next;
m->m_data+=heln;
m->m_len-=hlen;
/*当第一个分片到来时,创建一个重装表*/
if(fp==0){
if(t=m_get(M_DONTWAIT,MT_FTABLE))==null)
goto dropfrag;
fp=mtod(t,struct ipq *);
insque(fp,&ipq);
fp->ipq_ttl=IPFRAGTTL;
fp->ipq_p=ip->ip_p;
fp->ipq_id=ip->ip_id;
fp->ipq_next=fp->ipq_prev=(struct ipasfrag *) fp;
fp->ipq_src=((struct ip *) ip)->ip_src;
p->ipq_dst=((struct ip *) ip)->ip_dst;
q=(struct ipasfrag *) fp;
goto insert;}
for(q=fp->ipq_next;q!=(struct ipasfrag *) fp;q=q->ipf_next)
if(q->ip_off>ip->ip_off) break;
/*搜索数据链表找到一个偏移
*大于ip_off的*分片*/
if(q->ipf_prev!=(struct ipasfrag *)fp){
i=q->ipf_prev->ip_off+q->ipf_prev->ip_len-ip->ip_off;
if(i>0){
/*把新片中与早到分片末尾重叠的字节丢弃,切断重复部分,或
*者新片在以前都已经出现,则丢弃所有新片*/
if(i>=ip->ip_len) goto dropfrag;
m_adj(dtom(ip),i);
ip->ip_off+=i;
ip->ip_len-=i;
}}
while(q!=(struct ipasfrag*)fp&&ip->ip_off+ip->ip_len>ip->
ip_off){
i=(ip->ip_off)+ip->ip_len-q->ip_off;
q->ip_len-=i;
q->ip_off+=i;
m_adj(dtom(q),i);
break;}
q=q->ipf_next;
m_freem(dtom(q->ipf_prev));
ip_deq(q->ipf_prev);
}/*截断或丢弃已有的分片*/
insert:
ip_enq(ip,q->ipf_prev);
next=0;
for(q=fp->ipq_next;q!=(struct ipasfrag *)fp;q=q->ipf_next){
if(q->ip_off!=next) return 0;
next +=q->ip_len;
}
if(q->ipf_prev->ipf_mff&1) return 0;/*将到达分片插入重装链*表 */
q=fp->ipq_next;
m=dtom(q);
t=m->m_next;
m->m_next=0;
m_cat(m,t);
q=q->ipf_next;
while(q!=(struct ipasfrag *)fp){
t=dtom(q);
q=q->ipf_next;
m_cat(m,t);
}/*如果所有分片都已接收,用m_cat把分片重装成数据报*/
ip=fp->ipq_next;
ip->ip_len=next;
ip->ipf_mff&=~1;
((struct ip *)ip)->ip_src=fp->ipq_src;
((struct ip *)ip)->ip_dst=fp->ipq_dst;
remque(fp);
(void) m_free(dtom(fp));
m=dtom(ip);
m->m_len+=(ip->ip_hl<<2);
m->m_data-=(ip->ip_hl<<2);
/*重建数据报首部*/
if(m->m_flags&M_PKTHDR){
int plen=0;
for( t=m; m;m=m->m_next)
plen+=m->m_len;
t->m_pkthdr.len=plen;
}
return( (struct ip *)ip);/*计算缓存链中数据的字节数,并保存在
* m_pkthdr.len中*/
}
心得体会
通过
首页
上一页
1
2
3
4
下一页
尾页
3
/4/4
相关论文
上一篇
:
DDS的杂散对比与级联方案的研究
下一篇
:
MATLAB正交振幅调制解调仿真分析
推荐论文
本专业最新论文
Tags:
协议
设计
实现
模块
2010-04-11 22:02:33【
返回顶部
】
相关栏目
自动化相关
计算机论文
工程管理论文
法律论文
医学论文
人力资源
电子专业
电气工程
英语论文
行政管理
电子商务
社科文学
教育论文
物流专业
金融专业
财务管理
会计专业
化学化工材料科学
电子通信
环境科学
经济类
机械模具类
报告,总结,申请书
其他专业论文