亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

Chinaunix

標(biāo)題: free_pages_ok函數(shù),不解? [打印本頁(yè)]

作者: zmmkele    時(shí)間: 2013-07-05 16:06
標(biāo)題: free_pages_ok函數(shù),不解?
本帖最后由 zmmkele 于 2013-07-05 16:09 編輯

linux版本: 2.4.0

在free_pages_ok()函數(shù)源碼中有兩個(gè)疑問(wèn):
  1. while (mask + (1 << (MAX_ORDER-1))) {
  2.                 struct page *buddy1, *buddy2;

  3.                 if (area >= zone->free_area + MAX_ORDER)
  4.                         BUG();
  5.                 [color=Red]/* 這邊改變的貌似只能是area_map的第一個(gè)int中的bit而已? */[/color]
  6.                 if (!test_and_change_bit(index, area->map))
  7.                         /*
  8.                          * the buddy page is still allocated.
  9.                          */
  10.                         break;
  11.                 /*
  12.                  * Move the buddy up one level.
  13.                  */
  14.                 buddy1 = base + (page_idx ^ -mask);
  15.                 buddy2 = base + page_idx;
  16.                 if (BAD_RANGE(zone,buddy1))
  17.                         BUG();
  18.                 if (BAD_RANGE(zone,buddy2))
  19.                         BUG();

  20.               [color=Red] /* 怎么只刪除了buddy1所在的list,沒(méi)操作area其它頁(yè)面? */[/color]
  21.                 memlist_del(&buddy1->list);
  22.                 mask <<= 1;
  23.                 area++;
  24.                 index >>= 1;
  25.                 page_idx &= mask;
  26.         }
復(fù)制代碼
剛看內(nèi)存管理部分,望大家指教。
問(wèn)題1: if (!test_and_change_bit(index, area->map)),  這邊改變的貌似只能是area_map的第一個(gè)int中的bit而已?
問(wèn)題2: memlist_del(&buddy1->list), 怎么只刪除了buddy1所在的list,沒(méi)操作area其它頁(yè)面?

BR

作者: zmmkele    時(shí)間: 2013-07-05 16:56
問(wèn)題2,推測(cè)了下,buddy1為2^order area的首頁(yè)面,即代表著一整個(gè)area。
而一個(gè)area就只有首頁(yè)嗎鏈在area->free_list中。


作者: zmmkele    時(shí)間: 2013-07-06 09:57
我去,大神在哪里?

問(wèn)題1: test_and_change_bit只改變map第一個(gè)int的第一個(gè)bit,
            那么是不是說(shuō)一個(gè)zone的buddy系統(tǒng)所管理的最大的內(nèi)存size=32bits*2*4k per page*(2^0+2^1+....+2^10)
                                                                                               = 32*2*2^12*(2^11-1)
                                                                                               = 512M?

可以這么理解么?
作者: cayleylu    時(shí)間: 2013-08-21 08:34
問(wèn)題一:
buddy系統(tǒng)中兩個(gè)buddies之間,共用一個(gè)map中的bit。
test_and_change_bit(index, area->map)為什么會(huì)跟int有關(guān)系?這里是bit操作!
它反轉(zhuǎn)area->map 中第index個(gè)bit的值,并返回原來(lái)該bit的值。比如原來(lái)該第index個(gè)bit為1,這里返回1,并置第index個(gè)bit為0.
問(wèn)題二:沒(méi)看懂要問(wèn)什么
作者: aweii    時(shí)間: 2013-08-21 11:41
2.6.24已經(jīng)不用位圖了
作者: 瀚海書香    時(shí)間: 2013-08-21 13:09
回復(fù) 1# zmmkele
linux版本: 2.4.0


版本如此之老啊。估計(jì)研究這個(gè)版本的大神現(xiàn)在都創(chuàng)業(yè)去了,沒(méi)時(shí)間給你回答問(wèn)題了

   




歡迎光臨 Chinaunix (http://www.72891.cn/) Powered by Discuz! X3.2