ARM 的DCD指令

初学ARM,DCD指令给我留下了深刻印象,它的使用较为广泛,而且不易理解,现就对它做些小结:

在中断向量表中不直接LDR PC,"异常地址".而是使用一个标号,然后再在后面使用DCD定义这个标号,其原因是:

LDR 指令只能跳到当前PC 4kB 范围内,而B 指令能跳转到32MB 范围,而现在这样在LDR PC, "xxxx"这条指令不远处用"xxxx"DCD 定义一个字,而这

个字里面存放最终异常服务程序的地址,这样可以实现4GB 全范围跳转。

另:有如下语句

USR_STACK_LEGTH EQU 64 ;定义用户模式堆栈长度为64字

StackUsr DCD UsrStackSpace + (USR_STACK_LEGTH-1)*4 ;定义一个字的空间,这个字的内容是一个递减堆栈的首地址

UsrStackSpace SPACE USR_STACK_LEGTH*4 ;为用户模式分配一个64字的堆栈空间,若这个堆栈做递减使用,则其首地址为

UsrStackSpace + (USR_STACK_LEGTH-1)*4

你可能感兴趣的:(ARM 的DCD指令)