本文主要讲解了Linux内核数据包的传输流程,使用的内核的版本是2.6.32.27
为了方便理解,本文采用整体流程图加伪代码的方式从内核高层面上梳理了二层数据包发送传输的流程,希望可以对大家有所帮助。阅读本文章假设大家对C语言有了一定的了解
整体流程如下
数据包的传输可以分为两种:
一种是正常的传输流程,即一般网卡的发送流程用于一般的;另一种是基于软中断的发送流程,这种发送流程用于CPU冲突时候的重新调度和QOS的流量整形
正常的传输流程伪代码如下:
/*正常传输流程*/
/*高层协议dev_queue_xmit(skb)发送数据报文*/
static int pppoe_sendmsg(struct kiocb *iocb, struct socket *sock, struct msghdr *m, size_t total_len)
{
` skb = sock_wmalloc(sk, total_len + dev->hard_header_len + 32, 0, GFP_KERNEL);
if (!skb) {
error = -ENOMEM;
goto end;
}
//......
dev_queue_xmit(skb);
end:
release_sock(sk);
return error;
}
/*正常传输流程*/
int dev_queue_xmit(struct sk_buff *skb)
{
struct n

本文详细阐述了Linux 2.6.32.27内核中数据包的发送流程,包括正常传输和基于软中断的流程。通过整体流程图和伪代码,帮助读者理解二层数据包的传输机制,特别是软中断在流量整形中的应用。
最低0.47元/天 解锁文章
863

被折叠的 条评论
为什么被折叠?



