CP15协处理器.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CP15协处理器

访问CP15寄存器指令的编码格式及语法说明如下: 31  28 27  24 23  21 20 19  16 15  12 11  8 7  5 4 3  0 cond 1 1 1 0 opcode_1 L crn rd 1 1 1 1 opcode_2 1 crm 说明: opcode_1:协处理器行为操作码,对于CP15来说,opcode_1永远为0b000,否则结果未知。 rd:不能是r15/pc,否则,结果未知。 crn:作为目标寄存器的协处理器寄存器,编号为C0~C15。 crm:附加的目标寄存器或源操作数寄存器,如果不需要设置附加信息,将crm设置为c0,否则结果未知。 opcode_2:提供附加信息比如寄存器的版本号或者访问类型,用于区分同一个编号的不同物理寄存器,可以省略opcode_2或者将其设置为0,否则结果未知。指    令 说    明 语法格式 mcr 将ARM处理器的寄存器中的数据写到CP15中的寄存器中 mcr{cond}   p15, opcode_1, rd, crn, crm, {opcode_2}mrc 将CP15中的寄存器中的数据读到ARM处理器的寄存器中 mcr{cond}   p15, opcode_1, rd, crn, crm, {opcode_2}4.1.2  CP15寄存器介绍 CP15的寄存器列表如表4-1所示。 表4-1  ARM处理器中CP15协处理器的寄存器寄存器编号 基本作用 在MMU中的作用 在PU中的作用 0 ID编码(只读) ID编码和cache类型 1 控制位(可读写) 各种控制位 2 存储保护和控制 地址转换表基地址 Cachability的控制位 3 存储保护和控制 域访问控制位 Bufferablity控制位 4 存储保护和控制 保留 保留 5 存储保护和控制 内存失效状态 访问权限控制位 6 存储保护和控制 内存失效地址 保护区域控制 7 高速缓存和写缓存 高速缓存和写缓存控制 8 存储保护和控制 TLB控制 保留 9 高速缓存和写缓存 高速缓存锁定 10 存储保护和控制 TLB锁定 保留 11 保留 12 保留 13 进程标识符 进程标识符 14 保留 15 因不同设计而异 因不同设计而异 因不同设计而异 CP15的寄存器C0 CP15中寄存器C0对应两个标识符寄存器,由访问CP15中的寄存器指令中的opcode_2指定要访问哪个具体物理寄存器,opcode_2与两个标识符寄存器的对应关系如下所示:opcode_2编码 对应的标识符号寄存器 0b000 主标识符寄存器 0b001 cache类型标识符寄存器 其他 保留 1)主标识符寄存器 访问主标识符寄存器的指令格式如下所示: mrc p15, 0, r0, c0, c0, 0       ;将主标识符寄存器C0,0的值读到r0中 ARM不同版本体系处理器中主标识符寄存器的编码格式说明如下。 ARM7之后处理器的主标识符寄存器编码格式如下所示: 31             24      23            20      19              16    15              4     3               0由生产商确定 产品子编号 ARM体系版本号 产品主编号 处理器版本号 位 说    明 位[3: 0] 生产商定义的处理器版本号 位[15: 4] 生产商定义的产品主编号,其中最高4位即位[15:12]可能的取值为0~7但不能是0或7位[19: 16] ARM体系的版本号,可能的取值如下: 0x1   ARM体系版本4 0x2   ARM体系版本4T 0x3   ARM体系版本5 0x4   ARM体系版本5T 0x5   ARM体系版本5TE 其他  由ARM公司保留将来使用位[23: 20] 生产商定义的产品子编号,当产品主编号相同时,使用子编号来区分不同的产品子类,如产品中不同的高速缓存的大小等位[31: 24] 生产厂商的编号,现在已经定义的有以下值: 0x41  =A  ARM公司 0x44  =D  Digital Equipment公司 0x69  =I   intel公司 ARM7处理器的主标识符寄存器编码格式如下所示: 31             24     23     22                        16           15          4         3          0由生产商确定 A 产品子编号 产品主编号 处理器版本号 位 说    明 位[3: 0] 生产商定义的处理器版本号 位[15: 4] 生产商定义的产品主编号,其中最高4位即位[15:12]的值为0x7位[22:

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档