Linux内核API kzalloc

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,运行结果如图所示。

Linux内核API kzalloc

结果分析:

该测试文件调用kzalloc( )函数分配一个大小为8092字节的内存空间,mem_spvm为对该内存空间引用。从输出结果可知,内存空间的起始地址为0xffff8801481c2000。然后输出偏移为2和偏移为500的内存内容,均为0,说明kzalloc( )在分配了内存空间之后,又这些内存空间初始化为0。

最后在模块退出时调用kfree( )函数释放由kzalloc( )分配的内存空间。

赞(0)
未经允许不得转载:极客笔记 » Linux内核API kzalloc
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址