久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 5368|回復: 0
打印 上一主題 下一主題
收起左側

ARM的存儲器映射與存儲器重映射

[復制鏈接]
跳轉到指定樓層
樓主
ID:105323 發表于 2016-2-13 00:11 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
存儲器映射是指把芯片中或芯片外的FLASH,RAM,外設,BOOTBLOCK等進行統一編址。即用地址來表示對象。這個地址絕大多數是由廠家規定好的,用戶只能用而不能改。用戶只能在掛外部RAM或FLASH的情況下可進行自定義。
ARM7TDMI的存儲器映射可以有0X00000000~0XFFFFFFFF的空間,即4G的映射空間,但所有器件加起來肯定是填不滿的。
一般來說,0X00000000依次開始存放FLASH——0X00000000,SRAM——0X40000000,BOOTBLOCK,外部存儲器0X80000000,VPB(低速外設地址,如GPIO,UART)——0XE0000000,AHB(高速外設:向量中斷控制器,外部存儲器控制器)——從0XFFFFFFFF回頭。他們都是從固定位置開始編址的,而占用空間又不大,如AHB只占2MB,所以從中間有很大部分是空白區域,用戶若使用這些空白區域,或者定義野指針,就可能出現取指令中止或者取數據中止。
由于系統在上電復位時要從0X00000000開始運行,而第一要運行的就是廠家固化在片子里的BOOTBLOCK,這是判斷運行哪個存儲器上的程序,檢查用戶代碼是否有效,判斷芯片是否加密,芯片是否IAP(在應用編程),芯片是否ISP(在系統編程),所以這個BOOTBLOCK要首先執行。而芯片中的BOOTBLOCK不能放在FLASH的頭部,因為那要存放用戶的異常向量表的,以便在運行、中斷時跳到這來找入口,所以BOOTBLOCK只能放在FLSAH尾部才能好找到,呵呵。而ARM7的各芯片的FLASH大小又不一致,廠家為了BOOTBLOCK在芯片中的位置固定,就在編址的2G靠前編址的位置虛擬劃分一個區域作為BOOTBLOCK區域,這就是重映射,這樣訪問<2G即<0X80000000的位置時,就可以訪問到在FLASH尾部的BOOTBLOCK區了。
BOOTBLOCK運行完就是要運行用戶自己寫的啟動代碼了,而啟動代碼中最重要的就是異常向量表,這個表是放在FLASH的頭部首先執行的,而異常向量表中要處理多方面的事情,包括復位、未定義指令、軟中斷、預取指中止、數據中止、IRQ(中斷),FIQ(快速中斷),而這個異常向量表是總表,還包括許多分散的異常向量表,比如在外部存儲器,BOOTBLOCK,SRAM中固化的,不可能都由用戶直接定義,所以還是需要重映射把那些異常向量表的地址映到總表中。

為存儲器分配地址的過程稱為存儲器映射,那么什么叫存儲器重映射呢?為了增加系統的靈活性,系統中有部分地址可以同時出現在不同的地址上,這就叫做存儲器重映射。重映射主要包括引導塊“BootBlock”重映射和異常向量表的重映射。
1.引導塊“Boot Block”及其重映射
BootBlock是芯片設計廠商在LPC2000系列ARM內部固化的一段代碼,用戶無法對其進行修改或者刪除。這段代碼在復位時被首先運行,主要用來判斷運行哪個存儲器上面的程序,檢查用戶代碼是否有效,判斷芯片是否被加密,系統的在應用編程(IAP)以及在系統編程功能(ISP)等。
BootBlock存在于內部Flash,LPC2200系列大小為8kb,它占用了用戶的Flash空間,但也有其他的LPC系列不占用FLash空間的,而部分沒有內部Flash空間的ARM處理器仍然存在BootBlock。
重映射的原因:
BootBlock中有些程序可被用戶調用,如擦寫片內Flash的IAP代碼。為了增加用戶代碼的可移植性,所以最好把BootBlock的代碼固定的某個地址上。但由于各芯片的片內Flash大小不盡相同,如果把BootBlock的地址安排在內部Flash結束的位置上,那就無法固定Boot Block的地址。
為了解決上面的問題,于是芯片廠家將BootBlock的地址重映射到片內存儲器空間的最高端,即接近2Gb的地方,這樣無論片內存儲器的大小如何,都不會影響BootBlock的地址。因此當BootBlock中包含可被用戶調用的IAP操作的代碼時,不用修改IAP的操作地址就可以在不同的LPC系列的ARM上運行了。
2.異常向量表及其重映射
ARM內核在發生異常后,會使程序跳轉到位于0x0000~0x001C的異常向量表處,再經過向量跳轉到異常服務程序。但ARM單條指令的尋址范圍有限,無法用一條指令實現4G范圍的跳轉,所以應在其后面的0x0020~0x003F地址上放置跳轉目標,這樣就可以實現4G范圍內的任意跳轉,因此一個異常向量表實際上占用了16個字的存儲單元。以下為一張中斷向量表:
                   LDR    PC, ResetAddr
                   LDR    PC, UndefinedAddr
                   LDR    PC, SWI_Addr
                   LDR    PC, PrefetchAddr
                   LDR    PC, DataAbortAddr
                   DCD    0xb9205f80
                   LDR    PC, [PC, #-0xff0]
                   LDR    PC, FIQ_Addr
               ResetAddr      DCD    ResetInit
                  UndefinedAddr  DCD    Undefined
                   SWI_Addr       DCD    SoftwareInterrupt
                   PrefetchAddr   DCD    PrefetchAbort
                   DataAbortAdd   DCD    DataAbort
                   Nouse       DCD    0
                   IRQ_Addr       DCD    0
                   FIQ_Addr       DCD    FIQ_Handler
重映射的原因:
由于ARM處理器的存儲器結構比較復雜,可能同時存在片內存儲器和片外存儲器等,他們在存儲器映射上的起始地址都不一樣,因此ARM內核要訪問的中斷向量表可能不在0x0000~0x003F地址上,因此采用了存儲器重映射來實現將存在與不同地方的中斷向量表都映射到0x0000~0x003F地址上。
注意:Boot Block 也存在中斷向量表,而且復位后這段代碼首先映射到0x0000~0x003F地址上,也就是說復位后首先運行的是Boot Block程序。各個存儲區域的中斷向量表也不盡相同。

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 四虎四虎 | 久久机热这里只有精品 | 99re视频| 国产永久视频 | 国产成人午夜高潮毛片 | 五月婷婷丁香花 | 国产精品久久久国产盗摄 | 夜夜骑夜夜操 | 成人av播放| 欧美特黄视频 | 婷婷午夜天 | 免费在线观看黄 | 色综合婷婷 | 中文在线观看免费视频 | 午夜无遮挡 | 欧美日韩亚洲视频 | 国产激情一区二区三区 | 亚洲精品成人网 | 成人深夜福利视频 | 中文字幕在线观看网址 | 中文字幕在线免费播放 | 色婷婷导航| 欧美一区不卡 | 天天射天天爽 | 日韩一级在线 | 亚洲一区二区三区免费视频 | 国产精自产拍久久久久久蜜 | 久久精品一区二区三区不卡牛牛 | 国产一区二区三区视频在线 | 成人免费视频观看视频 | 黑人系列合集h | 亚洲无人区一线二线三线 | 国产精品aaa | 国产成人91| 成人香蕉网 | 69免费视频 | www.精品| 中国一级黄色 | 亚洲天堂影院 | 毛片网站大全 | 国产精品久久久久久久久久久久午夜片 |