ARM Cortex-M3 学习笔记(4-6)

最近在学ARM Cortex-M3,找了本号称很经典的书“An Definitive Guide to The ARM Cortex-M3”在看。这个系列学习笔记其实就是在学习这本书的过程中做的读书笔记。

对内存的互斥访问

Cortex-M3 中提供了三对用于互斥访问的内存的指令,分别是:LDREX/STREX, LDREXH/STREXH, LDREXB/STREXB,这三对指令分别对应于字、半字、字节 的取出与写入。

LDREX 的基本指令格式为:

LDREX Rxf, [Rn, #offset]

这条指令与LDR Rxf,[Rn,#offset] 的作用是相同的,唯一的区别是这条指令还会通知内核对它所访问的内存空间特殊关照。如何特殊关照,在STREX 指令执行时显现出来。

 

STREX的基本指令格式为:

STREX Rd, Rxf, [Rn, #offset],作用是将Rxf 的内容写入到 Rn+#offset 地址处的内存,并且将Rd的值改写为0,当然这些操作的前提是这条指令是LDR Rxf,[Rn, #offset]指令执行之后的第一条对Rn+#offset地址处执行写入操作的指令。如果在STREX指令执行之前就有其他的指令对Rn+#offset 地址处的内存进行了写入操作,那么STREX指令将不会改动Rn+#offset 地址处内存,并将Rd的值改写为1以此来表明写入操作不成功。这样,通过在程序中判断Rd的值就可以确定STREX指令是否成功了,如果不成功可以重新再试以此。通过这种机制,就可以实现对资源的保护了。

 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值