打印
[ZLG-ARM]

请教 ZLG_ARM

[复制链接]
1475|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
南京土著人|  楼主 | 2007-5-21 12:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
lg, ARM, AC, ck, ST

smartarm 上的有关给不同模式分配堆栈指针的问题

程序如下:

;设置管理模式堆栈
        MSR     CPSR_c, #0xd3
        LDR     SP, StackSvc
;设置中断模式堆栈
        MSR     CPSR_c, #0xd2
        LDR     SP, StackIrq
;设置快速中断模式堆栈
        MSR     CPSR_c, #0xd1
        LDR     SP, StackFiq
;设置中止模式堆栈
        MSR     CPSR_c, #0xd7
        LDR     SP, StackAbt
;设置未定义模式堆栈
        MSR     CPSR_c, #0xdb
        LDR     SP, StackUnd
;设置系统模式堆栈
        MSR     CPSR_c, #0xdf
        LDR     SP, =StackUsr

        MOV     PC, R0

StackSvc           DCD     SvcStackSpace + (SVC_STACK_LEGTH - 1)* 4  ;
StackIrq           DCD     IrqStackSpace + (IRQ_STACK_LEGTH - 1)* 4
StackFiq           DCD     FiqStackSpace + (FIQ_STACK_LEGTH - 1)* 4
StackAbt           DCD     AbtStackSpace + (ABT_STACK_LEGTH - 1)* 4
StackUnd           DCD     UndtStackSpace + (UND_STACK_LEGTH - 1)* 4

        AREA    MyStacks, DATA, NOINIT, ALIGN=2
SvcStackSpace      SPACE   SVC_STACK_LEGTH * 4  ;管理模式堆栈空间
IrqStackSpace      SPACE   IRQ_STACK_LEGTH * 4  ;中断模式堆栈空间
FiqStackSpace      SPACE   FIQ_STACK_LEGTH * 4  ;快速中断模式堆栈空间
AbtStackSpace      SPACE   ABT_STACK_LEGTH * 4  ;中止义模式堆栈空间
UndtStackSpace     SPACE   UND_STACK_LEGTH * 4  ;未定义模式堆栈

我想知道的是:
StackSvc           DCD     SvcStackSpace + (SVC_STACK_LEGTH - 1)* 4 
这里为什么要“减1”呢

还有就是:
AREA    MyStacks, DATA, NOINIT, ALIGN=2
SvcStackSpace      SPACE   SVC_STACK_LEGTH * 4  ;管理模式堆栈空间
IrqStackSpace      SPACE   IRQ_STACK_LEGTH * 4  ;中断模式堆栈空间
FiqStackSpace      SPACE   FIQ_STACK_LEGTH * 4  ;快速中断模式堆栈空间
AbtStackSpace      SPACE   ABT_STACK_LEGTH * 4  ;中止义模式堆栈空间
UndtStackSpace     SPACE   UND_STACK_LEGTH * 4  ;未定义模式堆栈
这里给5种模式分配的空间在内存中是不是连续的啊?

相关帖子

沙发
blueprince| | 2007-5-21 12:30 | 只看该作者

菜鸟也想知道

据俺揣测:
1. -1是因为从0开始的。
2.应该是连续的。
我继续关注版主回复。

使用特权

评论回复
板凳
南京土著人|  楼主 | 2007-5-21 12:38 | 只看该作者

111


可是在Startup.s中定义的堆栈的大小是:
;定义堆栈的大小
SVC_STACK_LEGTH         EQU         0
FIQ_STACK_LEGTH         EQU         0
IRQ_STACK_LEGTH         EQU         256
ABT_STACK_LEGTH         EQU         0
UND_STACK_LEGTH         EQU         0

“0”-1不就是负数了吗

使用特权

评论回复
地板
computer00| | 2007-5-21 13:24 | 只看该作者

负数也无所谓了,反正都不使用堆栈,栈底地址也就没意义

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

5

主题

11

帖子

1

粉丝