<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > Linux操作系統之快速內存操作技術(shù)

Linux操作系統之快速內存操作技術(shù)

作者: 時(shí)間:2016-10-08 來(lái)源:網(wǎng)絡(luò ) 收藏

我們總希望能在內核空間和用戶(hù)空間自由交換數據,傳統的方式是采用內核提供的vma機制,通過(guò)copy_to/from_user之類(lèi)的方法來(lái)實(shí)現。這對于高速數據塊傳送是不可取的。 其實(shí)kswapd有時(shí)交換數據至外存時(shí),性能相當差,一般而言,你的PC主存并不見(jiàn)得就用盡了,而且很多應用并是你所關(guān)心的,但卻實(shí)實(shí)在在消耗你的計算資源,此時(shí),你可能會(huì )想到采用實(shí)地址操作你的應用(盡管有MMU的支持),在uClinux中,當沒(méi)有MMU時(shí),工作起來(lái)是挺爽的。

本文引用地址:http://dyxdggzs.com/article/201610/305315.htm

最方便的,最高效的,無(wú)非是實(shí)地址下,操作物理內存,相當于DMA.盡管Linux 2.6內核在VMA方面的性能要優(yōu)于2.4,但swap機制有一定的缺限。在VxWorks中,對內存的管理是很細致且精確的。如果你在Linux下申請大塊內存操作時(shí),當觸發(fā)kswap快速交換回主存時(shí),你會(huì )發(fā)現你的計算機 哪一段時(shí)間,幾乎要休息幾分鐘,盡管你看起來(lái)free輸出的面已經(jīng)很多了,但此時(shí)的外存幾乎一直忙著(zhù),且CPU負荷相當重,這時(shí)也可能你根本就沒(méi)做任何操作。

有沒(méi)有辦法既在VMA機制下工作,又能直接處理主存數據呢?

回答是肯定的。內核啟動(dòng)后,會(huì )將主存映射為/dev/mem,當我們在VMA中申請一塊邏輯區間后,將轉換的物理地址傳與用戶(hù)空間,用戶(hù)空間就可以線(xiàn)性操作這段區間了,直接采用mmap就可以在物理主存中讀寫(xiě)。

還有更快的方式嗎?不采用mmap行嗎?

當然有,當VMA將物理區塊地址及大小傳與用戶(hù)空間后,用戶(hù)完全可以采用地址讀寫(xiě)模式,這幾近于機器指令操作了(可以獨立于OS之外)。 此種實(shí)現方式很簡(jiǎn)單,首先打開(kāi)/dev/mem,直接定位至VMA傳上來(lái)的地址就可以操作了,無(wú)需mmap.通知用戶(hù)空間,可以采用procfs/sysfs等。

強烈建議:在邊界控制上,一定要精確細致,不推薦初學(xué)者采用,一旦越界,可能引起“Kernel Panic”。 更有可能就DOWN了。 對于此實(shí)現方式,建議參考mapper(LDD3)程序。 同時(shí),也可以用mapper檢查讀寫(xiě)是否正確。

新的IA32中,PAGE_SIZE = 4K MAX_ORDER = 11 ,gfp最大申請4M線(xiàn)性邏輯空間,減去PAGE_OFFSET即可得到物理地址。 如果采用了HIMEM和NUMA,請參見(jiàn)Kernel關(guān)于內存映射的算法。 當主存達到1G或超過(guò)時(shí),請減小用戶(hù)空間大小。

隨著(zhù)硬件技術(shù)的發(fā)展,VMA在主存相當大時(shí),可以考慮進(jìn)行修正,完全可以集中采用物理映射方式。沒(méi)必要交換了。否則,反而影響性能。 32位平臺,如果主存2G,采用SWAP會(huì )使得性能有較大下降。 而在大容量數據傳輸時(shí),也不可能采用SWAP方式的,不允許換出。 建議Linus在VMA中加入進(jìn)程分類(lèi),不平類(lèi)別的應用,分配不同的內存塊。 小數據PAGE_SIZE = 4K/大數據4M/128M. 地址模式全轉換為64位,兼容32位,當應用于Embedded系統時(shí),直接使用32位模式。

如將做成多個(gè)微系統,不同微核,運行不同應用(不同的進(jìn)程管理,內存管理,文件管理),只是接口可以統一,不同標志而已。



關(guān)鍵詞:

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>