2.6.29 pageblocks flag 的问题
兄弟们,最近在看2.6.29 boot mem 部分
关于setup_usemap 中 pageblock_flags
大概作用是放 MIGRATE type 的,一共有5种 ,占3bit
但是这个pageblock_flags 的大小的算法不太能看懂,
static unsigned long __init usemap_size(unsigned long zonesize)
{
unsigned long usemapsize;
usemapsize = roundup(zonesize, pageblock_nr_pages);
usemapsize = usemapsize >> pageblock_order; /* =16k/2k =8 */
usemapsize *= NR_PAGEBLOCK_BITS; /* 8*3 =24 */
usemapsize = roundup(usemapsize, 8 * sizeof(unsigned long));
return usemapsize / 8; /* 32/8 = 4 */
}
上面函数中,根据实际情况,比如smdk2410 ,64M no dma, highmem ,那么zonesize 64M 就是有16K page
pageblock_order =maxoder-1 ,如果设置maxorder=12, 那么 pageblock_order=11 ,
然后估算出来为4 byte ,
如果我猜的意思是对的话, 就是所每2048个 page 设置3bit flag , 但是为什么每2048个page 占3bit
是否是因为一开始所有free area 上内存都挂在最大order 11 上, 只是先对这个order 的所有page block 分配user map
等后面实际分配过程中再对挂在不同order 上的pageblock (大小不同了,order 10 pageblock =1024个page), 分配新的usemap ,但我没找到相应代码
请有懂的兄弟解释下,谢了
关于setup_usemap 中 pageblock_flags
大概作用是放 MIGRATE type 的,一共有5种 ,占3bit
但是这个pageblock_flags 的大小的算法不太能看懂,
static unsigned long __init usemap_size(unsigned long zonesize)
{
unsigned long usemapsize;
usemapsize = roundup(zonesize, pageblock_nr_pages);
usemapsize = usemapsize >> pageblock_order; /* =16k/2k =8 */
usemapsize *= NR_PAGEBLOCK_BITS; /* 8*3 =24 */
usemapsize = roundup(usemapsize, 8 * sizeof(unsigned long));
return usemapsize / 8; /* 32/8 = 4 */
}
上面函数中,根据实际情况,比如smdk2410 ,64M no dma, highmem ,那么zonesize 64M 就是有16K page
pageblock_order =maxoder-1 ,如果设置maxorder=12, 那么 pageblock_order=11 ,
然后估算出来为4 byte ,
如果我猜的意思是对的话, 就是所每2048个 page 设置3bit flag , 但是为什么每2048个page 占3bit
是否是因为一开始所有free area 上内存都挂在最大order 11 上, 只是先对这个order 的所有page block 分配user map
等后面实际分配过程中再对挂在不同order 上的pageblock (大小不同了,order 10 pageblock =1024个page), 分配新的usemap ,但我没找到相应代码
请有懂的兄弟解释下,谢了
作者: liu090 发布时间: 2011-02-18
顶一下
作者: liu090 发布时间: 2011-02-18