久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区

Rss & SiteMap

曙海教育集團論壇 http://www.bjzhda.cn

曙海教育集團論壇
共1 條記錄, 每頁顯示 10 條, 頁簽: [1]
[瀏覽完整版]

標題:ARM基礎知識連載之五

1樓
wangxinxin 發表于:2010-11-18 12:06:15
[ARM技術]ARM基礎知識連載之五(轉貼)
在應用程序中安裝異常中斷處理程序
1.使用跳轉指令:可以在異常中斷對應異常向量表中特定位置放置一條跳轉指令,直接跳轉到該異常中斷的處理程序。這種方法有一個缺點,即只能在32M空間范圍內跳轉。
2.使用數據讀取指令LDR:使用數據讀取指令LDR向程序計數器PC中直接賦值。這種方法分為兩步:先將異常中斷處理程序的絕對地址存放在存放在距離向量表4KB范圍內的一個存儲單元中;再使用數據讀取指令LDR將該單元的內容讀取到程序計數器PC中。
**在系統復位時安裝異常中斷處理程序**
1.地址0x00處為ROM的情況
  使用數據讀取指令LDR示例如下所示:
  Vector_Init_Block
  LDR PC, Reset_Addr
  LDR PC, Undefined_Addr
  LDR PC, SW_Addr
  LDR PC, Prefeth_Addr
  LDR PC, Abort_Addr
  NOP
  LDR PC, IRQ_Addr
  LDR PC, FIQ_Addr
  Reset_Addr  DCD Start_Boot
  Undefined_Addr DCD Undefined_Handle
  SW_Addr  DCD SWI_Handle
  Prefeth_Addr  DCD Prefeth_Handle
  Abort_Addr  DCD Abort_Handle
   DCD 0
  IRQ_Addr  DCD IRQ_Handle
  FIQ_Addr  DCD FIQ_Handle
使用跳轉指令的示例如下所示:
  Vector_Init_Block
  BL Reset_Handle
  BL DCD Undefined_Handle
  BL SWI_Handle
  BL Prefeth_Handle
  BL Abort_Handle
  NOP
  BL IRQ_Handle
  BL FIQ_Handle
2.地址0x00處為RAM的情況
地址0x00處為RAM時,中斷向量表必須使用數據讀取指令直接指向PC中賦值的形式。而且,必須使用下面的代碼巴中斷向量表從ROM中復制到RAM中地址0x00開始處的存儲空間中:

