?? ch375hfm.h
字號:
#endif
#ifndef NO_DEFAULT_CH375_F_QUERY
extern UINT8 CH375FileQuery( void ); /* 查詢當前文件的信息 */
#endif
extern void xQueryInterrupt( void ); /* 外部定義的被CH375程序庫調用的子程序,查詢CH375中斷并更新中斷狀態 */
extern void xDelay100uS( void ); /* 外部定義的被CH375程序庫調用的子程序,延時100uS */
#ifdef EN_DISK_WRITE
extern void xDelayAfterWrite( void ); /* 外部定義的被CH375程序庫調用的子程序,寫操作后延時 */
#endif
extern void xFileNameEnumer( void ); /* 外部定義的被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; /* 命令參數 */
//#pragma SAVE
//#pragma PACK(4)
#ifdef DISK_BASE_BUF_ADDR
__align(8) UINT8 DISK_BASE_BUF[512] _at_ DISK_BASE_BUF_ADDR; /* 外部RAM的磁盤數據緩沖區,緩沖區長度為一個扇區的長度,起始地址必須為8字節邊界地址 */
#else
__align(8) UINT8 DISK_BASE_BUF[512]; /* 外部RAM的磁盤數據緩沖區,緩沖區長度為一個扇區的長度,起始地址必須為8字節邊界地址 */
#endif
//#pragma RESTORE
#ifdef FILE_DATA_BUF_LEN
//#pragma SAVE
//#pragma PACK(4)
#ifdef FILE_DATA_BUF_ADDR
__align(8) UINT8 FILE_DATA_BUF[ FILE_DATA_BUF_LEN ] _at_ FILE_DATA_BUF_ADDR; /* 外部RAM的文件數據緩沖區,緩沖區長度不小于一次讀寫的數據長度,起始地址建議為8字節邊界地址 */
#else
__align(8) UINT8 FILE_DATA_BUF[ FILE_DATA_BUF_LEN ]; /* 外部RAM的文件數據緩沖區,緩沖區長度不小于一次讀寫的數據長度,起始地址建議為8字節邊界地址 */
#endif
//#pragma RESTORE
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_F_ENUM /* 在應用程序中定義NO_DEFAULT_CH375_F_ENUM可以禁止默認的枚舉文件程序,然后用自行編寫的程序代替它 */
UINT8 CH375FileEnumer( void ) /* 枚舉文件 */
{
UINT8 status;
status = CH375FileOpen( );
if ( status == ERR_FOUND_NAME ) status = ERR_SUCCESS; /* 操作成功 */
return( status );
}
#endif
#ifndef NO_DEFAULT_CH375_F_QUERY /* 在應用程序中定義NO_DEFAULT_CH375_F_QUERY可以禁止默認的查詢當前文件的信息程序,然后用自行編寫的程序代替它 */
UINT8 CH375FileQuery( void ) /* 查詢當前文件的信息 */
{
PUINT8 buf;
UINT8 count;
buf = (PUINT8)( & mCmdParam.Modify.mFileSize );
for ( count = sizeof( mCmdParam.Modify ); count != 0; count -- ) {
*buf = 0xFF; /* 輸入參數全部無效,僅查詢不修改 */
buf ++;
}
return( CH375FileModify( ) );
}
#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 CH375Interrupt( void ) __irq /* 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
#ifndef NO_DEFAULT_DELAY_100US /* 在應用程序中定義NO_DEFAULT_DELAY_100US可以禁止默認的延時100uS子程序,然后用自行編寫的程序代替它 */
void xDelay100uS( void ) /* 延時100uS */
{
UINT32 count;
for ( count = 1300; count != 0; count -- ); /* 延時100uS,4x20nS@50MHz */
}
#endif
#ifdef EN_DISK_WRITE
#ifndef NO_DEFAULT_DELAY_WRITE /* 在應用程序中定義NO_DEFAULT_DELAY_WRITE可以禁止默認的寫操作后延時程序,然后用自行編寫的程序代替它 */
void xDelayAfterWrite( void ) /* 寫操作后延時 */
{
UINT32 count;
for ( count = 2600; count != 0; count -- ); /* 延時200uS左右 */
}
#endif
#endif
#ifndef NO_DEFAULT_FILE_ENUMER /* 在應用程序中定義NO_DEFAULT_FILE_ENUMER可以禁止默認的文件名枚舉回調程序,然后用自行編寫的程序代替它 */
void xFileNameEnumer( void ) /* 文件名枚舉回調子程序 */
{
/* 如果指定枚舉序號CH375vFileSize為0xFFFFFFFF后調用FileOpen,那么每搜索到一個文件FileOpen都會調用本回調程序,
回調程序xFileNameEnumer返回后,FileOpen遞減CH375vFileSize并繼續枚舉直到搜索不到文件或者目錄。建議做法是,
在調用FileOpen之前定義一個全局變量為0,當FileOpen回調本程序后,本程序由CH375vFdtOffset得到結構FAT_DIR_INFO,
分析結構中的DIR_Attr以及DIR_Name判斷是否為所需文件名或者目錄名,記錄相關信息,并將全局變量計數增量,
當FileOpen返回后,判斷返回值如果是ERR_MISS_FILE或ERR_FOUND_NAME都視為操作成功,全局變量為搜索到的有效文件數。
如果在本回調程序xFileNameEnumer中將CH375vFileSize置為1,那么可以通知FileOpen提前結束搜索。以下是回調程序例子 */
#if 0
#ifdef FILE_DATA_BUF_LEN
UINT8 i;
UINT16 FileCount;
P_FAT_DIR_INFO pFileDir;
PUINT8 NameBuf;
pFileDir = (P_FAT_DIR_INFO)( (PUINT8)(&DISK_BASE_BUF[0]) + CH375vFdtOffset ); /* 當前FDT的起始地址 */
FileCount = (UINT16)( 0xFFFFFFFF - CH375vFileSize ); /* 當前文件名的枚舉序號,CH375vFileSize初值是0xFFFFFFFF,找到文件名后遞減 */
if ( FileCount < FILE_DATA_BUF_LEN / 12 ) { /* 檢查緩沖區是否足夠存放,假定每個文件名需占用12個字節存放 */
NameBuf = & FILE_DATA_BUF[ FileCount * 12 ]; /* 計算保存當前文件名的緩沖區地址 */
for ( i = 0; i < 11; i ++ ) NameBuf[ i ] = pFileDir -> DIR_Name[ i ]; /* 復制文件名,長度為11個字符,未處理空格 */
if ( pFileDir -> DIR_Attr & ATTR_DIRECTORY ) NameBuf[ i ] = 1; /* 判斷是目錄名 */
NameBuf[ i ] = 0; /* 文件名結束符 */
}
#endif
#endif
}
#endif
#ifdef EXT_BLK_INTERFACE
#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 += (UINT32)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 += (UINT32)mCmdParam.WriteX.mDataBuffer; /* mDataBuffer中為負值 */
mCmdParam.WriteX.mDataBuffer = 0; /* 為了支持重試,在調用CH375FileWriteX之前也應該清0 */
}
}
#endif
#endif
#else /* LIB_CFG_FILE_IO != 0,文件讀寫的數據的復制方式不是"外部子程序" */
#ifdef FILE_DATA_BUF_LEN
void xWriteToExtBuf( UINT8 mLength ) /* 不會調用該子程序 */
{
mLength --; /* 該操作無意義,只是避免出現警告信息 */
}
#ifdef EN_DISK_WRITE
void xReadFromExtBuf( UINT8 mLength ) /* 不會調用該子程序 */
{
mLength --; /* 該操作無意義,只是避免出現警告信息 */
}
#endif
#endif
#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 + -