linux上ARM单板kdump概率性启动失败

kdump在内核die或者panic时自动触发,保存第一个内核的现场,跳转到第二个内核执行。但是在启动到第二个内核的工程中概率性启动失败。通过启动打印信息,因为我们的单板是需要定时喂狗的,否则就看门狗溢出直接复位单板。

首先排查到定时器没有触发,那么是软中断没有触发,还是说看门狗的定时器没有初始化成功。结果是软中断没有触发,软中断是通过硬中断来出发的,使用jiffies来计时。通过时钟中断来更新时戳(jiffies)。经过定位发现确实时钟中断没有触发。为什么时钟中断概率性丢失,不触发呢?经过对比kdump加载成功与失败的打印,找到规律:启动成功的内核在复位时是CPU0上;而启动失败的内核在复位时是CPU0外的CPU上。

找到问题自然尝试解决的办法:只要保证复位时运行的CPU是0是否就可以了呢?在kdump的流程把当前线程绑定到CPU0就可以了。修改代码后果然每次kdump都能顺利加载成功。说明果然是必须要把从CPU0加载才可以。问题很清楚了,至于为什么必须绑定到CPU0,那么需要CPU的设计人员解答了。

        以上情况都是在hisi的芯片上验证。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值