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

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > S3C2440與SDRAM與NAND與NOR的地址連線分析

          S3C2440與SDRAM與NAND與NOR的地址連線分析

          作者: 時間:2016-11-09 來源:網(wǎng)絡 收藏
          S3C2440有27根地址線ADDR[26:0],8根片選信號nGCS0-nGCS7,對應bank0-bank7,當訪問bankx的地址空間,nGCSx引腳為低電平,選中外設。

          2^27=2^7 * 2^10 * 2^10 = 128Mbyte

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

          8*128Mbyte = 1Gbyte

          所以S3C2440總的尋址空間是1Gbyte。

          市面上很少有32位寬度的單片SDRAM,一般選擇2片16位SDRAM擴展得到32位SDRAM.

          選擇的SDARM是HY57V561620F,4Mbit * 4bank *16,共16Mbyte?(后面有解釋)

          兩塊HY57V561620F并接,構(gòu)成64M×32bit的SDRAM

          首先了解下SDRAM的尋址原理。

          SDRAM內(nèi)部是一個存儲陣列??梢园阉胂蟪梢粋€表格。和表格的檢索原理一樣,先指定行,再指定列,就可以準確找到所需要的存儲單元。這個表格稱為邏輯BANK。目前的SDRAM基本都是4個BANK。尋址的流程就是先指定BANK地址,再指定行地址,最后指定列地址。這就是SDRAM的尋址原理。存儲陣列示意圖如下:

          查看HY57V561620F的資料,這個SDRAM有

          13根行地址線 RA0-RA12

          9根列地址線 CA0-CA8

          2根BANK選擇線 BA0-BA1(4個bank的選擇)

          SDRAM的地址引腳是復用的,在讀寫SDRAM存儲單元時,操作過程是將讀寫的地址分兩次輸入到芯片中,每一次都由同一組地址線輸入。兩次送到芯片上去的地址分別稱為行地址和列地址。它們被鎖存到芯片內(nèi)部的行地址鎖存器和列地址鎖存器。

          /RAS是行地址鎖存信號,該信號將行地址鎖存在芯片內(nèi)部的行地址鎖存器中;

          /CAS是列地址鎖存信號,該信號將列地址鎖存在芯片內(nèi)部的列地址鎖存器中。

          NSCS接到bank6上,決定了SDRAM的物理地址是0x30000000

          地址連線如下圖:

          LnSCS0腳接了nGCS6,即接在了bank6上,所以SDRAM的物理地址從0X30000000開始

          為啥LADDR2接A0呢?

          @CPU的尋址空間中,仍然是按8bit一個字節(jié)為單位操作的

          @由于SDRAM并接成了32位,即4個字節(jié),這樣接使得SDRAM的最小單位是4個字節(jié),方便32位的讀寫操作吧

          為啥LADDR24/25接BA0/1?

          @ BA1:BA0是SDRAM的最高位,組合選擇4個bank中的哪一個

          @ LADDR0~LADDR25,總共26根地址線,可尋址(2的26次方)64MB

          為啥一個bank4MB,而容量不是4mb×4bank=16MB是8×4=32MB?

          @ 13根行地址線+9根列地址線 = 22根(4MB)。另外HY57V561620F一個存儲單元是2個字節(jié)(本身是16位的),相當于有了23根地址線。

          NORFLASH中A0接CPU的LADDR1,那么,norflash的最小尋址單元為2個字節(jié)(16位),事實上只有A0~A19是有效的,因為該nor本身才有2MB,2的20次方=1MB,加上nor本身是16位的(2個字節(jié)),所以1MB×2就是nor的大小

          @ 26腳接了nGCS0,即接在了bank0上,所以,nor的物理地址從0X00000000開始

          從接線上可以看出NAND有點特殊,他并沒有通過CPU的地址線訪問,這就回答了為啥可以接1GB的NAND,當然他也沒有接bank選擇線,自然不存在物理地址了,由此我猜想NAND是由硬件本身識別的,即OM開關(guān)選擇是NOR還是NAND啟動,這似乎也驗證了數(shù)據(jù)手冊上這兩種啟動方式的映射圖,NAND的啟動方式可參考前面的日志

          0x4000_0000-0x4000_0fff

          -----這4K字節(jié)的就是前面說的stepingstone的啦。0x4000_0fff_0x4800_0000是沒用到的。

          0x4800_0000-0x6000_0000

          -----這空間是特殊功能寄存器的.你發(fā)現(xiàn),所有的寄存器都是在這個范圍內(nèi)的。

          0x6000_0000—0Xffff_ffff

          -----還是未用到的。

          理論上可以尋址的空間為(2的32次方,32根地址線)4GB,但其中有3GB的空間都預留給處理器內(nèi)部的寄存器和其他設備了,留給外部可尋址的空間只有1GB,也就是0X00000000~0X3FFFFFFF,總共應該有30根地址線。這1GB的空間,2440處理器又根據(jù)所支持的設備的特點將它分為了8份,每份空間有128MB,這每一份的空間又稱為一個BANK。為方便操作,2440獨立地給了每個BANK一個片選信號(nGCS7~nGCS0)。其實這8個片選信號可以看作是2440處理器內(nèi)部30根地址線的最高三位所做的地址譯碼的結(jié)果。正因為這3根地址線所代表的地址信息已經(jīng)由8個片選信號來傳遞了,因此2410處理器最后輸出的實際地址線就只有A26~A0

          nandflash由于其自身的特點,不具備運行程序的功能。但s3c2440通過稱為“Steppingstone”的內(nèi)部SRAM緩存,實現(xiàn)了可以運行存儲在外部nandflash中的啟動代碼的功能。它的機制是:當檢測到是由nandflash啟動時,系統(tǒng)會自動把nandflash中的前4k字節(jié)的數(shù)據(jù)加載到Steppingstone中,然后把該Steppingstone映射為Bank0,因此系統(tǒng)會從Steppingstone開始運行程序,從而實現(xiàn)了s3c2440的nandflash自啟動的功能。這一過程是由系統(tǒng)自動完成的,無需人為干預。在系統(tǒng)啟動以后,Steppingstone所在的SRAM就可以用作其他用途了。



          關(guān)鍵詞: S3C2440SDRAMNANDNOR地址連

          評論


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