專注電子技術(shù)學(xué)習(xí)與研究
當(dāng)前位置:單片機(jī)教程網(wǎng) >> MCU設(shè)計實例 >> 瀏覽文章

根據(jù)FAT表研究MSP430內(nèi)存對齊問題

作者:未知   來源:轉(zhuǎn)自學(xué)會珍惜LW   點(diǎn)擊數(shù):  更新時間:2014年08月27日   【字體:

      這兩天仔細(xì)研究了下FAT32,發(fā)現(xiàn)里面涉及到了一個大端、小端對齊有點(diǎn)意思,這里也簡單總結(jié)一下。先在這里說明一下,MSP430是小端對齊的,還有FAT32文件系統(tǒng)中存放字段的順序也是小端模式,所以用MSP430來實現(xiàn)FAT32文件系統(tǒng)的話,讀取數(shù)據(jù)的時候不需要做特殊處理~

 

      下面簡單講一下大端對齊和小端對齊。

       我們知道,我們定義變量的時候,在內(nèi)存中會給該變量分配一個位置,如果該變量是一個char型的變量,那么只會分配給它一個字節(jié)的位置,但是如果該變量int型或者long int型呢?這里以16位的C編譯器編譯結(jié)果來看的話,int型占2個字節(jié),long int型占4個字節(jié),那具體是如何分配呢?我們以0x12345678這個4字節(jié)數(shù)據(jù)為例。

       如果在內(nèi)存中,按地址從低往高,存儲是4個字節(jié)的數(shù)據(jù)依次是0x78,0x56,0x34,0x12的話,則為小端存儲,如下圖所示;

       如果在內(nèi)存中,按地址從低往高,存儲的4個字節(jié)的數(shù)據(jù)依次是0x12,0x34,0x56,0x78的話,則為大端存儲如下圖所示;

       不同的CPU,對齊方式不同,所以如果我們在移植程序時,涉及到這種多個字節(jié)拼湊成多個字節(jié)的數(shù)據(jù)出問題時,可以考慮是否是內(nèi)存對齊方式的問題。

        FAT表一般有兩張,兩張表緊挨著,內(nèi)容完全一樣,第二張是起備份作用。

 

        FAT表中的編號是從0開始,下面依次是第1簇,第2簇……

        其中第0簇和第1簇是存放的FAT表本身,文獻(xiàn)里沒有看到這種說法,文獻(xiàn)里只所數(shù)據(jù)簇是從第2簇開始,但是這樣理解應(yīng)該也可以;

        第2簇是首目錄簇,存放的是文件的文件名、文件格式、文件大小、起始位置等信息;

        真正的數(shù)據(jù)簇是從第3簇開始的。所以如果以SD卡及FAT32文件系統(tǒng)為例,將SD卡格式化之后,存入一個文件,會發(fā)現(xiàn)其FAT表的第一個扇區(qū)的數(shù)據(jù)如下圖所示。紅線處為第一個存放數(shù)據(jù)的簇,為第3簇,是緊跟在首目錄簇后面的那一簇。



        

關(guān)閉窗口

相關(guān)文章