欧美自拍小视频_国产片在线免费观看_中文字幕啪啪_成人av高清在线_欧美一区二区视频免费观看_亚洲国产激情

以文本方式查看主題

-  曙海教育集團論壇  (http://www.rfoamep.cn/bbs/index.asp)
--  ARM技術(shù)討論專區(qū)  (http://www.rfoamep.cn/bbs/list.asp?boardid=14)
----  ARM基礎(chǔ)知識連載之五  (http://www.rfoamep.cn/bbs/dispbbs.asp?boardid=14&id=1453)

--  作者:wangxinxin
--  發(fā)布時間:2010-11-18 12:06:15
--  ARM基礎(chǔ)知識連載之五
[ARM技術(shù)]ARM基礎(chǔ)知識連載之五(轉(zhuǎn)貼)
在應(yīng)用程序中安裝異常中斷處理程序
1.使用跳轉(zhuǎn)指令:可以在異常中斷對應(yīng)異常向量表中特定位置放置一條跳轉(zhuǎn)指令,直接跳轉(zhuǎn)到該異常中斷的處理程序。這種方法有一個缺點,即只能在32M空間范圍內(nèi)跳轉(zhuǎn)。
2.使用數(shù)據(jù)讀取指令LDR:使用數(shù)據(jù)讀取指令LDR向程序計數(shù)器PC中直接賦值。這種方法分為兩步:先將異常中斷處理程序的絕對地址存放在存放在距離向量表4KB范圍內(nèi)的一個存儲單元中;再使用數(shù)據(jù)讀取指令LDR將該單元的內(nèi)容讀取到程序計數(shù)器PC中。
**在系統(tǒng)復(fù)位時安裝異常中斷處理程序**
1.地址0x00處為ROM的情況
  使用數(shù)據(jù)讀取指令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
使用跳轉(zhuǎn)指令的示例如下所示:
  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時,中斷向量表必須使用數(shù)據(jù)讀取指令直接指向PC中賦值的形式。而且,必須使用下面的代碼巴中斷向量表從ROM中復(fù)制到RAM中地址0x00開始處的存儲空間中:

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

主站蜘蛛池模板: 亚洲av无码一区二区乱子伦 | 天堂亚洲国产日韩在线看 | 成人a毛片手机免费播放 | 狂猛欧美激情性xxxx大豆行情 | 成人午夜在线观看 | 91精品国产亚洲爽啪在线影院 | 欧美激情肉欲高潮视频 | 中文字幕日本六区小电影 | 日本人妻伦在线中文字幕 | 99视频国产在线 | 欧美成本人视频免费播放 | 日韩欧美自拍 | 成人小视频网 | 久久99精品久久久久久不卡 | 国产成人毛片视频不卡在线 | 97中文在线| 精品国产一二三区在线影院 | 久久国产加勒比精品无码 | 免费黄色电影在线观看 | 亚洲狠狠97婷婷综合久久久久 | 国产91久久久久久久免费 | 91香蕉视频污污 | 精品在线观看一区 | 亚洲高清中文字幕 | 日本www在线 | 国产成人无码www免费视频播放 | 美女的隐私视频网站蜜桃视频 | 亚洲精品国产成人 | 蜜臀av性久久久久蜜臀aⅴ | 亚洲精品久久久久久久观小说 | 四虎国产永久在线精品免费观看 | 亚洲首页国产精品丝袜 | 中文字幕精品视频 | 亚欧精品一区二区三区四区 | 午夜精品视频在线看 | 日本一级毛片毛片一级毛片 | 久久久精品成人免费看 | 日本人妻丰满熟妇久久久久久 | 午夜免费成人 | 日本高清va在线播放 | 300部国产真实乱 |