根据《cm3权威指南》,软件复位有两种方法:
1、通过置位nvic中应用程序中断与复位控制寄存器(aircr)的vectreset位:
ldr r0, =0xe000ed0c ; nvic aircr address
ldr r1, =0x05fa0001 ; 置位 vectreset位,前面的0x05fa是访问钥匙
str r1, [r0] ; 触发复位序列
deadloop
b deadloop ; 该死循环保证后面的指令不可能被执行到
这种复位的作用范围覆盖了整个cm3 处理器中,除了调试逻辑之外的所有角落,但是它不会影响到cm3 处理器外部的任何电路,所以单片机上的各片上外设和其它电路都不受
影响。
2、置位同一个寄存器的sysresetreq位。这种复位会覆盖整个芯片上的电路。代码如下:
ldr r0, =0xe000ed0c ; nvic aircr address
ldr r1, =0x05fa0004 ; 置位 sysresetreq,前面的0x05fa是访问钥匙
str r1, [r0] ; 触发复位序列
deadloop
b deadloop ; 该死循环保证后面的指令不可能被执行到
大
这里有一个要注意的问题:从sysresetreq 被置为有效,到复位发生器执行复位命令,
往往会有一个延时。在此延时期间,处理器仍然可以响应中断请求。但我们的本意往往是要
让此次执行到此为止,不要再做任何其它事情了。所以,最好在发出复位请求前,先把
faultmask 置位。需要加上这句:__set_faultmask(1);//关闭所有中断
3.5的库时,需要在函数中添加nvic_systemreset(); 这个函数在cor_cm3.h中,如下:
static __inline void nvic_systemreset(void)
{
scb->aircr = ((0x5fa << scb_aircr_vectkey_pos) |
(scb->aircr & scb_aircr_prigroup_msk) |
scb_aircr_sysresetreq_msk);
__dsb();
while(1);
}
另外一些nvic函数在misc.h中。
『本文转载自网络,皇冠最新app版本的版权归原作者所有,如有侵权请联系删除』