• 2023年10月5号


    数据搬移指令:

    1. <opcode>{<cond>}{s} <Rd>, <shifter_operand>
    2. 解释:
    3. <opcode>:指令码
    4. {<cond>}:条件码
    5. {s}:状态位,如果在指令后面加上s,则运算的结果会影响CPSR的条件位
    6. <Rd>:目标寄存器
    7. <shifter_operand>:第一操作数,可以是寄存器,也可以是立即数
    8. 按照指令码将第一操作数运算后的结果保存在目标寄存器
    9. 指令码功能:
    10. mov:将第一操作数的值保存在目标寄存器
    11. mvn:将第一操作数的值按位取反,将结果保存在目标寄存器

    移位指令:

    1. 格式:<opcode>{<cond>}{s} <Rd>, <Rn>, <shifter_operand>
    2. 解释:将第一操作寄存器的数值移位第二操作数指定的位数,将结果保存在目标寄存器中
    3. 指令码:
    4. LSL:左移运算 低位补0
    5. LSR:右移运算 高位补0
    6. ROR:循环右移:低位移出的值补到高位

    位运算指令:

    1. 格式:<opcode>{<cond>}{s} <Rd>, <Rn>, <shifter_operand>
    2. 解释:将第一操作寄存器和第二操作数进行位运算,将结果保存在目标寄存器中
    3. 指令码:
    4. and:与 与001不变
    5. orr:或 或110不变
    6. eor:异或 相同为0 不同为1
    7. bic:按位清零指令,想将哪一位设置为0,只需要用bic指令给这一位运算一个1即可

    算数运算指令:

    1. 算数运算指令
    2. 4.1 格式以及指令码
    3. 格式:<opcode>{<cond>}{s} <Rd>, <Rn>, <shifter_operand>
    4. 解释:将第一操作寄存器的值和第二操作数进行算数运算,结果保存在目标寄存器中
    5. add:加法运算
    6. adc:进行加法运算时需要考虑CPSR的条件位
    7. sub:减法运算
    8. sbc:进行减法运算时需要考虑CPSR的条件位
    9. mul:乘法运算

    比较指令:

    1. 格式:
    2. cmp 第一操作数,第二操作寄存器
    3. 比较两个数据
    4. cmp命令本质:实际上就是比较的两个数进行减法运算,并且减法运算的结果会影响到CPSR寄存器的条件位
    5. 通常比较指令完毕之后会使用条件码进行判断,根据判断的结果做不同的逻辑

    跳转指令:

    1. 格式:
    2. <opcode>{<cond>} 标签
    3. 功能:跳转到指定的标签下
    4. 指令码:
    5. b:跳转时不影响LR寄存器的值

    寄存器内存读写指令:

    1. 向内存中写:
    2. str:向内存中写一个字(4字节)的数据
    3. strh:向内存写半个字(2字节)的数据
    4. strb:向内存写一个字节的数据
    5. 从内存读:
    6. ldr:从内存读取一个字的数据
    7. ldrh:从内存读取半个字的数据
    8. ldrb:从内存读取一个字节的数据
    9. 指令码{条件码} 目标寄存器 [目标地址]
    10. str 目标寄存器 ,[目标地址]:将目标寄存器的数据写入到以目标地址为起始的内存中
    11. ldr 目标寄存器 ,[目标地址]:从以目标地址为起始的内存中读一个字的数据到目标寄存器

    批量寄存器的内存读写方式:

    1. 向内存写:
    2. stm 目标地址,{寄存器列表}
    3. 将寄存器列表中每一个寄存器的值都写道目标地址指向的连续空间之中
    4. 从内存读
    5. ldm 目标地址,{寄存器列表}
    6. 将目标地址指向的连续内存中的数据读到寄存器列表中的寄存器中
    7. 注意事项:
    8. 1.如果寄存器列表中寄存器的编号连续,可以用-表示列表,如果不连续,用,分割寄存器
    9. {r1-r5,r7}
    10. 2.无论寄存器列表中如何表示,我们在读写内存的时候始终是低地址 对应低寄存器编号

  • 相关阅读:
    SpringSecurity系列——密码存储加密策略day7-1(源于官网5.7.2版本)
    214. Devu和鲜花
    【FPGA】十进制计数器 | 实现 4-bit 2421 十进制计数器 | 有限状态机(FSM)
    enumerate内置函数的使用
    【云原生】SpringCloud系列之客户端负载均衡Ribbon
    [Flask笔记]一个完整的Flask程序
    Webfunny大版本改造(mysql迁移至clickhouse)
    注解与反射_注解
    IO模型简介
    滚雪球学Java(44):掌握Java编程的关键:深入解析System类
  • 原文地址:https://blog.csdn.net/2201_75732711/article/details/133580508