新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > CF卡在手機測試系統(tǒng)中的應用

CF卡在手機測試系統(tǒng)中的應用

作者: 時間:2004-12-10 來源:網絡 收藏
摘要:介紹閃存的中的,提出具體的硬件開發(fā)和軟件實現方案。包括卡的讀寫操作、緩沖區(qū)操作的具體源程序。

關鍵詞:閃存

引言

目前,作為日常生活中一種重要的通信工具,越來越受到人們的關注。它的最大特性就是方便易攜帶。那么,如何保證手機在不同地理位置的條件下仍然具有優(yōu)質的網絡服務,進而保證其通話質量,成為移動通信部門的一種研究課題。為此,需要一種設備能夠測試出手機處于不同地理位置,不同時間的各種網絡參數來加以分析,即“便攜式手機測試記錄儀”。它能夠將手機的各種網絡數據從手機串口傳送到存儲設備;存儲設備將數據存儲下來,達到一定數目,再通過串行上載到PC機;在PC機上利用分析軟件來進行數據分析,從而達到測試的目的。在此測試過程中,由于系統(tǒng)要求處理大量的數據,一般的存儲器如EEPROM等很難達到要求,同時,系統(tǒng)要求數據在舊電時不丟失,即要求數據存儲的非易失性,因此不能使用易失性的存儲器如SRAM、SDRAM等。為此,在系統(tǒng)中采用了一種新型存儲裝置,即CF卡(Compact Flash Card)。

1 CF卡簡介

Flash存儲器是近年來發(fā)展迅速的一種存儲器,屬于非揮發(fā)性內存(Non-Volatile,即斷電數據也能保存)。它具有EEPROM電擦除的特點,還具有低功耗、密度高、體積小、可靠性高、可擦除、可重寫、可重復編程等優(yōu)點。單片機的Flash Memory芯片容量有限,同時接口邏輯比較特殊,在大數據量場合使用會使得控制邏輯較為繁瑣。集成了多片Flash存儲器和外部接口、控制機構和協(xié)議的CF卡,可以提供相當可觀的存儲容量和標準的電氣接口協(xié)議,可以滿足本系統(tǒng)對于數據處理的要求。其內部結構如圖1所示。

CF卡的在很小的體積內集成了控制裝置、Flash Memory陣列和讀寫緩沖區(qū)。實際上,控制裝置起到了種協(xié)議轉換的作用,將對Flash Memory的讀寫轉化成對ATA協(xié)議控制器的訪問。CF卡對于緩沖區(qū)的設計使用了一種比緩沖結構,使得外部設備和CF卡通信的同時,CF卡的片內MCU可以對Flash Memory陣列進行讀寫。這種設計可以增加CF卡數據讀寫的可靠性,同時提高數據通訊的速率。在實際系統(tǒng)中,CF卡選用了SST公司的SST48CF096,容量達到了96MB,封裝為252的雙列插座,其工作電壓為+5V/+3.3V,傳輸速率最大可達20MB/s,低功耗30mA/50mA(3.3V/5V)。其典型 電路如圖2所示。

CF卡的主要功能引腳為數據線D0~D15,地址線A0~A9,片選及數據選擇CS1、CS0,讀寫控制端ATA SEL、WE,寄存器選擇REG,卡讀寫忙判斷INTRQ、RESET等。數據線D0~D15用于數據的讀寫。CF可以工作于16位數據總線方式也可以工作于8位總線方式。讀寫速度上的要求不是很嚴格的情況下,為了方便和8位MCU的接口,一般選擇為8位數據總線工作方式。若選擇8位工作方式,CS1應接固定高電平,CS0低電平有效。CFMemory工作方式下,僅地址線A0~A3起作用,用于選擇讀寫端口,其余地址線可以接固定電平。REG用于選擇是對CF卡進行命令、狀態(tài)讀寫還是讀寫CF卡的屬性寄存器。REG=1時讀寫命令。在Memory方式下,對CF的控制和數據讀寫均是通過對這幾個端口的讀寫來實現的。INIRQ用于判斷CF卡是否處于讀寫忙狀態(tài)。出于嚴謹性可以在對CF卡進行讀寫之前利用此引腳判斷CF卡是否空閑。在數據讀寫量較小的情況下,使用一定的延時即可。

圖2中96MB的CF卡工作于Memory方式,8位數據總線,接口的主控MCU的89C52。單片機按標準的P2、P0口復用方式與CF卡接口。CS0~CS1、REG分別接單片機的P2.6、P2.5、P2.7,端口選擇A3~A0接收經373鎖存的低4位地址,CF卡的讀寫引腳分別與單片機的讀寫信號相接。若把閑置地址引腳接固定電平,則系統(tǒng)分配給CF卡的端口地址為[B000]~[B007]。INTRQ(即BSY/RDY)腳接到單片機的P1.7。

2 系統(tǒng)方案

2.1 硬件實現

系統(tǒng)采用模塊化設計,由電源控制單元(PU)、單片機控制單元、地址鎖存單元、數據緩沖單元以及存儲單元(CF卡)構成,如圖3所示。測試過程中,首先由單片機發(fā)送相關命令參數給手機,手機接收到命令后,經由串口輸出網絡數據。單片機將收到的數據通過緩沖器再送至CF卡。數據采集完畢后,將CF卡中的數據上傳至PC機,利用上位機分析軟件來進行網絡分析。在實際系統(tǒng)中,MCU選用的是AT89C52、由于單片機的P0口和P2口采用了引腳復用,所以需要一片地址鎖存,地址鎖存器選用的是74HC373、CF卡的一次讀寫操作必須是512字節(jié),而89C52只有256字節(jié)的內部RAM,需要在外部擴展一片緩沖器,緩沖器選用的是6116、由于系統(tǒng)是由手機電池統(tǒng)一供電,手機電池輸出電壓為+3.6V,而上述芯片的正常工作電壓為+5V,因此,需要升壓芯片作為電源模塊,選用的是MAX756。

