登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
AI 队友
登录
注册
代码拉取完成,页面将自动刷新
开源项目
>
其他开源
>
操作系统
&&
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
17
Star
203
Fork
34
GVP
openvela
/
nuttx
代码
Issues
1
Pull Requests
1
Wiki
统计
流水线
服务
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
我知道了,不再自动展开
1
tcp timer异常导致重传时间异常变大
已关闭
meissi_jian:dev
openvela:dev
meissi_jian
创建于 2024-12-20 16:25
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
概要:tcp发生重传之后,tcp重传时间异常 1. 在TCP连接发生重传之后,tcp backoff 算法更新了conn->timer 2. 在重传恢复之后,Jacobson / Karels 算法,其中RTTest M = conn->rto - conn->timer为负,导致conn->sa为负值并翻转,从而使conn->rto异常变大 测试: 在tcp_input拦截ack包,制造丢包,并打印Jacobson / Karels 算法后的conn->rto ``` diff --git a/net/tcp/tcp_input.c b/net/tcp/tcp_input.c index 70b99f345b..b812ef3ff5 100644 --- a/net/tcp/tcp_input.c +++ b/net/tcp/tcp_input.c @@ -61,6 +61,7 @@ #include "devif/devif.h" #include "utils/utils.h" #include "tcp/tcp.h" @@ -742,6 +743,13 @@ static void tcp_input(FAR struct net_driver_s *dev, uint8_t domain, /* Demultiplex this segment. First check any active connections. */ conn = tcp_active(dev, tcp); + if (((tcp->flags & TCP_CTL) == (TCP_SYN | TCP_ACK)) && conn->drop_count < 2) + { + conn->drop_count++; + printf("WARNING: ************* Drop first sync ack packet \n"); + goto drop; + } + if (conn) { /* We found an active connection.. Check for the subsequent SYN @@ -1135,6 +1143,8 @@ found: m = m - (conn->sv >> 2); conn->sv += m; conn->rto = (conn->sa >> 3) + conn->sv; + printf("WARNING:### conn=%p conn->rto=%d m=%d conn->timer=%d conn->sv=%d conn->sa=%d ###\n", + conn, (int)conn->rto, (int)m,(int)conn->timer,(int)conn->sv,(int)conn->sa); } ``` 合入patch前测试结果: ``` nsh> iperf -c 10.192.41.28 -t 5 -i 1 IP: 192.168.31.92 mode=tcp-client sip=192.168.31.92:5001,dip=10.192.41.28:5001, interval=1, time=5 *****tcp_timer 0 WARNING: ************* Drop first sync ack packet WARNING: ************* Drop first sync ack packet *****tcp_timer 3 WARNING:### conn=0x3fc8d8a0 conn->rto=46 m=-1 conn->timer=6 conn->sv=15 conn->sa=253 ### WARNING:### conn=0x3fc8d8a0 conn->rto=70 m=28 conn->timer=46 conn->sv=43 conn->sa=222 ### WARNING:### conn=0x3fc8d8a0 conn->rto=84 m=17 conn->timer=70 conn->sv=60 conn->sa=195 ### WARNING:### conn=0x3fc8d8a0 conn->rto=90 m=9 conn->timer=84 conn->sv=69 conn->sa=171 ### WARNING:### conn=0x3fc8d8a0 conn->rto=91 m=4 conn->timer=90 conn->sv=73 conn->sa=150 ### WARNING:### conn=0x3fc8d8a0 conn->rto=89 m=0 conn->timer=91 conn->sv=73 conn->sa=132 ### WARNING:### conn=0x3fc8d8a0 conn->rto=85 m=-2 conn->timer=89 conn->sv=71 conn->sa=116 ### WARNING:### conn=0x3fc8d8a0 conn->rto=80 m=-3 conn->timer=85 conn->sv=68 conn->sa=102 ### ``` 合入patch后测试结果 ``` nsh> iperf -c 10.192.41.28 -t 10 -i 1 IP: 192.168.31.92 mode=tcp-client sip=192.168.31.92:5001,dip=10.192.41.28:5001, interval=1, time=10 *****tcp_timer 0 WARNING: ************* Drop first sync ack packet WARNING: ************* Drop first sync ack packet *****tcp_timer 3 WARNING:### conn=0x3fc8e010 conn->rto=12 m=-4 conn->timer=6 conn->sv=12 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=9 m=-3 conn->timer=12 conn->sv=9 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=7 m=-2 conn->timer=9 conn->sv=7 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=6 m=-1 conn->timer=7 conn->sv=6 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=5 m=-1 conn->timer=6 conn->sv=5 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=4 m=-1 conn->timer=5 conn->sv=4 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=-1 conn->timer=4 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### WARNING:### conn=0x3fc8e010 conn->rto=3 m=0 conn->timer=3 conn->sv=3 conn->sa=0 ### ```
此 Pull Request 需要贡献者签署贡献者协议后方可合并。
此 Pull Request 需要通过一些审核项
类型
指派人员
状态
审查
openvela-robot
进行中
(0/1人)
测试
openvela-robot
进行中
(0/1人)
怎样手动合并此 Pull Request
git checkout dev
git pull https://gitee.com/meissi-jian/nuttx.git dev
git push origin dev
评论
2
提交
1
文件
1
检查
代码问题
0
批量操作
展开设置
折叠设置
审查
Code Owner
审查人员
tanghao
tanghaoruoyi
李桂丁
li-guiding
openvela-robot
openvela-robot
未设置
最少人数
1
测试
tanghao
tanghaoruoyi
李桂丁
li-guiding
openvela-robot
openvela-robot
未设置
最少人数
1
优先级
不指定
严重
主要
次要
不重要
标签
未设置
关联 Issue
未关联
Pull Request 合并后将关闭上述关联 Issue
里程碑
未关联里程碑
参与者
(3)
C
1
https://gitee.com/open-vela/nuttx.git
git@gitee.com:open-vela/nuttx.git
open-vela
nuttx
nuttx
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册