直播推薦
企業(yè)動(dòng)態(tài)
- 紛享銷客發(fā)布首個(gè)企業(yè)級(jí)智能CRM平臺(tái)ShareAI
- 揭秘西企業(yè)數(shù)字化+低碳化轉(zhuǎn)型“工具箱”:西門子X(jué)celerator
- 企業(yè)AI賦能數(shù)智制造,用友U9 cloud世界級(jí)云ERP煥新升級(jí)
- 《“智“領(lǐng)石化,“質(zhì)“造未來(lái)——威圖石化行業(yè)數(shù)智化實(shí)踐白皮書(shū)》隆重發(fā)布
- 攜手共贏!德國(guó)Agfa搭載瑞典IPCO鋼帶,實(shí)現(xiàn)印刷設(shè)備振動(dòng)銳減6倍,提升印刷速度與精度
- 創(chuàng)四方集團(tuán)榮獲“知名商標(biāo)品牌閃亮”證書(shū),助力品牌戰(zhàn)略升級(jí)
- 皇冠CAD(CrownCAD)2025 R3版本來(lái)了,率先開(kāi)啟C“Ai”D時(shí)代!
- 電費(fèi)砍半!中國(guó)制冷展:海爾發(fā)布AI建筑最新成果
推薦展會(huì)
技術(shù)難點(diǎn)分析
⑴.mmu的使用
mmu是存儲(chǔ)器管理單元的縮寫,是用來(lái)管理虛擬內(nèi)存系統(tǒng)的器件。mmu通常是cpu的一部分,本身有少量存儲(chǔ)空間存放從虛擬地址到物理地址的匹配表。此表稱作tlb(轉(zhuǎn)換旁置緩沖區(qū))。所有數(shù)據(jù)請(qǐng)求都送往mmu,由mmu決定數(shù)據(jù)是在ram內(nèi)還是在大容量存儲(chǔ)器設(shè)備內(nèi)。如果數(shù)據(jù)不在存儲(chǔ)空間內(nèi),mmu將產(chǎn)生頁(yè)面錯(cuò)誤中斷。
mmu的兩個(gè)主要功能是:
將虛地址轉(zhuǎn)換成物理地址。
控制存儲(chǔ)器存取允許。mmu關(guān)掉時(shí),虛地址直接輸出到物理地址總線。
在實(shí)踐中,使用mmu解決了如下幾個(gè)問(wèn)題:
①使用dram作為大容量存儲(chǔ)器時(shí),如果dram的行列是非平方的,會(huì)導(dǎo)致該dram的物理地址不連續(xù),這將給程序的編寫調(diào)試造成極大不便,而適當(dāng)配置mmu可將其轉(zhuǎn)換成虛擬地址連續(xù)的空間。
②arm內(nèi)核的中斷向量表要求放在0地址, 對(duì)于rom在0地址的情況,無(wú)法調(diào)試中斷服務(wù)程序,所以在調(diào)試階段有必要將可讀寫的存儲(chǔ)器空間映射到0地址。
③系統(tǒng)的某些地址段是不允許被訪問(wèn)的,否則會(huì)產(chǎn)生不可預(yù)料的后果,為了避免這類錯(cuò)誤,可以通過(guò)mmu匹配表的設(shè)置將這些地址段設(shè)為用戶不可存取類型。
啟動(dòng)程序中生成的匹配表中包含地址映射,存儲(chǔ)頁(yè)大?。?m,64k,或4k)以及是否允許存取等信息。
例如:目標(biāo)板上的16兆dram的物理地址區(qū)間為0xc000,0000~0xc07f,ffff;0xc100,0000~0xc17f,ffff;16兆rom的虛擬地址區(qū)間為:0x0000,0000~0x00ff,ffff。匹配表配置如下:
可以看到左邊是連續(xù)的虛擬地址空間,右邊是不連續(xù)的物理地址空間,而且將dram映射到了0地址區(qū)間。 mmu通過(guò)虛擬地址和頁(yè)面表位置信息,按照轉(zhuǎn)換邏輯獲得對(duì)應(yīng)物理地址,輸出到地址總線上。
應(yīng)注意到的是使能mmu后,程序繼續(xù)運(yùn)行,但是對(duì)于程序員來(lái)說(shuō)程序計(jì)數(shù)器的指針已經(jīng)改變,指向了rom所對(duì)應(yīng)的虛擬地址。
⑵目標(biāo)文件的分布裝載分析
首先創(chuàng)建一個(gè)文本文件,稱為分布裝載描述文件。它為應(yīng)用程序的各部分裝載區(qū)間和執(zhí)行區(qū)間。
舉例如下:
flash 0x01000000 0x011fffff ;2m flash
{
flash 0x01000000
{
boot.o(boot,+first)
* (+ro)
}
dram 0x00000000
{
vector.0(vector,+first)
int_handler.o (+ro)
* (+rw,+zi)
}
}
在arm鏈接器的命令行里加入“-scov desc-ription-file –scf”或“-scatter desc-ription-file”,編譯鏈接后,將產(chǎn)生一個(gè)分布裝載文件。
鏈接器同時(shí)產(chǎn)生一組符號(hào),給出每個(gè)分布描述文件中命名的區(qū)間的長(zhǎng)度,裝載地址和執(zhí)行地址。由于鏈接器和c庫(kù)都沒(méi)有將代碼從它的裝載區(qū)間拷貝到執(zhí)行區(qū)間,或創(chuàng)建一個(gè)零初始化區(qū)域的功能,所以要由應(yīng)用程序員利用這組符號(hào)產(chǎn)生的信息完成這項(xiàng)工作,這是在呼叫c程序之前必須完成的,舉例如下:
ldr r0, = |load$$dram$$base|
ldr r1, = |image$$dram$$base|
cmp r0, r1 ; 檢查裝載地址和執(zhí)行地址是否相同
beq do_zi_init ; 相同,則不拷貝該區(qū)間,初始化零數(shù)據(jù)區(qū)
mov r2, r1 ; 不相同,將裝載區(qū)拷貝到執(zhí)行區(qū)
ldr r4, = |image$$dram$$length|
add r2, r2, r4
bl copy
do_zi_init
ldr r1, = |image$$dram$$zi$$base|
mov r2, r1
ldr r4, = |image$$dram$$zi$$length|
add r2, r2, r4
mov r3, #0
bl zi_init ; 調(diào)用零初始化子程序
結(jié)束語(yǔ):
本文介紹的啟動(dòng)程序已經(jīng)在以cirrus logic公司的ep7211和ateml公司的at91m40400開(kāi)發(fā)的系統(tǒng)上運(yùn)行并測(cè)試通過(guò)。今后可以在這一基礎(chǔ)上添加串行通信模塊和flash操作模塊,開(kāi)發(fā)系統(tǒng)監(jiān)控程序,從而實(shí)現(xiàn)應(yīng)用程序的在線升級(jí)。
免責(zé)聲明
- 凡本網(wǎng)注明"來(lái)源:智能制造網(wǎng)"的所有作品,版權(quán)均屬于智能制造網(wǎng),轉(zhuǎn)載請(qǐng)必須注明智能制造網(wǎng),http://towegas.com。違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
- 企業(yè)發(fā)布的公司新聞、技術(shù)文章、資料下載等內(nèi)容,如涉及侵權(quán)、違規(guī)遭投訴的,一律由發(fā)布企業(yè)自行承擔(dān)責(zé)任,本網(wǎng)有權(quán)刪除內(nèi)容并追溯責(zé)任。
- 本網(wǎng)轉(zhuǎn)載并注明自其它來(lái)源的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品來(lái)源,并自負(fù)版權(quán)等法律責(zé)任。
- 如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
2025第十一屆中國(guó)國(guó)際機(jī)電產(chǎn)品交易會(huì) 暨先進(jìn)制造業(yè)博覽會(huì)
展會(huì)城市:合肥市展會(huì)時(shí)間:2025-09-20