找回密码
 注册
关于网站域名变更的通知
查看: 713|回复: 2
打印 上一主题 下一主题

ARM 指令的寻址方式

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-7-29 15:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
1、立即寻址操作数在指令中直接给出

ADD R0,R0,#1;R0←R0+1
! A- ^- t- v: M' GADD R0,R0,#0x3f;R0←R0+0x3f

, U! y( P, {/ b  M- ]# E) e0 c

2、寄存器寻址操作数在寄存器

ADD R0,R1,R2;R0←R1+R2

3、寄存器间接寻址 操作数的地址在寄存器

ADD R0,R1,[R2];R0←R1+[R2]% B: B( l0 G) b' H5 Q; d/ ?
LDR R0,[R1];R0←[R1]
, R/ l, b2 f  E$ {8 ]7 z/ U+ rSTR R0,[R1];[R1]←R0


6 {* ?4 d0 p8 y2 M9 Z2 b* z' [

4、基址变址寻址操作数地址=基址寄存器+指令中给出的地址偏移

LDR R0,[R1,#4];R0←[R1+4]
* n; I3 p* _  K. ]! }+ `6 VLDR R0,[R1,#4]! ;R0←[R1+4]、R1←R1+4
1 V' q3 `" [# nLDR R0,[R1],#4;R0←[R1]、R1←R1+4. J( }2 W1 o) y) e
LDR R0,[R1,R2];R0←[R1+R2]


$ O9 j/ {) \8 V* k$ c3 Y

5、多寄存器寻址类似寄存器寻址,此处是多个寄存器而已

LDMIA R0,{R1,R2,R3,R4};R1←[R0]
$ e. n5 U2 j/ V; f;R2←[R0+4]! U- t* [2 M. g0 j# V
;R3←[R0+8]
+ q9 L" J+ b! H* g) q0 ?) ~;R4←[R0+12]

+ B9 [: ?& t1 j! p2 ~: v' Q# R

6、相对寻址目标地址= pc当前值+指令给出的标号偏移地址

BL NEXT;跳转到子程序NEXT处执行: @) @/ t' N; d2 z& B
......2 b* t) a0 \3 G0 r  G. _* O' m
NEXT
8 ~6 H* {/ z5 c2 f& G8 E......
2 i& W5 H1 n( p# w3 j8 s- z/ mMOV PC,LR;从子程序返回

/ S; M- E5 s7 q" E( X

7、堆栈寻址
* N' D8 T6 t% R- ]3 ]8 iARM微处理器支持这四种类型的堆栈工作方式。

-满递增堆栈:堆栈指针指向最后压入的数据,且由低地址向高地址生成。+ I5 q! A5 E) p1 I4 M( O+ m) l
-满递减堆栈:堆栈指针指向最后压入的数据,且由高地址向低地址生成。  ~/ \# l( ~! g6 R1 d
-空递增堆栈:堆栈指针指向下一个将要放入数据的空位置,且由低地址向高地址生成。  ]' B& s: u2 p+ o9 X
-空递减堆栈:堆栈指针指向下一个将要放入数据的空位置,且由高地址向低地址生成。' w6 J- p. w& O& M

该用户从未签到

2#
发表于 2021-7-29 16:41 | 只看该作者
立即寻址、寄存器寻址
  • TA的每日心情
    开心
    2023-1-3 15:10
  • 签到天数: 2 天

    [LV.1]初来乍到

    3#
    发表于 2021-7-29 17:28 | 只看该作者
    ARM指令的寻址方式
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-24 12:20 , Processed in 0.156250 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表