现在的位置: 首页 > 技术文章 > 正文

STMFD和LDMFD指令详解与个人理解分析

2013年12月06日 技术文章 ⁄ 共 839字 ⁄ 字号 STMFD和LDMFD指令详解与个人理解分析已关闭评论 ⁄ 阅读 7,116 次

LDM/STM指令主要用于现场保护,数据复制,参数传送等。

STMFD指令

STMFD  Rn{!},{reglist}{^}

STMFD指令解释

STMFD指令解释

举例说明:

STMFD SP!,{R0-R7,LR}

对于这条指令伪代码的解释,大体是这样的:

SP = SP - 9×4;

address = SP;

for i = 0 to 7

Memory[address] = Ri;

address  = address + 4;

Memory[address] = LR;

假设此时SP地址为: 0x40000460,由前面解释伪代码可得下图(蓝色填充区为地址)

堆栈示意

堆栈示意

 LDMFD 指令

LDMFD  Rn{!},{reglist}{^}

这条指令的意思是以Rn为基址(起始地址),取值写入寄存器列表。

LDMFD指令解释

LDMFD指令解释

举例说明:

LDMFD SP!,{R0-R7,PC}^

对于这条指令伪代码的解释,大体是这样的:

address = SP;

for i = 0 to 7

Ri = Memory[address ,4]

address = address + 4;

SP = address;

假设此时SP地址为: 0x4000043C,由前面解释伪代码可得下图(蓝色填充区为地址):

LDMFD指令堆栈示意

LDMFD指令堆栈示意

蓝色标注的SP为执行指令前的SP地址,红色标注的SP是执行指令后的SP地址。

×