了解LDR和STR?

Col*_*y21 2 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."
Run Code Online (Sandbox Code Playgroud)

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

小智 6

LDRSTR指令使用后变址寻址来更新其地址寄存器。

STR指令将一个字存储到内存中。

LDR指令从内存中加载一个字。

阅读更多

  • LDR R0,[R0] 使用 R0 作为该内存的地址从内存加载一个值。STR R0,[R1] 使用 R1 作为该内存的地址将 R0 中的值存储到内存中。再举一个例子,LDR R0,[R2,#4] 将使用 (R2+4) 作为地址从内存中加载 R0 的值。 (4认同)
  • 如果不清楚的话:LDR R0,[R1,#4]使用R1+4作为地址并加载R0。LDR R0,[R1,#4]!使用R1+4作为地址,加载R0,并将4加到R1,或者可以将4加到R1,然后使用更新的R1作为地址并加载R0。LDR R0,[R1],#4 使用 R1 作为地址,然后将 4 加到 R1 上。 (2认同)