首先我提几个主题:
磁盘高速缓存、内存高速缓存、硬件高速缓存、每cpu页框高速缓存、页高速缓存、目录项高速缓存、索引节点高速缓存、转换后援缓冲器(TLB)、哈佛结构的高速缓存、写缓冲器、高速缓存一致性、L1和L2等高速缓存在驱动的使用。
上面这些就我在接下来的文章中要讨论的东西。如果您对上面的东西了如指掌,真心希望您能给本屌丝指点指点。
高速缓存大家喜欢叫cache。对于嵌入式的观众,第一反应可能是arm中常提到的dcache、icache。如果你意识到这个;恭喜你!你已经看见哈佛结构的高速缓存了同时明白了硬件高速缓存。对于这样的认识,只是在硬件层,本身哈佛结构就是硬件层的话题。但是我的所有讨论都是在linux环境下,那么linux中提到的高速缓存是什么?(下面代码参考linux-3.2.8)
下面我们讨论由软件机制构造出的高速缓存。(自备饮料、爆米花和3D眼镜)
1.每CPU页框高速缓存。
内核经常请求和释放单个页框。为了提升系统性能,每个内存管理区定义了一个“每CPU”页框高速缓存。所有“每CPU”高速缓存包含一些预先分配的页框。
这个高速缓存分为两个缓存,一个是热高速缓存,它存放的页框中所包含的的内容很可能就在cpu硬件高速缓存中。;另一个是冷高速缓存。
对于这两个的管理,很多文章说有两个per_cpu_pages描述符组成。不过在我在linux-3.2.8中看到只用了一个,简单看一下:
struct per_cpu_pages *pcp;
struct list_head *list;
//…省略代码