CH375b并口查詢 一直無法連接成功 !錯誤 80 或FF 是什么錯誤啊

電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# P2.4 = A0 P2.6= INT#

程序如下:#include #include #include #include

#define MAX_PATH_LEN 32 /* 最大路徑長度,含所有斜杠分隔符和小數(shù)點間隔符以及路徑結束符00H,CH375模塊支持的最大值是64,最小值是13 */ #include "CH375HM.H"

/* 電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# 如果沒有外部RAM,那么CS#=P26,如果有超過16KB的外部RAM,那么CS#=P27 & ! P26 & ...,所以CS#的片選地址為BXXXH P2.4 = A0 p2.6= INT# 雖然連接到INT0,但是本程序只是查詢模塊的INT#的狀態(tài),所以可以用P1口等普通I/O引腳代替INT0 說明 沒有外界RAM 使用STC89C58RD

*/ sbit INT = P2^6; sbit P1_0 = P1^0; #define CH375HM_INDEX XBYTE[0x60F0] /* CH375模塊的索引端口的I/O地址 */ #define CH375HM_DATA XBYTE[0x70F1] /* CH375模塊的數(shù)據(jù)端口的I/O地址 */ #define CH375HM_INT_WIRE INT /* 假定CH375模塊的INT#引腳連接到單片機的INT0引腳 */

/* 假定文件數(shù)據(jù)緩沖區(qū): ExtRAM: 0000H-7FFFH */ unsigned char xdata DATA_BUF[ 512 * 64 ] _at_ 0x0000; /* 外部RAM的文件數(shù)據(jù)緩沖區(qū),從該單元開始的緩沖區(qū)長度不小于一次讀寫的數(shù)據(jù)長度,最少為512字節(jié) */

CMD_PARAM mCmdParam; /* 默認情況下該結構將占用64字節(jié)的RAM,可以修改MAX_PATH_LEN常量,當修改為32時,只占用32字節(jié)的RAM */ unsigned char mIntStatus; /* CH375模塊的中斷狀態(tài)或者操作完成狀態(tài) */

sbit LED_OUT = P1^4; /* P1.4 低電平驅動LED顯示,用于監(jiān)控演示程序的進度 */

/* 對于模擬的并口讀寫時序或者其它并口讀寫方式,請修改以下3個子程序 */ #define CH375HM_INDEX_WR( Index ) { CH375HM_INDEX = (Index); } /* 寫索引地址 */ #define CH375HM_DATA_WR( Data ) { CH375HM_DATA = (Data); } /* 寫數(shù)據(jù) */ #define CH375HM_DATA_RD( ) ( CH375HM_DATA ) /* 讀數(shù)據(jù) */

/* 以毫秒為單位延時,適用于24MHz時鐘 */ void mDelaymS( unsigned char delay ) { unsigned char i, j, c; for ( i = delay; i != 0; i -- ) { for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz時鐘下延時500uS */ for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz時鐘下延時500uS */ } } 以后的和例子一樣??! 接U盤 一直提示 錯誤 80 或FF 是什么錯誤啊

INT#引腳不能接P2。6,建議接P1口上面在做測試


/* 電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# 如果沒有外部RAM,那么CS#=P26,如果有超過16KB的外部RAM,那么CS#=P27 & ! P26 & ...,所以CS#的片選地址為BXXXH P2.4 = A0 p1.3 =INT# 雖然連接到INT0,但是本程序只是查詢模塊的INT#的狀態(tài),所以可以用P1口等普通I/O引腳代替INT0 */ sbit INT = P1^3; sbit P1_0 = P1^0; #define CH375HM_INDEX XBYTE[0x60f0] /* CH375模塊的索引端口的I/O地址 */ #define CH375HM_DATA XBYTE[0x70f1] /* CH375模塊的數(shù)據(jù)端口的I/O地址 */ #define CH375HM_INT_WIRE INT

/* 假定文件數(shù)據(jù)緩沖區(qū): ExtRAM: 0000H-7FFFH */ unsigned char xdata DATA_BUF[ 512 * 64 ] _at_ 0x0000; /* 外部RAM的文件數(shù)據(jù)緩沖區(qū),從該單元開始的緩沖區(qū)長度不小于一次讀寫的數(shù)據(jù)長度,最少為512字節(jié) */

CMD_PARAM mCmdParam; /* 默認情況下該結構將占用64字節(jié)的RAM,可以修改MAX_PATH_LEN常量,當修改為32時,只占用32字節(jié)的RAM */ unsigned char mIntStatus; /* CH375模塊的中斷狀態(tài)或者操作完成狀態(tài) */

sbit LED_OUT = P1^4; /* P1.4 低電平驅動LED顯示,用于監(jiān)控演示程序的進度 */

問題還是一樣的。串口受到Start Wait Udisk后 一直沒有變化。CH375B 24腳接LED 燈沒有亮 !


