如果模块需要分配大块的内存,使用页面的分配技术会更好一些。
unsigned long get_zeroed_page(gfp_t gfp_mask)
返回指向新页面的指针并将页面清零。
unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order);
用于以gfp_mask分配方式分配2的order次方个连续的物理页,并返回指向该区域第一个字节的指针。不清零页面。
gfp_mask掩码和kmalloc一样。
order有最大值,可能是10或者11,这依赖于系统。
还有更为简洁的宏__get_free_page,如下
#define __get_free_page(gfp_mask) \
__get_free_pages((gfp_mask), 0)
有分配就有释放,以下是释放页面的函数:
#define free_page(addr) free_pages((addr), 0)
void free_pages(unsigned long addr, unsigned int order);
释放同样是一个函数和一个简化后的宏。如果试图释放和先前分配数目不等的页面,内存映射关系就会被破坏,随后系统就会出错。
值得强调的是,只要符合和kmalloc同样的规则,get_free_pages和其他函数可以在任何时间调用。某些情况下函数分配内存时会失败,特别是在使用GFP_ATOMIC的时候。因此,调用了这些函数的程序在分配出错时都应提供相应的处理。