新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > ARM專題之字節(jié)對齊

ARM專題之字節(jié)對齊

作者: 時間:2016-11-09 來源:網(wǎng)絡 收藏
什么叫字節(jié)對齊?
如果一個數(shù)據(jù)是以能被4 整除的地址開始的連續(xù)存儲,那么它就是字對齊,否則就是非字對齊。舉例說明四字節(jié)對齊:對內(nèi)存進行操作時,被訪問的地址必須為4的倍數(shù)。如果分配到的地址的地址不是4的倍數(shù)時,CPU實際訪問的地址還是按照字對齊的方式來操作。

用ADS的ARMC Complier下Optimization Level可能引起問題,其中的一個問題就是字節(jié)對齊的問題。下面講講問題的現(xiàn)象及實質(zhì)。

當時問題的現(xiàn)象是:程序使用一公共變量Buf創(chuàng)建隊列,如果ADS編譯優(yōu)化選項采用Minium則軟件工作正常;源碼不變,如果采用ALL優(yōu)化,則不正常,數(shù)據(jù)紊亂且無法工作。為了發(fā)現(xiàn)問題,我們分別用Minium和ALL編譯,在反匯編條件下單步跟蹤程序,觀察CPU寄存器和內(nèi)存變量的變化情況。

當內(nèi)存起始地址為4字節(jié)對齊地址的情況時,編譯器分配地址和實際地址一致,因此不存在上述問題。

本文引用地址:http://2s4d.com/article/201611/317649.htm

結(jié) 論:

在ARM嵌入式系統(tǒng)中,當把一個內(nèi)存區(qū)域初始化為某個結(jié)構(gòu)體時,必須注意字節(jié)對齊的情況。如果該內(nèi)存起始地址為非對齊地址,不僅得不到預期的結(jié)果,還可能導致一些很奇怪的讓人無法理解表面問題。在C層面上不太容易觀察到這些問題的實質(zhì),只有深入到匯編一層去分析程序,才可能理解這些現(xiàn)象的深層原因。



評論


技術(shù)專區(qū)

關閉