<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 嵌入式軟件開發(fā)之: 復(fù)位和初始化

          嵌入式軟件開發(fā)之: 復(fù)位和初始化

          作者: 時間:2013-09-30 來源:網(wǎng)絡(luò) 收藏

          本文引用地址:http://www.ex-cimer.com/article/257026.htm

          1.先搬移后映射(Remap after Copy)

          圖13.15顯示一種典型的存儲器地址重映射情況。

          圖13.15 ROM/RAM重映射(1)

          原來RAM和ROM各有自己的地址,進行重映射以后RAM和ROM的地址都發(fā)生了變化。這種情況下,可以采用以下方案。

          ① 上電后,從0x0地址的ROM開始往下執(zhí)行。

          ② 根據(jù)映射前的地址,對RAM進行必要的代碼和數(shù)據(jù)拷貝。

          ③ 拷貝完后,進行remap操作。

          ④ 因為RAM在remap前準備好了內(nèi)容,使得PC指針能繼續(xù)在RAM里取到正確的指令。

          2.先映射后搬移(Copy after Remap)

          系統(tǒng)上電后的缺省狀態(tài)是0x0地址上放有ROM。這塊ROM有兩個地址:從0起始和從0x10000起始,里面存儲了代碼。當進行地址remap以后,從0x0起始的地址被定向到RAM上,ROM則只保留有惟一的從0x10000起始的地址。

          如果存儲在ROM里的異常處理程序(Reset-Handler)一直在0x0~0x4000的地址上運行,則當執(zhí)行完remap以后,下面的指令將從RAM里預(yù)取,這必然會導(dǎo)致程序執(zhí)行流程的中斷。根據(jù)系統(tǒng)特點,可以用下面的辦法來解決這個問題。

          ① 上電后系統(tǒng)從0x0地址開始自動執(zhí)行,設(shè)計跳轉(zhuǎn)指令在remap發(fā)生前使PC指針指向0x10000開始的ROM地址中去,因為不同地址指向的是同一塊ROM,所有程序能夠順利執(zhí)行。

          ② 這時候0x0~0x4000的地址空間空閑,不被程序引用,執(zhí)行remap后把RAM引進。因為程序一直在0x10000起始的ROM空間里運行,remap對運行流程沒有任何影響。

          ③ 通過在ROM里運行的程序,對RAM進行相應(yīng)的代碼和數(shù)據(jù)拷貝,完成應(yīng)用程序運行的

          圖13.16顯示了ROM和RAM重映射的第二種解決方案。

          圖13.16 ROM/RAM重映射(2)

          該ROM與RAM地址重映射的方法可以應(yīng)用于任何具有ROM/RAM重映射機制的平臺,但是內(nèi)存重映射的地址根據(jù)具體平臺的不同而不同。

          圖13.16顯示的地址重映射例子中,第一條指令實現(xiàn)從ROM臨時地址(0x0地址)到實際ROM的跳轉(zhuǎn)。然后,控制寄存器的重映射位,清除ROM的臨時地址設(shè)置。該代碼通常在系統(tǒng)后立即執(zhí)行。重新映射必須在執(zhí)行C庫代碼前完成。

          在具有MMU的系統(tǒng)中,可通過在系統(tǒng)啟動時配置MMU來實現(xiàn)重映射。

          下面的例子顯示了在的Integrator開發(fā)板上實現(xiàn)的ROM/RAM重映射過程。

          ; --- Integrator CM control reg

          CM_ctl_reg EQU 0x1000000C ;定義CM控制寄存器地址

          Remap_bit EQU 0x04 ;CM控制寄存器重映射掩碼

          ENTRY

          ;異常處理程序開始

          ; 執(zhí)行跳轉(zhuǎn)指令,轉(zhuǎn)到實際的ROM執(zhí)行

          LDR pc, =Instruct_2

          Instruct_2

          ; 設(shè)置CM控制寄存器的重映射位

          LDR r1, =CM_ctl_reg

          LDR r0, [r1]

          ORR r0, r0, #Remap_bit

          STR r0, [r1]

          ; 重映射后,RAM在0x0地址

          ; 將從ROM拷貝到 RAM (由 __main函數(shù)完成)

          13.5.3 局部存儲器設(shè)置有關(guān)的考慮事項

          許多處理器內(nèi)核具有片上存儲器系統(tǒng),如MMU或MPU。這些設(shè)備通常是在系統(tǒng)啟動過程中進行設(shè)置并啟用的。因此,帶有局部存儲器系統(tǒng)的內(nèi)核的初始化序列需要特別地考慮。

          在前面所述的代碼啟動的過程中,__main中C庫初始化代碼負責(zé)建立代碼執(zhí)行時的內(nèi)存映像,在跳轉(zhuǎn)到__main前,必須建立處理器內(nèi)核的運行時存儲器視圖。這就是說,在復(fù)位處理程序中必須設(shè)置并啟用MMU或MPU。

          另外,在跳轉(zhuǎn)到__main前(通常在MMU/MPU設(shè)置前),必須啟用緊耦合存儲器TCM(Tightly coupled Memory),因為在通常情況下都是采用分散加載方法將代碼和數(shù)據(jù)裝入TCM。當TCM啟用后,用戶不必存取由TCM屏蔽的存儲器。

          在跳轉(zhuǎn)到__main前,如果啟用了Cache,可能還會遇到Cache一致性的問題,__main中的函數(shù)將程序代碼從其加載域拷貝到執(zhí)行域,在此過程中將指令作為數(shù)據(jù)進行處理。這樣,一些指令可能被放入數(shù)據(jù)Cache中,在執(zhí)行這些指令時,由于找不到地址路徑而產(chǎn)生錯誤。為了避免Cache一致性的問題,在C庫初始化序列執(zhí)行完成后再啟用Cache。

          存儲器相關(guān)文章:存儲器原理




          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();