青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 17  文章 - 48  trackbacks - 0
<2015年4月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

常用鏈接

留言簿(3)

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

上一篇從 Bootloader 開始到內核載入使用的都是平坦內存,即所有地址對應實際的物理地址。現代操作系統都使用分頁來管理內存,分頁可以讓每個進程都有完整的虛擬地址空間,進程間的虛擬地址空間相互隔離以提供頁層級的保護。另外分頁可以讓物理內存少于虛擬地址空間,同時可以使用磁盤存儲暫時未使用的內存頁,提供更多的「內存」。

分頁

分頁通過 CPU 的 MMU(Memory Management Unit) 完成,MMU 通過當前的分頁表完成虛擬地址到物理地址的轉換。在 x86 下 MMU 通過兩級分頁表(也可以開啟三級)完成地址轉換,這兩級分別是頁目錄(Page Directory)和頁表(Page Table)。在 x86 下,由 cr3 寄存器存儲頁目錄的地址(物理地址),頁目錄和頁表都包含 1024 項,每項 4 字節,因此頁目錄和頁表大小為 4KB ,按照 4KB 一頁的話,剛好占用一頁。
MMU 將虛擬地址轉換成物理地址的方式是,取虛擬地址的 22~31bits 表示頁目錄的下標,獲得頁目錄項定位到頁表,再取 12~21bits 表示頁表的下標,獲得頁表項定位到頁,最后取 0~11bits 表示頁偏移。頁目錄項和頁表項的下標分別用 10bits 表示,剛好最大 1024 項,頁內偏移用 12bits 表示,剛好 4KB。
頁目錄項結構如下:
其中 S 表示頁大小是 4KB 還是 4MB,P 表示頁表是否在內存中,如果在內存中,那么 12~31 bits 存儲了 4KB 對齊的頁表地址(同樣是物理地址),其它 bit 的含義請參考這里
頁表項結構如下:
同樣的,P 表示此頁是否在內存中,如果在內存中,12~31 bits 存儲了頁的地址。
我們知道了頁目錄和頁表的結構,準備好頁目錄和頁表,就可以開啟分頁了,開啟分頁只需把頁目錄地址放到 cr3 寄存器中,并把 cr0 的最高 bit 置 1。通過頁目錄項,我們可以發現頁表不需要都存在內存當中,當訪問一個虛擬地址,它對應的頁表或者頁不存在內存中時會觸發 Page Fault 異常,我們可以在異常處理函數中完成頁表或者頁的分配,理論上開啟分頁只需要準備好頁目錄。

分頁前后

準備好頁目錄頁表,設置 cr3 和 cr0,開啟了分頁之后,內核的所有地址都變成了虛擬地址,所有的地址都要通過 MMU 映射到物理地址再訪問內存。這一變化是需要小心注意的,開啟分頁前,訪問的所有地址是物理地址,開啟分頁之后,所有的地址都變成了虛擬地址,因此,如果分頁由內核來完成,那么內核就需要考慮到前后的變化,即有一部分代碼運行在物理地址下,其它代碼都運行在虛擬地址下;如果分頁由 Bootloader 完成,那么 Bootloader 需要注意這個變化,并正確跳轉到內核,讓內核完整運行在虛擬地址下。
上一篇我把內核展開到從 0x100000 開始的物理內存中,編譯鏈接內核的時候也把代碼段的地址指定到 0x100000 的地址。開啟分頁之后,內核一般運行在高地址(比如 Linux 內核地址從 0x80000000 開始,Windows 從 0xC0000000 開始),而內核同樣是展開到從 0x100000 開始的物理內存中。我選擇把內核的虛擬地址鏈接到從 0xC0100000 開始,并把這個虛擬地址映射到 0x100000 的物理地址,開啟分頁之前運行的代碼,凡是涉及到地址的操作,我都會把虛擬地址調整為物理地址再操作,開啟分頁之后,所有虛擬地址就可以正常運行了。

物理內存管理

