?? ch375hf7.h
字號:
#define EN_DISK_FAT32 1
#define EN_BYTE_ACCESS 1
#define LIB_CFG_DISK_IO 1 /* 默認情況下,磁盤讀寫的數據的復制方式 */
#ifndef LIB_CFG_FILE_IO
#define LIB_CFG_FILE_IO 1 /* 默認情況下,文件讀寫的數據的復制方式為"內部復制" */
#endif
#ifndef LIB_CFG_UPD_SIZE
#define LIB_CFG_UPD_SIZE 0 /* 默認情況下,在添加數據后文件長度的更新方式為"不更新" */
#endif
#ifndef LIB_CFG_NO_DLY
#define LIB_CFG_NO_DLY 0 /* 默認情況下,在寫操作結束后的延時方式為"寫后延時" */
#endif
#ifndef LIB_CFG_INT_EN
#define LIB_CFG_INT_EN 0 /* 默認情況下,CH375的INT#引腳連接方式為"查詢方式" */
#endif
#define LIB_CFG_VALUE ( ( LIB_CFG_INT_EN << 7 ) | ( LIB_CFG_NO_DLY << 5 ) | ( LIB_CFG_UPD_SIZE << 4 ) | ( LIB_CFG_FILE_IO << 2 ) | LIB_CFG_DISK_IO ) /* CH375程序庫配置值 */
/* 子程序庫中提供的變量 */
extern UINT8V CH375IntStatus; /* CH375操作的中斷狀態 */
extern UINT8V CH375DiskStatus; /* 磁盤及文件狀態 */
extern UINT8 CH375LibConfig; /* CH375程序庫配置,下行說明 */
/* 位7: CH375的INT#引腳連接方式: 0查詢方式,1中斷方式 */
/* 位5: 在寫操作結束后是否延時: 0寫后延時,1不延時 */
/* 位4: 在添加數據后是否自動更新文件長度: 0不更新,1自動更新 */
/* 位3位2: 針對文件讀寫的多扇區數據的復制方式: 00外部子程序, 01,10,11內部復制 */
/* 位1位0: 針對磁盤讀寫的單扇區數據的復制方式: 總是內部復制 */
/* 如果CH375的INT#引腳連接到單片機的中斷輸入引腳并且準備使用中斷方式,那么LIB_CFG_INT_EN定義為1,否則定義為0由單片機查詢INT#引腳 */
/* 在CH375子程序讀寫文件數據時,CH375的程序庫提供兩種優化速度的方式,在LIB_CFG_FILE_IO中定義:
方式0:"外部子程序", 只適用于文件讀寫時的數據復制(只用于CH375FileReadX和CH375FileWriteX兩個子程序),
是指由子程序xWriteToExtBuf和xReadFromExtBuf進行數據復制,這兩個子程序是在應用程序中定義的,由CH375的程序庫調用,
方式1:"內部復制", 程序內置的常規數據復制方式
對于文件數據讀寫,也就是應用程序調用CH375FileReadX和CH375FileWriteX子程序時:
在方式0下,由應用程序在xWriteToExtBuf和xReadFromExtBuf子程序中自行管理緩沖區,設定緩沖區初值等,
在方式1下,應用程序每次調用CH375FileReadX和CH375FileWriteX時,CH375的程序庫都會從指定緩沖區的起始地址開始讀寫數據,
例如: 某文件長度為1K(占用2個扇區), 如果調用CH375FileReadX時讀1K(指定mCmdParam.Read.mSectorCount為2), 那么1K數據全讀到指定緩沖區中,
如果緩沖區較小只有0.5K, 那么分兩次讀取, 第一次調用CH375FileReadX時讀0.5K, 處理完這0.5K數據后再調用CH375FileReadX讀下一個0.5K并處理
*/
extern UINT8 CH375vDiskFat; /* 邏輯盤的FAT標志:1=FAT12,2=FAT16,3=FAT32 */
extern UINT8 CH375vSecPerClus; /* 邏輯盤的每簇扇區數 */
extern UINT32 CH375vStartCluster; /* 當前文件或者目錄的起始簇號 */
extern UINT32 CH375vFileSize; /* 當前文件的長度 */
extern UINT32 CH375vCurrentOffset; /* 當前文件指針,當前讀寫位置的字節偏移 */
#ifdef EN_CH375LIB_MORE
/* FAT數據區中文件目錄信息 */
typedef struct _FAT_DIR_INFO {
UINT8 DIR_Name[11]; /* 00H,文件名,共11字節,不足處填空格 */
UINT8 DIR_Attr; /* 0BH,文件屬性,參考前面的說明 */
UINT8 DIR_NTRes; /* 0CH */
UINT8 DIR_CrtTimeTenth; /* 0DH,文件創建的時間,以0.1秒單位計數 */
UINT16 DIR_CrtTime; /* 0EH,文件創建的時間 */
UINT16 DIR_CrtDate; /* 10H,文件創建的日期 */
UINT16 DIR_LstAccDate; /* 12H,最近一次存取操作的日期 */
UINT16 DIR_FstClusHI; /* 14H */
UINT16 DIR_WrtTime; /* 16H,文件修改時間,參考前面的宏MAKE_FILE_TIME */
UINT16 DIR_WrtDate; /* 18H,文件修改日期,參考前面的宏MAKE_FILE_DATA */
UINT16 DIR_FstClusLO; /* 1AH */
UINT32 DIR_FileSize; /* 1CH,文件長度 */
} FAT_DIR_INFO; /* 20H */
typedef FAT_DIR_INFO *P_FAT_DIR_INFO;
extern BOOL1 CH375Version2; /* 芯片版本:0-CH375,1-CH375A */
extern UINT32 CH375vDataStart; /* 邏輯盤的數據區域的起始LBA */
extern UINT32 CH375vFdtLba; /* 當前FDT所在的LBA地址 */
extern UINT16 CH375vFdtOffset; /* 當前FDT在扇區內的偏移地址 */
#ifdef EN_DISK_FAT32
extern UINT32 CH375vDiskRoot; /* 對于FAT16盤為根目錄占用扇區數,對于FAT32盤為根目錄起始簇號 */
#else
extern UINT8 CH375vDiskRoot; /* 對于FAT16盤為根目錄占用扇區數 */
#endif
extern UINT8 CH375ReadBlock( void ); /* 從磁盤讀取多個扇區的數據到外部接口交換區 */
#ifdef EN_DISK_WRITE
extern UINT8 CH375WriteBlock( void ); /* 將外部接口交換區的多個扇區的數據塊寫入磁盤 */
#endif
#endif
/* 子程序庫中提供的子程序 */
/* 下述子程序中, 文件操作子程序CH375File*和磁盤查詢子程序CH375DiskQuery都可能會用到磁盤數據緩沖區DISK_BASE_BUF,
并且有可能在DISK_BASE_BUF中保存了磁盤信息, 所以必須保證DISK_BASE_BUF不被用于其它用途,
如果RAM較少, 要將DISK_BASE_BUF臨時用于其它用途, 那么在臨時用完后必須調用CH375DirtyBuffer清除磁盤緩沖區 */
extern UINT8 CH375GetVer( void ); /* 獲取當前子程序庫的版本號 */
extern void CH375Reset( void ); /* 復位CH375 */
extern UINT8 CH375Init( void ); /* 初始化CH375 */
extern void CH375DirtyBuffer( void ); /* 清除磁盤緩沖區 */
extern UINT8 CH375FileOpen( void ); /* 打開文件或者枚舉文件 */
extern UINT8 CH375FileEnumer( void ); /* 枚舉文件 */
extern UINT8 CH375FileClose( void ); /* 關閉當前文件 */
extern UINT8 CH375FileQuery( void ); /* 查詢當前文件的信息 */
extern UINT8 CH375FileModify( void ); /* 查詢或者修改當前文件的信息 */
extern UINT8 CH375FileLocate( void ); /* 移動當前文件指針 */
extern UINT8 CH375FileReadX( void ); /* 從當前文件讀取數據到指定緩沖區 */
#ifdef EN_DISK_WRITE
extern UINT8 CH375FileErase( void ); /* 刪除文件并關閉 */
extern UINT8 CH375FileCreate( void ); /* 新建文件并打開,如果文件已經存在則先刪除后再新建 */
extern UINT8 CH375FileWriteX( void ); /* 向當前文件寫入指定緩沖區的數據 */
extern UINT8 CH375DiskSize( void ); /* 查詢磁盤容量 */
extern UINT8 CH375DiskQuery( void ); /* 查詢磁盤信息 */
#endif
#ifdef EN_BYTE_ACCESS
extern UINT8 CH375ByteLocate( void ); /* 以字節為單位移動當前文件指針 */
extern UINT8 CH375ByteRead( void ); /* 以字節為單位從當前位置讀取數據塊 */
#ifdef EN_DISK_WRITE
extern UINT8 CH375ByteWrite( void ); /* 以字節為單位向當前位置寫入數據塊 */
#endif
#endif
extern UINT8 CH375BulkOnlyCmd( void ); /* 執行基于BulkOnly協議的命令 */
extern UINT8 CH375DiskReady( void ); /* 查詢磁盤是否準備好 */
extern UINT8 CH375DiskConnect( void ); /* 檢查磁盤是否連接 */
/* 該頭文件可以為CH375子程序庫分配必要的I/O及內存資源,并產生必要的與硬件有關的目標代碼,
如果該文件是被工程項目的多個源程序包含作為頭文件,那么應該只允許一個頭文件分配資源和產生代碼,
除此之外的頭文件應該被事先定義CH375HF_NO_CODE,從而禁止該頭文件產生重復的目標代碼,例如:
#define CH375HF_NO_CODE 1
#include CH375HF?.H
*/
#ifdef CH375HF_NO_CODE
extern CMD_PARAM_I mCmdParam; /* 命令參數 */
extern UINT8 DISK_BASE_BUF[512]; /* 外部RAM的磁盤數據緩沖區,緩沖區長度為一個扇區的長度 */
#ifdef FILE_DATA_BUF_LEN
extern UINT8 FILE_DATA_BUF[ FILE_DATA_BUF_LEN ]; /* 外部RAM的文件數據緩沖區,緩沖區長度不小于一次讀寫的數據長度 */
extern UINT8 CH375FileRead( void ); /* 從當前文件讀取數據 */
#ifdef EN_DISK_WRITE
extern UINT8 CH375FileWrite( void ); /* 向當前文件寫入數據 */
#endif
#endif
extern void xQueryInterrupt( void ); /* 外部定義的被CH375程序庫調用的子程序,查詢CH375中斷并更新中斷狀態 */
extern UINT8 CH375LibInit( void ); /* 初始化CH375程序庫和CH375芯片,操作成功返回0 */
#else
void xWriteCH375Cmd( UINT8 mCmd ); /* 外部定義的被CH375程序庫調用的子程序,向CH375寫命令,最小周期為4uS,否則之前之后各延時2uS */
void xWriteCH375Data( UINT8 mData ); /* 外部定義的被CH375程序庫調用的子程序,向CH375寫數據,最小周期為1.5uS,否則之后延時1.5uS */
UINT8 xReadCH375Data( void ); /* 外部定義的被CH375程序庫調用的子程序,從CH375讀數據,最小周期為1.5uS,否則之前延時1.5uS */
CMD_PARAM_I mCmdParam; /* 命令參數 */
UINT8 DISK_BASE_BUF[512]; /* 外部RAM的磁盤數據緩沖區,緩沖區長度為一個扇區的長度,起始地址建議為4字節邊界地址 */
#ifdef FILE_DATA_BUF_LEN
UINT8 FILE_DATA_BUF[ FILE_DATA_BUF_LEN ]; /* 外部RAM的文件數據緩沖區,緩沖區長度不小于一次讀寫的數據長度,起始地址建議為4字節邊界地址 */
UINT8 CH375FileRead( void ) /* 從當前文件讀取數據 */
{
mCmdParam.ReadX.mDataBuffer = &FILE_DATA_BUF[0]; /* 指向文件數據緩沖區 */
return( CH375FileReadX( ) );
}
#ifdef EN_DISK_WRITE
UINT8 CH375FileWrite( void ) /* 向當前文件寫入數據 */
{
mCmdParam.WriteX.mDataBuffer = &FILE_DATA_BUF[0]; /* 指向文件數據緩沖區 */
return( CH375FileWriteX( ) );
}
#endif
#endif
/* 以下程序可以根據需要修改 */
#ifndef NO_DEFAULT_CH375_INT /* 在應用程序中定義NO_DEFAULT_CH375_INT可以禁止默認的中斷處理程序,然后用自行編寫的程序代替它 */
#if LIB_CFG_INT_EN == 0 /* CH375的INT#引腳連接方式為"查詢方式" */
void xQueryInterrupt( void ) /* 查詢CH375中斷并更新中斷狀態 */
{
while ( CH375_INT_WIRE ); /* 如果CH375的中斷引腳輸出高電平則等待 */
xWriteCH375Cmd( CMD_GET_STATUS ); /* 獲取當前中斷狀態,發出命令后至少延時2uS */
CH375IntStatus = xReadCH375Data( ); /* 獲取中斷狀態 */
if ( CH375IntStatus == USB_INT_DISCONNECT ) CH375DiskStatus = DISK_DISCONNECT; /* 檢測到USB設備斷開事件 */
else if ( CH375IntStatus == USB_INT_CONNECT ) CH375DiskStatus = DISK_CONNECT; /* 檢測到USB設備連接事件 */
}
#else /* LIB_CFG_INT_EN != 0, CH375的INT#引腳連接方式為"中斷方式" */
void xQueryInterrupt( void ) /* 查詢中斷狀態,等待硬件中斷 */
{
while ( CH375IntStatus == 0 ); /* 子程序庫調用該子程序之前CH375IntStatus=0,硬件中斷后,由中斷服務程序置為非0的實際中斷狀態后返回 */
}
void interrupt CH375Interrupt( void ) /* CH375中斷服務程序,由CH375的INT#的低電平或者下降沿觸發單片機中斷 */
{
xWriteCH375Cmd( CMD_GET_STATUS ); /* 獲取中斷狀態并取消中斷請求 */
CH375IntStatus = xReadCH375Data( ); /* 獲取中斷狀態 */
if ( CH375IntStatus == USB_INT_DISCONNECT ) CH375DiskStatus = DISK_DISCONNECT; /* 檢測到USB設備斷開事件 */
else if ( CH375IntStatus == USB_INT_CONNECT ) CH375DiskStatus = DISK_CONNECT; /* 檢測到USB設備連接事件 */
#ifdef CLEAR_INT_MARK
CLEAR_INT_MARK( ); /* 某些單片機需要由軟件清除中斷標志 */
#endif
}
#endif
#endif
#if LIB_CFG_FILE_IO == 0 /* 文件讀寫的數據的復制方式為"外部子程序" */
#ifdef LIB_CFG_FILE_IO_DEFAULT /* 如果應用程序中定義該值則使用默認"外部子程序",否則應該自行編寫程序代替 */
unsigned char *current_buffer; /* 保存文件數據讀寫時的緩沖區的當前指針,由應用程序在調用CH375FileReadX和CH375FileWriteX子程序前設置初值 */
void xWriteToExtBuf( UINT8 mLength ) /* 該子程序由CH375的子程序庫調用,用于從CH375讀取文件數據到外部緩沖區,被CH375FileReadX調用 */
{
/* if ( (UINT32)current_buffer + mLength >= (UINT32)&FILE_DATA_BUF + sizeof( FILE_DATA_BUF ) ) return;*/ /* 防止緩沖區溢出 */
if ( mLength ) {
do { /* 根據長度讀取數據,實際上長度總是CH375_MAX_DATA_LEN,也就是64 */
*current_buffer = xReadCH375Data( ); /* 讀出數據并保存,可以用這種方式將文件數據保存到單片機的各種串行存儲器中 */
current_buffer ++;
} while ( -- mLength );
} /* 復制上述數據的總時間不得超過2mS */
else { /* 重試,恢復緩沖區起址,如果將文件數據讀寫的緩沖區的當前指針放在mCmdParam.ReadX.mDataBuffer中則會被自動恢復,無需下面的兩行程序 */
current_buffer += (UINT16)mCmdParam.ReadX.mDataBuffer; /* mDataBuffer中為負值 */
mCmdParam.ReadX.mDataBuffer = 0; /* 為了支持重試,在調用CH375FileReadX之前也應該清0 */
}
}
#ifdef EN_DISK_WRITE
void xReadFromExtBuf( UINT8 mLength ) /* 該子程序由CH375的子程序庫調用,用于從外部緩沖區讀取文件數據到CH375,被CH375FileWriteX調用 */
{
if ( mLength ) {
do { /* 根據長度寫入數據,實際上長度總是CH375_MAX_DATA_LEN,也就是64 */
xWriteCH375Data( *current_buffer ); /* 將數據寫入,可以用這種方式從單片機的各種串行存儲器中取出文件數據 */
current_buffer ++;
} while ( -- mLength );
} /* 復制上述數據的總時間不得超過2mS */
else { /* 重試,恢復緩沖區起址,如果將文件數據讀寫的緩沖區的當前指針放在mCmdParam.WriteX.mDataBuffer中則會被自動恢復,無需下面的兩行程序 */
current_buffer += (UINT16)mCmdParam.WriteX.mDataBuffer; /* mDataBuffer中為負值 */
mCmdParam.WriteX.mDataBuffer = 0; /* 為了支持重試,在調用CH375FileWriteX之前也應該清0 */
}
}
#endif
#endif
#else /* LIB_CFG_FILE_IO != 0,文件讀寫的數據的復制方式不是"外部子程序" */
void xWriteToExtBuf( UINT8 mLength ) /* 不會調用該子程序 */
{
mLength --; /* 該操作無意義,只是避免出現警告信息 */
}
#ifdef EN_DISK_WRITE
void xReadFromExtBuf( UINT8 mLength ) /* 不會調用該子程序 */
{
mLength --; /* 該操作無意義,只是避免出現警告信息 */
}
#endif
#endif
UINT8 CH375LibInit( void ) /* 初始化CH375程序庫和CH375芯片,操作成功返回0 */
{
CH375LibConfig = LIB_CFG_VALUE; /* CH375程序庫配置值 */
DISK_BASE_BUF[0] = 0; /* 該操作無意義,只是為了防止編譯器優化時不產生DISK_BASE_BUF緩沖區 */
if ( CH375GetVer( ) < CH375_LIB_VER ) return( 0xFF ); /* 獲取當前子程序庫的版本號,版本太低則返回錯誤 */
return( CH375Init( ) ); /* 初始化CH375 */
}
#endif
#ifdef __cplusplus
}
#endif
#endif
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -