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