當(dāng)前位置:首頁(yè) > 電源 > 數(shù)字電源
[導(dǎo)讀]現(xiàn)代的處理器(SoC)或DSP都內(nèi)建有內(nèi)存控制器,它是外部SDRAM、FLASH、EEPROM、SRAM……等內(nèi)存的控制接口。但不同處理器內(nèi)部的內(nèi)存控制方式都不盡相同,而且它們的控制程序大部分都位于開(kāi)機(jī)程序內(nèi),皆屬于

現(xiàn)代的處理器(SoC)或DSP都內(nèi)建有內(nèi)存控制器,它是外部SDRAM、FLASH、EEPROM、SRAM……等內(nèi)存的控制接口。但不同處理器內(nèi)部的內(nèi)存控制方式都不盡相同,而且它們的控制程序大部分都位于開(kāi)機(jī)程序內(nèi),皆屬于匯編語(yǔ)言,所以常令人不知所云。

  SDRAM的規(guī)格

  現(xiàn)代的處理器并不需要額外的外部器件,就可以直接將外部?jī)?nèi)存連接至處理器的腳位上。但是,在選擇SDRAM時(shí),還是必須考慮下列幾項(xiàng)因素:

  ● 工作電壓

  ● 最大的工作頻率

  ● 最大的記憶容量

  ● I/O大小和排數(shù)(bank number)

  ● “列地址閃控(column address strobe;CAS)”的延遲(latency)

  ● 刷新(refresh)的速率

  ● 分頁(yè)大小(page size)

  ● 初始化的順序(sequency):可程序化的順序是MRS=>REF(refresh)或REF=>MRS。

  上述參數(shù)都列在SDRAM規(guī)格中,它們必須能符合處理器內(nèi)部的內(nèi)存控制器之要求,惟有如此,才不需要額外的外部器件,否則就必須另外設(shè)計(jì)邏輯電路來(lái)銜接。在圖1中,SDRAM-B無(wú)法符合ADSP-TS201S處理器的內(nèi)存控制器的要求。因?yàn)镾DRAM-B的“突發(fā)資料組之寬度(burst length)”是1,而不是“全分頁(yè)”;而且SDRAM-B的分頁(yè)大小是2048字組(word或16bits),但是ADSP-TS201S處理器最多只能支持1024字組。所以,相較之下,應(yīng)該SDRAM-A才對(duì)。

  緩存器的設(shè)定

  與其它控制器一樣,處理器內(nèi)部的內(nèi)存控制器也需要透過(guò)緩存器(register)去設(shè)定它的組態(tài)與功能。根據(jù)圖1的規(guī)格,可以設(shè)定ADSP-TS201S處理器的“SDRAM控制緩存器(SDRCON)”。SDRCON緩存器的初始值是0,表示SDRAM是在禁能(disable)狀態(tài)。圖2是SDRCON緩存器的每個(gè)位的名稱(chēng)。

  1. 位0(SDRAM ENABLE):設(shè)為1時(shí),表示有SDRAM存在。

  2. 位1~2(CAS LATENCY;CL):表示當(dāng)讀取(read)命令發(fā)出之后,至數(shù)據(jù)出現(xiàn)時(shí)之間的時(shí)間。它與寫(xiě)入作業(yè)無(wú)關(guān)。此值可以在SDRAM規(guī)格表中查到,如圖3所示。假設(shè)外部總線速率是100MHz,則CL應(yīng)設(shè)為2。有些SDRAM的時(shí)序參數(shù)(例如:CL、tRAS、tRP…..等)是根據(jù)不同的傳輸速率和速率等級(jí)(speed grade)而定的。

  3.位3(PIPE DEPTH):當(dāng)有數(shù)個(gè)SDRAM并排使用時(shí),可能需要外部緩沖存儲(chǔ)器(buffer),這時(shí),此位必須設(shè)為1。不過(guò),如果SDRAM腳位上的電容值遠(yuǎn)低于30pF,則此位可以設(shè)為0。

  4.位4~5(PAGE BOUNDARY):分頁(yè)邊界,是用來(lái)定義分頁(yè)的大小,單位是字組。此值與“列的地址(column addresses)”數(shù)目相等。圖4是SDRAM-A的規(guī)格,從中可以查出:列地址的總數(shù)目是256(A0~A7),因此,分頁(yè)大小是256。

  5. 位7~8(REFRESH RATE):這個(gè)值能決定處理器內(nèi)部的刷新計(jì)數(shù)器(refresh counter)之值,好讓處理器的速率能與外部SDRAM所需的刷新速率相配合。于圖4中,刷新計(jì)數(shù)值是4K;而且在SDRAM規(guī)格中,會(huì)經(jīng)常見(jiàn)到:64ms,4096 cycle refresh或者4096 cycles/64ms或15.6μs/row。刷新速率的計(jì)算公式是:cycles=SOCCLK×tREF/Rows,其中,SOCCLK是處理器的CPU速率,tREF是SDRAM刷新間隔(refresh period),Rows是行地址的位數(shù)目。假設(shè)SOCCLK等于250MHz,由上述公式可以求得刷新速率等于3900周期(cycles)。因此,實(shí)際的刷新速率必須等于或小于3900周期,但是ADSP-TS201S處理器的內(nèi)存控制器最多只支持3700周期,所以此值要設(shè)定為3700。

  6. 位9~10(PRC TO RAS DELAY):此參數(shù)決定SDRAM的Precharge到RAS之間的延遲時(shí)間,也就是tRP,如圖5所示。圖6是SDRAM的時(shí)序規(guī)格范例,其中,傳輸率屬-6等級(jí)者,它的最小tRP值是18ns,若使用100MHz速率,則至少需要1.8周期(100MHz×18ns=1.8)。因此,tRP應(yīng)該設(shè)為2周期。

  7. 位11~13(RAS TO PRC DELAY):此參數(shù)決定RAS到Precharge之間的延遲時(shí)間,也就是tRAS。如圖6所示,最小的tRAS值是42ns,若使用100MHz速率,則至少需要4.2周期。因此,tRAS應(yīng)該設(shè)為5周期。

  8. 位14(INIT SEQUENCE):它決定SDRAM于開(kāi)機(jī)時(shí)的初始化程序。若此程序是:在開(kāi)機(jī)后100μs內(nèi),至少必須執(zhí)行一個(gè)COMMAND INHIBIT或NOP命令,之后,執(zhí)行PRECHARGE命令,此時(shí),SDRAM是處于閑置(idle)狀態(tài)。然后,執(zhí)行兩個(gè)AUTO-REFRESH,再設(shè)定“模式緩存器(mode register)”。最后,才能執(zhí)行讀寫(xiě)作業(yè)。這表示此SDRAM的初始化時(shí)間至少需要:PRE+2×Autorefresh+MRS(mode register set)。

  9. 位15(EMR ENABLE):只有當(dāng)連接至低功率(2.5V)的SDRAM時(shí),才必須設(shè)定這個(gè)位值,否則保持0。

  當(dāng)SDRCON緩存器按照上述規(guī)則被設(shè)定好之后,內(nèi)存控制器將會(huì)發(fā)出MRS命令,對(duì)外部SDRAM進(jìn)行初始化。

