DPDK之Cache和内存

存储系统简介:存储系统是指计算机用于存储数据部分,如磁盘,硬盘,内存以及cpu内部cache。
1.RAM(Random Access memory):随机访问存储器
2.SRAM(static RAM):静态随机访问存储器
3.DRAM(dynamic RAM):动态随机访问存储器
4.DDR
Cache的种类,从成本和生产工艺的角度考虑,一般分为三级,L1/L2/L3,速度一次减慢。cache的容量一般都很小,一般在几百KB到几MB不等。
根据cache和内存之间的映射关系的不同,cache可以分为全关联性,直接关联性,组关联性。
全关联性cache:
全关联性cache是指主存中的任意一块内存都可以映射到cache中的任意一块位置上。通过目录表查询是否该内容缓存在cache中。目录表由三部分组成:内存地址,cache块号和一个有效位。
如何查找?
内存的块地址A在cache的目录表中进行查询,如果找到等值的内存块地址,就检查有效位是否有效,只有有效的情况下,才能通过cache块号在cache中找到缓存的内容,取地对应的数据,称之为cache命中。
直接关联性cache:
直接关联性cache是指主存中的一块内存只能映射到cache的一个特定的块中。
直接关联性的目录表由两部分组成:区号和有效位,内存地址被分为区号,块号和块内存地址三部分。通过区号找到在目录表对应的区号,判断是否有效,如果找到且有效则数据在cache中,根据块号和块内地址找到对应的数据。
组关联性cache:
组关联性是目前cache中用的不叫广泛的一种,是全关联性和直接关联性的折中选择。内存被分为很多个组,一个组的大小为多个cache line的大小,一个组被映射到多个连续的cache line,也就是一个cache组。内存组中的任意一块可以映射到对应cache组的任意一个。

cache的写策略
内存数据加载到cache中,某一个时刻要被写回内存,对于时刻的选择,有几种不同的策略:
1.直写
处理器在对cache先写入的同时也将数据直接写入内存。
2.回写
只有在cache line被选中需要替换会内存中时候,检查dirty位是否有修改,修改过的数据才会写入内存。
cache预取
根据空间局部性和时间局部性,预测数据并取入到Cache中。
cache一致性
cache一致性策略,cache无效和cache刷新。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值