ARM 学习笔记之7: The Read-Modify-Write operation

本文详细介绍了如何通过读改写操作安全地修改系统寄存器中的特定位,以避免因错误修改而导致程序行为异常。文章提供了具体的指令示例,包括复制系统寄存器到通用寄存器、清除指定位、设置指定位以及将通用寄存器的值写回系统寄存器的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

The read-modify-write operation ensures that you modify only the specific bits in a system register that
you want to change.
Individual bits in a system register control different system functionality. Modifying the wrong bits in a
system register might cause your program to behave incorrectly.
        VMRS r10,FPSCR ; copy FPSCR into the general-purpose r10
        BIC r10,r10,#0x00370000 ; clear STRIDE bits[21:20] and LEN bits[18:16]
        ORR r10,r10,#0x00030000 ; set bits[17:16] (STRIDE =1 and LEN = 4)
        VMSR FPSCR,r10 ; copy r10 back into FPSCR

To read-modify-write a system register, the instruction sequence is:
1. The first instruction copies the value from the target system register to a temporary general-purpose register.
2. The next one or more instructions modify the required bits in the general-purpose register. This can be one or both of:
    • BIC to clear to 0 only the bits that must be cleared.
    • ORR to set to 1 only the bits that must be set.
3. The final instruction writes the value from the general-purpose register to the target system register.
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值