+ -
当前位置:首页 → 问答吧 → linux 2.6.36的free_area结构

linux 2.6.36的free_area结构

时间:2010-11-07

来源:互联网

《深入理解linux内核 第三版》
#define MIGRATE_TYPES 5
struct free_area
{
struct list_head free_list[MIGRATE_TYPES];

unsigned long nr_free;
}
在linux 2.4或者2.6早起版本都是struct list_head free_list;现在变成struct list_head free_list[MIGRATE_TYPES];是不是说现在每个固定大小的空闲块(2^k个页框)有5个链表来组织而不再是以前的一个链表呢?

作者: diandianlianyi   发布时间: 2010-11-07

非也... 本质上和以前是一样的...只不过同一个ORDER的buddy被分为很多种类型...
如不可移动的...可以移动的..可回收的... 这样做是为了解决系统运行时间长之后...buddy allocator造成的系统的连续物理页面会降低的问题.  比如尽管系统依旧有很多的内存. 但是都是一些碎片页.非常的分散. 这样在需要分配大的连续物理内存就会失败...系统运行的时间越长这就越明显.    分类后就可以合理而且更加方便的进行反碎片工作.

作者: PCliangtao   发布时间: 2010-11-08