概述
1. 问题背景
产品在做稳定性测试,发现设备异常重启
2. 问题描述
用户应用在做长运压测,发现设备长运2~3天后会异常重启,log中未发现有代码奔溃现象。
3. 问题分析
系统重启,需要判断重启原因,系统中的重启原因有如下:
typedef enum {
SYS_POWERON
= 0,
//硬件上电启动
SYS_WATCHDOG_CHIP_RST
= 1,
//看门狗复位重启,包含整个系统
SYS_WATCHDOG_CPU_RST
= 2,
//看门狗复位重启,仅CPU
SYS_REBOOT
= 6,
//执行reboot命令重启
SYS_CPU_RST
= 7,
//cpu异常复位启动
SYS_NVIC_RST
= 8,
//中断异常重启
}SystemStartupState;
在系统阶段就可以插桩代码,判断重启原因,下面是示例代码:
const char* startup_state_str[] = {"powerOn", "wdgSocRst", "wdgCpuRst", "sleep",
"standby", "hibernation", "reboot", "cpuRst","nvicRst"};
printf("startup state: %sn", startup_state_str[SysGetStartupState()]);
通过插桩代码,就可以明确重启原因,导致看门狗喂狗不及时而重启。
4. 解决办法
(1)插桩代码,判断重启原因。
(2)如果是看门狗重启,大部分情况下看门狗重启都是由于代码执行异常卡死,解决该问题,就先把看门狗关掉,接上JTAG等调试工具,程序执行异常,就会block住(不会重启),就可以利用jtag判断代码执行位置,进而找出异常点。
原贴链接:https://bbs.aw-ol.com/topic/718/
全志在线开发者交流企鹅群(客服机器人24小时在线解答):498263967
资源获取、问题讨论可以到全志在线开发者社区进行:https://www.aw-ol.com/
全志及开发者最新动态可以关注全志在线微信公众号
最后
以上就是辛勤自行车为你收集整理的全志XR806芯片 系统异常重启如何解决?的全部内容,希望文章能够帮你解决全志XR806芯片 系统异常重启如何解决?所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复