MOV r8,#0
ADR r9,Vector_Init_Block
;復制中斷向量表(8字)
LDMIA r9!,(r0-r7)
STMIA r8!,(r0-r7)
;復制保存各中斷處理函數地址的表(8字words)
LDMIA r9!,(r0-r7)
STMIA r8!,(r0-r7)
*********************************************
ARM存儲系統概述
*********************************************
ARM存儲系統的體系結構適應不同的嵌入式
應用系統的需要差別很大。最簡單的存儲系統使用平辦事的地址映射機制,就像一些簡單的彈片機系統中一樣,地址空間的分配方式是固定的,系統各部分都使用物
理地址。而一些復雜系統可能包括下面的一種或幾種技術,從而提供更為強大的存儲系統。
**系統中可能包含多種類型的存儲器,如FLASH,ROM,RAM,EEPROM等,不同類型的存儲器的速度和寬度等各不相同。
**通過使用CACHE及WRITE BUFFER技術縮小處理器和存儲系統速度差別,從而提高系統的整體性能。
**內存管理部件通過內存映射技術實現虛擬空間到物理空間的映射。在系統加電時,將ROM/FLASH影射為地址0,這樣可以進行一些初始化處理;當這些初始化完成后將RAM地址影射為0,并把系統程序加載到RAM中運行,這樣很好地解決了嵌入式系統的需要。
**引入存儲保護機制,增強系統的安全性。
**引入一些機制保證I/O操作應設成內存操作后,各種I/O操作能夠得到正確的結果。
**與存儲系統相關的程序設計指南**
本節從外部來看ARM存儲系統,及ARM存儲系統提供的對外接口。本節介紹用戶通過這些接口來訪問ARM存儲系統時需要遵守的規則。
1.地址空間
ARM體系使用單一的和平板地址空間。該地址空間大小為2^32個8位字節,這些字節的單元地址是一個無符號的32位數值,其
取值范圍為0~2^32-1。ARM地址空間也可以看作是2^30個32位的字單元。這些字單元的地址可以被4整除,也就是說該地址低兩位為0b00。地
址為A的字數據包括地址為A、A+1、A+3、A+3 4個字節單元的內容。
各存儲單元的地址作為32為無符號數,可以進行常規的整數運算。這些運算的結果進行2^32取模。
程序正常執行時,每執行一條ARM指令,當前指令計數器加4個字節;每執行一條Thumb指令,當前指令計數器加2個字節。但是,當地址上發生溢出時,執行結果將是不可預知的。
2.存儲器格式
在ARM中,如果地址A是字對齊的,有下面幾種:
**地址為A的字單元包括字節單元A,A+1,A+2,A+3。
**地址為A的班子單元包括字節單元A,A+1。
**地址為A+2的半字單元包括字節單元A+2,A=3.
**地址為A的字單元包括半字節單元A,A+2。
在big-endian格式中,對于地址為a的字單元其中字節單元由高位到低位字節順序為A,A+1,A=2,A+3;這種存儲器格式如下所示:
31       24 23                    16 15           8 7        0
--------------------------------------------------------------------
字單元A           |
--------------------------------------------------------------------
半字單元A   | 半字單元A+2     |
--------------------------------------------------------------------
字節單元A    | 字節單元A+1 | 字節單元A+2   | 字節單元A+3|
--------------------------------------------------------------------
在little-endian格式中,對于地址為A的字單元由高位到低位字節順序為A+3,A+2,A+1,A,這種存儲格式如下所示
31       24 23                    16 15           8 7        0
--------------------------------------------------------------------
字單元A           |
--------------------------------------------------------------------
半字單元A+2   | 半字單元A     |
--------------------------------------------------------------------
字節單元A+3    |字節單元A+2 | 字節單元A+1   | 字節單元A  |
--------------------------------------------------------------------
在ARM系統中沒有提供指令來選擇存儲器格式。如果系統中包含標準的ARM控制協處理器CP15,則CP15的寄存器C1的位[7]決定系統中存儲
器的格式。當系統復位時,寄存器C1的[7]值為零,這時系統中存儲器格式為little-endian格式。如果系統中采用的是big-endian格
式,則復位異常中斷處理程序中必須設置c1寄存器的[7]位。
3.非對齊的存儲訪問操作
非對齊:位于arm狀態期間,低二位不為0b00;位于Thumb狀態期間,最低位不為0b0。
3.1非對齊的指令預取操作
如果系統中指定當發生非對齊的指令預取操作時,忽略地址中相應的位,則由存儲系統實現這種忽略。
3.2非對齊的數據訪問操作
對于LOAD/STORE操作,系統定義了下面3中可能的結果:
***執行結果不可預知
***忽略字單元地址低兩位的值,即訪問地址為字單元;忽略半字單元最低位的值,即訪問地址為半字單元。
***由存儲系統忽略字單元地址中低兩位的值,半字單元地址最低位的值。
4.指令預取和自修改代碼
當用戶讀取PC計數器的值時,返回的是當前指令下面的第二條指令的地址。對于ARM指令來說,返回當前指令地址值加8個字節;對于Thumb指令來說,返回值為當前指令地址值加4個字節。
自修改代碼指的是代碼在執行過程中修改自身。應盡量避免使用。
5.存儲器映射的I/O空間
在ARM中,I/O操作通常被影射為存儲器操作。通常需要將存儲器映射的I/O空間設置成非緩沖的。
*************************************************************
ARM編譯器支持的數據類型
************************************************************
數據類型 長度(位) 對齊特性
Char       8                1(字節對齊)
short      16               2(百字對齊)
Int           32              4(字對齊)
Long      32               4(字對齊)
Longlong 64            4(字對齊)
Float       32              4(字對齊)
Double     64               4(字對齊)
Long double 64           4(字對齊)
All pointers 32             4(字對齊)
Bool(C++ only) 32           4(字對齊)
1.整數類型
在ARM體系中,整數類型是以2的補碼形式存儲的。對于long long類型來說,在little
endian內存模式下,其低32位保存在低地址的字單元中,高32為保存在高地址的字單元中;在big
endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數據的操作遵守下面的規則:
**所有帶符號的整型書的運算是按照二進制的補碼進行的。
**帶符號的整型數的運算不進行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**制定的移位位數的數是8位的無符號數。
**進行移位操作的數被作為32位數。
**超過31位的邏輯左移的結果為0。
**對于無符號數和有符號的正數來說,超過32位的右移操作結果為0;對于有符號的負數來說,超過32位的右移操作結果為-1。
**整數除法運算的余數和除數有相同的符號。
**當把一個整數截斷成位數更短的整數類型的數時,并不能保證所得到的結果的最高位的符號位的正確性。
**整型數據之間的類型轉換不會產生異常中斷。
**整型數據的溢出不會產生異常中斷。
**整型數據除以0將會產生異常中斷。
2.浮點數
在ARM體系中,浮點數是按照IEEE標準存儲的。
**float類型的數是按照IEEE的單精度數表示的。
**double和long double 是用IEEE的雙精度數表示的。
對于浮點數的操作遵守下面的規則:
**遵守正常的IEEE754規則。
**當默認情況下禁止浮點數運算異常中斷。
**當發生卷繞時,用最接近的數據來表示。
3.指針類型的數據
下面的規則適用于處數據成員指針以外的其他指針:
**NULL被定義為0。
**相鄰的兩個存儲單元地址相差一。
**在指向函數的指針和指向數據的指針進行數據轉換時,編譯器將會產生警告信息。
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指針類型的數據相減時,結果可以按照下面的公式得到。
    ((int)a-(int)b)/(int)sizeof(type pointed to)
