linux驱动物理内存,Linux驱动开发6——DDR内存分配

1、kmalloc和kfree

#include

void *kmalloc(size_t size, intflags);

flag:

GFP_ATOMIC-用来从中断处理和进程上下文之外的其他代码中分配内存,从不睡眠

GFP_KERNEL-内核内存的正常分配,可以睡眠,物理地址上连续,内部调用__get_free_pages

GFP_USER-用来为用户空间页分配内存,可以睡眠

GFP_HIGHUSER- 通GFP_USER,但是从高端内存分配

void kfree(const void *objp);

2、后备缓存

Linux内核提供了后备缓存机制,用来创建一组相同大小对象的内存池,应用在反复分配许多相同大小内存的场景,如USB和SCSI驱动等。Linux内核的缓存管理者为——slab分配器。

#include 创建一个新的,可以驻留任意数目全部同样大小的后备缓存对象

kmem_cache_t*kmem_cache_create(const char *name,

size_t size,

size_t offset,

unsignedlongflags,void (*constructor)(void *, kmem_cache_t *, unsigned longflags),void (*destructor)(void *, kmem_cache_t *, unsigned longflags)

);

name:名称

size:每一个后备缓存的大小

offset: 页内的第一个对象的偏移

flags:

SLAB_NO_REAP-保护缓存在系统查找内存时被削减

SLAB_HWCACHE_ALIGN-对齐

SLAB_CACHE_DMA-在DMA内存区分配内存

constructor-构造函数

deconstructor-析构函数

一旦一个对象的缓存被创建,可以通过kmem_cache_alloc从它分配对象void *kmem_cache_alloc(kmem_cache_t *cache, intflag);

释放对象void kmem_cache_free(kmem_cache_t *cache, const void *obj);

卸载对象int kmem_cache_destroy(kmem_cache_t *cache);

可以通过/proc/slabinfo节点获取后备缓存使用统计

3、内存池

Linux内核创建了一个已知的内存池(mempool)的抽象,它真实地只是一类后备缓存,尽力一直保持一个空闲内存列表给紧急时使用,通常用在不允许内存分配失败的地方。

#include mempool_t*mempool_create(intmin_nr,

mempool_alloc_t*alloc_fn,

mempool_free_t*free_fn,void *pool_data

);

min_nr: 内存池应当一直保留的最小数量的分配对象,实际分配和释放对象由alloc_fn和free_fn处理

alloc_fn:

typedefvoid *(mempool_alloc_t)(int gfp_mask, void *pool_data);

通常使用mempool_alloc_slab分配对象

free_fn:

typedefvoid (mempool_free_t)(void *element, void *pool_data);

通常使用mempool_free_slab释放对象

pool_data: 传递给alloc_fn和free_fnvoid *mempool_alloc(mempool_t *pool, intgfp_mask);void *mempool_free(void *element, mempool_t *pool);int mempool_resize(mempool_t *pool, int new_min_nr, intgfp_mask);void mempool_destroy(mempool_t *pool);

4、get_free_page

分配页

get_zeroed_page(unsignedintflags);

__get_free_page(unsignedintflags);

__get_free_pages(unsignedint flags, unsigned intorder);

释放页void free_page(unsigned longaddr);void free_pages(unsigned long addr, unsigned long order);

5、alloc_pages

Linux页分配器的真正核心是alloc_pages_node函数

struct page *alloc_pages_node(int nid, unsigned int flags, unsigned intorder);

变种函数:struct page *alloc_page(unsigned intflags);struct page *alloc_pages(unsigned int flags, unsigned intorder);

释放页:void __free_page(struct page *page);void __free_pages(struct page *page, unsigned int order);

6、vmalloc和vfree

以页为单位的内存分配,在虚拟内存空间分配一块连续的内存区,但是这些页在物理内存中是不连续的。效率比较低,大部分情况下不鼓励使用。

#include

void *vmalloc(unsigned longsize);void vfree(void *addr);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值