网络子系统21_传输接收软中断的触发

本文深入探讨了Linux内核网络子系统中传输接收过程中的软中断触发机制。通过解析关键的数据包处理路径,阐述了如何在接收到网络数据时激活软中断,以及软中断如何协助高效地完成数据包的传输和接收任务。内容涉及网络协议栈、中断处理和内核同步等方面的知识。

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

//参考 深入理解linux网络技术内幕

//设备接收数据的调度
//在由驱动程序提供的数据接收中断中:
//	1.非napi设备使用netif_rx向上传递skb
//	2.napi设备使用netif_rx_schedule


//设备发送数据的调度
//	调度只针对具有队列规则的设备,在qdisc_run中如果无法获得xmit_lock锁,则通过规则队列重新入队skb,在net_tx_action中,获取queue_lock失败,调度设备
//	对于不使用队列规则的设备,直接通过dev_queue_xmit调用驱动的hard_start_xmit完成传输
//调度发生的路径
//	dev_queue_xmit->qdisc_run->netif_schedule
//	net_tx_action->netif_schedule

//调度设备发送数据,将设备链接到per-cpu的softnet_data->output_queue中,触发软中断
1.1 static inline void netif_schedule(struct net_device *dev)
{
	//如果设备没有关闭传输
	if (!test_bit(__LINK_STATE_XOFF, &dev->state))
		//执行实际的调度设备操作
		__netif_schedule(dev);
}

//netif_schedule->__netif_schedule
1.2 static inline void __netif_schedule(struct net_device *dev)
{
	//设备没有被调度
	if (!test_and_set_bit(__LINK_STATE_SCHED, &dev->state)) {
		unsigned long flags;
		struct softnet_d
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值