了解LDR和STR?

时间:2014-05-01 03:20:48

标签: assembly arm

我正在使用ARMSim,我猜它是一个ARM模拟器,我有这个演示程序。它基本上读取文本文件并从文本文件中打印整数(仅第一行)。

Start:
@Open file for input.
LDR R0, =InputFileName
MOV R1, #0
SWI SWI_Open
BCS FileError

@Save file handle to memory.
LDR R1, =InputFileHandle
STR R0, [R1]

@Read integers.
LDR R0, =InputFileHandle
LDR R0, [R0]
SWI SWI_RdInt

@Print to ARMSIM console.
MOV R1, R0
MOV R0, #Stdout
SWI SWI_PrInt

BAL End

FileError:
MOV R0, #Stdout
LDR R1, =FileErrorMess
SWI SWI_PrStr
BAL Quit

End:
SWI SWI_Exit

.data
.align
InputFileHandle: .skip 4
InputFileName: .asciz "integers.txt"
FileErrorMess: .asciz "Can't open file."

它运行良好,但我不太了解LDR或STR指令的工作原理。尤其是看起来像LDR R0,[R0]或STR R0,[R1]的那些。任何人都可以清楚这些是如何工作的吗?

1 个答案:

答案 0 :(得分:4)

LDR STR 指令使用后索引编址来更新其地址寄存器。

STR 说明将单词存储到内存中。

LDR 指令从内存加载一个单词。

Read more