mempool_kmalloc函数功能描述:内存池创建时需要有内存分配(alloc)和释放(free)函数,alloc和free方法常见由mempool_alloc_slab( )和 mempool_free_slab( )函数实现,但mempool_kmalloc( )和mempool_kfree( )也可实现内存元素的分配与释放,它们的实现主要是调用kmalloc( )和kfree( ),在这种情况下pool_data标志要分配和释放的内存空间的大小。
因此mempool_kmalloc( )的功能是内存池的一种分配器,用来为内存池中的element数组中的元素分配空间。
mempool_kmalloc文件包含
#include<linux/mempool.h>
mempool_kmalloc函数定义
在内核源码中的位置:linux-3.19.3/mm/mempool.c
函数定义格式:
void *mempool_kmalloc(gfp_t gfp_mask, void *pool_data)
mempool_kmalloc输入参数说明
gfp_mask
:内存的分配标志,其常见取值及其含义参考alloc_pages( )函数的分析。pool_data
:其值表示要分配的内存空间大小。
mempool_kmalloc返回参数说明
该函数返回所分配的内存元素的起始地址。
mempool_kmalloc实例解析
编写测试文件:mempool_kmalloc.c
头文件及全局变量声明如下:
#include <linux/mm.h>
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/mempool.h>
#include <linux/blkdev.h>
#include <linux/writeback.h>
MODULE_LICENSE("GPL");
static int __init mempool_kmalloc_init(void);
static void __exit mempool_kmalloc_exit(void);
int * pool_data;
void * element = NULL;
模块初始化函数:
int __init mempool_kmalloc_init(void)
{
pool_data = (int *)8192; //设置分配的内存空间大小
element = mempool_kmalloc( GFP_KERNEL , pool_data ); //分配一个内存元素
if( element ! = NULL )
printk("element = 0x%lx\n", (unsigned long)element); //输出起始地址
else
printk("mempool_kmalloc failed! \n");
return 0;
}
模块退出函数:
void __exit mempool_kmalloc_exit(void)
{
if(element)
{
mempool_kfree(element, pool_data); //释放内存元素空间
printk("mempool_kfree successfully! \n");
}
printk("exit! \n");
}
模块初始化及退出函数调用:
module_init(mempool_kmalloc_init);
module_exit(mempool_kmalloc_exit);
实例运行结果及分析:
首先编译模块,执行命令insmod mempool_kmalloc.ko插入模块,然后执行命令dmesg -c,会出现如图所示的结果。
执行命令rmmod mempool_kmalloc.ko卸载模块,执行命令dmesg -c,会出现如图所示的结果。
结果分析:
该测试程序比较简单,要调用mempool_kmalloc( )函数,首先要给其传递参数,gfp_mask选择常用的GFP_KERNEL分配标志,设置要分配的内存空间大小为8192字节(pool_data = (int *)8192)
,然后调用mempool_kmalloc( )函数。由输出信息可知,所分配的内存元素的地址为element = 0xffff8800a7b64000。在模块退出时,为mempool_kfree( )函数传递参数值element、pool_data以释放分配的内存空间,参考极客笔记网关于该函数的分析。