关闭看门狗
上面几个宏定义所对应的地址,都可以在对应的datasheet中找到对应的定义:
dr r0, =pWTCON
这里的ldr和前面介绍的ldr指令不是一个意思。
这里的ldr是伪指令ldr。
什么是伪指令
伪指令,就是“伪”的指令,是针对“真”的指令而言的。
真的指令就是那些常见的指令,比如上面说的arm的ldr,bic,msr等等指令,是arm体系架构中真正存在的指令,你在arm汇编指令集中找得到对应的含义。
而伪指令是写出来给汇编程序看的,汇编程序能看的伪指令具体表示的是啥意思,然后将其翻译成真正的指令或者进行相应的处理。
只不过 mov 指令后面的立即数是有限制的,这个立即数,能够必须由一个 8 位的二进制数,即属于 0x00-0xFF 内的某个值,经过偶数次右移后得到,这样才是合法数据,而 ldr 伪指令没有这个限制。
那为何 ldr 伪指令的操作数没有限制呢,那是因为其是伪指令,写出来的伪指令,最终会被编译器解释成为真正的,合法的指令的,一般都是对应的 mov 指令。
这样的话,写汇编程序的时候,使用 MOV 指令是比较麻烦的,因为有些简单的数据比较容易看出来,有些数据即不容易看出来是否是合法数据。所以,对此,ldr 伪指令的出现,就是为了解决这个问题的,你只管放心用 ldr 伪指令,不用关心操作数,而写出的 ldr 伪指令,编译器会帮你翻译成对应的真正的汇编指令的。(这个意思就是机器判断了)
而关于编译器是如何将这些ldr伪指令翻译成为真正的汇编指令的,我的理解是,其自动会去算出来对应的操作数,是否是合法的mov 的操作数,如果是,就将该ldr伪指令翻译成mov指令,否则就用别的方式处理,我所观察到的,其中一种方式就是,单独申请一个4字节的空间用于存放操作数,然后用ldr指令实现。
【总结】
而这里的:
ldr r0, =pWTCON
mov
意思就很清楚了,就是把宏pWTCON的值赋值给r0寄存器,即
r0=0x53000000
mov r1, #0x0
str
str r1, [r0]
所以,上面几行代码意思也很清楚:
先是用r0寄存器存pWTCON的值,然后r1=0,再将r1中的0写入到pWTCON中,其实就是
pWTCON = 0;
是时候来看看watchdog了?