這時,只要指針所指的對象不是pack的,其對齊特性能夠滿足整除的要求。
*****************************************************
ARM編譯器中預定義的宏
*****************************************************
ARM編譯器預定義了一些宏,這些預定義宏對應一定的數值,有些預定義宏沒有對應數值,見下表:
_arm                _               使用編譯器armcc,tcc,armcpp,tcpp時
_ARMCC_VERSION      Ver             代表編譯器版本號,其格式為:
                                    PVtbbb,其中:
                                    P為產品編號(1代表ADS)
                                    V為副版本號(1代表1.1)
                                    T為補丁版本號(0代表1.1)
                                    bbb為build號(比如650)
_APCS_INTERWORK     _               使用編譯選項-apcs/interwork時
_APCS_ROPI          _               使用編譯選項apcs/ropi時
_RWPI               _               使用編譯選項-apcs/rwpi時
_APCS_SWST          _               使用編譯選項-apcs/swst時
_BIG_ENDIAN         _               編譯器針對目標系統使用big-endian內存模式時
_cplusplus          _               編譯器工作與C++模式時
_CC_ARM             _               返回編譯器的名稱
_DATE_              date            編譯源文件的日期
_embedded_cplusplus                 編譯器工作于EC++模式時
_FEATURE_SINGED_CHAE                使用編譯設置選項-zc時設置該預定義宏
_FILE_              name            包含全路徑的當前被編譯的源文件名稱
_func_              name            當前被編譯的函數名稱
_LINE_              num             當前被編譯的代碼行號名稱
共1 條記錄, 每頁顯示 10 條, 頁簽: [1]

