ICache和DCache

本文介绍了ICache和DCache的基本概念及作用。ICache用于缓存指令,提高CPU执行速度;DCache则用于缓存数据,其使用依赖于MMU。文章详细解释了两者的访问机制,并通过汇编代码展示了如何控制ICache的开启与关闭。

ICache和DCache

ICache和DCache

在这里插入图片描述
那么,什么是icache呢
它是一种内存,虽然目前接触了好几种内存,寄存器,DDR等,它们在物理上的工作原理虽然不同,但是访问属性却很像。

在速度上
CPU > 寄存器 > Cache > DDR
在容量上
CPU < 寄存器 < Cache < DDR

整个系统中,CPU的供应链由:寄存器+cache+DDR+硬盘/flash 四阶组成
icache用来缓存指令,
dcache用来缓存数据,dcache用的前提是mmu要启动。目前裸机部分用不到,操作系统MMU才用得到。
在这里,目前icache的一切都是自动的,不需要我们去做什么。
我们只需要打开或者关闭icache。
在这里插入图片描述
我们的程序在SDRAM中,如果不用cache的话,cpu每执行一条指令,都要去访问SDRAM。速度很慢。加上icache的话,当cpu去访问SDRAM时,会把附近一小块指令放到icache中去,下次执行时它会先看看icache中有没有那些指令,如果有直接从icache中取出来执行,如果没有就去SDRAM中取。
汇编代码读写CP15以开关icache
[plain] view plain copy

  1. mrc p15,0,r0,c1,c0,0 // 读出cp15的c1到r0中
  2. bic r0, r0, #(1<<12) // bit12 置0 关icache
  3. orr r0, r0, #(1<<12) // bit12 置1 开icache
  4. mcr p15,0,r0,c1,c0,0;

reference

1.笑看江湖路6 icache和dcache

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

静思心远

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值