assembly 了解LDR和STR?

icnyk63a  于 4个月前  发布在  其他
关注(0)|答案(1)|浏览(69)

我使用的是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]的指令。有人能澄清一下这些指令是如何工作的吗?

wxclj1h5

wxclj1h51#

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

  • STR指令在内存中存储一个字。
  • LDR指令从内存中加载一个字。

Read more

相关问题