Linux内核内存分配

  • Post author:
  • Post category:linux


kmalloc

得到的是逻辑地址。(逻辑地址的访问速度比虚拟地址快)

得到的内存在物理上是连续的。(大部分DMA设备要求对应的内存是物理连续的)

适合分配小块内存,最好不要大于一页。

有最大尺寸限制,比如128K(因系统/配置而异)。

基于slub。

vmalloc

返回的是虚拟地址。

得到的内存在物理上不一定是连续的。

适合分配大块内存, 比如几MB到几十MB。

基于buddy system。

alloc_pages/get_free_page …

参见:

Physical Page Allocation


得到的可以是逻辑地址(要映射到高端内存),也可以是虚拟地址。

适合分配大块内存。一次分配若干页。

基于buddy system。

buddy system(伙伴系统) 与 slub

伙伴系统是批发商。slub是零售商。

伙伴系统在分配内存时是以物理页为单位的,一次至少分配4K(因系统/配置而异)。

slub是为了解决小内存分配问题的。slub依赖于伙伴系统。slub所做的事情,就是把伙伴系统分配的大块内存进一步的细分成很多份小块内存进行管理。一次至少分配32字节(因系统/配置而异)。



版权声明:本文为emaillk原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。