免费注册 查看新帖 |

Chinaunix

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

[中断] nmi watchdog与nmi 中断 [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之北控
日期:2016-03-15 22:53:29
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-12-07 11:04 |只看该作者 |倒序浏览
下面是Linux-4.0.4内核中函数watchdog_nmi_enable()的语句:
        wd_attr = &wd_hw_attr;
        wd_attr->sample_period = hw_nmi_get_sample_period(watchdog_thresh);

        /* Try to register using hardware perf events */
        event = perf_event_create_kernel_counter(wd_attr, cpu, NULL, watchdog_overflow_callback, NULL);

其中wd_hw_attr定义如下:
static struct perf_event_attr wd_hw_attr = {
        .type                = PERF_TYPE_HARDWARE,
        .config                = PERF_COUNT_HW_CPU_CYCLES,
        .size                = sizeof(struct perf_event_attr),
        .pinned                = 1,
        .disabled        = 1,
};

可见nmi watchdog是依据cpu-cycles的perf 计数器实现的。

我的理解是,每当达到wd_attr->sample_period,就会产生nmi中断,并调用到
函数watchdog_overflow_callback(),但是实际上在正常情况下发现nmi中断并没有增加。

看了很久代码也没有找到答案,请教大家了,为什么nmi中断没有增加?!

论坛徽章:
1
15-16赛季CBA联赛之北控
日期:2016-03-15 22:53:29
2 [报告]
发表于 2015-12-08 12:01 |只看该作者
没有人吗,随便说点啥啊,内核版怎么这么冷清了,哪些往昔的熟面孔好像也不来逛内核版了?!

论坛徽章:
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
3 [报告]
发表于 2015-12-08 17:49 |只看该作者
加入jprobe跑了一下,好像每1000s调一下watchdog_overflow_callback

论坛徽章:
1
15-16赛季CBA联赛之北控
日期:2016-03-15 22:53:29
4 [报告]
发表于 2015-12-09 18:46 |只看该作者
回复 3# nswcfd


谢谢回复,不知道你用的内核是什么版本,你的1000s一次是有规律的吗,
但是系统的hardlock检测不可能是1000s一次的吧?!

   

论坛徽章:
1
15-16赛季CBA联赛之北控
日期:2016-03-15 22:53:29
5 [报告]
发表于 2015-12-10 09:31 |只看该作者
原来nmi watchdog统计的是UnHalted Core Cycles ,关键是UnHalted

论坛徽章:
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
6 [报告]
发表于 2015-12-14 16:58 |只看该作者
回复 4# yangPSO

2.6.32

        wd_attr->sample_period = hw_nmi_get_sample_period();
        event = perf_event_create_kernel_counter(wd_attr, cpu, NULL, watchdog_overflow_callback, NULL);

u64 hw_nmi_get_sample_period(void)
{
        return (u64)(cpu_khz) * 1000 * 60;
}


PS,为什么说Unhalted是关键?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP