+ -
当前位置:首页 → 问答吧 → 伙伴算法中的MIGRATE_*属性

伙伴算法中的MIGRATE_*属性

时间:2010-04-30

来源:互联网

2.6.24版的内核:空块结构是
struct free_area {
struct list_head free_list[MIGRATE_TYPES];
unsigned long nr_free;
};

#define MIGRATE_UNMOVABLE 0
#define MIGRATE_RECLAIMABLE 1
#define MIGRATE_MOVABLE 2
#define MIGRATE_RESERVE 3
#define MIGRATE_ISOLATE 4 /* can't allocate from here */
#define MIGRATE_TYPES 5

而我在<<Linux内核情景分析>>中它是以2.4内核讲解的,它的空块结构是
typedef struct free_area_struct {
struct list_head free_list;
unsigned int *map;
} free_area_t;


对于某个指定的块大小,即以前只有一个链表,而现在却分为5个链表。

为什么要这样做? 或者说分5个链表有什么好处?

作者: new_new_one   发布时间: 2010-04-30

热门下载

更多