最近在学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指令是否成功了,如果不成功可以重新再试以此。通过这种机制,就可以实现对资源的保护了。