免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7293 | 回复: 16
打印 上一主题 下一主题

[网络子系统] 高手指点:为什么可以在任何上下文调用dev_get_by_name() [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-03-18 16:42 |只看该作者 |倒序浏览
为什么可以在任何上下文调用dev_get_by_name()?
在内核源码里面
struct net_device *dev_get_by_name(struct net *net, const char *name)
{
        struct net_device *dev;

        read_lock(&dev_base_lock);
        dev = __dev_get_by_name(net, name);
        if (dev)
                dev_hold(dev);
        read_unlock(&dev_base_lock);
        return dev;
}
该函数是要去拿dev_base_lock这个读写锁的。而dev_base_lock这个读写锁的所有写操作只是禁止了软中断,并没有禁止中断。那么如果在isr中调用dev_get_by_name()。而dev_base_lock这个锁又恰好被一个写操作获得了锁,这个时候不会死锁吗?

请教高手指点

论坛徽章:
10
戌狗
日期:2013-10-17 09:43:0215-16赛季CBA联赛之广东
日期:2018-02-05 11:22:1215-16赛季CBA联赛之八一
日期:2016-07-04 12:26:1815-16赛季CBA联赛之青岛
日期:2016-06-08 11:15:4115-16赛季CBA联赛之辽宁
日期:2016-04-05 10:10:1415-16赛季CBA联赛之辽宁
日期:2016-03-11 11:11:48酉鸡
日期:2014-12-18 14:35:48狮子座
日期:2014-02-20 10:14:07寅虎
日期:2013-12-02 13:48:2915-16赛季CBA联赛之广夏
日期:2018-03-21 08:51:10
2 [报告]
发表于 2013-03-19 12:05 |只看该作者
确实有点怪啊,除非这个锁只是用在软中断?所以锁软中断就够了? 同问求解!

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
3 [报告]
发表于 2013-03-19 12:55 |只看该作者
回复 1# kyok520
该函数是要去拿dev_base_lock这个读写锁的。而dev_base_lock这个读写锁的所有写操作只是禁止了软中断,并没有禁止中断。那么如果在isr中调用dev_get_by_name()。而dev_base_lock这个锁又恰好被一个写操作获得了锁,这个时候不会死锁吗?

恩。貌似dev_get_by_name应该不能再中断上下文中调用。
   

论坛徽章:
0
4 [报告]
发表于 2013-03-19 21:05 |只看该作者
如果写操作所在的进程 和 ISR是在同一个CPU上运行的话,那么写操作所在的进程应该可以迁移到其他CPU上运行吧

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
5 [报告]
发表于 2013-03-20 08:30 |只看该作者
回复 4# yevv
如果写操作所在的进程 和 ISR是在同一个CPU上运行的话,那么写操作所在的进程应该可以迁移到其他CPU上运行吧

首先是不会自动迁移的其他CPU的,况且如果只有一个CPU呢?
作者原来的注释是错的。


   

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
6 [报告]
发表于 2013-03-20 08:36 |只看该作者
回复 1# kyok520

The authors have confirmed our doubts!

The comment is wrong.
net/  has essentially no functions which can be called from hard irq context.
As matter of fact, there is only one: netif_rx(). Plus some trivial
library functions.
   

论坛徽章:
10
戌狗
日期:2013-10-17 09:43:0215-16赛季CBA联赛之广东
日期:2018-02-05 11:22:1215-16赛季CBA联赛之八一
日期:2016-07-04 12:26:1815-16赛季CBA联赛之青岛
日期:2016-06-08 11:15:4115-16赛季CBA联赛之辽宁
日期:2016-04-05 10:10:1415-16赛季CBA联赛之辽宁
日期:2016-03-11 11:11:48酉鸡
日期:2014-12-18 14:35:48狮子座
日期:2014-02-20 10:14:07寅虎
日期:2013-12-02 13:48:2915-16赛季CBA联赛之广夏
日期:2018-03-21 08:51:10
7 [报告]
发表于 2013-03-20 09:30 |只看该作者
瀚海书香 发表于 2013-03-20 08:36
回复 1# kyok520

The authors have confirmed our doubts!


论坛徽章:
0
8 [报告]
发表于 2013-03-20 18:02 |只看该作者
回复 6# 瀚海书香


    请问下你发的这个注释在哪里看到的?

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
9 [报告]
发表于 2013-03-23 10:05 |只看该作者
回复 8# kyok520
这不是哪里看到的。
是我跟netdev成员沟通的结果。这块我已经提交了patch,有人认为需要添加,但是Eric dumazet认为不需要。现在还在讨论是否放到comment中。

   

论坛徽章:
2
申猴
日期:2013-12-26 22:11:31天秤座
日期:2014-12-23 10:23:19
10 [报告]
发表于 2013-03-25 12:23 |只看该作者
瀚海书香 发表于 2013-03-23 10:05
回复 8# kyok520
这不是哪里看到的。
是我跟netdev成员沟通的结果。这块我已经提交了patch,有人认为需要 ...


目测你的changelog又要被喷
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP