linux 物理页面分配

linux 物理页面分配

核心接口函数

alloc_pages:

include/linux/gfp.h
    
static inline struct page *
alloc_pages(gfp_t gfp_mask, unsigned int order)

用来分配2的order次幂个连续的物理页面,返回第一个物理页面的page数据结构.

mm/page_alloc.c
    
if (unlikely(order >= MAX_ORDER)) {
		WARN_ON_ONCE(!(gfp_mask & __GFP_NOWARN));
		return NULL;
	}

MAX_ORDER 需要小于MAX_ORDER,默认是11

include/linux/mmzone.h

#ifndef CONFIG_FORCE_MAX_ZONEORDER
#define MAX_ORDER 11
#else
#define MAX_ORDER CONFIG_FORCE_MAX_ZONEORDER
#endif

__get_free_pages:

unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order){
    struct page *page;

	page = alloc_pages(gfp_mask & ~__GFP_HIGHMEM, order);
	if (!page)
		return 0;
	return (unsigned long) page_address(page);
}

返回分配内存空间的虚地址,从gfp_mask & ~__GFP_HIGHMEM这个函数不会使用内核的高端地址.

分配一个物理页

#define alloc_page(gfp_mask) alloc_pages(gfp_mask, 0)

#define __get_free_page(gfp_mask) \
		__get_free_pages((gfp_mask), 0)

只是将order值设置为0,注意使用alloc_page 正常来说是会填充一些不确定的值.但是内核提供了一个可以返回全0页面的接口

include/linux/gfp.h
    
    extern unsigned long get_zeroed_page(gfp_t gfp_mask);

    unsigned long get_zeroed_page(gfp_t gfp_mask)
    {
        return __get_free_pages(gfp_mask | __GFP_ZERO, 0);
    }

gfp_mask (分配掩码)添加了一个 __GFP_ZERO 标志

页面的释放

#define free_page(addr) free_pages((addr), 0)
__free_pages(virt_to_page((void *)addr), order);
void __free_pages(struct page *page, unsigned int order)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DipsyHu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值