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

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 解釋什么是字對(duì)齊什么是半字對(duì)齊

          解釋什么是字對(duì)齊什么是半字對(duì)齊

          作者: 時(shí)間:2016-11-28 來(lái)源:網(wǎng)絡(luò) 收藏
          ARM 處理器對(duì)存儲(chǔ)器空間的訪問(wèn)分辨率以字節(jié)為最小單位;ARM 處理器還支持 16bit 數(shù)據(jù)(2 字節(jié))的存儲(chǔ)器訪問(wèn)和 32bit數(shù)據(jù)(4 子節(jié))的存儲(chǔ)器訪問(wèn)。在ARM 中將32 位的數(shù)據(jù)稱之為‘字’,將 16 位的數(shù)據(jù)稱之為‘半字’。

          ARM 處理器在對(duì)于“字”/ “半字”數(shù)據(jù)進(jìn)行訪問(wèn)時(shí),對(duì)數(shù)據(jù)的存儲(chǔ)格式是有要求的【書中講到若不按照如此要求:可能存儲(chǔ)器系統(tǒng)的實(shí)現(xiàn)更加困難;可能給ARM系統(tǒng)的移植帶來(lái)麻煩(缺少統(tǒng)一標(biāo)準(zhǔn));標(biāo)準(zhǔn)軟件(編譯器和軟件工具)在不遵守規(guī)則的系統(tǒng)中可能不工作?!吭诖鎯?chǔ)器緊鄰的兩個(gè)字節(jié)單元,并且首字節(jié)地址必須能被2整除,這樣存儲(chǔ)的 16bit 數(shù)據(jù)稱為 ‘半字對(duì)齊’存儲(chǔ)數(shù)據(jù),16bit 數(shù)據(jù)這樣的存儲(chǔ)方式稱為 ‘半字對(duì)齊’存儲(chǔ)。類似的,ARM 處理器在進(jìn)“字”數(shù)據(jù)訪問(wèn)時(shí),要求被訪問(wèn)的“字”必須 存放在存儲(chǔ)器緊鄰的4 個(gè)字節(jié)單元,并且首字節(jié)地址必須能被4 整除,【按照二進(jìn)制從低位數(shù)起的1248換算法,能被2整除最低位的1不能有,能被4整除,低位的1和2都不能有】這樣存儲(chǔ)的32bit 數(shù) 據(jù)稱為‘字對(duì)齊’存儲(chǔ)數(shù)據(jù),32bit 數(shù)據(jù)這樣的存儲(chǔ)方式稱為‘字對(duì)齊’存儲(chǔ)。
          能被2 整除數(shù)據(jù)的二進(jìn)制表示,其最低位一定是‘0’;能被4 整除數(shù)據(jù)的二進(jìn)制表示,其最低兩位一定是‘00’。ARM 體系要求32 位長(zhǎng)的ARM 指令在存儲(chǔ)器中必須字對(duì)齊存儲(chǔ),16 位長(zhǎng)的 Thumb 指令必須半字對(duì)齊存儲(chǔ)。因此,在ARM 狀態(tài)下,R15 的值總是能被4 除,也就是R15 寄存器的最低2 位總是 00;Thumb 狀態(tài)下,R15 的值總是能被2 整除,也就是R15 寄存器的最低位總是0。【借此就能夠檢測(cè)處理器工作于何種狀態(tài)之下】
          *【】中是我自己的注解,要思辨地看待……


          評(píng)論


          技術(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); })();