在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 關(guān)于ARM和存儲(chǔ)器地址線錯(cuò)位連接詳解

            關(guān)于ARM和存儲(chǔ)器地址線錯(cuò)位連接詳解

            作者: 時(shí)間:2016-11-11 來(lái)源:網(wǎng)絡(luò) 收藏
            首先,SST39VF16 FLASH是16位的,也就是以?xún)蓚€(gè)字節(jié)(半字)為最小操作單位的。也就是說(shuō)你在FLASH地址上給0x00000,則它給出的數(shù)據(jù)是第一個(gè)16位的半字;在FLASH地址上給0x00001,它給出的是第二個(gè)16位的半字;在FLASH地址上給0x00002,它給出的是第三個(gè)16位的半字。。。但ARM的地址是以字節(jié)編址的,它可以以字節(jié)單位來(lái)讀取或者寫(xiě)外設(shè)。
            假設(shè)我們要讀取FLASH的第一個(gè)[color=#FF0000]字節(jié)[/color],LDRB R0,[R1];將R1內(nèi)容寫(xiě)0x00000,這個(gè)時(shí)候ARM執(zhí)行的是這樣的操作:
            1、送出地址0x00000
            2、在D0-D15上讀取數(shù)據(jù)
            3、將讀到的16位數(shù)據(jù)的[color=#FF0000]低[/color]8位給R0低8位(高24位為0)

            假設(shè)我們要讀取FLASH的第二個(gè)[color=#FF0000]字節(jié)[/color],LDRB R0,[R1];將R1內(nèi)容寫(xiě)0x00001,
            這個(gè)時(shí)候ARM執(zhí)行的是這樣的操作:
            1、送出地址ox00001
            2、在D0-D15上讀取數(shù)據(jù)
            3、將讀到的16位數(shù)據(jù)的[color=#FF0000]高[/color]8位給R0的低8位(高24位為0)

            從上面的操作可以看到,如果我們一一對(duì)應(yīng)的將ARM和FLASH得地址連接,那么我們想讀FLASH的第2個(gè)字節(jié)的話,就沒(méi)有辦法讀到了。因?yàn)槟愕刂方o0x00001,FLASH就在數(shù)據(jù)線上給的是第3個(gè)字節(jié)和第4個(gè)字節(jié)的數(shù)據(jù),并將高8位(FLASH的第4個(gè)字節(jié))給R0;如果你給的地址是0x00000的話,ARM的理解就是將數(shù)據(jù)線D0-D15的低8位給R0,顯然這個(gè)16位的數(shù)據(jù)是FLASH的第1個(gè)字節(jié)和第2個(gè)字節(jié)的數(shù)據(jù),低8位指的就是第一個(gè)自己的數(shù)據(jù)。顯然怎么也讀不到FLASH的第2個(gè)數(shù)據(jù)。
            我們既要遵循ARM的規(guī)則,又要讓FLASH給我們正確的數(shù)據(jù)。你自己想應(yīng)該怎么辦?很簡(jiǎn)單,把ARM給的地址最低位剪掉,把剩下的給FLASH。要讀第2個(gè)字節(jié),還是送0x00001,但是最后的1被剪掉了,F(xiàn)LASH得到的地址是ox00000,顯然給出的數(shù)據(jù)是第1個(gè)和第二個(gè)字節(jié)。而ARM覺(jué)得送出的地址是0x00001啊,應(yīng)該把高地址給R0啊,即把第2個(gè)字節(jié)給了R0。就是一個(gè)“欺上瞞下”的過(guò)程。


            評(píng)論


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

            關(guān)閉