操作系統采用分頁方式管理內存,因此物理內存的管理也需按照頁的方式管理,在 Page Fault 異常觸發時,在異常處理函數中分配新的物理頁并把它映射到分頁表中。這里牽涉到空閑物理內存頁的分配和釋放,我們很容易想到一種直觀的方法,把所有空閑內存頁用鏈表串聯起來,分配釋放一頁只需對鏈表進行操作。這種方式管理對進程的物理頁分配簡單有效,但是對內核本身使用的內存分配釋放會導致內存利用率不高,因為這種方式管理的最大連續內存是一頁,而內核中經常會分配大對象,連續多頁的物理內存有更好的利用率。Linux 采用 Buddy memory allocation 方式管理物理內存,使用 Slab/Slub 管理內核對象的分配釋放。
我的實現也采用 Buddy 方式管理物理內存,把空閑內存頁用多層級的 Buddy 方式管理,分別是 order 0 ~ order 10,表示 2^order 頁連續內存頁塊,即 order 0 管理單頁的空閑內存塊,order 10 管理連續 1024 頁的空閑內存塊。分配內存時,算出最佳的 order,在相應的 order 層級里分配一塊內存塊,如果當前 order 中沒有可用的空閑內存塊,就向 order + 1 層級中借一塊,并把借來的空閑內存塊平分成 2 塊 order 層級的空閑內存塊,其中一塊當作分配結果返回,另一塊放入到 order 層級中待以后分配使用。當第 order 塊的內存使用完釋放時,把這塊釋放的內存塊放入 order 層級時,判斷與它相連的同樣大小的內存塊是否在 order 層級中,如果存在,把它和它的 Buddy 合并成一個 order + 1 的內存塊放入到 order + 1的層級中。

內存管理器初始化之前

