国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

電子工程網

標題: 帶你走進嵌入式ARM MMU神秘的內部世界 [打印本頁]

作者: ludi    時間: 2017-8-22 12:00
標題: 帶你走進嵌入式ARM MMU神秘的內部世界
ARM MMU頁表框架
file:///C:\Users\郭曉娟\AppData\Local\Temp\ksohtml\wpsF282.tmp.png
先上一張arm mmu的頁表結構的通用框圖(以下的論述都由該圖來逐漸展開):
file:///C:\Users\郭曉娟\AppData\Local\Temp\ksohtml\wpsF293.tmp.jpgfile:///C:\Users\郭曉娟\AppData\Local\Temp\ksohtml\wpsF2A3.tmp.png
以上是arm的頁表框圖的典型結構:即是二級頁表結構:
其中第一級頁表(L1)是由虛擬地址的高12bit(bits[31:20])組成,所以第一級頁表有4096個item,每個item占4個字節,所以一級頁表的大小為16KB,而在第一級頁表中的每個entry的最低2bit可以用來區分具體是什么種類的頁表項,2bit可以區分4種頁表項,具體每種頁表項的結構如下:
file:///C:\Users\郭曉娟\AppData\Local\Temp\ksohtml\wpsF2B4.tmp.jpg
簡而言之L1頁表的頁表項主要有兩大類:
第一大類是指向第二級頁表(L2頁表)的基地址;
第二類直接指向1MB的物理內存。
L1頁表中每個表項可以覆蓋1MB的內存,由于有4096K個選項(item),所以總計可以覆蓋4096K*1MB=4GB的內存空間。
具體對應到Linux,由于linux的軟件架構是支持3級頁表結構,而arm架構實際只有2級的頁表結構,所以linux代碼中的中間級頁表的實現是空的。在linux代碼中,第一級的頁表的頁目錄表項用pgd表示,中間級的頁表的頁目錄表項用pud表示(arm架構其實不需要),第三級的頁表的頁目錄表項用pmd表示(由于中間pud是空的,所以pgd=pmd),另外目前arm體系的移動設備中RAM的page大小一般都是4KB/page,所以L1頁表中的頁表項都是指向fine page table的信盈達嵌入式企鵝要妖氣嗚嗚吧就零久要
但在linux內核啟動的初始化階段,臨時建立頁表(initial page tables)以供linux內核初始化提供執行環境,這時L1的頁表項使用的就是第二種頁表項(section enty),他直接映射的是1M的內存空間。具體的可以參考arch/arm/kernel/head.S中的__create_page_tables函數,限于篇幅,這里就不展開說了。
針對這種section page translation,mmu硬件執行虛擬地址轉物理地址的過程如下:
file:///C:\Users\郭曉娟\AppData\Local\Temp\ksohtml\wpsF2C5.tmp.jpg
以上在初始化過程使用的臨時頁表(initial page tables),在內核啟動的后期會被覆蓋掉,即在paging_init--->map_lowmem函數中會重新建立頁表,該函數為物理內存從0地址到低端內存(lowmem_limit)建立一個一一映射的映射表。所謂的一一映射就是物理地址和虛擬地址就差一個固定的偏移量,該偏移量一般就是0xc0000000(呵呵,為什么是0xc0000000?)
說到這里引入一個重要的概念,就是與低端內存相對的高端內存,什么是高端內存?為什么需要高端內存?為了解析這個問題,我們假設我們使用的物理內存有2GB大小,另外由于我們內核空間的地址范圍是從3G-4G的空間,并且前面也說到了,linux內核的低端內存空間都是一一映射的,如果不引入高端內存這個概念,全部都使用一一映射的方式,那內核只能訪問到1GB的物理內存,但實際上,我們是需要內核在內核空間能夠訪問所有的4GB的內存大小的,那怎么做到呢?
方法就是我們不讓3G-4G的空間都使用一一映射,而是將物理地址的[0x00,fix_addr](fix_addr<1GB)映射到內核空間虛擬地址[0x00+3G,fix_addr+3G],然后將[fix_addr+3G,4G]這段空間保留下來用于動態映射,這樣我們可以通過這段虛擬地址來訪問從fix_addr到4GB的物理內存空間。怎么做到的呢?
譬如我們想要訪問物理地址[fix_addr,4GB]這段區間中的任何一段,我就用寶貴的內核虛擬地址[fix_addr+3G,4G]的一段去映射他,建立好mmu硬件使用的頁表,訪問完后,將映射清除,將內核的這段虛擬地址釋放,以供下次訪問其他的物理內存使用。這樣就可以達到訪問所有4GB的物理內存的目的。






歡迎光臨 電子工程網 (http://m.qingdxww.cn/) Powered by Discuz! X3.4
主站蜘蛛池模板: 男人的亚洲天堂 | 亚洲一区欧洲一区 | 欧美日韩国产另类在线观看 | 午夜免费观看_视频在线观看 | 在线观看黄免费 | 啦啦啦高清影视在线观看视频? | 欧美一区二区aa大片 | 欧美综合自拍亚洲综合图片区 | 亚洲国产精品影院 | 性欧美午夜高清在线观看 | 亚洲国产欧美精品一区二区三区 | 一级做性色a爰片久久毛片免费 | 精品国产一区二区三区久 | 国产福利麻豆精品一区 | 91精品国产麻豆91久久久久久 | 欧美国产三级 | 亚洲国产欧美在线不卡中文 | 一本久久精品一区二区 | 麻豆全集 | 日韩成人在线免费视频 | 欧美成人在线观看 | 亚洲成人一级片 | 终极教师电视剧免费观看完整版 | 日本在线观看网址 | 国产国语在线播放视频 | 成年女人18毛片毛片免费 | 欧美网站在线 | 成人免费观看网欧美片 | 91九色丨porny丨制服 | 免费看污污的网站 | 国产资源站 | 2021国产精品视频 | 农奴完整版在线观看 | 动漫免费网站 | 欧美成人午夜视频 | 亚洲一区二区三区福利在线 | 97日韩 | 久久精品免费观看久久 | 26uuu天天夜夜综合 | 久久精品中文字幕有码日本 | 成人免费黄色网 |