EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
ARM汇编指令之数据交换指令、移位指令、协处理器指令、异常产生指令介绍。 5 ~% r" J- P9 o6 X1 F1 q" C
七、数据交换指令 1、SWP指令 SWP指令的格式为: SWP{条件} 目的寄存器,源寄存器1,[源寄存器2] 1 ]; T) J( p5 q* I# u/ H N
SWP指令用于将源寄存器2所指向的存储器中的字数据传送到目的寄存器中,同时将源寄存器1中的字数据传送到源寄存器2所指向的存储器中。显然,当源寄存 器1和目的寄存器为同一个寄存器时,指令交换该寄存器和存储器的内容。 指令示例: SWP R0,R1,[R2] ;将R2所指向的存储器中的字数据传送到R0,同时将R1 中的字数据传送到R2所指向的存储单元。
4 N: m' ]2 Q- p: z4 w; D1 C" ESWP R0,R0,[R1] ;该指令完成将R1所指向的存储器中的字数 据与R0中的数据交换。 2、SWPB指令 SWPB指令的格式为: SWP{条件}B 目的寄存器,源寄存器1,[源寄存器2] SWPB指令用于将源寄存器2所指向的存储器中的字节数据传送到目的寄存器中,目的寄存器的高24清零,同时将源寄存 器1中的字节数据传送到源寄存器2所指向的存储器中。显然,当源寄存器1和目的寄存器为同一个寄存器时,指令交换该寄存器和存储器的内容。 指令示例: SWPB R0,R1,[R2] ;将R2所指向的存储器中的字节数据传送到 R0,R0的高24位清零,同时将R1中的低8位数据传送到R2所指向的存储单元。
/ h4 d5 t$ h$ [7 [. x1 rSWPB R0,R0,[R1] ;该指令完成将R1所指向的存储器中的 字节数据与R0中的低8位数据交换。 - K+ j1 F4 |9 _7 j3 V" S6 C
1 J; Q+ D5 ]/ i# o+ }* v1 b$ \八、移位指令 1、LSL(或ASL) LSL(或ASL)的格式为: 通用寄存器,LSL(或ASL) 操作数 LSL(或ASL)可完成对通用寄存器中的内容进行逻辑(或算术)的左移操作,按操作数所指定的数量向左移位,低位用零来填充。 其中,操作数可以是通用寄存器,也可以是立即数(0~31)。 操作示例 MOV R0, R1, LSL #2 ;将R1中的内容左移两位后传送到R0 中。 2、LSR
, b8 J- b- k) d- p8 d7 Q; }! F; I
4 d9 w; e- `1 C- Z4 D |