全部的的程序

/* 2004.06.05 **************************************** ** Copyright (C) W.ch 1999-2007 ** ** Web: http://www.winchiphead.com ** **************************************** ** USB Host File Module @CH375 ** ** TC2.0@PC, KC7.0@MCS51 ** **************************************** */ /* U盤文件讀寫模塊, 連接方式: 并口+查詢 */ /* MCS-51單片機C語言示例程序, 僅適用于V3.0A及以上版本的模塊 */ /* 因為使用U盤文件讀寫模塊而不是使用U盤文件級子程序庫,所以占用較少的單片機資源,可以使用89C51單片機測試 */

#include #include #include #include

#define MAX_PATH_LEN 32 /* 最大路徑長度,含所有斜杠分隔符和小數(shù)點間隔符以及路徑結束符00H,CH375模塊支持的最大值是64,最小值是13 */ #include "CH375HM.H"

/* 電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# P2.4 = A0 p1.3 =INT# 雖然連接到INT0,但是本程序只是查詢模塊的INT#的狀態(tài),所以可以用P1口等普通I/O引腳代替INT0 */ sbit INT = P1^3; sbit P1_0 = P1^0; #define CH375HM_INDEX XBYTE[0x60f0] /* CH375模塊的索引端口的I/O地址 */ #define CH375HM_DATA XBYTE[0x70f1] /* CH375模塊的數(shù)據(jù)端口的I/O地址 */ #define CH375HM_INT_WIRE INT /* 假定CH375模塊的INT#引腳連接到單片機的INT0引腳 */

/* 假定文件數(shù)據(jù)緩沖區(qū): ExtRAM: 0000H-7FFFH */ unsigned char xdata DATA_BUF[ 512 * 64 ] _at_ 0x0000; /* 外部RAM的文件數(shù)據(jù)緩沖區(qū),從該單元開始的緩沖區(qū)長度不小于一次讀寫的數(shù)據(jù)長度,最少為512字節(jié) */

CMD_PARAM mCmdParam; /* 默認情況下該結構將占用64字節(jié)的RAM,可以修改MAX_PATH_LEN常量,當修改為32時,只占用32字節(jié)的RAM */ unsigned char mIntStatus; /* CH375模塊的中斷狀態(tài)或者操作完成狀態(tài) */

sbit LED_OUT = P1^4; /* P1.4 低電平驅動LED顯示,用于監(jiān)控演示程序的進度 */

/* 對于模擬的并口讀寫時序或者其它并口讀寫方式,請修改以下3個子程序 */ #define CH375HM_INDEX_WR( Index ) { CH375HM_INDEX = (Index); } /* 寫索引地址 */ #define CH375HM_DATA_WR( Data ) { CH375HM_DATA = (Data); } /* 寫數(shù)據(jù) */ #define CH375HM_DATA_RD( ) ( CH375HM_DATA ) /* 讀數(shù)據(jù) */

/* 以毫秒為單位延時,適用于24MHz時鐘 */ void mDelaymS( unsigned char delay ) { unsigned char i, j, c; for ( i = delay; i != 0; i -- ) { for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz時鐘下延時500uS */ for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz時鐘下延時500uS */ } }

