内存申请方式

1、void *kmalloc(size_t size, gfp_t flags)                作者:DayInAI 日期:20190124

kmalloc() 申请的内存位于物理内存映射区域,而且在物理上也是连续的,它们与真实的物理地址
    只有一个固定的偏移,因为存在较简单的转换关系,所以对申请的内存大小有限制,不能超过128KB。 
       较常用的 flags(分配内存的方法):
GFP_ATOMIC —— 分配内存的过程是一个原子过程,分配内存的过程不会被(高优先级进程或中断)打断;
GFP_KERNEL —— 正常分配内存;
GFP_DMA —— 给 DMA 控制器分配内存,需要使用该标志(DMA要求分配虚拟地址和物理地址连续)。
flags 的参考用法: 
 |– 进程上下文,可以睡眠     GFP_KERNEL 
 |– 进程上下文,不可以睡眠    GFP_ATOMIC 
 |  |– 中断处理程序       GFP_ATOMIC 
 |  |– 软中断          GFP_ATOMIC 
 |  |– Tasklet         GFP_ATOMIC 
 |– 用于DMA的内存,可以睡眠   GFP_DMA | GFP_KERNEL 
 |– 用于DMA的内存,不可以睡眠  GFP_DMA |GFP_ATOMIC 

对应的内存释放函数为:
void kfree(const void *objp);

2、void *vmalloc(unsigned long size)

kmalloc时基于slab分配器来实现的,其分配的物理内存时连续的,但是kmalloc一次分配的内存不能太大,现在说vmalloc,vmalloc分配的虚拟内存时连续的,其分配的区间为内存初始化时分配的从VMALLOC_START到VMALLOC_END区间,分配的虚拟内存时以PAGE_SIZE对齐的:

void *vmalloc(unsigned long size)
{
    return __vmalloc_node_flags(size, NUMA_NO_NODE,
                    GFP_KERNEL | __GFP_HIGHMEM);
}
vmalloc函数的调用关系为:

vmalloc()->__vmalloc_node_flags()->__vmalloc_node()->__vmalloc_node_range():
 

猜你喜欢

转载自blog.csdn.net/TheDayIn_CSDN/article/details/86584682