Copyright © 2000 - 2009 曙海教育集團
Powered By 曙海教育集團 Version 2.2
Processed in .01758 s, 2 queries.
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
蜜臀久久久99精品久久久久久| 欧美一区二区三区日韩视频| 成人看片在线| 99久久精品国产麻豆演员表| 99se婷婷在线视频观看| 国产私拍一区| 日本一区二区三不卡| 中国人体摄影一区二区三区| 色噜噜狠狠色综合中国| 欧美喷潮久久久xxxxx| 日韩精品专区在线影院观看| 中文字幕乱码一区二区免费| 亚洲人精品午夜| 日韩激情在线观看| 国产91精品在线观看| 2022国产精品| 日韩精品久久一区二区三区| 欧美日韩国产综合一区二区三区 | 欧美做爰猛烈大尺度电影无法无天| 在线观看免费亚洲| 欧美成人精精品一区二区频| 中文字幕在线不卡国产视频| 日韩中文字幕区一区有砖一区 | 精品久久久久久最新网址| 国产嫩草影院久久久久| 亚洲午夜久久久久久久久电影网| 男男视频亚洲欧美| 99国产欧美久久久精品| 欧美一区二区三区四区在线观看地址| 欧美曰成人黄网| 欧美韩日一区二区三区四区| 日韩精品午夜视频| av电影天堂一区二区在线 | 亚州欧美一区三区三区在线| 91麻豆精品国产自产在线观看一区| 国产欧美日韩精品在线| 水野朝阳av一区二区三区| 成人精品免费看| 日韩精品欧美在线| 精品免费日韩av| 午夜在线成人av| 97碰碰视频| 欧美自拍偷拍午夜视频| 国产农村妇女毛片精品久久麻豆| 日日摸夜夜添夜夜添亚洲女人| 91丝袜国产在线播放| 色综合天天综合给合国产| 久久色成人在线| 麻豆精品精品国产自在97香蕉 | 欧美日韩国产综合一区二区| 欧美激情在线看| 国产一区在线观看麻豆| 欧美日韩精品不卡| 精品久久国产97色综合| 日韩电影在线一区二区三区| 成人免费在线看片| 欧美人xxxx| 亚洲成人免费影院| 99久久综合狠狠综合久久止| 欧美日韩一区在线| 亚洲自拍欧美精品| 国产精品 日韩| 欧美精品自拍偷拍动漫精品| 亚洲成人自拍偷拍| 国产伦精品一区二区三区| 884aa四虎影成人精品一区| 亚洲成人av电影在线| 国产经典一区二区三区| 日韩精品中文字幕一区| 麻豆免费精品视频| 亚洲一区二区三区乱码| 自拍偷在线精品自拍偷无码专区| 成人精品小蝌蚪| 欧美色图免费看| 肉肉av福利一精品导航| 日韩av高清| 欧美亚洲国产bt| 伊人婷婷欧美激情| 国产精品大全| 日韩av电影免费观看高清完整版 | 丁香婷婷综合激情五月色| 天堂精品一区二区三区| 国产午夜亚洲精品不卡| 高清不卡在线观看| 欧美群妇大交群中文字幕| 丝袜脚交一区二区| 午夜欧美性电影| 亚洲免费在线播放| 久久99精品久久久久久秒播放器| 国产精品123| 欧美人与禽zozo性伦| 蜜桃视频在线一区| 在线亚洲欧美专区二区| 日韩一区精品视频| 色菇凉天天综合网| 日韩激情视频在线观看| 一本大道久久精品懂色aⅴ| 丝袜美腿高跟呻吟高潮一区| 一区二区三区欧美成人| 偷窥少妇高潮呻吟av久久免费| 午夜精品亚洲一区二区三区嫩草 | 在线播放一区二区三区| 99国产精品国产精品久久| 亚洲电影激情视频网站| 国产精品第四页| 久久伊人蜜桃av一区二区| 欧美日韩视频一区二区| 欧洲一区二区在线观看| 久久精彩视频| 国产精品乱子乱xxxx| 91免费版在线| 91在线精品观看| 97se狠狠狠综合亚洲狠狠| 国产成人av福利| 国产精品色噜噜| 国产自产2019最新不卡| 99久久99久久精品免费看蜜桃| 日韩av图片| 日韩激情视频在线观看| 亚洲在线视频一区二区| 全国精品久久少妇| 欧美另类videos死尸| 粉嫩在线一区二区三区视频| 久久久www免费人成精品| 国产精品播放| 亚洲人午夜精品天堂一二香蕉| 视频一区视频二区视频| 免费美女久久99| 日韩欧美一二三| 成人免费在线看片| 亚洲一区二区三区影院| 欧美日本一区二区| 91久久伊人青青碰碰婷婷| 亚洲视频免费在线| 色婷婷激情综合| 国产精品自在在线| 欧美福利一区二区| 一区二区三区中文免费| 一区二区三区av在线| 韩日精品视频一区| 国产日韩成人精品| 亚洲无玛一区| 成人福利视频在线| 亚洲欧美另类小说视频| 欧美在线观看你懂的| 99久久er热在这里只有精品15| 亚洲乱码中文字幕综合| 欧美日韩在线免费视频| 国产成人精品一区二区三区福利| 一区二区在线观看视频| 3d成人动漫网站| 九色91在线视频| 激情久久五月天| 国产精品色婷婷久久58| 欧美综合亚洲图片综合区| 波多野结衣精品久久| 三级精品在线观看| 午夜精彩视频在线观看不卡| www.66久久| 精品欧美一区二区久久| 色综合视频二区偷拍在线| 大尺度一区二区| 午夜在线成人av| 国产亚洲欧美激情| 欧美性生活久久| 国产精品视频免费一区| 老司机午夜精品99久久| 亚洲欧洲三级电影| 欧美一卡二卡三卡| 色综合一个色综合亚洲| 国产a一区二区| 国产成人亚洲综合a∨婷婷图片| 亚洲综合av网| 国产欧美精品一区二区色综合朱莉| 在线免费观看视频一区| 久久精品丝袜高跟鞋| 不卡的av电影| 精品一区二区三区久久久| 一区二区三区四区在线播放| 久久婷婷成人综合色| 欧美伦理视频网站| 亚洲一区影院| 美国av一区二区三区| 91免费看片在线观看| 国产老妇另类xxxxx| 午夜精品久久久久久久久久久| 中文字幕第一区第二区| 91丨九色丨尤物| 日本伊人色综合网| 一区二区免费看| 中文字幕一区二区三| 精品国产乱码久久久久久久久 | 欧美日韩精品系列| 色女孩综合网| 久久精品日韩| 国产精品毛片va一区二区三区| 成人av网站在线| 国产91精品一区二区| 久久国产尿小便嘘嘘尿| 爽爽淫人综合网网站|