/* 執(zhí)行命令 */ unsigned char ExecCommandBuf( unsigned char cmd, unsigned char len, unsigned char xdata *bufstart ) /* 輸入命令碼和輸入?yún)?shù)長度,返回操作狀態(tài)碼,輸入?yún)?shù)和返回參數(shù)都在CMD_PARAM結構中 */ /* 輸入?yún)?shù)bufstart僅用于CMD_FileRead或者CMD_FileWrite命令,指定外部RAM緩沖區(qū)的起始地址,可以參考中斷方式C程序采用全局變量buffer的方式 */ { unsigned char i, status; unsigned char data *buf; unsigned char xdata *CurrentBuf; CH375HM_INDEX_WR( PARA_COMMAND_ADDR ); CH375HM_DATA_WR( cmd ); /* 向索引地址PARA_COMMAND_ADDR寫入命令碼 */ if ( len ) { /* 有參數(shù) */ i = len; CH375HM_INDEX_WR( PARA_BUFFER_ADDR ); /* 指向緩沖區(qū) */ buf = (unsigned char *)&mCmdParam; /* 指向輸入?yún)?shù)的起始地址 */ do { CH375HM_DATA_WR( *buf ); /* 從索引地址PARA_BUFFER_ADDR開始,寫入?yún)?shù) */ buf ++; } while ( -- i ); } CH375HM_INDEX_WR( PARA_CMD_LEN_ADDR ); CH375HM_DATA_WR( len | PARA_CMD_BIT_ACT ); /* 向索引地址PARA_CMD_LEN_ADDR寫入后續(xù)參數(shù)的長度,最高位通知模塊,說明命令包已經(jīng)寫入,請求開始執(zhí)行命令 */ CurrentBuf = bufstart; /* 外部RAM緩沖區(qū)起始地址,僅用于FileRead或者FileWrite命令 */ while ( 1 ) { /* 處理數(shù)據(jù)傳輸,直到操作完成才退出 */

#if 1 while ( CH375HM_INT_WIRE ); /* 等待模塊完成操作產(chǎn)生低電平中斷,最佳檢測方式是對模塊的INT#信號進行下降沿邊沿檢測 */ #else do { /* 如果不需要扇區(qū)方式讀寫,那么可以查詢模塊的命令碼單元代替查詢模塊INT#引腳 */ CH375HM_INDEX_WR( PARA_COMMAND_ADDR ); } while ( CH375HM_DATA_RD( ) ); /* 模塊操作完成時該值會清0,僅適用于非扇區(qū)方式讀寫 */ #endif

CH375HM_INDEX_WR( PARA_STATUS_ADDR ); /* 寫入索引地址 */ status = CH375HM_DATA_RD( ); /* 從索引地址PARA_STATUS_ADDR讀取中斷狀態(tài) */ CH375HM_INDEX_WR( PARA_CMD_LEN_ADDR ); CH375HM_DATA_WR( PARA_CMD_BIT_INACT ); /* 中斷應答,取消來自模塊的中斷請求 */ /* 因為模塊在收到中斷應答后3uS之內才撤消中斷請求,所以,如果是查詢INT#信號的低電平,那么在發(fā)出中斷應答后3uS之內不應該再查詢INT#信號的狀態(tài) 但是由于51單片機較慢,下面的處理時間已經(jīng)超過3uS,所以不必另加延時等待模塊撤消中斷請求 */ if ( status == ERR_SUCCESS ) { /* 操作成功 */ CH375HM_INDEX_WR( PARA_STS_LEN_ADDR ); i = CH375HM_DATA_RD( ); /* 從索引地址PARA_STS_LEN_ADDR讀取返回結果數(shù)據(jù)的長度,計數(shù) */ if ( i ) { /* 有結果數(shù)據(jù) */ CH375HM_INDEX_WR( PARA_BUFFER_ADDR ); /* 指向緩沖區(qū) */ buf = (unsigned char *)&mCmdParam; /* 指向輸出參數(shù)的起始地址 */ do { *buf = CH375HM_DATA_RD( ); /* 從索引地址PARA_BUFFER_ADDR開始,讀取結果 */ buf ++; } while ( -- i ); } // status = ERR_SUCCESS; break; /* 操作成功返回 */ } else if ( status == USB_INT_DISK_READ ) { /* 正在從U盤讀數(shù)據(jù)塊,請求數(shù)據(jù)讀出 */ CH375HM_INDEX_WR( PARA_BUFFER_ADDR ); /* 指向緩沖區(qū) */ i = 64; /* 計數(shù) */ do { /* 要提高文件數(shù)據(jù)讀寫速度,這段程序用匯編程序效率更高,在C51中,do+while比for或者while結構效率高 */ *CurrentBuf = CH375HM_DATA_RD( ); /* 從索引地址0到63依次讀出64字節(jié)的數(shù)據(jù) */ CurrentBuf ++; /* 讀取的數(shù)據(jù)保存到外部緩沖區(qū) */ } while ( -- i ); /* 上面這一小段C程序用匯編程序效率要高近一倍 */ CH375HM_INDEX_WR( PARA_CMD_LEN_ADDR ); CH375HM_DATA_WR( PARA_CMD_BIT_ACT ); /* 通知模塊繼續(xù),說明64字節(jié)數(shù)據(jù)已經(jīng)讀取完成 */ } else if ( status == USB_INT_DISK_WRITE ) { /* 正在向U盤寫數(shù)據(jù)塊,請求數(shù)據(jù)寫入 */ CH375HM_INDEX_WR( PARA_BUFFER_ADDR ); /* 指向緩沖區(qū) */ i = 64; /* 計數(shù) */ do { CH375HM_DATA_WR( *CurrentBuf ); /* 向索引地址0到63依次寫入64字節(jié)的數(shù)據(jù) */ CurrentBuf ++; /* 寫入的數(shù)據(jù)來自外部緩沖區(qū) */ } while ( -- i ); CH375HM_INDEX_WR( PARA_CMD_LEN_ADDR ); CH375HM_DATA_WR( PARA_CMD_BIT_ACT ); /* 通知模塊繼續(xù),說明64字節(jié)數(shù)據(jù)已經(jīng)寫入完成 */ } else if ( status == USB_INT_DISK_RETRY ) { /* 讀寫數(shù)據(jù)塊失敗重試,應該向回修改緩沖區(qū)指針 */ CH375HM_INDEX_WR( PARA_BUFFER_ADDR ); /* 指向緩沖區(qū) */ i = CH375HM_DATA_RD( ); /* 大端模式下為回改指針字節(jié)數(shù)的高8位,如果是小端模式那么接收到的是回改指針字節(jié)數(shù)的低8位 */ status = CH375HM_DATA_RD( ); /* 大端模式下為回改指針字節(jié)數(shù)的低8位,如果是小端模式那么接收到的是回改指針字節(jié)數(shù)的高8位 */ CurrentBuf -= ( (unsigned short)i << 8 ) + status; /* 這是大端模式下的回改指針,對于小端模式,應該是( (unsigned short)status << 8 ) + i */ CH375HM_INDEX_WR( PARA_CMD_LEN_ADDR ); CH375HM_DATA_WR( PARA_CMD_BIT_ACT ); /* 通知模塊繼續(xù),說明重試狀態(tài)碼已經(jīng)處理完成 */ } else { /* 操作失敗 */ if ( status == ERR_DISK_DISCON || status == ERR_USB_CONNECT ) { /* U盤剛剛連接或者斷開,應該延時幾十毫秒再操作 */ mDelaymS( 100 ); if ( CH375HM_INT_WIRE ) break; /* 沒有中斷則返回,如果仍然有中斷請求說明之前的中斷是U盤插拔通知中斷,現(xiàn)在再處理命令完成中斷而暫不返回 */ } else break; /* 操作失敗返回 */ } } /* while( CH375HM_INT_WIRE == 0 ); 如果單片機速度很快,有可能該程序返回前模塊尚未撤消中斷請求,那么應該等待中斷請求引腳無效 */ return( status ); }

/* 執(zhí)行命令 */ unsigned char ExecCommand( unsigned char cmd, unsigned char len ) /* 輸入命令碼和輸入?yún)?shù)長度,返回操作狀態(tài)碼,輸入?yún)?shù)和返回參數(shù)都在CMD_PARAM結構中 */ { return( ExecCommandBuf( cmd, len, 0 ) ); /* 只有CMD_FileRead或者CMD_FileWrite命令用到輸入?yún)?shù)bufstart,其它命令沒有用到 */ }

/* 檢查操作狀態(tài),如果錯誤則顯示錯誤代碼并停機,應該替換為實際的處理措施 */ void mStopIfError( unsigned char iError ) { unsigned char led; if ( iError == ERR_SUCCESS ) return; /* 操作成功 */ printf( "Error: %02X\n", (unsigned short)iError ); /* 顯示錯誤 */ led=0; while ( 1 ) { LED_OUT = led&1; /* LED閃爍 */ mDelaymS( 100 ); led^=1; } }

/* 為printf和getkey輸入輸出初始化串口 */ void mInitSTDIO( ) { SCON = 0x50; PCON = 0x80; TMOD = 0x20; TH1 = 0xfa; /* 24MHz晶振, 9600bps */ TR1 = 1


如果你那邊有示波器的話,建議你這樣操作,首先死循環(huán)的發(fā)送索引地址,用示波器去看下各個引腳在WR的上升延的時候個個信號線是否正常,其次,寫數(shù)據(jù)端口,按照上面的方法在看下各個引腳的信號線是否正常。


公司沒有 家里有。要回家測試了。 能再具體講講嗎?具體看那個腳 。發(fā)索引地址是發(fā)60FF 嗎? 謝謝 了 最好給個例子! 我用的單片機晶體是11。0592M


在幫看看 我程序是否錯誤!! /* **************************************** ** Copyright (C) W.ch 1999-2007 ** ** Web: http://www.winchiphead.com ** **************************************** ** USB Host File Module @CH375 ** **************************************** */ /* CH375 主機文件系統(tǒng)接口模塊 */ /* 支持: FAT12/FAT16/FAT32 */ /* U盤文件讀寫模塊C語言頭文件 */

#ifndef __CH375HM_H__ #define __CH375HM_H__

#define CH375HM_VER 0x30 /* 當前模塊版本 */

/* ********************************************************************************************************************* */ /* 返回的操作狀態(tài)碼 */ /* 以下是事件通知狀態(tài)碼,檢測到當前U盤已經(jīng)連接或者已經(jīng)斷開,可以作為最終狀態(tài)碼 */ #define ERR_USB_CONNECT 0x15 /* 檢測到USB設備連接事件,磁盤已經(jīng)連接 */ #define ERR_DISK_DISCON 0x82 /* 檢測到USB設備連接事件,磁盤已經(jīng)斷開,或者磁盤尚未連接 */ /* 代碼0XH用于USB設備方式的操作狀態(tài)代碼,由CH375返回,是USB設備模式的中斷狀態(tài) */ #define ERR_USB_DAT_DOWN 0x02 /* USB設備模式: 數(shù)據(jù)下傳成功,上位機下傳的數(shù)據(jù)已經(jīng)在模塊中 */ #define ERR_USB_DAT_UP 0x0A /* USB設備模式: 數(shù)據(jù)上傳成功,模塊中的上傳數(shù)據(jù)已經(jīng)被上位機取走 */ /* 以下是階段性的狀態(tài)碼,用于請求數(shù)據(jù)交換,不是最終的操作狀態(tài) */ #define USB_INT_DISK_READ 0x1D /* USB存儲器讀數(shù)據(jù)塊,只用于CMD_FileRead命令,請求數(shù)據(jù)讀出 */ #define USB_INT_DISK_WRITE 0x1E /* USB存儲器寫數(shù)據(jù)塊,只用于CMD_FileWrite命令,請求數(shù)據(jù)寫入 */ #define USB_INT_DISK_RETRY 0xEE /* USB存儲器讀寫數(shù)據(jù)塊失敗重試,只用于CMD_FileRead命令和CMD_FileRead命令,操作失敗重試 */ /* USB_INT_DISK_RETRY重試狀態(tài)碼要求用戶端程序回改文件數(shù)據(jù)緩沖區(qū)指針,以便重新發(fā)送或者接收文件數(shù)據(jù), 在USB_INT_DISK_RETRY重試狀態(tài)碼之后用戶端程序將收到兩個字節(jié)的數(shù)據(jù),也就是一個16位的數(shù)據(jù),指定需要回改指針的字節(jié)數(shù),大端時高字節(jié)在前,小端時低字節(jié)在前 */ /* 最終狀態(tài)碼 */ #define ERR_SUCCESS 0x00 /* 操作成功 */ #define ERR_CH375_ERROR 0x81 /* CH375硬件錯誤,可能需要復位CH375 */ #define ERR_STATUS_ERR 0x83 /* 磁盤狀態(tài)錯誤,可能正在連接或者斷開磁盤 */ #define ERR_MBR_ERROR 0x91 /* 磁盤的主引導記錄無效,可能磁盤尚未分區(qū)或者尚未格式化 */ #define ERR_TYPE_ERROR 0x92 /* 磁盤分區(qū)類型不支持,只支持FAT12/FAT16/BigDOS/FAT32,需要由磁盤管理工具重新分區(qū) */ #define ERR_BPB_ERROR 0xA1 /* 磁盤尚未格式化,或者參數(shù)錯誤,需要由WINDOWS采用默認參數(shù)重新格式化 */ #define ERR_TOO_LARGE 0xA2 /* 磁盤非正常格式化并且容量大于4GB,或者容量大于250GB,需要由WINDOWS采用默認參數(shù)重新格式化 */ #define ERR_FAT_ERROR 0xA3 /* 磁盤的文件系統(tǒng)不支持,只支持FAT12/FAT16/FAT32,需要由WINDOWS采用默認參數(shù)重新格式化 */ #define ERR_DISK_FULL 0xB1 /* 磁盤文件太滿,剩余空間太少或者已經(jīng)沒有,需要磁盤整理 */ #define ERR_FDT_OVER 0xB2 /* 目錄內文件太多,沒有空閑的目錄項,FAT12/FAT16根目錄下的文件數(shù)應該少于500個,需要磁盤整理 */ #define ERR_MISS_DIR 0xB3 /* 指定路徑的某個子目錄沒有找到,可能是目錄名稱錯誤 */ #define ERR_FILE_CLOSE 0xB4 /* 文件已經(jīng)關閉,如果需要使用,應該重新打開文件 */ #define ERR_OPEN_DIR 0x41 /* 指定路徑的目錄被打開 */ #define ERR_MISS_FILE 0x42 /* 指定路徑的文件沒有找到,可能是文件名稱錯誤 */ #define ERR_FOUND_NAME 0x43 /* 搜索到與通配符相匹配的文件名,文件名及其完整路徑在命令緩沖區(qū)中,如果需要使用,應該打開該文件 */ #define ERR_USB_DISK_ERR 0x1F /* USB存儲器操作失敗,在初始化時可能是USB存儲器不支持,在讀寫操作中可能是磁盤損壞或者已經(jīng)斷開 */ /* 其余錯誤代碼未定義,可以發(fā)出命令CMD_QueryStatus查詢模塊狀態(tài)并分析 */

/* ********************************************************************************************************************* */ /* 磁盤及文件狀態(tài),適用于CMD_PARAM.Status.mDiskStatus */ #define DISK_UNKNOWN 0x00 /* 尚未初始化,未知狀態(tài) */ #define DISK_DISCONNECT 0x01 /* 磁盤沒有連接或者已經(jīng)斷開 */ #define DISK_CONNECT 0x02 /* 磁盤已經(jīng)連接,但是尚未初始化或者無法識別該磁盤 */ #define DISK_MOUNTED 0x03 /* 磁盤已經(jīng)初始化成功,但是尚未分析文件系統(tǒng)或者文件系統(tǒng)不支持 */ #define DISK_READY 0x10 /* 已經(jīng)分析磁盤的文件系統(tǒng)并且能夠支持 */ #define DISK_OPEN_ROOT 0x12 /* 已經(jīng)打開根目錄,扇區(qū)模式,只能以扇區(qū)為單位讀寫目錄的內容,使用后必須關閉,注意FAT12/FAT16根目錄是固定長度 */ #define DISK_OPEN_DIR 0x13 /* 已經(jīng)打開子目錄,扇區(qū)模式,只能以扇區(qū)為單位讀寫目錄的內容 */ #define DISK_OPEN_FILE 0x14 /* 已經(jīng)打開文件,扇區(qū)模式,可以以扇區(qū)為單位進行數(shù)據(jù)讀寫 */ #define DISK_OPEN_FILE_B 0x15 /* 已經(jīng)打開文件,字節(jié)模式,可以以字節(jié)為單位進行數(shù)據(jù)讀寫 */

/* ********************************************************************************************************************* */ /* FAT類型標志,適用于CMD_PARAM.Query.mDiskFat */ #define DISK_FS_UNKNOWN 0 /* 未知的文件系統(tǒng) */ #define DISK_FAT12 1 /* FAT12文件系統(tǒng) */ #define DISK_FAT16 2 /* FAT16文件系統(tǒng) */ #define DISK_FAT32 3 /* FAT32文件系統(tǒng) */

/* ********************************************************************************************************************* */ /* 文件屬性,適用于CMD_PARAM.Modify.mFileAttr */ #define ATTR_READ_ONLY 0x01 /* 文件為只讀屬性 */ #define ATTR_HIDDEN 0x02 /* 文件為隱含屬性 */ #define ATTR_SYSTEM 0x04 /* 文件為系統(tǒng)屬性 */ #define ATTR_VOLUME_ID 0x08 /* 卷標 */ #define ATTR_DIRECTORY 0x10 /* 子目錄 */ #define ATTR_ARCHIVE 0x20 /* 文件為存檔屬性 */ #define ATTR_LONG_NAME ( ATTR_READ_ONLY | ATTR_HIDDEN | ATTR_SYSTEM | ATTR_VOLUME_ID ) /* 文件屬性 unsigned char */ /* bit0 bit1 bit2 bit3 bit4 bit5 bit6 bit7 */ /* 只 隱 系 卷 目 存 未定義 */ /* 讀 藏 統(tǒng) 標 錄 檔 */ /* 文件時間 unsigned short,適用于CMD_PARAM.Modify.mFileTime */ /* Time = (Hour<<11) + (Minute<<5) + (Second>>1) */ #define MAKE_FILE_TIME( h, m, s ) ( (h<<11) + (m<<5) + (s>>1) ) /* 生成指定時分秒的文件時間數(shù)據(jù) */ /* 文件日期 unsigned short,適用于CMD_PARAM.Modify.mFileDate */ /* Date = ((Year-1980)<<9) + (Month<<5) + Day */ #define MAKE_FILE_DATE( y, m, d ) ( ((y-1980)<<9) + (m<<5) + d ) /* 生成指定年月日的文件日期數(shù)據(jù) */

/* ********************************************************************************************************************* */ /* 文件名,適用于CMD_PARAM.?.mPathName */ #define PATH_WILDCARD_CHAR 0x2A /* 路徑名的通配符 '*' */ #define PATH_SEPAR_CHAR1 0x5C /* 路徑名的分隔符 '\' */ #define PATH_SEPAR_CHAR2 0x2F /* 路徑名的分隔符 '/' */ #ifndef MAX_PATH_LEN #define MAX_PATH_LEN 65 /* 最大路徑長度,含所有斜杠分隔符和小數(shù)點間隔符以及路徑結束符00H,并口方式下最大值為62 */ #endif #if MAX_PATH_LEN > 65 #undef MAX_PATH_LEN #define MAX_PATH_LEN 65 #endif #ifndef MAX_BYTE_IO #define MAX_BYTE_IO ( MAX_PATH_LEN - 1 ) /* 以字節(jié)為單位單次讀寫文件時的最大長度,超過該長度可以分多次讀寫,并口方式下最大值為61 */ #endif #if MAX_BYTE_IO > 64 #undef MAX_BYTE_IO #define MAX_BYTE_IO 64 #endif

/* ********************************************************************************************************************* */ /* 外部命令碼 */ #define CMD_QueryStatus 0x60 /* 查詢當前模塊的狀態(tài) */ #define CMD_DiskQuery 0x61 /* 查詢磁盤信息 */ #define CMD_FileEnumer 0x63 /* 枚舉文件,返回文件名 */ #define CMD_FileOpen 0x64 /* 打開文件 */ #define CMD_FileCreate 0x65 /* 新建文件并打開,如果文件已經(jīng)存在則先刪除后再新建 */ #define CMD_FileErase 0x66 /* 刪除文件并關閉 */ #define CMD_FileClose 0x67 /* 關閉當前文件 */ #define CMD_FileQuery 0x68 /* 查詢當前文件的信息 */ #define CMD_FileModify 0x69 /* 查詢或者修改當前文件的信息 */ #define CMD_FileLocate 0x6A /* 移動當前文件指針 */ #define CMD_FileRead 0x6B /* 從當前文件讀取數(shù)據(jù) */ #define CMD_FileWrite 0x6C /* 向當前文件寫入數(shù)據(jù) */ #define CMD_ByteLocate 0x7A /* 以字節(jié)為單位移動當前文件指針 */ #define CMD_ByteRead 0x7B /* 以字節(jié)為單位從當前文件讀取數(shù)據(jù)塊 */ #define CMD_ByteWrite 0x7C /* 以字節(jié)為單位向當前文件寫入數(shù)據(jù)塊 */ #define CMD_BulkOnlyCmd 0x70 /* 執(zhí)行基于BulkOnly協(xié)議的命令 */ #define CMD_DiskReady 0x71 /* 查詢磁盤是否準備好 */ #define CMD_DiskSize 0x72 /* 查詢磁盤容量 */ #define CMD_FileDirInfo 0x75 /* 存取當前已打開文件的目錄信息 */ #define CMD_DirCreate 0x76 /* 新建目錄并打開,如果目錄已經(jīng)存在則直接打開 */ #define CMD_FileReadLast


具體的將,假如在死循環(huán)的往索引地址上面發(fā)送0XAA的索引地址,那么,這個時候,一個示波器去探測WR引腳,在WR的上升延去用示波器的另外幾個引腳,例如,發(fā)送0XAA的所以地址的話,在WR的上升延,A0=0,CS=0,RD=1,D7-D0的數(shù)據(jù)為10101010。這個你需要去測模塊引腳,而不能去測單片機引腳。相同的方法,你去測試寫數(shù)據(jù)是否一樣。


測試結果:使用STC89C58RD+ 電路連接 /* 電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# P24 = A0 P1.3 = INT# */ sbit PINT = P1^3; #define CH375HM_INDEX XBYTE[0x6FFF] /* CH375模塊的索引端口的I/O地址 */ #define CH375HM_DATA XBYTE[0x7FFF] /* CH375模塊的數(shù)據(jù)端口的I/O地址 */ #define CH375HM_INT_WIRE PINT /* 假定CH375模塊的INT#引腳連接到單片機的INT0引腳 */

/* 假定文件數(shù)據(jù)緩沖區(qū): ExtRAM: 0000H-7FFFH */ unsigned char xdata DATA_BUF[ 512 ]_at_ 0x1FF;

....... main( ) { // unsigned char i, c, SecCount; // unsigned long OldSize; // unsigned short NewSize, count; LED_OUT = 0; /* 開機后LED亮一下以示工作 */ mDelaymS( 200 ); /* 延時100毫秒,CH375模塊上電后需要100毫秒左右的復位時間 */ mDelaymS( 250 ); LED_OUT = 1; mInitSTDIO( ); printf( "Start\n" ); // mCmdParam.Setup.mSetup = 0x01; /* 輸入?yún)?shù): 模塊配置值,位0為1則空閑時查詢U盤連接狀態(tài)并自動中斷通知 */ // i = ExecCommand( CMD_SetupModule, 1 ); /* 設置模塊配置 */ // mStopIfError( i ); /* 其它電路初始化 */ while ( 1 ) { /* 主循環(huán) */

CH375HM_INDEX_WR( 0xaa );

在WR 由0到1時,AO=0 CS=0 P0。0 P0。2 P0。3 P0。4 PO。6 P0。7 均為由1到0 或由0到1的變化 而P0。2和P0。5 一直是高電平 (1)。 發(fā)CH375HM_DATA_WR(0XAA) ;結果和上面一樣 。?這樣對嗎? 感覺是不是CH375壞了?。。]有新片更換)

還有什么問題?。?/p>

問 :我用STC89C58RD+ 連接CH375

另有P2。0--P2。3做I/O中斷可以嗎?會影響CH375嗎? 電路連接方式 單片機 模塊 P0 = D0-D7 RD = RD# WR = WR# P2.7 = CS# P24 = A0 P1.3 = INT# */ sbit PINT = P1^3; #define CH375HM_INDEX XBYTE[0x60FF] /* CH375模塊的索引端口的I/O地址 */ #define CH375HM_DATA XBYTE[0x70FF] /* CH375模塊的數(shù)據(jù)端口的I/O地址 */ #define CH375HM_INT_WIRE PINT


沒有使用 外部RAM 對U盤操作 只是改名、查詢等 能推薦個歷程嗎?(使用并口+查詢的例程?。┲x謝了!


5.4.1 初始化(除數(shù)據(jù)流模式的命令外,進行任何一種文件操作之前的必要步驟) ⑴ 初始化單片機與模塊之間的接口,設置必要的參數(shù)等 ⑵ 等待U 盤連接(中斷方式依靠CH375 事件通知,查詢方式依靠主動查詢) ⑶ CMD_DiskReady,可選步驟,強烈建議執(zhí)行此步驟 ⑷ CMD_DiskSize,可選步驟,通常不需要

能詳細說明初始化的過程嗎?都對什么初始化 例如對并口+查詢都要初始化什么內容???


while ( 1 ) { /* 主循環(huán) */

CH375HM_INDEX_WR( 0x0a );CH375HM_INDEX_WR( 0x00 );

在WR 由0到1時,AO=0 CS=0 P0。0 P0。2 P0。3 P0。4 PO。6 P0。7 均為由1到0 或由0到1的變化 P0。2和P0。5 也由1到0 或由0到1的變化 能解釋是什么原因嗎?


while ( 1 ) { /* 主循環(huán) */

CH375HM_INDEX_WR( 0x0a );

} 應該按照上面的程序來操作,看下每一個I/O口的電平,要確切的說明在WR的上升延的時候沒個I/O口的電平是多少


發(fā)表于:2008-3-8 8:57:00,來源于:58.213.74.48 ,發(fā)貼心情: ----------------------------------------------------------------------------------------------------- while ( 1 ) { /* 主循環(huán) */

CH375HM_INDEX_WR( 0x0a );

} 應該按照上面的程序來操作,看下每一個I/O口的電平,要確切的說明在WR的上升延的時候沒個I/O口的電平是多少 wr 為上升沿 P0。7--P0。0 是00001010 這樣對嗎? 但P0。1一直是高電平。P0。4為脈沖 (矩形波)

請解答下列問題 ?。?.4.1 初始化(除數(shù)據(jù)流模式的命令外,進行任何一種文件操作之前的必要步驟) ⑴ 初始化單片機與模塊之間的接口,設置必要的參數(shù)等 ⑵ 等待U 盤連接(中斷方式依靠CH375 事件通知,查詢方式依靠主動查詢) ⑶ CMD_DiskReady,可選步驟,強烈建議執(zhí)行此步驟 ⑷ CMD_DiskSize,可選步驟,通常不需要

能詳細說明初始化的過程嗎?都對什么初始化 例如對并口+查詢都要初始化什么內容啊?

沒有使用 外部RAM 對U盤操作 只是改名、查詢等 能推薦個歷程嗎?(使用并口+查詢的例程?。┲x謝了!


記得看過 HCN 在論壇中發(fā)過關于并口+查詢 字節(jié)讀寫的例子 能在給發(fā)下嗎? 找不到 了!

發(fā)表于:2008-3-8 8:57:00,來源于:58.213.74.48 ,發(fā)貼心情: ----------------------------------------------------------------------------------------------------- while ( 1 ) { /* 主循環(huán) */

CH375HM_INDEX_WR( 0x0a );

} 應該按照上面的程序來操作,看下每一個I/O口的電平,要確切的說明在WR的上升延的時候沒個I/O口的電平是多少 wr 為上升沿 P0。7--P0。0 是00001010 這樣對嗎? 但P0。1一直是高電平。P0。4為脈沖 (矩形波)

請解答下列問題 !:5.4.1 初始化(除數(shù)據(jù)流模式的命令外,進行任何一種文件操作之前的必要步驟) ⑴ 初始化單片機與模塊之間的接口,設置必要的參數(shù)等 ⑵ 等待U 盤連接(中斷方式依靠CH375 事件通知,查詢方式依靠主動查詢) ⑶ CMD_DiskReady,可選步驟,強烈建議執(zhí)行此步驟 ⑷ CMD_DiskSize,可選步驟,通常不需要

能詳細說明初始化的過程嗎?都對什么初始化 例如對并口+查詢都要初始化什么內容?。?/p>

沒有使用 外部RAM 對U盤操作 只是改名、查詢等 能推薦個歷程嗎?(使用并口+查詢的例程?。┲x謝了!


如果按照你上面說的在WR的上升延為這個的話,示波器看到的數(shù)據(jù)是這個數(shù)據(jù)的話那是沒有問題的。 1,這個初始化主要是只對單片機的一些和模塊連接的I/O口的初始化,例如設置I/O口的方向等等。 2,實際是發(fā)送查詢U盤是否連接的命令,如果連接的話,那么,返回的數(shù)據(jù)的第2個字節(jié)就是代表U盤是否連接 3,發(fā)送這個命令是將U盤初始化,否則不能對U盤進行正確的操作 4,這個命令僅僅是用來查詢U盤的容量的,如果你不需要U盤的容量的話,也可以不需要。


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

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