?? ch375hft.c
字號:
for ( c = 0; c < 255; c ++ ) { /* 最多搜索前255個(gè)文件 */
i = mCopyCodeStringToIRAM( mCmdParam.Open.mPathName, pCodeStr ); /* 搜索文件名,*為通配符,適用于所有文件或者子目錄 */
mCmdParam.Open.mPathName[ i ] = c; /* 根據(jù)字符串長度將結(jié)束符替換為搜索的序號,從0到255 */
i = CH375FileOpen( ); /* 打開文件,如果文件名中含有通配符*,則為搜索文件而不打開 */
if ( i == ERR_MISS_FILE ) break; /* 再也搜索不到匹配的文件,已經(jīng)沒有匹配的文件名 */
if ( i == ERR_FOUND_NAME ) { /* 搜索到與通配符相匹配的文件名,文件名及其完整路徑在命令緩沖區(qū)中 */
printf( " match file %03d#: %s\n", (unsigned int)c, mCmdParam.Open.mPathName ); /* 顯示序號和搜索到的匹配文件名或者子目錄名 */
continue; /* 繼續(xù)搜索下一個(gè)匹配的文件名,下次搜索時(shí)序號會加1 */
}
else { /* 出錯(cuò) */
mStopIfError( i );
break;
}
}
}
else { /* 找到文件或者出錯(cuò) */
mStopIfError( i );
/* printf( "Query\n" );
i = CH375FileQuery( ); 查詢當(dāng)前文件的信息
mStopIfError( i );*/
printf( "Read\n" );
if ( CH375vFileSize > CH375vSectorSize * 3 ) { /* 由于用單片機(jī)內(nèi)置的1KB外部RAM演示,每次只能讀取一個(gè)扇區(qū),假定演示讀取最多3個(gè)扇區(qū) */
SecCount = 3; /* 演示讀取最多3個(gè)扇區(qū), 分3次, 每次讀取一個(gè)扇區(qū)并處理 */
NewSize = CH375vSectorSize * 3;
}
else { /* 如果原文件較小,那么使用原長度 */
SecCount = ( CH375vFileSize + CH375vSectorSize - 1 ) / CH375vSectorSize; /* 計(jì)算文件的扇區(qū)數(shù),因?yàn)樽x寫是以扇區(qū)為單位的,先加CH375vSectorSize-1是為了讀出文件尾部不足1個(gè)扇區(qū)的部分 */
NewSize = (UINT16)CH375vFileSize; /* 原文件的長度 */
}
printf( "Size=%ld, Len=%d, Sec=%d\n", CH375vFileSize, NewSize, (UINT16)SecCount );
CH375vFileSize += CH375vSectorSize -1 ; /* 默認(rèn)情況下,以扇區(qū)方式讀取數(shù)據(jù)時(shí),無法讀出文件尾部不足1個(gè)扇區(qū)的部分,所以必須臨時(shí)加大文件長度以讀取尾部零頭 */
while( SecCount ) { /* 分多次讀取文件數(shù)據(jù) */
mCmdParam.Read.mSectorCount = 1; /* 由于RAM緩沖區(qū)有限,所以只讀取1個(gè)數(shù)據(jù) */
/* current_buffer = & FILE_DATA_BUF[0]; 如果文件讀寫的數(shù)據(jù)的復(fù)制方式為"外部子程序",那么需要設(shè)置存放數(shù)據(jù)的緩沖區(qū)的起始地址 */
i = CH375FileRead( ); /* 從文件讀取數(shù)據(jù) */
mStopIfError( i );
CH375DirtyBuffer( ); /* 因?yàn)槲募x寫緩沖區(qū)與磁盤數(shù)據(jù)緩沖區(qū)重疊,所以在CH375FileRead讀文件后和在CH375FileWrite寫文件前必須清除磁盤緩沖區(qū) */
i = FILE_DATA_BUF[100];
FILE_DATA_BUF[100] = 0; /* 置字符串結(jié)束標(biāo)志,最多顯示100個(gè)字符 */
printf( "Line 1: %s\n", FILE_DATA_BUF ); /* 用顯示數(shù)據(jù)代替對數(shù)據(jù)的處理 */
FILE_DATA_BUF[100] = i; /* 恢復(fù)原字符 */
SecCount --;
}
CH375vFileSize -= CH375vSectorSize - 1; /* 恢復(fù)原文件長度 */
/*
如果文件比較大,一次讀不完,可以再調(diào)用CH375FileRead繼續(xù)讀取,文件指針自動向后移動
while ( 1 ) {
mCmdParam.Read.mSectorCount = 1; 指定讀取的扇區(qū)數(shù)
CH375FileRead(); 讀完后文件指針自動后移
CH375DirtyBuffer( ); 因?yàn)槲募x寫緩沖區(qū)與磁盤數(shù)據(jù)緩沖區(qū)重疊,所以在CH375FileRead讀文件后和在CH375FileWrite寫文件前必須清除磁盤緩沖區(qū)
處理已讀出的CH375vSectorSize字節(jié)數(shù)據(jù),完成后繼續(xù)讀取下一個(gè)扇區(qū)
if ( mCmdParam.Read.mSectorCount != 1 ) break; 實(shí)際讀出的扇區(qū)數(shù)較小則說明文件已經(jīng)結(jié)束
}
如果希望從指定位置開始讀寫,可以移動文件指針
mCmdParam.Locate.mSectorOffset = 3; 跳過文件的前3個(gè)扇區(qū)開始讀寫
i = CH375FileLocate( );
mCmdParam.Read.mSectorCount = 1;
CH375FileRead(); 直接讀取從文件的第(CH375vSectorSize*3)個(gè)字節(jié)開始的數(shù)據(jù),前3個(gè)扇區(qū)被跳過
CH375DirtyBuffer( ); 因?yàn)槲募x寫緩沖區(qū)與磁盤數(shù)據(jù)緩沖區(qū)重疊,所以在CH375FileRead讀文件后和在CH375FileWrite寫文件前必須清除磁盤緩沖區(qū)
如果希望將新數(shù)據(jù)添加到原文件的尾部,可以移動文件指針
CH375FileOpen( );
CH375FileQuery( );
OldSize = mCmdParam.Modify.mFileSize;
mCmdParam.Locate.mSectorOffset = 0xffffffff; 移到文件的尾部,以扇區(qū)為單位,如果原文件是3字節(jié),則從CH375vSectorSize字節(jié)開始添加
CH375FileLocate( );
for ( i=0; i!=新增扇區(qū)數(shù); i++ ) { 為了申請文件空間而寫入無效數(shù)據(jù)
mCmdParam.Write.mSectorCount = 1;
CH375FileWrite( );
}
mCmdParam.Locate.mSectorOffset = (OldSize+CH375vSectorSize-1)/CH375vSectorSize; 移到文件的原尾部,以扇區(qū)為單位,如果原文件是3字節(jié),則從CH375vSectorSize字節(jié)開始添加
CH375FileLocate( );
for ( i=0; i!=新增扇區(qū)數(shù); i++ ) { 分多次寫入真正的文件數(shù)據(jù)
CH375DirtyBuffer( ); 因?yàn)槲募x寫緩沖區(qū)與磁盤數(shù)據(jù)緩沖區(qū)重疊,所以在CH375FileRead讀文件后和在CH375FileWrite寫文件前必須清除磁盤緩沖區(qū)
將準(zhǔn)備寫入文件的數(shù)據(jù)復(fù)制到文件數(shù)據(jù)緩沖區(qū),如果文件數(shù)據(jù)復(fù)制方式為"外部子程序",那么可以由xReadFromExtBuf將數(shù)據(jù)直接送給CH375芯片而不經(jīng)過文件數(shù)據(jù)緩沖區(qū)
mCmdParam.Write.mSectorCount = 1;
CH375FileWrite(); 在原文件的后面添加數(shù)據(jù)
}
*/
printf( "Close\n" );
i = CH375FileClose( ); /* 關(guān)閉文件 */
mStopIfError( i );
}
#ifdef EN_DISK_WRITE /* 子程序庫支持寫操作 */
/* 產(chǎn)生新文件 */
LED_WR_ACT( ); /* 寫操作 */
NewSize = CH375vSectorSize * 4; /* 新文件的長度 */
SecCount = 4; /* (NewSize+CH375vSectorSize-1)/CH375vSectorSize, 計(jì)算文件的扇區(qū)數(shù),因?yàn)樽x寫是以扇區(qū)為單位的 */
printf( "Create\n" );
mCopyCodeStringToIRAM( mCmdParam.Create.mPathName, "\\程序空間.BIN" ); /* 新文件名,在根目錄下,中文文件名 */
i = CH375FileCreate( ); /* 新建文件并打開,如果文件已經(jīng)存在則先刪除后再新建 */
mStopIfError( i );
printf( "PreWrite\n" );
/* 新建文件的長度為1, 占用一個(gè)簇, 如果后面準(zhǔn)備寫入的數(shù)據(jù)總長度超過一個(gè)簇, 就需要在CH375FileWrite過程中自動申請文件空間,
而申請文件空間的過程需要用到磁盤數(shù)據(jù)緩沖區(qū), 由于本例中RAM太少使磁盤數(shù)據(jù)緩沖區(qū)與文件數(shù)據(jù)緩沖區(qū)合用,
所以CH375FileWrite過程中自動申請文件空間會導(dǎo)致文件數(shù)據(jù)緩沖區(qū)中的數(shù)據(jù)無效, 所以實(shí)際上這個(gè)時(shí)候?qū)懭氲臄?shù)據(jù)沒有意義,
如果事先知道后續(xù)數(shù)據(jù)的總長度不超過一個(gè)簇(簇在Windows中稱為"分配單元"的大小), 那么可以跳過這個(gè)為了申請文件空間而寫入無效數(shù)據(jù)的步驟 */
for ( i = 0; i != SecCount; i ++ ) {
mCmdParam.Write.mSectorCount = 1; /* 寫入1個(gè)扇區(qū)的數(shù)據(jù) */
/* current_buffer = & FILE_DATA_BUF[0]; 如果文件讀寫的數(shù)據(jù)的復(fù)制方式為"外部子程序",那么需要設(shè)置存放數(shù)據(jù)的緩沖區(qū)的起始地址 */
mStopIfError( CH375FileWrite( ) ); /* 向文件寫入數(shù)據(jù),只是為了申請文件空間,實(shí)際寫入的數(shù)據(jù)沒有意義 */
}
printf( "Locate head\n" );
mCmdParam.Locate.mSectorOffset = 0; /* 因?yàn)榍懊嫔暾埼募臻g使文件指針處于尾部,所以在寫入真正的數(shù)據(jù)前需要將文件指針回到頭部 */
i = CH375FileLocate( ); /* 移動文件指針到文件頭部 */
mStopIfError( i );
printf( "Write\n" );
pCodeStr = 0; /* 從程序空間的起始地址開始取數(shù)據(jù) */
while( SecCount ) { /* 分多次寫入真正的文件數(shù)據(jù) */
CH375DirtyBuffer( ); /* 因?yàn)槲募x寫緩沖區(qū)與磁盤數(shù)據(jù)緩沖區(qū)重疊,所以在CH375FileRead讀文件后和在CH375FileWrite寫文件前必須清除磁盤緩沖區(qū) */
/* 將準(zhǔn)備寫入文件的數(shù)據(jù)復(fù)制到文件數(shù)據(jù)緩沖區(qū),如果文件數(shù)據(jù)復(fù)制方式為"外部子程序",
那么可以由自己定義的"外部子程序"xReadFromExtBuf將數(shù)據(jù)直接送給CH375芯片而不經(jīng)過文件數(shù)據(jù)緩沖區(qū),該子程序被CH375FileWrite子程序調(diào)用 */
for ( count = 0; count != CH375vSectorSize; count ++ ) { /* 本例是將程序空間的數(shù)據(jù)復(fù)制到文件數(shù)據(jù)緩沖區(qū)再寫入文件 */
FILE_DATA_BUF[ count ] = *pCodeStr; /* 實(shí)際應(yīng)用中,數(shù)據(jù)可以來自外部ADC或者日志數(shù)據(jù) */
pCodeStr ++;
}
mCmdParam.Write.mSectorCount = 1; /* 寫入1個(gè)扇區(qū)的數(shù)據(jù) */
/* current_buffer = & FILE_DATA_BUF[0]; 如果文件讀寫的數(shù)據(jù)的復(fù)制方式為"外部子程序",那么需要設(shè)置存放數(shù)據(jù)的緩沖區(qū)的起始地址 */
i = CH375FileWrite( ); /* 向文件寫入數(shù)據(jù) */
mStopIfError( i );
SecCount --;
}
/* printf( "Modify\n" );
mCmdParam.Modify.mFileAttr = 0xff; 輸入?yún)?shù): 新的文件屬性,為0FFH則不修改
mCmdParam.Modify.mFileTime = 0xffff; 輸入?yún)?shù): 新的文件時(shí)間,為0FFFFH則不修改,使用新建文件產(chǎn)生的默認(rèn)時(shí)間
mCmdParam.Modify.mFileDate = MAKE_FILE_DATE( 2004, 5, 18 ); 輸入?yún)?shù): 新的文件日期: 2004.05.18
mCmdParam.Modify.mFileSize = NewSize; 輸入?yún)?shù): 如果原文件較小,那么新的文件長度與原文件一樣長,否則被RAM所限,如果文件長度大于64KB,那么NewSize必須為UINT32
i = CH375FileModify( ); 修改當(dāng)前文件的信息,修改日期和長度
mStopIfError( i );
*/
printf( "Close\n" );
mCmdParam.Close.mUpdateLen = 1; /* 自動計(jì)算文件長度,如果自動計(jì)算,那么該長度總是CH375vSectorSize的倍數(shù) */
i = CH375FileClose( );
mStopIfError( i );
/* 刪除某文件 */
/* printf( "Erase\n" );
mCopyCodeStringToIRAM( mCmdParam.Create.mPathName, "\\OLD" ); 將被刪除的文件名,在根目錄下
i = CH375FileErase( ); 刪除文件并關(guān)閉
if ( i != ERR_SUCCESS ) printf( "Error: %02X\n", (UINT16)i ); 顯示錯(cuò)誤
*/
LED_WR_INACT( );
/* 查詢磁盤信息 */
/* printf( "Disk\n" );
i = CH375DiskQuery( );
mStopIfError( i );
printf( "Fat=%d, Total=%ld, Free=%ld\n", (UINT16)mCmdParam.Query.mDiskFat, mCmdParam.Query.mTotalSector, mCmdParam.Query.mFreeSector );
*/
#endif
LED_RUN_INACT( );
printf( "Take out\n" );
while ( CH375DiskStatus != DISK_DISCONNECT ) xQueryInterrupt( ); /* 查詢CH375中斷并更新中斷狀態(tài),等待U盤拔出 */
LED_OUT_INACT( ); /* LED滅 */
mDelay100mS( );
mDelay100mS( );
}
}
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -