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

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Flash與S3C44B0X連接時(shí)地址線為什么要偏移一位

          Flash與S3C44B0X連接時(shí)地址線為什么要偏移一位

          作者: 時(shí)間:2016-11-11 來(lái)源:網(wǎng)絡(luò) 收藏
          FlashS3C44B0X的接口電路圖如圖2所示。處理器ADDR20~1對(duì)應(yīng)著Flash ROM的A19~0,偏移了1位,這是由于S3C44B0X是按照字節(jié)編址的,而Flash ROM是以16位為一個(gè)存儲(chǔ)單元。


          圖2 程序存儲(chǔ)器Nor Flash的擴(kuò)展

          本文引用地址:http://www.ex-cimer.com/article/201611/316815.htm

          代碼一:
          #define Writeflash(addr,dat) *((volatile INT16U *)(addr<<1))=(INT16U)dat
          #define Readflash(addr) (*((volatile INT16U *)(addr<<1)))
          /*addr為讀寫(xiě)操作的半字地址,data則為要寫(xiě)入的半字?jǐn)?shù)據(jù)。因?yàn)锳RM處理器是以字節(jié)為單位
          進(jìn)行數(shù)據(jù)處理的,而SST39VF160是16位數(shù)據(jù)寬度,所以,addr地址必須左移1位。*/

          代碼二:
          //擦除是否為空
          int SST39VF160_CheckBlank(INT32U addr,INT32U WordSize)
          {
          INT32U i,temp;
          for (i=addr;i<(addr+WordSize);i++)
          {
          temp=*((volatile INT16U *)(i<<1)); //地址左移一位,也就得到16位的數(shù)據(jù)了。
          if(temp!=0xffff) //因?yàn)樯葏^(qū)被擦除后,扇區(qū)的各位都是1.所以判斷temp是否等于0xffff //0xffff
          return 0; //如果扇區(qū)的各個(gè)地址都不為0xffff;則返回0
          }
          return 1;
          }

          在網(wǎng)上看到這么一段話,我琢磨不透。“S3C44B0X是按照字節(jié)編址的,而Flash ROM是以16位為一個(gè)存儲(chǔ)單元”是怎樣推出要“偏移一位”呢?代碼一的注釋和上一段一樣,也沒(méi)有給出是如何推導(dǎo)出來(lái)的。而且代碼二中的下面這行代碼的注釋更是讓我不解。前面的i被定義成INT32U 型,怎么通過(guò)左移一位就可以得到16的數(shù)據(jù)呢?懇請(qǐng)各位大俠給出較為詳細(xì)的解釋.
          temp=*((volatile INT16U *)(i<<1)); //地址左移一位,也就得到16位的數(shù)據(jù)了。

          解答:

          關(guān)于那個(gè)錯(cuò)位,我不知道能不能跟你說(shuō)清楚。首先,SST39VF16 FLASH是16位的,也就是以兩個(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è)字節(jié),LDRB R0,[R1];將R1內(nèi)容寫(xiě)0x00000,這個(gè)時(shí)候ARM執(zhí)行的是這樣的操作:
          1、送出地址0x00000
          2、在D0-D15上讀取數(shù)據(jù)
          3、將讀到的16位數(shù)據(jù)的低8位給R0低8位(高24位為0)

          假設(shè)我們要讀取FLASH的第二個(gè)字節(jié),LDRB R0,[R1];將R1內(nèi)容寫(xiě)0x00001,
          這個(gè)時(shí)候ARM執(zhí)行的是這樣的操作:
          1、送出地址ox00001
          2、在D0-D15上讀取數(shù)據(jù)
          3、將讀到的16位數(shù)據(jù)的高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ò)程。



          關(guān)鍵詞: FlashS3C44B0X地址

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