在內存管理初始化之前,內核沒有動態內存分配能力,因此很多時候我們需要使用靜態全局變量。內存管理器初始化時,可能會使用到動態內存分配,這就出現雞與蛋的問題,為了解決這個問題,通常會實現一個簡單的 Boot Allocator 用在內存管理器初始化之前分配動態內存。我的實現是從內核展開的末尾位置開始建立一個只分配不釋放的 Boot Allocator,等到內存管理器初始化完成之后,Boot Allocator 的使命便完成了。
另外還有一個問題,我們管理物理內存,需要知道安裝了多少物理內存,因此我們要探測安裝了多少物理內存,這里介紹了幾種探測方法,我使用的是 BIOS 的 INT 0x15, EAX = 0xE820 函數,它由 Bootloader 調用完成,最后通過參數把它傳遞給操作系統內核。
posted on 2015-04-27 12:53 airtrack 閱讀(3444) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            狠狠色丁香久久综合频道| 欧美一区二区三区日韩| 亚洲欧美日韩在线高清直播| 亚洲免费综合| 亚洲欧美国产不卡| 久久精品二区三区| 你懂的视频欧美| 亚洲高清免费| 亚洲裸体视频| 亚洲免费网站| 久久婷婷色综合| 欧美另类一区| 国产视频久久网| 亚洲国产午夜| 亚洲欧美国产视频| 国产三区二区一区久久| 一区二区三区在线视频观看| 91久久精品美女高潮| 亚洲欧美成人一区二区在线电影| 久久久久国产一区二区三区| 亚洲电影自拍| 欧美在线播放视频| 欧美日韩美女| 亚洲国产精品va在线看黑人| 午夜精品一区二区三区在线播放| 欧美成人在线免费视频| 亚洲一区欧美激情| 嫩草影视亚洲| 狠狠色丁香久久综合频道| 亚洲一区二区免费视频| 欧美aa国产视频| 亚洲一级二级| 欧美国产精品| 精品电影在线观看| 午夜精品久久久久久久| 亚洲国产精品一区在线观看不卡| 亚洲欧美三级在线| 欧美日韩一区在线观看视频| 亚洲第一黄色网| 久久久国产一区二区三区| 夜夜夜精品看看| 欧美精品二区三区四区免费看视频| 国产一区二区三区久久悠悠色av | 在线播放豆国产99亚洲| 一区二区三区免费看| 麻豆91精品| 亚洲一区二区成人| 欧美精品在线免费播放| 亚洲激情视频网| 欧美freesex8一10精品| 久久精品成人欧美大片古装| 国产精品一级二级三级| 亚洲一区二区三区在线看| 亚洲国内高清视频| 欧美成人视屏| 亚洲国产成人午夜在线一区 | 久久久久国内| 性欧美video另类hd性玩具| 国产精品视频成人| 午夜日韩在线| 亚洲欧美激情一区| 国产日韩综合| 久久久久久日产精品| 久久国产精品毛片| 在线日韩av| 亚洲激情av| 欧美视频在线观看视频极品| 国产精品乱子乱xxxx| 亚洲自拍啪啪| 亚洲欧美日韩成人| 激情亚洲网站| 亚洲国产婷婷综合在线精品 | 欧美一区二区三区久久精品| 国产农村妇女精品一区二区| 欧美有码视频| 久久久青草青青国产亚洲免观| 在线看视频不卡| 欧美激情视频网站| 欧美精品1区2区3区| 亚洲伊人伊色伊影伊综合网| 香蕉久久一区二区不卡无毒影院| 国内精品久久久久久久影视蜜臀 | 久久精品在线| 亚洲国产成人午夜在线一区 | 亚洲婷婷综合久久一本伊一区| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 欧美mv日韩mv国产网站app| 一本色道久久综合狠狠躁的推荐| 这里只有精品视频| 伊人色综合久久天天五月婷| 日韩视频免费观看| 国产一区高清视频| 亚洲青涩在线| 国内欧美视频一区二区| 亚洲久久一区二区| 国产一区二区三区电影在线观看| 欧美激情精品久久久久久免费印度 | 久久青草欧美一区二区三区| 日韩一级黄色大片| 性亚洲最疯狂xxxx高清| 99av国产精品欲麻豆| 欧美亚洲视频在线观看| 99精品视频网| 久久久在线视频| 亚洲欧美在线观看| 欧美大学生性色视频| 久久久久国产一区二区三区| 欧美日韩精选| 欧美大片网址| 狠狠干综合网| 午夜精品福利在线观看| 亚洲综合清纯丝袜自拍| 欧美波霸影院| 欧美不卡在线| 国内揄拍国内精品久久 | 欧美日韩成人在线播放| 美女露胸一区二区三区| 国产精品美女久久久久久久| 亚洲激情视频网站| 在线视频日本亚洲性| 久久精品国产在热久久| 亚洲欧美日韩国产综合在线 | 欧美视频免费在线观看| 欧美激情视频一区二区三区免费| 国产午夜精品视频免费不卡69堂| 一本色道久久综合亚洲二区三区| 亚洲日本一区二区三区| 久久综合九色综合网站| 麻豆国产精品一区二区三区| 国产午夜精品理论片a级大结局| 亚洲一区二区三区欧美| 亚洲欧美在线一区二区| 欧美日韩不卡合集视频| 亚洲精品韩国| 亚洲欧美日韩精品久久亚洲区 | 欧美a级一区| 亚洲国产成人91精品| 亚洲娇小video精品| 免费成人黄色片| 亚洲第一天堂av| 99re热这里只有精品免费视频| 欧美精品97| 中日韩高清电影网| 欧美一区二区在线| 激情欧美日韩| 免费成人黄色片| 亚洲精品免费在线观看| 亚洲视频一二区| 国产欧美日韩高清| 久久久久久久一区二区三区| 欧美99在线视频观看| 亚洲乱码国产乱码精品精98午夜| 欧美破处大片在线视频| 亚洲一区二区欧美日韩| 久久久国产精彩视频美女艺术照福利 | 亚洲综合视频在线| 国产亚洲精品久| 免费观看成人网| 一本色道88久久加勒比精品| 欧美专区在线| 亚洲人永久免费| 国产精品人成在线观看免费| 欧美在线精品免播放器视频| 欧美黑人多人双交| 亚洲一区二区三区四区视频| 国内揄拍国内精品久久| 欧美精品激情| 午夜精品久久久久久久99水蜜桃| 欧美成年人视频| 亚洲影视在线播放| 激情文学一区| 欧美亚一区二区| 裸体一区二区| 亚洲欧美不卡| 91久久国产精品91久久性色| 久久疯狂做爰流白浆xx| 亚洲人午夜精品| 国产欧美亚洲一区| 欧美精品在欧美一区二区少妇| 欧美在线地址| 一本色道**综合亚洲精品蜜桃冫| 能在线观看的日韩av| 亚洲伊人一本大道中文字幕| 亚洲国产mv| 国产一区二区三区的电影 | 欧美激情成人在线| 欧美在线网址| 在线亚洲成人| 亚洲欧洲一区二区在线播放 | 欧美与黑人午夜性猛交久久久| 91久久精品久久国产性色也91| 国产区二精品视| 国产精品xxxxx| 欧美激情亚洲精品| 久久天天狠狠| 久久精品国产综合| 欧美专区第一页| 亚洲制服av| 一区二区三区高清不卡| 亚洲精品久久久久久久久久久久 |