慢慢欣赏linux 网络协议栈三 监听链路状态

本文介绍了链接监视器的任务队列处理流程,包括如何通过延迟工作队列唤醒处理网络设备状态变化的消息,以及如何针对紧急和非紧急事件进行调度。同时,详细解释了在网络设备载波状态改变时触发事件的具体实现。

唤醒任务队列处理消息

static DECLARE_DELAYED_WORK(linkwatch_work, linkwatch_event);
=>void linkwatch_event(struct work_struct *dummy)
	rtnl_lock();
	__linkwatch_run_queue(time_after(linkwatch_nextevent, jiffies));
	=>void __linkwatch_run_queue(int urgent_only)
		list_splice_init(&lweventlist, &wrk);
		while (!list_empty(&wrk))
			dev = list_first_entry(&wrk, struct net_device, link_watch_list);
			list_del_init(&dev->link_watch_list);

			if (urgent_only && !linkwatch_urgent_event(dev)) {
				list_add_tail(&dev->link_watch_list, &lweventlist);
				continue;
			}

			linkwatch_do_dev(dev);
		
		if (!list_empty(&lweventlist))
			linkwatch_schedule_work(0);
			
	rtnl_unlock();

状态变化添加消息

void netif_carrier_on(struct net_device *dev)
	linkwatch_fire_event(dev);
	=>void linkwatch_fire_event(struct net_device *dev)
		bool urgent = linkwatch_urgent_event(dev);
		linkwatch_add_event(dev);
		=>void linkwatch_add_event(struct net_device *dev)
			if (list_empty(&dev->link_watch_list)) 
				list_add_tail(&dev->link_watch_list, &lweventlist);
				dev_hold(dev);

		linkwatch_schedule_work(urgent);
	if (netif_running(dev))
		__netdev_watchdog_up(dev);

`queue_delayed_work` 是 Linux 内核中用于将工作(work)延迟执行的函数。该函数会在指定的时间后将工作放入工作队列(workqueue)中,并在工作队列的上下文中执行。 具体来说,`queue_delayed_work` 函数将一个 `delayed_work` 结构体加入到工作队列中,并将其延迟执行指定的时间。`delayed_work` 结构体包含一个工作函数指针和一个工作队列项(workqueue_item),当该项被处理时,工作函数将被执行。 以下是一个使用 `queue_delayed_work` 的示例: ```c #include <linux/workqueue.h> #include <linux/delay.h> static struct delayed_work my_delayed_work; static void my_work_fn(struct work_struct *work) { printk(KERN_INFO "my_work_fn executed\n"); } static int __init my_init(void) { printk(KERN_INFO "my_init called\n"); INIT_DELAYED_WORK(&my_delayed_work, my_work_fn); queue_delayed_work(system_wq, &my_delayed_work, msecs_to_jiffies(1000)); return 0; } static void __exit my_exit(void) { printk(KERN_INFO "my_exit called\n"); cancel_delayed_work_sync(&my_delayed_work); } module_init(my_init); module_exit(my_exit); ``` 在上述示例中,我们定义了一个 `delayed_work` 结构体 `my_delayed_work`,并初始化其工作函数为 `my_work_fn`。然后,我们调用 `queue_delayed_work` 函数将该工作项加入到系统工作队列中并延迟执行 1 秒。最后,在模块退出时,我们调用 `cancel_delayed_work_sync` 函数取消该工作项的延迟执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值