設(shè)計(jì)程序

 

  了解了SDRAM規(guī)格與內(nèi)存控制器的緩存器功能之后,接著就要設(shè)計(jì)SDRAM的初始化程序,其一般設(shè)計(jì)程序概述如下:

  1. 設(shè)定刷新定時(shí)器(refresh timer)的預(yù)分頻(prescaler)參數(shù):它決定刷新定時(shí)器的輸入頻率(input clock)??偩€頻率除以此參數(shù)(或者還要再加上一個(gè)正整數(shù)值)就等于刷新定時(shí)器。

  2. 設(shè)定刷新定時(shí)器的計(jì)時(shí)時(shí)間的長(zhǎng)度(或刷新速率):亦即,設(shè)定刷新SDRAM暫存內(nèi)容的時(shí)間間隔。當(dāng)此計(jì)時(shí)時(shí)間終了時(shí),內(nèi)存控制器會(huì)自動(dòng)發(fā)出刷新請(qǐng)求。例如:若已知系統(tǒng)頻率和最大可允許的刷新時(shí)間,就可以經(jīng)由預(yù)分頻參數(shù)、系統(tǒng)頻率、最大可允許的刷新時(shí)間,求出適當(dāng)?shù)乃⑿聲r(shí)間間隔(不能大于最大可允許的刷新時(shí)間)。請(qǐng)參考上節(jié)的REFRESH RATE定義。

  3. 設(shè)定基準(zhǔn)地址(base address):大多數(shù)的SoC都是采用多任務(wù)式總線(multiplexed bus)架構(gòu),使不同種類(lèi)的內(nèi)存、不同的數(shù)據(jù)端口大小(port size)能夠共享使用相同的總線,此時(shí),內(nèi)存控制器必須根據(jù)此基準(zhǔn)地址,來(lái)和目前所要存取的地址做比較,之后,內(nèi)存控制器才能知道目前要和哪一種內(nèi)存——具有某種特定的屬性——進(jìn)行存取作業(yè)。這些特定的屬性包括:內(nèi)存的作業(yè)模式或類(lèi)型、數(shù)據(jù)端口大小、防止寫(xiě)入、使用外部的內(nèi)存控制器、局部區(qū)域的獨(dú)立運(yùn)算(atomic opration)、支持?jǐn)?shù)據(jù)管線作業(yè)(data pipelining;可以增加一個(gè)執(zhí)行周期,以省略掉數(shù)據(jù)建立所需的額外時(shí)間)、數(shù)據(jù)是正確的。

  4. 設(shè)定存取模式:這包含,設(shè)定SDRAM的大小、單一SDRAM的內(nèi)部記憶排的數(shù)量、行起始地址的位(row start address bit)、行地址線的數(shù)目(row address lines)、分頁(yè)模式(當(dāng)總線閑置時(shí),分頁(yè)是關(guān)閉的;亦或一直保持開(kāi)啟,直到發(fā)生分頁(yè)失誤或執(zhí)行刷新作業(yè))、取消內(nèi)部記憶排交錯(cuò)(bank interleaving)。

  5. 設(shè)定作業(yè)模式:這包含,選擇多任務(wù)尋址的方式(記憶排交錯(cuò)或分頁(yè)交錯(cuò))、啟動(dòng)刷新作業(yè)、存取SDRAM時(shí)執(zhí)行何種作業(yè)、選擇多任務(wù)尋址的腳位與記憶排的多任務(wù)地址線、決定A10腳位、設(shè)定SDRAM的各種時(shí)間參數(shù)(請(qǐng)參考上節(jié)介紹與SDRAM規(guī)格書(shū))、突量數(shù)據(jù)(burst)的長(zhǎng)度、開(kāi)啟外部多任務(wù)尋址、延長(zhǎng)SDRAM的控制(命令)時(shí)間。

  6. 按照不同內(nèi)存控制器的要求,執(zhí)行SDRAM的初始化程序(下列僅是范例):

  ● 對(duì)所有記憶排,執(zhí)行PRECHARGE命令1次。

  ● 執(zhí)行CBR REFRESH命令8次。

  ● 執(zhí)行MODE REGISTER WRITE命令1次。

  ● 啟動(dòng)刷新服務(wù),讓SDRAM進(jìn)入正常作業(yè)狀態(tài)中。

  轉(zhuǎn)譯備份緩沖器

  “轉(zhuǎn)譯備份緩沖器(Translation Lookaside Buffer;TLB)”保存著最近才被使用的“分頁(yè)表項(xiàng)目(page table entry;PTE)”。PTE是一種數(shù)據(jù)結(jié)構(gòu),包含著可以將“有效地址”轉(zhuǎn)譯成“實(shí)體地址”的信息。PTE是以分頁(yè)為一個(gè)儲(chǔ)存單位,一個(gè)分頁(yè)是4 KBytes。通常,32-bit處理器的一個(gè)PTE含有8 Bytes的信息,而64-bit處理器的一個(gè)PTE含有16 Bytes的信息。

  通常,TLB是位于“內(nèi)存管理單元(MMU)”內(nèi)部,而且又可區(qū)分為:指令MMU內(nèi)的“指令TLB(ITLB)”、數(shù)據(jù)MMU內(nèi)的“數(shù)據(jù)TLB(DTLB)”。它們和外部?jī)?nèi)存的關(guān)系很密切,所以,在完成SDRAM的初始化作業(yè)之后,通常會(huì)令全部的PTE無(wú)效,并關(guān)閉指令緩沖器(I Cache)和數(shù)據(jù)緩沖器(D Cache),以清除所有殘留的數(shù)據(jù)。

  結(jié) 語(yǔ)

  內(nèi)存的控制方式在系統(tǒng)開(kāi)機(jī)時(shí)就被決定了。因此,如果要對(duì)SDRAM進(jìn)行硬件線路的除錯(cuò)驗(yàn)證,都必須在開(kāi)機(jī)程序(boot code)中進(jìn)行。若不了解SDRAM的規(guī)格和SoC處理器的內(nèi)存控制方式,這個(gè)除錯(cuò)工作將會(huì)變得很困難。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