ch375讀寫u盤的奇怪問題

用2407搭配ch375,將程序燒寫到flash中后斷電,家電,讀寫u盤正常,斷電再加電,程序就不正常了,出現(xiàn)莫名奇妙的問題。不是初始化375不過,就是打開文件或創(chuàng)建文件錯誤。重新燒寫后,又是同樣的問題。頭疼中


熱門產(chǎn)品 : USB3.0 HUB控制器:CH634

不用頭疼,第一次成功,至少說明軟硬件基本上都沒什么問題。 (1)第二次運行時,哪步出錯,出錯代碼是什么? (2)試試第一次操作完,等待時間長一點,再上電看看是否可行


最多的是打開文件或者創(chuàng)建新文件是出錯,返回代碼是2,就是參數(shù)錯誤。我查了下,好像是存文件名的數(shù)組中的內(nèi)容不對,是亂碼。


問題不是找到么!文件名的數(shù)組中的內(nèi)容不對,打開或創(chuàng)建文件自然是出錯了。 應(yīng)重點分析一下文件名的數(shù)組中的內(nèi)容為何不對,文件名的賦值是否正確,文件名緩沖區(qū)是否有問題呢?


strcpy(fat_cmd.create.buffer,"\\TEST.TXT"); sts4=fat_fcreate(F_CREATE_NEW); 這就是我的文件名賦值,fat_cmd.create.buffer是fat.h中定義的。而且第一次運行沒問題啊。


好像第二次運行時,strcpy函數(shù)總出錯,誰知道是什么問題啊,我改成這樣 strcpy(filename,"\\TEST.TXT"); strcpy(fat_cmd.create.buffer,filename); sts4=fat_fcreate(F_CREATE_NEW); 第一次運行沒問題,第二次運行時,filename中的內(nèi)容就變成亂碼了。我用的是2407,怎么回事啊。


如果strcpy函數(shù)有問題,您干脆直接手動賦值試試,如: fat_cmd.create.buffer[ 0 ] = '\\'; fat_cmd.create.buffer[ 1 ] = 'T'; fat_cmd.create.buffer[ 2 ] = 'E'; fat_cmd.create.buffer[ 3 ] = 'S'; fat_cmd.create.buffer[ 4 ] = 'T'; fat_cmd.create.buffer[ 5 ] = '.'; fat_cmd.create.buffer[ 6 ] = 'T'; fat_cmd.create.buffer[ 7 ] = 'X'; fat_cmd.create.buffer[ 8 ] = 'T'; fat_cmd.create.buffer[ 9 ] = 0;


還是不對,是不是ram不夠啊


fat_cmd.create.buffer[&nbsp0 ] = '\\'; fat_cmd.create.buffer[&nbsp1 ] = 'T'; fat_cmd.create.buffer[&nbsp2 ] = 'E'; fat_cmd.create.buffer[&nbsp3 ] = 'S'; fat_cmd.create.buffer[&nbsp4 ] = 'T'; fat_cmd.create.buffer[&nbsp5 ] = '.'; fat_cmd.create.buffer[&nbsp6 ] = 'T'; fat_cmd.create.buffer[&nbsp7 ] = 'X'; fat_cmd.create.buffer[&nbsp8 ] = 'T'; fat_cmd.create.buffer[&nbsp9 ] =&nbsp0; 這樣改了后,打開文件沒問題了,但是完txt文件中寫數(shù),還是要用到strcpy函數(shù)啊,2407還不支持sprintf函數(shù) ,怎么辦啊


照您的說法,那么與我們提供給您的文件系統(tǒng)沒關(guān)系了,且與2407芯片也沒關(guān)系,主要原因在于您所用的編譯器了,只能咨詢編譯器的技術(shù)支持了,其實您也可以自己寫一個類似于strcpy的函數(shù),如: UINT8 mCopyString( UINT8 *iDestination, UINT8 *iSource ) { UINT8 i = 0; while ( *iDestination = *iSource ) { iDestination ++; iSource ++; i ++; } return( i ); }


只有登錄才能回復(fù),可以選擇微信賬號登錄

国产91精品新入口,国产成人综合网在线播放,九热这里只有精品,本道在线观看,美女视频a美女视频,韩国美女激情视频,日本美女pvp视频