【kernel 中内存分配那点事】
首先呢作為車載bsp開發人員,寫大量的內核代碼是不現實的事情,多數都是修修改改,但是要有內核代碼閱讀瀏覽理解的能力,畢竟linux kernel 還是很nb 的,所有技術人員深入研究內核代碼是必須的,也毛病,而且越是資深的大佬對這方便越牛。
kernel 中內存分配的常用幾種方式:
1、kmalloc: (分配連續的物理空間,最大為128K)
?通用 cache
void *kmalloc(size_t size, gfp_t flags)
kmalloc 基于以下幾種size的mem cache:32, 64, 128, 256, 512, 1,024, 2,048, 4,096,8,192, 16,384, 32,768, 65,536 和 131,072 bytes。其本質也是調用kmem_cache_alloc來分配object。所以kmalloc一次最大可分配的size為128KB。kmalloc分配速度很快,在分配時需注意gfp flag
參數:在不interrupt上下文(ISR, softirq, tasklet)及不可睡眠上下文使用GFP_ATOMIC。
? ?內核還增加了內存清零的分配函數:kzalloc。
?專用 cache
kmem_cache_create()
void *kmem_cache_alloc(struct kmem_cache *cachep, gfp_t flags)如果你需要頻繁的分配和釋放某個結構,建議不要采用kmalloc,而是自己在slab系統中創建memory cache。
指定該結構的object size。分配時使用kmem_cache_alloc。同樣的slab object大小也有限制,一般情況下一個MAX_OBJ_ORDER是5,也就是32個頁,128KB。
2、vmalloc (非連續內存分配,可以申請的較大的連續的內存空間)
void *vmalloc(unsigned long size)超過128KB的內存顯然不能使用slab分配,并且當申請的連續內存大小不能在buddy系統中得到滿足,那么就需要使用vmalloc。vmalloc為了把物理的非連續頁一個個映射,從而導致比直接內存映射大的多的后援緩沖區抖動。除非需要特別大的內存,否則盡量不要使用vmalloc。
3、基于DMA 分配
void * dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp)
在某些arch中,可以使用dma_alloc_coherent來分配DMA專用內存。列入在arch/arm/mm/consistent.c中,該函數先分配最小可滿足size的2^order內存,然后釋放2^order-size多余的頁給buddy。而arch/i386/kernel/pci-dma.c中,則直接分配2^order塊內存。
4、__get_free_pages(分配大空間的連續物理內存,4MB)
頁分配
unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order)直接從buddy系統中獲得原始頁。最原始的分配方式。
slab分配器
總結
以上是生活随笔為你收集整理的【kernel 中内存分配那点事】的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LVDS 相关功能调式
- 下一篇: repo 原理