kzalloc函数功能描述:kzalloc( )函数与kmalloc( )函数功能类似,都是基于slab分配在物理上连续的实际的内存。但是kzalloc( )函数在分配了内存之后,又将内存中的内容都初始化为0。
kzalloc文件包含
#include<linux/slab.h>
kzalloc函数定义
在内核源码中的位置:linux-3.19.3/include/linux/slab.h
函数定义格式:
static inline void *kzalloc(size_t size, gfp_t flags)
kzalloc输入参数说明
size
:指要分配的内存的字节数。flags
:分配标志,它提供了多种kzalloc( )的行为,其选项取值参考kmalloc( )函数的分析。
kzalloc返回参数说明
kzalloc( )函数返回对所分配的内存对象的引用,即得到该内存对象的起始地址。
kzalloc实例解析
编写测试文件:kzalloc.c
头文件及全局变量声明如下:
#include <linux/slab.h>
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("GPL");
static int __init kzalloc_init(void);
static void __exit kzalloc_exit(void);
#define MEM_KZALLOC_SIZE 8092
char * mem_spvm;
模块初始化函数:
int __init kzalloc_init(void)
{
// 调用kzalloc分配一个内存空间
mem_spvm = (char *)kzalloc(MEM_KZALLOC_SIZE, GFP_KERNEL);
if(mem_spvm == NULL )
printk("kzalloc failed! \n");
else
{
printk("kzalloc successfully! addr = 0x%lx\n", (unsigned long)mem_spvm );
printk("the content of mem_spvm+2 is: %d\n", *(mem_spvm+2));
printk("the content of mem_spvm+500 is: %d\n", *(mem_spvm+500));
}
return 0;
}
模块退出函数:
void __exit kzalloc_exit(void)
{
if(mem_spvm ! = NULL)
{
kfree(mem_spvm); //释放由kzalloc( )所分配的内存空间
printk("kfree ok! \n");
}
printk("exit! \n");
}
模块初始化及退出函数调用:
module_init(kzalloc_init);
module_exit(kzalloc_exit);
实例运行结果及分析:
首先编译模块,执行命令insmod kzalloc.ko插入模块,然后执行命令dmesg -c,运行结果如图所示。
结果分析:
该测试文件调用kzalloc( )函数分配一个大小为8092字节的内存空间,mem_spvm为对该内存空间引用。从输出结果可知,内存空间的起始地址为0xffff8801481c2000。然后输出偏移为2和偏移为500的内存内容,均为0,说明kzalloc( )在分配了内存空间之后,又这些内存空间初始化为0。
最后在模块退出时调用kfree( )函数释放由kzalloc( )分配的内存空间。