ARM的协处理器CP15
https://blog.csdn.net/daocaokafei/article/details/114292514
介绍CP15所有寄存器的文档:
DDI0438I_cortex_a15_r4p0_trm.pdf
DDI0406C_d_armv7ar_arm.pdf
协处理器CP15,包含16个32位的寄存器,编号为0~15。常用来控制cache、TCM和存储器管理。
而访问CP15寄存器的指令主要是MCR和MRC这两个指令:
MRC:协处理器寄存器到ARM寄存器的数据传送指令(读出协处理器寄存器)。
(记忆:RC :read cp15,读cp15寄存器的值到ARM寄存器)
MCR:ARM寄存器到协处理器寄存器的数据传送指令(写入协处理器寄存器)。
(记忆:CR :cp15 read,将ARM寄存器的值 写到 协处理器寄存器)
格式:
MRC{cond} p15,<Opcode_1>,<Rd>,<CRn>,<CRm>,<Opcode_2>
MCR{cond} p15,<Opcode_1>,<Rd>,<CRn>,<CRm>,<Opcode_2>
格式解释:
cond:为指令执行的条件码。当cond忽略时指令为无条件执行。
Opcode_1:协处理器的特定操作码. 对于CP15寄存器来说,opcode1=0。
Rd:作为源寄存器的ARM寄存器,其值将被传送到协处理器寄存器中,或者将协处理器寄存器的值传送到该寄存器里面 ,通常为R0。
CRn:作为目标寄存器的协处理器寄存器,其编号是C~C15。
CRm:协处理器中附加的目标寄存器或源操作数寄存器。如果不需要设置附加信息,将CRm设置为c0,否则结果未知 。
Opcode_2:可选的协处理器特定操作码。(用来区分同一个编号的不同物理寄存器,当不需要提供附加信息时,指定为0)。
示例:
mrc p15, 0, r0, c1, c0, 0 //将 CP15 的寄存器 C1 的值读到 r0 中
mcr p15, 0, r0, c7, c7, 0 //(写值到cp15)关闭ICaches和DCaches
mcr p15, 0, r0, c8, c7, 0 //(写值到cp15)使无效整个数据TLB和指令TLB
C0~C15 每个寄存器每个位的含义,见引用文档。
设置异常向量表
1、CP15的寄存器 C1(SCTLR ) 的(bit[13])
对于支持高端异常向量表的系统,本控制位控制向量表的位置
0 :选择低端异常中断向量 0x0~0x1c
1 :选择高端异常中断向量0xffff0000~ 0xffff001c
对于不支持高端异常向量表的系统,读取时该位返回0,写入时忽略。
2、CP15的寄存器 C12(VBAR)
CP15寄存器C12用来设置异常向量基地址,其编码格式如下所示:
MCR p15, 0, r0, c12, c0, 0 ;r0中存放要修改的异常向量基地址
注:只有ARM11和cortex-a 可以任意修改异常向量基地址。arm7,ARM9,ARM10只可以在0地址或0xffff0000中