2.2 軟件實現

2.2.1 CF卡的讀寫操作

CF卡采取的是類似硬盤的分塊存儲方式,分為柱面Cylinder、頭Head和扇區(qū)Sector管理。對96MB的CF卡而言,共有733個柱面,每個柱面8個頭,每個頭32個扇區(qū),每個扇區(qū)512字節(jié)(8位)。CF卡的讀寫是以一個扇區(qū)為基本單位的,在讀寫一個扇區(qū)之前先送出當前需要讀寫的柱面、頭和扇區(qū),然后發(fā)送讀寫命令,一個扇區(qū)的512字節(jié)需要一次性連續(xù)寫入或者讀出。下面給出對CF卡進行讀和寫C51程序段:

#define DataPort XBYTE[0xB800]

#define Feature XBYTE[0xB801]

#define SecCount XBYTE[0xB802]

#define SecNo XBYTE[0xB803]

#define CylLow XBYTE[0xB804]

#define CylHigh XBYTE[0xB805]

#define CardHead XBYTE[0xB806]

#define Command XBYTE[0xB807] //定義CF卡端口

void NextSector(){ //讀寫下一個扇區(qū)

sector++;

if(sector= =32){//一個頭的扇區(qū)是否全部讀寫完畢

sector=0;

head++;

if(head= =16){//一個柱面的所有頭是否全部讀寫完畢

head=0;

cylinder++;

if(cylinder= =733){//所有柱面是否全部讀寫完畢

cylinder--;

DiskFull=1;{//標志位置1,表示CF卡容易已滿讀寫過程結束

}

}

}

}

CardHead=0xA0+head; //置當前頭

SecCount=0x01; /*一次讀寫一個扇區(qū)

SecNo=sector; //置當前扇區(qū)

CylLow=cylinder%255; //置柱面高位

CylHigh=cylinder/255; //置柱面低位

Command=????; //讀/寫扇區(qū)命令,讀為0X20,寫為0x30

Delay(1); //延時1ms

//寫操作為:

for(i=1;i=512;i++){

DataPort=mem[0xE800+i]; //寫512字節(jié)

}

NextSector(); //為寫下一個扇區(qū)作準備讀操作為:

for(i=1;i=512;i++){

mem[0xE800+i]=DataPort; //讀512字節(jié)

}

NextSector(); //為讀下一個扇區(qū)作準備

2.2.2 緩沖區(qū)的操作

由于CF卡必須以扇區(qū)(512字節(jié))為基本單位來進行讀寫操作,因此,系統(tǒng)需要擴展一片6116作為寫緩沖區(qū)(地址口為0xE800開始)。系統(tǒng)在平時將收到的測試數據暫存于寫緩沖區(qū)中。當接收到的數據累計超過一個扇區(qū)之后,再傳送至CE卡。在實際系統(tǒng)中,開辟了1K的緩沖區(qū),通過一個標志位low和緩沖區(qū)指針count來聯合確定傳送數據的范圍。

①low=0,count=0。

 

 

②low=0,count=512、開始寫緩沖區(qū)的有512字節(jié),每寫入一個字節(jié),緩沖區(qū)指針自動加1。

③low=1,count>=512、當緩沖區(qū)指針大于512,表示前512字節(jié)已被填滿,此時將low置為1,開將緩沖區(qū)前512個字節(jié)的內容送入CF卡,標志位由0變?yōu)?。

④low=1,count=512。當緩沖區(qū)指針指到1024時,緩沖區(qū)指針清0,重新開始計數。此時將后512字節(jié)的內容送入CF卡,標志位由1變?yōu)?。

⑤low=0,count=512。下一次循環(huán)過程開始。

由于向CF卡寫入數據的同時,手機端仍然有數據輸出。為了防止在寫CF卡的過程中出現數據丟失現象,單片機手同端的通信采用串行口中斷方式。程序如下:

void single() interrupt 4 using 2//串行口中斷服務子程序,中斷號為4

{

if(RI= =1){ //判斷是否為單行口輸入引起的中斷

mem[0xe800+count]=SBUF; //將串行數據緩沖器中的數據送至數據緩沖區(qū)

count++; //緩沖區(qū)指針自動加1

if(count= =1024){ //如果緩沖區(qū)指針指向1024,則清0,重新計數

count=0;

}

RI=0; //串行口接收中斷請求標志位清0

}

else if(TI= =1){ //判斷是否為串行口輸出引起中斷

TI=0; //串行口發(fā)送中斷請求標志位清0

}

}

本文以移動通信的手機的背景,介紹了CF手機測試系統(tǒng)中的具體,包括其硬件開發(fā)和軟件實現。由于CF卡具高傳輸速率,大容量非易失性固態(tài)盤,掉電數據不丟失,良好的震性能,寬溫工作范圍與所有數碼相機、便攜式PC、數字式音頻播放器及其它具有Compact Flash插槽的設備兼容等特點,它的應用范圍也將越來越廣泛。



評論


相關推薦

技術專區(qū)

關閉