?? ch375hmi.c
字號:
led=0;
while ( 1 ) {
LED_OUT = led&1; /* LED閃爍 */
mDelaymS( 100 );
led^=1;
}
}
/* 為printf和getkey輸入輸出初始化串口 */
void mInitSTDIO( )
{
SCON = 0x50;
PCON = 0x80;
TMOD = 0x20;
TH1 = 0xf3; /* 24MHz晶振, 9600bps */
TR1 = 1;
TI = 1;
}
main( ) {
unsigned char i, c, SecCount;
unsigned long OldSize;
unsigned short NewSize, count;
LED_OUT = 0; /* 開機后LED亮一下以示工作 */
mDelaymS( 500 ); /* 延時500毫秒,CH375模塊上電后需要500毫秒左右的復(fù)位時間 */
LED_OUT = 1;
mInitSTDIO( );
printf( "Start\n" );
while ( 1 ) { /* 主循環(huán) */
printf( "Wait\n" );
while ( 1 ) { /* 使用查詢方式看U盤是否連接 */
i = ExecCommand( CMD_QueryStatus, 0 ); /* 查詢當(dāng)前模塊的狀態(tài) */
mStopIfError( i );
if ( mCmdParam.Status.mDiskStatus >= DISK_CONNECT ) break; /* U盤已經(jīng)連接 */
mDelaymS( 100 ); /* 可以在打算讀寫U盤時再查詢,沒有必要一直連續(xù)不停地查詢,可以讓單片機做其它事,沒事可做就延時等待一會再查詢 */
}
mDelaymS( 200 ); /* 延時,可選操作,有的USB存儲器需要幾十毫秒的延時 */
LED_OUT = 0; /* LED亮 */
/* 檢查U盤是否準(zhǔn)備好,大多數(shù)U盤不需要這一步,但是某些U盤必須要執(zhí)行這一步才能工作 */
for ( i = 0; i < 5; i ++ ) {
mDelaymS( 100 );
printf( "Ready ?\n" );
if ( ExecCommand( CMD_DiskReady, 0 ) == ERR_SUCCESS ) break; /* 查詢磁盤是否準(zhǔn)備好 */
}
/* 讀取原文件 */
printf( "Open\n" );
memcpy( mCmdParam.Open.mPathName, "\\C51\\CH375HFT.C", MAX_PATH_LEN ); /* 文件名,該文件在C51子目錄下 */
i = ExecCommand( CMD_FileOpen, MAX_PATH_LEN ); /* 打開文件,輸入?yún)?shù)置為最大值,省得再計算參數(shù)長度 */
if ( i == ERR_MISS_DIR || i == ERR_MISS_FILE ) { /* ERR_MISS_DIR說明沒有找到C51子目錄,ERR_MISS_FILE說明沒有找到文件 */
/* 列出根目錄下的文件 */
printf( "List file \\*\n" );
for ( c = 0; c < 255; c ++ ) { /* 最多搜索前255個文件 */
/* memcpy( mCmdParam.Enumer.mPathName, "\\C51\\CH375*", MAX_PATH_LEN );*/ /* 搜索C51子目錄下以CH375開頭的文件名,*為通配符 */
memcpy( mCmdParam.Enumer.mPathName, "\\*", MAX_PATH_LEN ); /* 搜索文件名,*為通配符,適用于所有文件或者子目錄 */
/* i = strlen( mCmdParam.Enumer.mPathName );*/ /* 計算文件名的長度 */
for ( i = 0; i < MAX_PATH_LEN - 1; i ++ ) if ( mCmdParam.Enumer.mPathName[ i ] == 0 ) break; /* 指向搜索文件名的結(jié)束符 */
mCmdParam.Enumer.mPathName[ i ] = c; /* 將結(jié)束符替換為搜索的序號,從0到255 */
i = ExecCommand( CMD_FileEnumer, i+1 ); /* 枚舉文件,如果文件名中含有通配符*,則為搜索文件而不打開,輸入?yún)?shù)的長度很好計算 */
if ( i == ERR_MISS_FILE ) break; /* 再也搜索不到匹配的文件,已經(jīng)沒有匹配的文件名 */
if ( i == ERR_SUCCESS || i == ERR_FOUND_NAME ) { /* 搜索到與通配符相匹配的文件名,文件名及其完整路徑在命令緩沖區(qū)中 */
printf( " match file %03d#: %s\n", (unsigned int)c, mCmdParam.Enumer.mPathName ); /* 顯示序號和搜索到的匹配文件名或者子目錄名 */
continue; /* 繼續(xù)搜索下一個匹配的文件名,下次搜索時序號會加1 */
}
else { /* 出錯 */
mStopIfError( i );
break;
}
}
strcpy( DATA_BUF, "Note: \n原本是打算將/C51/CH375HFT.C文件中的小寫字母轉(zhuǎn)成大寫后寫入新的文件,但是找不到這個文件\n" );
OldSize = 0;
NewSize = strlen( DATA_BUF ); /* 新文件的長度 */
SecCount = ( NewSize + 511 ) >> 9; /* (NewSize+511)/512, 計算文件的扇區(qū)數(shù),因為讀寫是以扇區(qū)為單位的 */
}
else { /* 找到文件\C51\CH375HFT.C或者出錯 */
mStopIfError( i );
printf( "Query\n" );
i = ExecCommand( CMD_FileQuery, 0 ); /* 查詢當(dāng)前文件的信息,沒有輸入?yún)?shù) */
mStopIfError( i );
printf( "Read\n" );
OldSize = mCmdParam.Modify.mFileSize; /* 原文件的長度 */
if ( OldSize > (unsigned long)(64*512) ) { /* 演示板用的62256只有32K字節(jié) */
SecCount = 64; /* 由于演示板用的62256只有32K字節(jié),所以只讀取不超過64個扇區(qū),也就是不超過32768字節(jié) */
NewSize = 64*512; /* 由于RAM有限所以限制長度 */
}
else { /* 如果原文件較小,那么使用原長度 */
SecCount = ( OldSize + 511 ) >> 9; /* (OldSize+511)/512, 計算文件的扇區(qū)數(shù),因為讀寫是以扇區(qū)為單位的 */
NewSize = (unsigned short)OldSize; /* 原長度 */
}
printf( "Size=%ld, Len=%d, Sec=%d\n", OldSize, NewSize, (unsigned short)SecCount );
mCmdParam.Read.mSectorCount = SecCount; /* 讀取全部數(shù)據(jù),如果超過60個扇區(qū)則只讀取60個扇區(qū) */
buffer = & DATA_BUF; /* 存放數(shù)據(jù)的緩沖區(qū)的起始地址,由CH375模塊中斷服務(wù)程序負責(zé)讀出數(shù)據(jù) */
i = ExecCommand( CMD_FileRead, 1 ); /* 從文件讀取數(shù)據(jù) */
mStopIfError( i );
/*
如果文件比較大,一次讀不完,可以再用命令CMD_FileRead繼續(xù)讀取,文件指針自動向后移動
while ( 剩余未讀完 ) {
mCmdParam.Read.mSectorCount = 32;
ExecCommand( CMD_FileRead, 1 ); 讀完后文件指針自動后移
TotalLength += 32*512; 累計文件總長度
}
如果希望從指定位置開始讀寫,可以移動文件指針
mCmdParam.Locate.mSectorOffset = 3; 跳過文件的前3個扇區(qū)開始讀寫
i = ExecCommand( CMD_FileLocate, 4 ); 輸入?yún)?shù)的長度4是sizeof( mCmdParam.Locate.mSectorOffset )
mCmdParam.Read.mSectorCount = 10;
ExecCommand( CMD_FileRead, 1 ); 直接讀取從文件的第(512*3)個字節(jié)開始的數(shù)據(jù),前3個扇區(qū)被跳過
如果希望將新數(shù)據(jù)添加到原文件的尾部,可以移動文件指針
i = ExecCommand( CMD_FileOpen, (unsigned char)( strlen( mCmdParam.Open.mPathName ) + 1 ) );
mCmdParam.Locate.mSectorOffset = 0xffffffff; 移到文件的尾部,以扇區(qū)為單位,如果原文件是3字節(jié),則從512字節(jié)開始添加
i = ExecCommand( CMD_FileLocate, sizeof( mCmdParam.Locate.mSectorOffset ) );
mCmdParam.Write.mSectorCount = 10;
ExecCommand( CMD_FileWrite, 1 ); 在原文件的后面添加數(shù)據(jù)
*/
printf( "Close\n" );
mCmdParam.Close.mUpdateLen = 0;
i = ExecCommand( CMD_FileClose, 1 ); /* 關(guān)閉文件 */
mStopIfError( i );
/* i = DATA_BUF[200];*/
/* DATA_BUF[200] = 0; 置字符串結(jié)束標(biāo)志,最多顯示200個字符 */
/* printf( "Line 1: %s\n", DATA_BUF );*/
/* DATA_BUF[200] = i; 恢復(fù)原字符 */
for ( count=0; count < NewSize; count ++ ) { /* 將文件中的小寫字符轉(zhuǎn)換為大寫 */
c = DATA_BUF[ count ];
if ( c >= 'a' && c <= 'z' ) DATA_BUF[ count ] = c - ( 'a' - 'A' );
}
}
/* 產(chǎn)生新文件 */
printf( "Create\n" );
/* memcpy( mCmdParam.Create.mPathName, "\\NEWFILE.TXT", MAX_PATH_LEN );*/
memcpy( mCmdParam.Create.mPathName, "\\雙擊我吧.TXT", MAX_PATH_LEN ); /* 新文件名,在根目錄下 */
i = ExecCommand( CMD_FileCreate, MAX_PATH_LEN ); /* 新建文件并打開,如果文件已經(jīng)存在則先刪除后再新建 */
mStopIfError( i );
printf( "Write\n" );
mCmdParam.Write.mSectorCount = 0x1; /* 寫入一個扇區(qū)512字節(jié) */
buffer = & DATA_BUF; /* 存放數(shù)據(jù)的緩沖區(qū)的起始地址,由CH375模塊中斷服務(wù)程序負責(zé)寫入數(shù)據(jù) */
i = ExecCommand( CMD_FileWrite, 1 ); /* 向文件寫入數(shù)據(jù) */
mStopIfError( i );
if ( SecCount > 1 ) { /* 因為數(shù)據(jù)不超過255個扇區(qū),所以完成能夠一次寫入,但是為了演示,特意分兩次寫入 */
mCmdParam.Write.mSectorCount = SecCount - 1;
/* buffer = & DATA_BUF + 512; 接著剛才的寫,不必設(shè)置緩沖區(qū)的起始地址 */
i = ExecCommand( CMD_FileWrite, 1 ); /* 向文件寫入數(shù)據(jù) */
mStopIfError( i );
}
printf( "Modify\n" );
mCmdParam.Modify.mFileAttr = 0xff; /* 輸入?yún)?shù): 新的文件屬性,為0FFH則不修改 */
mCmdParam.Modify.mFileTime = 0xffff; /* 輸入?yún)?shù): 新的文件時間,為0FFFFH則不修改,使用新建文件產(chǎn)生的默認時間 */
mCmdParam.Modify.mFileDate = ( (2004-1980)<<9 ) + ( 5<<5 ) + 18; /* 輸入?yún)?shù): 新的文件日期: 2004.05.18 */
mCmdParam.Modify.mFileSize = NewSize; /* 輸入?yún)?shù): 如果原文件較小,那么新的文件長度與原文件一樣長,否則被RAM所限 */
i = ExecCommand( CMD_FileModify, 4+2+2+1 ); /* 修改當(dāng)前文件的信息,修改日期和長度,參數(shù)長度為sizeof(mCmdParam.Modify.mFileSize)+... */
mStopIfError( i );
printf( "Close\n" );
mCmdParam.Close.mUpdateLen = 0; /* 不要自動計算文件長度,如果自動計算,那么該長度總是512的倍數(shù) */
i = ExecCommand( CMD_FileClose, 1 );
mStopIfError( i );
/* 刪除某文件 */
printf( "Erase\n" );
memcpy( mCmdParam.Create.mPathName, "\\OLD", MAX_PATH_LEN ); /* 將被刪除的文件名,在根目錄下 */
i = ExecCommand( CMD_FileErase, MAX_PATH_LEN ); /* 刪除文件并關(guān)閉 */
/* mStopIfError( i );*/
/* 查詢磁盤信息 */
/* printf( "Disk\n" );
i = ExecCommand( CMD_DiskQuery, 0 );
mStopIfError( i );
i = mCmdParam.Query.mDiskFat;
if ( i == 1 ) i = 12;
else if ( i == 2 ) i = 16;
else if ( i == 3 ) i = 32;
printf( "FatCode=FAT%d, TotalSector=%ld, FreeSector=%ld\n", (unsigned short)i, mCmdParam.Query.mTotalSector, mCmdParam.Query.mFreeSector );*/
/* 等待U盤斷開 */
printf( "Take_out\n" );
while ( 1 ) { /* 使用查詢方式看U盤是否斷開 */
i = ExecCommand( CMD_QueryStatus, 0 ); /* 查詢當(dāng)前模塊的狀態(tài) */
mStopIfError( i );
if ( mCmdParam.Status.mDiskStatus <= DISK_DISCONNECT ) break; /* U盤已經(jīng)斷開 */
mDelaymS( 100 ); /* 沒有必要一直連續(xù)不停地查詢,可以讓單片機做其它事,沒事可做就延時等待一會再查詢 */
}
LED_OUT = 1; /* LED滅 */
}
}
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -