當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]摘 要: 新型超大容量Flash存儲(chǔ)器K9F2G08U0M的基本組織結(jié)構(gòu),給出了存儲(chǔ)器與C8051F020單片機(jī)外部存儲(chǔ)器接口(EMIF)的硬件連接方式以及存儲(chǔ)器的主要操作流程和部分C語言代碼。關(guān)鍵詞: K9F2G08U0M 外部存儲(chǔ)器接口 管道

摘 要: 新型超大容量Flash存儲(chǔ)器K9F2G08U0M的基本組織結(jié)構(gòu),給出了存儲(chǔ)器與C8051F020單片機(jī)外部存儲(chǔ)器接口(EMIF)的硬件連接方式以及存儲(chǔ)器的主要操作流程和部分C語言代碼。

關(guān)鍵詞: K9F2G08U0M 外部存儲(chǔ)器接口 管道通徑儀

    閃存(Flash Memory)是一種可以進(jìn)行電擦寫并且掉電后信息不丟失(非易失,Non-Volatile)的存儲(chǔ)器,具有功耗低、擦寫速度快等特點(diǎn),被廣泛應(yīng)用于外部存儲(chǔ)領(lǐng)域。
    管道運(yùn)輸作為當(dāng)前油氣資源的主要輸送手段,其運(yùn)行安全性受到越來越多的重視。由于不同的要求使得鋪設(shè)的管道直徑不盡相同,并且管道在長期運(yùn)行過程中也會(huì)存在各種變形,這對(duì)管道缺陷檢測(cè)器的運(yùn)行有相當(dāng)大的影響,容易造成卡死等后果。通徑儀就是鑒于此研制的記錄管徑變動(dòng)情況的儀器。一般情況下,通徑儀連續(xù)運(yùn)行幾百公里,相應(yīng)記錄的數(shù)據(jù)將達(dá)到上百兆字節(jié)。32MB、64MB的閃存已經(jīng)不能滿足需求。因此選用了Samsung公司開發(fā)的K9F2G08U0M,其單片容量高達(dá)264MB,可滿足工程需求。
本文將介紹該存儲(chǔ)器的主要性能及其在管道通徑儀中的應(yīng)用。
1 K9F2G08U0M存儲(chǔ)器簡(jiǎn)介
    從接口角度看,雖然K9F2G08U0M的容量和尋址范圍遠(yuǎn)遠(yuǎn)超過常見單片機(jī)的容量和尋址范圍,但由于芯片上的寫控制器能自動(dòng)控制所有編程和擦除功能,提供必要的重復(fù)脈沖、內(nèi)部確認(rèn)和數(shù)據(jù)空間,而且只通過I/O接口接收單片機(jī)的命令和數(shù)據(jù)而不需要地址線,因此實(shí)際操作起來非常方便。另外芯片是通過“與非”單元結(jié)構(gòu)增大容量,所以沒有因此而削弱自身性能;芯片具有獨(dú)立的1頁大小的數(shù)據(jù)存儲(chǔ)器和緩存存儲(chǔ)器,因此可以在0.2ms內(nèi)完成2112B的頁編程操作,在 2ms內(nèi)完成128KB的塊擦除操作,同時(shí)數(shù)據(jù)區(qū)內(nèi)的數(shù)據(jù)能以30ns/B的速度讀出。
   整個(gè)存儲(chǔ)區(qū)被分為2 048個(gè)相互獨(dú)立的塊,可從邏輯上和物理上對(duì)塊的組織結(jié)構(gòu)分類。
圖1為塊的邏輯結(jié)構(gòu),每個(gè)塊分為64頁,每頁為2 112B(2 048B+額外存儲(chǔ)區(qū)的64B)。芯片通過頁地址和頁內(nèi)字節(jié)地址訪問每一個(gè)字節(jié)。通常頁地址稱為行地址,而頁內(nèi)字節(jié)地址稱為列地址,即264MB=2048塊×64頁/塊×2112字節(jié)/頁=217行×2112列。因此,行地址需要3個(gè)字節(jié),列地址2個(gè)字節(jié),輸入順序如表1所示。

 

 


   從物理結(jié)構(gòu)上看,該芯片為“與非”結(jié)構(gòu)存儲(chǔ)器,每個(gè)塊由兩個(gè)“與非”結(jié)構(gòu)串組成,每個(gè)“與非”結(jié)構(gòu)串包含 16 896個(gè)“與非”結(jié)構(gòu),每個(gè)“與非”結(jié)構(gòu)由32個(gè)基本單元(每個(gè)基本單元為1位)組成,這32個(gè)基本單元分別位于不同的頁內(nèi),由此得到每個(gè)塊的物理結(jié)構(gòu),如圖2所示。

 
2 硬件連接設(shè)計(jì)
   管道通徑儀的結(jié)構(gòu)框圖如圖3所示。管道檢測(cè)時(shí)MCU采集參數(shù)并存儲(chǔ)在Flash中,檢測(cè)完畢后通過USB接口傳輸至上位機(jī)進(jìn)行數(shù)據(jù)分析。

 

 

    如前所述,對(duì)K9F2G08U0M的操作可以通過只向I/O接口發(fā)送數(shù)據(jù)(包括命令碼、行列地址碼等)來實(shí)現(xiàn),因此最直接的方式是使用單片機(jī)的一個(gè)端口作為與芯片的數(shù)據(jù)接口,并以單片機(jī)的GPIO引腳連接CE、ALE、CLE以及,編程時(shí)按照手冊(cè)中的時(shí)序圖控制這些引腳。但是由于每次操作這些引腳都需要大量的控制線電平轉(zhuǎn)換,使程序十分繁冗。
由于C8051F020提供了外部存儲(chǔ)器接口(EMIF),而接口時(shí)序由EMIF硬件產(chǎn)生,使其對(duì)片外擴(kuò)展的器件操作像對(duì)內(nèi)存單元的尋址一樣簡(jiǎn)便快捷。下面采用這種硬件連接方式,對(duì)K9F2G08U0M的主要操作進(jìn)行介紹。電路如圖4所示,C8051F020只畫出了EMIF接口部分,選用非復(fù)用方式,以 IO7~0作為數(shù)據(jù)線,CE、ALE、CLE作為地址線。由于通徑儀中需要隨時(shí)寫入數(shù)據(jù),因此寫保護(hù)端接高電平。
采用外部存儲(chǔ)器接口對(duì)器件編程時(shí),最重要的是保證總線時(shí)序與器件時(shí)序一致。C8051F020的EMIF接口時(shí)序能夠以系統(tǒng)時(shí)鐘周期為單位編程,因此允許連接具有不同建立時(shí)間和保持時(shí)間要求以及不同/WR、/RD選通脈沖寬度的器件。

 

 

   單片機(jī)EMIF在非復(fù)用方式,一次片外XRAM 操作的最小執(zhí)行時(shí)間為5 個(gè)SysClk 周期(用于或 脈沖的1 個(gè)SysClk+4個(gè)額外SysClk)。若單片機(jī)系統(tǒng)采用20MHz晶振,一次MOVX操作的最小執(zhí)行時(shí)間為250ns,而K9F2G08U0M交流參數(shù)中最小建立保持時(shí)間的上界為100ns,則即使采用EMI0TC最小的時(shí)序參數(shù)也不需要在程序中額外加入延時(shí)指令。
3 軟件設(shè)計(jì)
本系統(tǒng)采用C語言編程,提高了開發(fā)速度并降低了維護(hù)難度。下面分別介紹存儲(chǔ)器的主要操作。
3.1 按頁讀
K9F2G08U0M中有一個(gè)2112B即1頁大小的數(shù)據(jù)寄存器,這就決定了存儲(chǔ)器的讀操作是以1頁為基本單元進(jìn)行的。如圖5所示,寫入30H后,行地址所指定的頁中的數(shù)據(jù)將在25?滋s內(nèi)傳輸?shù)綌?shù)據(jù)寄存器中,然后在脈沖的作用下,不但可以從指定的列地址開始連續(xù)讀到該頁末尾,也可以按照流程圖中的虛線部分輸入隨機(jī)讀指令碼,任意讀取該頁中的內(nèi)容,并且不受次數(shù)限制。

 

 


