ARM处理器小端模式且编译器是采用“满递减”方式,多任务指针初始位置如上图所示。
“满递减”:PUSH使得SP递减,POP使得SP递增
说明:ARM处理器大部分是采用小端模式的,而且像ADS、IAR、KEIL等对ARM系列的处理器都采用小端模式,且堆栈是采用“满递减”方式。
KEIL51的编译器一般情况下是恰好相反的,8051很多是采用大端模式,而且堆栈是采用“空递增”方式。
“空递增”:PUSH使得SP递增,POP使得SP递减
KEIL 对8051系列的单片机,大部分是采用大端模式且编译器是采用“空递增”方式,多任务指针初始位置如上图所示。
若32位的ARM处理器的内存数据如下图:
以上内存内容分布时,执行POP {r4,pc}
后r4=0x78563412
pc=0xa5853520
即高地址在高位
8位C8051以上内存内容分布时,执行POP {pc}后
Pc=0x0096 即POP pc也是高地址放高位,至于其它寄存器,自己没有测试,但是我猜应该也是一样的。