曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 12350|回复: 0
打印 上一主题 下一主题

__get_free_pages | 分配内存(直接分页) | free_pages 释放内存

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34395
跳转到指定楼层
楼主
发表于 2009-9-1 02:26:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
函数原型:
#include <linux/gfp.h>
__get_free_pages (unsigned int gfp_mask, unsigned int order);

2.4 内核需要包含的头文件是 <linux/mm.h>

__get_free_pages() 函数的第一个变量 gfp_mask 可以直接使用 kmalloc() 函数中使用的参数。但是,第二个变量不是指定大小,而表示 2^order 次方个页,如是 0 就分配一个页,是 3 就分配 8 个页。

如果想为分配一块内存空间,但嫌计算所需多少页比较麻烦,那可以使用 get_order() 函数来获取 order 值。如:
char *buff;
int order;

order = get_order (8192);
buff = __get_free_pages (GFP_KERNEL, order);
if (buff != NULL) {

...

free_pages (buff, order);
}
使用该函数时,一定要注意 order 最大值,该最大值定义为 MAX_ORDER ,通常为 11 ,也可能是 10 ,这根据平台的不同而不同。如果 order 的值国大,则分配失败的几率就较高,通常使用小于 5 的值,即只分配 32 x PAGE_SIZE 大小的内存。

其实 kmalloc() 的底层实现也是基于 __get_free_pages() 。

由 __get_free_pages 申请的内存由 free_pages() 函数来释放,其原型为:
#include <linux/gfp.h>
free_pages(unsigned long addr, unsigned int order);
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-5-4 02:56 , Processed in 0.080891 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表