ARM MOV指令对立即数的要求
来源:互联网 发布:软件设计师 证书样式 编辑:程序博客网 时间:2024/04/29 09:08
MOV R1,#9
以上指令表示把9传送到寄存器R1中。
需要注意的是,这里的立即数是有要求的,不是说任何一个立即数都可以。
要求是:立即数可以由一个8位的常数循环右移偶数位得到。其中循环右移的位数由一个4位二进制的两倍表示。
如果立即数记作immediate
,8位常数记作immed_8
,4位的循环右移值记作rotate_imm
,则 immediate
=immed_8
循环右移(2*rotate_imm
)
这样并不是每一个32位的常数都是合法的立即数,只有能通过上面的构造方法得到的才是合法的立即数。
比如,0x101,0x102,0xFFF;
另外,一个合法的立即数,可能有多种编码方法。如0x3F0,它可以采用下面两种编码方法: immed_8
=0x3F,rotate_imm
=0xE
(0x3F循环右移28位,即0x3F左移4位得到0x3F0)
或者 immed_8
=0xFC,rotate_imm
=0xF
(0xFC循环右移30位,即0xFC左移2位得到0x3F0)
对于不合法的立即数,比如要把0xFFF传送到R1中,虽然不能用MOV指令,但是可以用LDR伪指令,用法是 LDR R1,=0xFFF
阅读全文
0 0
- ARM MOV指令对立即数的要求
- ARM中的MOV指令 立即数合法性
- arm指令MOV和ldr的区别
- ARM中的MOV指令
- ARM中的MOV指令
- arm指令之mov
- ARM指令 LDR、LDR伪指令、MOV的区别
- ARM之MOV指令分析
- ARM汇编之MOV指令
- ARM汇编指令ldr和MOV的区别
- arm指令集----ldr 和 mov的区别
- arm指令中mov和ldr的区别
- arm中ldr与mov指令的区别
- arm指令中mov和ldr的区别
- ARM 汇编的mov操作立即数的疑问
- ARM 汇编的mov操作立即数的疑问
- ARM立即数,LDR和MOV的区别
- ARM立即数,LDR和MOV的区别 (转)
- 配置ROS Indigo&gazebo仿真环境
- windows下 python安装pip 简易教程
- 如何在页面中获取到ModelAndView绑定的值
- 5月31日,每日20行。
- 【计算机组成原理】第3章 多层次的存储器
- ARM MOV指令对立即数的要求
- 21款Dashboards
- vi 中常用的几个命令
- leetcode 230. Kth Smallest Element in a BST
- UESTC
- 单链表的插入排序
- SQLite、MySQL和PostgreSQL 三种关系数据库哪个好?
- 关于Python中interval的处理
- JAVA 之 使用 POI 导出 Excel (一)