Linux内核API page_cache_get

page_cache_get宏功能描述:宏page_cache_get(page)用来增加页的引用计数,它与page_cache_release(page)有时是合用的,作用仅是锁定页而已,最终并不增加页计数。

page_cache_get文件包含

#include<linux/pagemap.h>

page_cache_get宏定义

在内核源码中的位置:linux-3.19.3/include/linux/pagemap.h

宏定义格式:

#def ine page_cache_get(page) get_page(page)

page_cache_get输入参数说明

  • page:它是页结构体指针,是对linux内存管理中页的描述,参考alloc_pages( )函数的分析。

page_cache_get返回参数说明

该宏没有返回值。

page_cache_get实例解析

编写测试文件:page_cache_get.c

头文件及全局变量声明如下:

#include <linux/init.h>
#include <linux/module.h>
#include <linux/gfp.h>
#include <linux/mm_types.h>
#include <linux/mm.h>
#include <linux/pagemap.h>
MODULE_LICENSE("GPL");
static int __init page_cache_get_init(void);
static void __exit page_cache_get_exit(void);
struct page * pages = NULL;

模块初始化函数:

int __init page_cache_get_init(void)
{
    pages = alloc_pages(GFP_KERNEL,0);  //分配一个页
    if(! pages)
    {
        printk("alloc failed! \n");
        return -ENOMEM;
    }
    else
    {
        printk("after allcating, _count=%d\n", pages->_count);
                                          // 输出页初始分配后的引用计数
        page_cache_get(pages);
        // 输出对页进行page_cache_get操作后,页的引用计数
        printk("after page_cache_get, _count=%d\n", pages->_count);
        page_cache_release(pages);
        // 输出对页进行page_cache_release操作后,页的引用计数
        printk("after page_cache_release, _count=%d\n", pages->_count);
    }
    return 0;
}

模块退出函数:

void __exit page_cache_get_exit(void)
{
    if(pages)
        __free_pages(pages,0);       //释放所分配的页
    printk("exit ok! \n");
}

模块初始化及退出函数调用:

module_init(page_cache_get_init);
module_exit(page_cache_get_exit);

实例运行结果及分析:

首先编译模块,执行命令insmod page_cache_get.ko插入模块,然后执行命令dmesg -c,会出现如图所示的结果。

Linux内核API page_cache_get

结果分析:

宏page_cache_get(page)和page_cache_release(page)的作用是改变页的引用计数。page结果体中_count字段是描述页的引用计数的,当一个页刚刚被分配,它的初始_count = 1。进行page_cache_get(pages)操作后,将对引用计数进行加1操作,由输出结果可知_count = 2,在进行page_cache_release(pages)操作,将对引用计数进行减1操作,_count又变为了1。页的引用计数是指页当前被几个用户使用,这两个宏可以用来实现页的加锁和解锁操作。

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

评论 抢沙发

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