1 cp15 registers access – Rainbow Electronics AT91CAP9S250A User Manual
Page 60
data:image/s3,"s3://crabby-images/3a32b/3a32b7cbb74ea247a8dc0c165aa8088f489ae2c0" alt="background image"
60
6264A–CAP–21-May-07
AT91CAP9S500A/AT91CAP9S250A
12.4.1
CP15 Registers Access
CP15 registers can only be accessed in privileged mode by:
• MCR (Move to Coprocessor from ARM Register) instruction is used to write an ARM register
to CP15.
• MRC (Move to ARM Register from Coprocessor) instruction is used to read the value of
CP15 to an ARM register.
Other instructions like CDP, LDC, STC can cause an undefined instruction exception.
The assembler code for these instructions is:
MCR/MRC{cond} p15, opcode_1, Rd, CRn, CRm, opcode_2.
The MCR, MRC instructions bit pattern is shown below:
• CRm[3:0]: Specified Coprocessor Action
Determines specific coprocessor action. Its value is dependent on the CP15 register used. For details, refer to CP15 spe-
cific register behavior.
• opcode_2[7:5]
Determines specific coprocessor operation code. By default, set to 0.
• Rd[15:12]: ARM Register
Defines the ARM register whose value is transferred to the coprocessor. If R15 is chosen, the result is unpredictable.
• CRn[19:16]: Coprocessor Register
Determines the destination coprocessor register.
• L: Instruction Bit
0 = MCR instruction
1 = MRC instruction
• opcode_1[23:20]: Coprocessor Code
Defines the coprocessor specific code. Value is c15 for CP15.
• cond [31:28]: Condition
For more details, see Chapter 2 in ARM926EJ-S TRM, ref. DDI0198B.
31
30
29
28
27
26
25
24
cond
1
1
1
0
23
22
21
20
19
18
17
16
opcode_1
L
CRn
15
14
13
12
11
10
9
8
Rd
1
1
1
1
7
6
5
4
3
2
1
0
opcode_2
1
CRm