tcp处理



进入包的处理(net/ipv4/tcp_input.c)

接收的段都由tcp_v4_do_rcv处理,该函数根据不同的状态交由不同的函数处理。LISTEN状态且已建立半连接的处理函数为tcp_v4_hnd_req,其他状态为tcp_rcv_state_process

tcp_rcv_established处理从一个建立的连接进入的tcp包,是处理tcp包的唯一入口点。Linux有两种方法处理tcp包:快速路径和慢速路径。

tcp_ack 处理ack或带ack的数据包

tcp_event_data_recv 处理tcp包。在接收到顺序数据段时处理。

tcp_data_queue() 处理数据段中的数据。套接字缓冲耗尽或者乱序,在这里面处理。此外还要处理重复数据段、窗口外数据段以及重传。


降窗函数tcp_cwnd_down

tcp_cong_void处理拥塞避免。实现了慢速启动和快速重传的拥塞控制算法。完全的拥塞控制机制在tcp_fastretrans_alert中实现。在tcp_ack中会调用tcp_fastretrans_alert函数


tcp_select_window计算通告窗口

tcp_push 发送数据


tcp_congestion_ops结构提纲了支持多种拥塞控制的机制。需要实现tcp_congestion_ops中的接口,必须实现ssthresh、cong_svoid。
必须将拥塞控制算法的名称添加到/proc/sys/net/ipv4/tcp_congestion_control中才能使用。比如要使用Bic和veno算法:
echo "bic veno">/proc/sys/net/ipv4/tcp_congestion_control

tcp_register_congestion_control将一个新的拥塞控制算法注册到tcp_congestion_ops中。除了reno,其他的拥塞控制算法都是作为模块在module_init中注册的。如bictcp_register、cubic_register。

选取某种拥塞控制算法tcp_set_congestion_control


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值