2011年5月15日星期日

  Linux内核设计与实现-内存管理学习小结

一,页

内存管理以页为基本单位,用 struct page 表示系统中的每个物理页。系统中的每个结构都要分配这样一个结构体,假定系统的物理页为4kb,系统有128M的物理内存,那么系统仅需1MB的内存用来管理就可以了,代价并不高。有个地方还不是很明白,书中说page结构与物理页相关,与虚拟页无关。因此,该结构对页的描述只是暂时的。书中也作解释了,但还不是很明白。

二,区

由于硬件的限制,内核把页划分成了不同的区。

Linux使用了三种区,分别为:ZONE_DMA, ZONE_NORMAL, ZONE_HIGHMEM.

在X86上,其分配为:ZONE_DMA < 16MB , ZONE_NORMAL  16M-896M, ZONE_HIGHMEM > 896M

三,内存分配接口

以页为单位获取页的接口:alloc_page(), alloc_pages(), _get_free_page(), _get_free_pages(), get_zeroed_page(),其中,alloc_page(), alloc_pages() 返回page结构体的地址,_get_free_page(), _get_free_pages(), get_zeroed_page() 返回所请求的页的逻辑地址。

如何释放页不再赘述。

四,kmalloc 和 vmalloc

kmalloc和vmalloc均可以以字节为单位获取内存。两者的主要不同是,前者分配的页要求虚拟地址和物理地址都要连续,而后者只需保证虚拟地址连续,而物理地址可以不连续。

在请求内存时通常需要提供内存分配标志。内存分配标志可以分为三类:行为修饰符、区修饰符及类型修饰符。我们通常只需要使用类型修饰符就可以,类型修饰符可以认为是行为修饰符和区修饰符的组合。

在这部分,作者提到只有alloc_pages()才能分配高端内存,对此还存在疑问,希望以后学习时能解决这个问题。

五,slab分配器

以前空闲链表的使用缺乏全局控制,如果内存紧缺时系统无法通知其进行内存回收。slab分配器在全局控制方面有了很好改善。由于slab分配器中空闲链表的缓存连续存放,所以避免了碎片的产生。同时,slab分配器对要分配的对象进行了通用初始化,减少了分配对象初始化的时间,也就减少了对象分配时间。

对于slab分配器来说,每一种对象类型对应一个高速缓存;每个高速缓存又被划分为多个slab;每个slab可以包含多个对象。

slab分配器提供的常用的三个接口:kmem_cache_create(), kmem_cache_alloc(), kmem_cache_free().

一篇剖析Linux slab 分配器的很好的文章:http://www.ibm.com/developerworks/cn/linux/l-linux-slab-allocator/

以上内容是今天学习的内容,其实也是复习了,以后学了新内容后再添加吧。

没有评论:

发表评论