baron · 3月18日 · 四川

05-cache相关的系统寄存器

快速连接

👉👉👉【精选】ARMv8/ARMv9架构入门到精通-目录 👈👈👈


 title=

引流关键词:缓存,高速缓存,cache, CCI,CMN,CCI-550,CCI-500,DSU,SCU,L1,L2,L3,system cache, Non-cacheable,Cacheable, non-shareable,inner-shareable,outer-shareable, optee、ATF、TF-A、Trustzone、optee3.14、MMU、VMSA、cache、TLB、arm、armv8、armv9、TEE、安全、内存管理、页表…

cache的很多结构、缓存替换策略、协议都是和硬件相关的,很多也都是更改不了的。对于不同的架构不同的core,可能都是不一样的。那么这些信息是如何告诉操作系统的呢?

操作系统需要知道以下信息:

  • 有多少级缓存?
  • cacheline有多大?
  • 缓存中有多少set,多少way?
  • 对于清零操作,有多少数据将清零?

CLIDR_EL1 : Cache Level ID Register

(注意,没有CLIDR_EL0 、CLIDR_EL2 、CLIDR_EL3 , 只有CLIDR_EL1 。)
在这里插入图片描述
提供cache的层级关系,以及Inner cache的定义。
在这里插入图片描述

CTR_EL0 : Cache Type Register

(注意,没有CTR_EL1、CTR_EL2、CTR_EL3, 只有CTR_EL0。)
在这里插入图片描述
获取cache的一些信息,如cache line的大小

CCSIDR_EL1 和 CSSELR_EL1

(这两个寄存器,也是只有EL1,没有EL0/2/3后缀)
CSSELR_EL1写入cache level值,然后从CCSIDR_EL1中读取该level cache的 set、way信息

(CSSELR_EL1)
在这里插入图片描述
(CCSIDR_EL1 )
在这里插入图片描述

DCZID_EL0 : Data Cache Zero ID Register

(注意,没有DCZID_EL1、DCZID_EL2、DCZID_EL3, 只有DCZID_EL0。)
DC ZVA, 按照虚拟地址数据清零,那么是给多少size的数据清零呢,由DCZID_EL0配置。
在这里插入图片描述

BS, bits [3:0]--Log2 of the block size in words.

SCTLR_ELx

(注意,有SCTLR_EL1、SCTLR_EL2、SCTLR_EL3, 没有SCTLR_EL0。)
在这里插入图片描述

SCTLR.I : disable or enable I-Cache
SCTLR.C: disable or enable D-Cache

SCTLR.M: disable or enable MMU

关注"Arm精选"公众号,备注进ARM交流讨论区。
图片1.png

推荐阅读
关注数
9466
内容数
212
以易懂、渐进、有序的方式,深入探讨ARMv8/ARMv9架构的核心概念。我们将从基础知识开始,逐步深入,覆盖最新的架构,不再纠缠于过时技术。本系列内容包含但不限于ARM基础、SOC芯片基础、Trustzone、gic、异常和中断、AMBA、Cache、MMU等内容,并将持续更新。
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息