免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2372 | 回复: 9

[内核模块] jiffies_关闭中断不更新问题 [复制链接]

论坛徽章:
0
发表于 2015-10-16 20:56 |显示全部楼层
taskset -c 1 cat /proc/scull_current

local_irq_save(flags);
while( jiffies  == j1 )
{
index++;
}
local_irq_restore(flags);

自己理解相关的知识点:jiffies是全局的,local_irq_save只关闭本cpu的中断,处理jiffies的时钟程序是绑定在cpu0上的.


local_irq_save关闭的只是本地中断,那么定时器的中断信号在其他处理器上应该是可以被激活的.
那么在多核上应该可以由其他核心激活定时器的中断而修改jiffies的值,
从而达到在cpu1上的任务访问jiffies的时候jiffies已经改变.


环境 :Linux ubuntu 2.6.32-21-generic #32-Ubuntu SMP Fri Apr 16 08:10:02 UTC 2010 i686 GNU/Linux
直接导致ubuntu无响应了。

论坛徽章:
0
发表于 2015-10-19 13:35 |显示全部楼层
问:
taskset -c 1 cat /proc/scull_current
//SMP(4核)
local_irq_save(flags);
while( jiffies  == j1 )
{
index++;
}
local_irq_restore(flags);

自己理解相关的知识点:jiffies是全局的,local_irq_save只关闭本cpu的中断,处理jiffies的时钟程序是绑定在cpu0上的.


local_irq_save关闭的只是本地中断,那么定时器的中断信号在其他处理器上应该是可以被激活的.
那么在多核上应该可以由其他核心激活定时器的中断而修改jiffies的值,
从而达到在cpu1上的任务访问jiffies的时候jiffies已经改变.


环境 :Linux ubuntu 2.6.32-21-generic #32-Ubuntu SMP Fri Apr 16 08:10:02 UTC 2010 i686 GNU/Linux
直接导致ubuntu无响应了。


答:

if(f)
{
        return -1;
}
printk(KERN_ALERT "preempt_disable\n");
local_irq_save(flags);
while( jiffies  == j1 )
{

        //printk(KERN_ALERT "\n%x %x\n",jiffies,index);
        //cpu_relax();
        index++;
}
local_irq_restore(flags);
f++;


在UP(单核)和SMP(双核)进行测试
UP(单核)        :执行了cat /proc/scull_current直接卡死了
SMP(双核)        :执行了cat /proc/scull_current,只执行了一次就推出了,证明其他核心确实可以更新jiffies全局变量。

而出现问题中的情况可能是,xwindow可能正好调度到 cat /proc/scull_current所在的核心,而此时,因为没有加if(f)的判断,此核心正在疯狂循环,根本抽不空闲的时间片来执行xwindow的程序,导致了卡死的假象。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
发表于 2015-10-19 18:58 |显示全部楼层
建议用taskset -c #cpuid(绑定cpu运行命令)测试一下,#cpuid分别取0/1。
如果是2core以上的机器,其它core的效果应该和1是一样的。

论坛徽章:
0
发表于 2015-10-20 22:44 |显示全部楼层
nswcfd 发表于 2015-10-19 18:58
建议用taskset -c #cpuid(绑定cpu运行命令)测试一下,#cpuid分别取0/1。
如果是2core以上的机器,其它co ...

taskset -c 0 car /proc/scull_current 会卡死,因为irq0的中断发生在cpu0上,cpu0的中断被禁用了,禁用之后irq0的中断函数无法调用,则jiffies的值无法更新进入死循环中。
taskset -c 1 car /proc/scull_current 不会卡死,因为irq0的中断发生在cpu0上,我这里使用cpu1,那么jiffies的值还是会由cpu0的irq0的中断函数timer_interrupt中的do_timer更新的。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
发表于 2015-10-21 10:54 |显示全部楼层
这样现象就跟理论统一了

论坛徽章:
0
发表于 2015-10-21 21:10 |显示全部楼层
nswcfd 发表于 2015-10-21 10:54
这样现象就跟理论统一了

但是现在如果先调用taskset -c 1 cat /proc/scull_current然后再调用taskset -c 1 cat /proc/scull_current不会出现卡死现象,怀疑是taskset不能真正的把第二次的进程分配到指定CPU。不知道有没有可以查看进程当前在哪个CPU的命令,在top上看不到进程在哪个CPU上。

论坛徽章:
0
发表于 2015-10-22 01:08 |显示全部楼层
回复 6# pang68599


    ps -p 进程的pid -o psr,cmd
可以看到在那个cpu上跑。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
发表于 2015-10-23 21:22 |显示全部楼层
补充:也可以在你的代码中加入smp_processor_id()打印。

论坛徽章:
0
发表于 2015-10-26 15:19 |显示全部楼层
回复 8# nswcfd
谢谢

论坛徽章:
0
发表于 2015-10-26 15:20 |显示全部楼层
回复 7# lainsonic
谢谢

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP