<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > ARMv7的非對齊地址訪(fǎng)問(wèn)

ARMv7的非對齊地址訪(fǎng)問(wèn)

作者: 時(shí)間:2016-11-10 來(lái)源:網(wǎng)絡(luò ) 收藏
ARMv7默認支持非對齊地址訪(fǎng)問(wèn),但有些條件:
CP15 的系統控制寄存器(SCTLR), bit.A = 0, (bit.U = 1, 對于A(yíng)RMv7已經(jīng)默認置1了,不可改).
訪(fǎng)問(wèn)的地址空間必須為Normal memory, 訪(fǎng)問(wèn)Device memory或Strongly memory都會(huì )引發(fā)alignment fault的Data Abort。而如果MMU disable的話(huà),所有的memory都被當作Strongly memory處理(這句話(huà)沒(méi)找到出處,來(lái)自ARM support回復的mail)。所以MMU必須enable,memory類(lèi)型由頁(yè)表項的C, B, TEX[2:0]決定,這部分可以查閱 的:

B3.7 Memory region attributes.

本文引用地址:http://dyxdggzs.com/article/201611/317217.htm
示例
    MRS   r0, CPSR    ORR   r0, r0, #(PSR_I_BIT|PSR_F_BIT) ; Disable IRQ & FIQ    MSR   CPSR_c, r0; Disable MMU stuff and caches    MRC   p15, 0, r0, c1, c0, 0      ; read control register to r0    BIC   r0, r0, #0x000f         ; clear W(Write buffer), C(Cache), A(Align), M(MMU) bits    BIC   r0, r0, #0x1100         ; clear I(ICache), S(System protection) bits    MCR   p15, 0, r0, c1, c0, 0      ; write control register.        stack_setup    LDR   r0, =|Image$$ZI$$Limit|    ADD   r0, r0, #STACK_SIZE_SVC            MSR   CPSR_c, #(MODE_SVC :OR: PSR_F_BIT :OR: PSR_I_BIT)    MOV   sp, r0mmu_setup        LDR   r2, =MMU_TABLE_BASE               ; mmu page base address    MCR   p15, 0, r2, c2, c0, 0      ; write mmu page base address            BL   _cpu_mmu_init                LDR   r0, =0x89    LDRH  r1, [r0]

關(guān)于編譯器

在Realview下,如果目標處理器選擇了ARMv6、ARMv7-A(如Cortex-A8)、ARMv7-R,編譯器的缺省選項是--unaligned_access, 而如果選擇了ARMv6以前的版本,或ARMv7-M體系的處理器,缺省選項是--no_unaligned_access。

對于選項--no_unaligned_access,編譯器會(huì )自動(dòng)將C語(yǔ)言對非對齊地址的變量的訪(fǎng)問(wèn),轉化成若干個(gè)字節操作。 比如:

__packed struct usb_endpoint_descriptor {  u8 bLength;  u16 wMaxPacketSize;  u8 bDescriptorType;  u8 bEndpointAddress;  u8 bmAttributes;  u8 bInterval;} ;int main(void){    volatile struct usb_endpoint_descriptor ep;   ep.wMaxPacketSize = 0x200;  while(1);  return 0;}如果--no_unaligned_access選項編譯,它的反匯編代碼如下:  main    0xe100c5f0:  e92d400c  .@-.  PUSH   {r2,r3,lr}    0xe100c5f4:  e3a00c02  ....  MOV   r0,#0x200    0xe100c5f8:  e5cd0001  ....  STRB   r0,[sp,#1]    0xe100c5fc:  e1a00420   ...  LSR   r0,r0,#8    0xe100c600:  e5cd0002  ....  STRB   r0,[sp,#2]     0xe100c604:  eafffffe  ....  B    0xe100c604 ; main + 20如果是--unaligned_access選項編譯,它的反匯編代碼如下:  main    0xe100c5f0:  e92d400c  .@-.  PUSH   {r2,r3,lr}    0xe100c5f4:  e3a00c02  ....  MOV   r0,#0x200    0xe100c5f8:  e1cd00b1  ....  STRH   r0,[sp,#1]     0xe100c5fc:  eafffffe  ....  B    0xe100c5fc ; main + 12

如果你的目標平臺是ARMv6或ARMv7-AR,但是在你的代碼中,MMU是disable的,那你應該手動(dòng)添加編譯選項--no_unaligned_access,讓編譯器來(lái)幫你處理非對齊訪(fǎng)問(wèn)。



關(guān)鍵詞: ARMv7非對齊地址訪(fǎng)

評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>