ARM 汇编指令:(二) LDR与STR 单内存访问指令

您所在的位置:网站首页 arm汇编与8086汇编 ARM 汇编指令:(二) LDR与STR 单内存访问指令

ARM 汇编指令:(二) LDR与STR 单内存访问指令

2024-06-05 13:58| 来源: 网络整理| 查看: 265

目录

一:LDR指令格式LDR指令用于从内存中加载数据到寄存器。它的基本语法为:

二:STR指令格式STR指令用于将数据从寄存器存储到内存。它的基本语法为:

三:LDR与STR 使用示例:

1.LDR   加载立即数或者地址值

2.LDR   将寄存器里的地址指向的内容(*p 这与C语言这条语句等价)加载到目标寄存器

3.STR 将寄存器里的值,保存到寄存器里保存地址所指向的内存空间里。

一:LDR指令格式LDR指令用于从内存中加载数据到寄存器。它的基本语法为: LDR{cond}{B}{T} Rd, [Rn{, #offset}]

其中:

{cond}是条件码,可选项。用于指定条件执行LDR指令的条件。

{B}是字节访问标志,可选项。用于指定是否进行字节级别的加载。

{T}是类型标志,可选项。用于指定加载的数据类型,例如字、半字或字节。

Rd是目标寄存器,用于存储从内存中加载的数据。

Rn是基地址寄存器,其中存储了要加载数据的内存地址。

#offset是可选的偏移量,用于指定基地址寄存器Rn与实际数据的偏移量。

LDR指令可以加载整数、浮点数、字符等类型的数据。

二:STR指令格式STR指令用于将数据从寄存器存储到内存。它的基本语法为: STR{cond}{B}{T} Rd, [Rn{, #offset}]

其中:

{cond}是条件码,可选项。用于指定条件执行STR指令的条件。

{B}是字节访问标志,可选项。用于指定是否进行字节级别的存储。

{T}是类型标志,可选项。用于指定存储的数据类型。

Rd是源寄存器,其中存储了要存储到内存的数据。

Rn是基地址寄存器,其中存储了要存储数据的内存地址。

#offset是可选的偏移量,用于指定基地址寄存器Rn与实际数据的偏移量。

STR指令将寄存器中的数据存储到内存中的指定位置。

三:LDR与STR 使用示例:

ldr:将内存中的值加载到寄存器(读内存,写寄存器)  ldr r0,[r1]

str:将寄存器的内容写入内存(写内存,读寄存器) str r0,[r1]

1.LDR   加载立即数或者地址值

     用于加载立即数或一个地址值到指定寄存器中,这种场景 ldr被视为一种伪指令,其作用同mov差不多,但是没有立即数的长度为8位的限制。如果使用ldr伪指令时,后面跟的立即数没有超过8位,那么在实际汇编的时候该ldr伪指令是被转换为mov指令的。

ldr r0, =0x3ff; #与mov r0, #0x3ff等价 char tabal[10]; ldr r0, =tabal; #将数组的首地址加载到r0上 2.LDR   将寄存器里的地址指向的内容(*p 这与C语言这条语句等价)加载到目标寄存器 ldr r0, [r1]; #将r1里存的地址指向的内容,写入寄存器r0 ldr r0, [r1, #32] #将r1里存的地址+32字节所指向的内容,写入寄存器r0 ldr r0, [r1], #32 #将r1里存的地址指向的内容+32,将结果写入寄存器r0 3.STR 将寄存器里的值,保存到寄存器里保存地址所指向的内存空间里。 str r1 [r0]; #将寄存器r1保存的值写入 r0保存的内存地址空间 str r1, [r0, #16] #将寄存器r1保存的值写入 r0保存的内存地址 + 16所指向的空间 str r1, [r0], #32 //#将寄存器r1保存的值写入 r0保存的内存地址空间,并且 r0=r0+32

下一页:ARM 汇编指令:(三)运算处理指令



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3