下面是按頁讀操作函數(shù)的C語言代碼。
sbit RdyorBsy=P0^0;
unsigned char xdata * data pK9F;
void PageRead(unsigned int ColAdd,unsigned long
RowAdd,unsigned int len)
{
unsigned int i=0;
unsigned char ColTemp,RowTemp;
ColTemp=(unsigned char)(ColAdd>>8);
RowTemp=(unsigned char)(RowAdd>>16);
ColTemp &=0x0F;
RowTemp &=0x01;

pK9F=0x8002;
 * pK9F=0x00;
pK9F=0x8001;
 * pK9F=(unsigned char)(ColAdd);
 * pK9F=ColTemp;
 * pK9F=(unsigned char)(RowAdd);
 * pK9F=(unsigned char)(RowAdd>>8);
 * pK9F=RowTemp;
 pK9F=0x8002;
 * pK9F=0x30;

while(RdyorBsy);
while(!RdyorBsy);
pK9F=0x8000;
for(i=0;i
  OutputData[i]= * pK9F;
}
3.2 頁編程
向器件寫入數(shù)據(jù)時(shí)先將數(shù)據(jù)寫入數(shù)據(jù)寄存器中,器件寫入操作是基于頁進(jìn)行的,同時(shí)允許在一個(gè)頁編程周期內(nèi)對(duì)一頁內(nèi)的連續(xù)部分編程。若不進(jìn)行擦除,則對(duì)同一頁的連續(xù)部分編程不能超過4次。
器件支持在1頁范圍內(nèi)的隨機(jī)數(shù)據(jù)輸入,由隨機(jī)輸入命令碼85H啟動(dòng),如圖6中虛線框內(nèi)部分所示,在1頁范圍內(nèi)可以啟動(dòng)任意多次隨機(jī)輸入操作。數(shù)據(jù)輸入完畢后,寫入頁編程確認(rèn)命令10H,將數(shù)據(jù)寄存器中的內(nèi)容寫入存儲(chǔ)區(qū)。寫入完成后,需要讀狀態(tài)寄存器(通過寫入70H實(shí)現(xiàn))判斷操作是否成功。若未能成功寫入,應(yīng)將當(dāng)前塊聲明為壞塊,并進(jìn)行塊數(shù)據(jù)替換操作,以保證整個(gè)系統(tǒng)的可靠性。
此外應(yīng)注意,同一塊內(nèi)頁編程時(shí)必須從地址最低的頁開始向高地址的頁依次編程,頁地址隨機(jī)的頁編程是被禁止的。
下面是頁編程子函數(shù)的C語言代碼。

 

 


unsigned char PageWrite(unsigned int ColAdd,unsigned long
RowAdd)
{
unsigned int data i=0;
unsigned char data Status=0;
unsigned char data ColTemp,RowTemp;

ColTemp=(unsigned char)(ColAdd>>8);
RowTemp=(unsigned char)(RowAdd>>16);
ColTemp &=0x0F;
RowTemp &=0x01;

pK9F=0x8002;
 * pK9F=0x80;
pK9F=0x8001;
 * pK9F=(unsigned char)(ColAdd);
 * pK9F=ColTemp;
 * pK9F=(unsigned char)(RowAdd);
 * pK9F=(unsigned char)(RowAdd>>8);
 * pK9F=RowTemp;
pK9F=0x8000;
for(i=0;i<2112;i++)
  * pK9F=InputData[i];
pK9F=0x8002;
  * pK9F=0x10;

while(RdyorBsy);
while(!RdyorBsy);

pK9F=0x8002;
 * pK9F=0x70;
pK9F=0x8000;
Status=* pK9F;
Status &=0x01;
return (Status);
}
3.3 塊擦除
擦除操作以塊為單位進(jìn)行,由于器件分為2 048塊,因此輸入的地址碼中只有A18~A2的11位有效,其余位將被忽略。通過輸入確認(rèn)命令碼來啟動(dòng)擦除以防止誤操作。塊擦除流程如圖7所示。同頁編程操作類似,擦除完畢后也應(yīng)該讀狀態(tài)寄存器并處理返回結(jié)果。

 

 


3.4 頁復(fù)制
    頁復(fù)制操作用來快速有效地實(shí)現(xiàn)頁間數(shù)據(jù)移動(dòng),這是由于省去了比較費(fèi)時(shí)的與片外設(shè)備之間的讀寫操作。這一特性的優(yōu)勢(shì)在塊替換操作用于頁間數(shù)據(jù)復(fù)制時(shí)體現(xiàn)尤為明顯。其實(shí)該操作是按頁讀與頁編程操作的復(fù)合,頁復(fù)制讀命令35H將頁中數(shù)據(jù)移至數(shù)據(jù)寄存器中,而頁復(fù)制寫命令85H將數(shù)據(jù)復(fù)制到目標(biāo)頁中。頁復(fù)制流程圖如圖8所示。

 

 


該操作也可以將原始頁中的數(shù)據(jù)修改后寫入目標(biāo)頁,如流程圖8中虛線框內(nèi)部分。
需要注意的是,頁復(fù)制操作只能在奇數(shù)頁之間或偶數(shù)頁之間進(jìn)行,奇偶頁之間的數(shù)據(jù)移動(dòng)將被禁止。
3.5 緩存區(qū)編程
芯片中除1頁大小的數(shù)據(jù)寄存器外,還有一個(gè)1頁大小的緩沖寄存器。該緩沖寄存器可以在數(shù)據(jù)寄存器參與頁編程的同時(shí)接收外部數(shù)據(jù),等待數(shù)據(jù)寄存器空閑時(shí)將數(shù)據(jù)轉(zhuǎn)移其中,然后繼續(xù)接收數(shù)據(jù)。因此,采用緩存區(qū)編程操作在連續(xù)寫入多頁數(shù)據(jù)時(shí)將會(huì)大大提高效率。
緩存區(qū)編程流程如圖9所示。當(dāng)?shù)谝唤M數(shù)據(jù)寫入緩沖寄存器時(shí),寫入緩存命令15H,將數(shù)據(jù)傳遞給數(shù)據(jù)寄存器并啟動(dòng)頁編程,然后使緩沖寄存器空閑,準(zhǔn)備接收下一組數(shù)據(jù)。在這個(gè)過程中芯片將處于忙狀態(tài),若內(nèi)部編程操作未完成,忙狀態(tài)持續(xù)的時(shí)間將被延長。

 


    需要注意的是,該操作只能在同一塊內(nèi)進(jìn)行,因此在多塊數(shù)據(jù)寫入時(shí)需要注意每塊的最后一頁。若系統(tǒng)僅僅通過芯片的Ready/Busy引腳監(jiān)測(cè)編程進(jìn)度,則最后一頁的寫入操作應(yīng)該由頁編程命令10H啟動(dòng)。另外也可以通過讀狀態(tài)寄存器中的I/O 5位來判斷。
    K9F2G08U0M 是一種新型的超大容量Flash存儲(chǔ)器,以其非易失、功耗低、操作簡(jiǎn)單而在單片嵌入式系統(tǒng)中得到廣泛應(yīng)用。本文在管道通徑儀的開發(fā)過程中,根據(jù)對(duì)外部存儲(chǔ)器接口的深入理解,將存儲(chǔ)器芯片的兩個(gè)控制線ALE和CLE用作地址線,使得對(duì)存儲(chǔ)器的操作更簡(jiǎn)捷高效。文中的程序已經(jīng)過實(shí)際驗(yàn)證,限于篇幅,只給出按頁讀和頁編程部分的代碼。

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

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

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

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

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

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(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中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

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

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

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

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐ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)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(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年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長三角投資(上海)有限...

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