UM10360 All information provided in this document is subject to legal disclaimers. © NXP B.V. 2013. All rights reserved.
User manual Rev. 3 — 20 December 2013  675 of 841
NXP Semiconductors
UM10360
Chapter 34: Appendix: Cortex-M3 user guide
34.2.4.8 LDREX and STREX
Load and Store Register Exclusive.
34.2.4.8.1 Syntax
LDREX{cond} Rt, [Rn {, #offset}]
STREX{cond} Rd, Rt, [Rn {, #offset}]
LDREXB{cond} Rt, [Rn]
STREXB{cond} Rd, Rt, [Rn]
LDREXH{cond} Rt, [Rn]
STREXH{cond} Rd, Rt, [Rn]
where:
cond is an optional condition code, see Section 34.2.3.7 “
Conditional execution”.
Rd is the destination register for the returned status.
Rt is the register to load or store.
Rn is the register on which the memory address is based.
offset is an optional offset applied to the value in Rn. If offset is omitted, the address is the 
value in Rn.
34.2.4.8.2 Operation
LDREX
, 
LDREXB
, and 
LDREXH
 load a word, byte, and halfword respectively from a memory 
address.
STREX
, 
STREXB
, and 
STREXH
 attempt to store a word, byte, and halfword respectively to a 
memory address. The address used in any Store-Exclusive instruction must be the same 
as the address in the most recently executed Load-exclusive instruction. The value stored 
by the Store-Exclusive instruction must also have the same data size as the value loaded 
by the preceding Load-exclusive instruction. This means software must always use a 
Load-exclusive instruction and a matching Store-Exclusive instruction to perform a 
synchronization operation, see Section 34.3.2.7 “
Synchronization primitives”
If an Store-Exclusive instruction performs the store, it writes 0 to its destination register. If 
it does not perform the store, it writes 1 to its destination register. If the Store-Exclusive 
instruction writes 0 to the destination register, it is guaranteed that no other process in the 
system has accessed the memory location between the Load-exclusive and 
Store-Exclusive instructions.
For reasons of performance, keep the number of instructions between corresponding 
Load-Exclusive and Store-Exclusive instruction to a minimum.
Remark: The result of executing a Store-Exclusive instruction to an address that is 
different from that used in the preceding Load-Exclusive instruction is unpredictable.
34.2.4.8.3 Restrictions
In these instructions: