📄 ch375hm.h
字号:
/*
****************************************
** Copyright (C) W.ch 1999-2004 **
** Web: http://www.winchiphead.com **
****************************************
** USB Host File Module @CH375 **
****************************************
*/
/* CH375 主机文件系统接口模块 */
/* 支持: FAT12/FAT16 */
/* U盘文件读写模块C语言头文件 */
#ifndef __CH375HM_H__
#define __CH375HM_H__
#define CH375HM_VER 0x16 /* 当前模块版本 */
/* ********************************************************************************************************************* */
/* 返回的操作状态码 */
/* 以下是事件通知状态码,检测到当前U盘已经连接或者已经断开,可以作为最终状态码 */
#define ERR_USB_CONNECT 0x15 /* 检测到USB设备连接事件,磁盘已经连接 */
#define ERR_DISK_DISCON 0x82 /* 检测到USB设备连接事件,磁盘已经断开,或者磁盘尚未连接 */
/* 以下是阶段性的状态码,用于请求数据交换,不是最终的操作状态 */
#define USB_INT_DISK_READ 0x1D /* USB存储器读数据块,只用于CMD_FileRead命令,请求数据读出 */
#define USB_INT_DISK_WRITE 0x1E /* USB存储器写数据块,只用于CMD_FileWrite命令,请求数据写入 */
/* 最终状态码 */
#define ERR_SUCCESS 0x00 /* 操作成功 */
#define ERR_CH375_ERROR 0x81 /* CH375硬件错误,可能需要复位CH375 */
#define ERR_STATUS_ERR 0x83 /* 磁盘状态错误,可能正在连接或者断开磁盘 */
#define ERR_MBR_ERROR 0x91 /* 磁盘的主引导记录无效,可能磁盘尚未分区或者尚未格式化 */
#define ERR_TYPE_ERROR 0x92 /* 磁盘分区类型不支持,只支持FAT12/FAT16/BigDOS/FAT32,需要由磁盘管理工具重新分区 */
#define ERR_BPB_ERROR 0xA1 /* 磁盘尚未格式化,或者参数错误,需要由WINDOWS采用默认参数重新格式化 */
#define ERR_TOO_LARGE 0xA2 /* 磁盘非正常格式化并且容量大于4GB,或者容量大于250GB,需要由WINDOWS采用默认参数重新格式化 */
#define ERR_FAT_ERROR 0xA3 /* 磁盘的文件系统不支持,只支持FAT12/FAT16/FAT32,需要由WINDOWS采用默认参数重新格式化 */
#define ERR_DISK_FULL 0xB1 /* 磁盘文件太满,剩余空间太少或者已经没有,需要磁盘整理 */
#define ERR_FDT_OVER 0xB2 /* 目录内文件太多,没有空闲的目录项,FAT12/FAT16根目录下的文件数应该少于500个,需要磁盘整理 */
#define ERR_MISS_DIR 0xB3 /* 指定路径的某个子目录没有找到,可能是目录名称错误 */
#define ERR_FILE_CLOSE 0xB4 /* 文件已经关闭,如果需要使用,应该重新打开文件 */
#define ERR_OPEN_DIR 0x41 /* 指定路径的目录被打开 */
#define ERR_MISS_FILE 0x42 /* 指定路径的文件没有找到,可能是文件名称错误 */
#define ERR_FOUND_NAME 0x43 /* 搜索到与通配符相匹配的文件名,文件名及其完整路径在命令缓冲区中,如果需要使用,应该打开该文件 */
#define ERR_USB_DISK_ERR 0x1F /* USB存储器操作失败,在初始化时可能是USB存储器不支持,在读写操作中可能是磁盘损坏或者已经断开 */
/* 其余错误代码未定义,可以发出命令CMD_QueryStatus查询模块状态并分析 */
/* ********************************************************************************************************************* */
/* 磁盘及文件状态,适用于CMD_PARAM.Status.mDiskStatus */
#define DISK_UNKNOWN 0x00 /* 尚未初始化,未知状态 */
#define DISK_DISCONNECT 0x01 /* 磁盘没有连接或者已经断开 */
#define DISK_CONNECT 0x02 /* 磁盘已经连接,但是尚未初始化或者无法识别该磁盘 */
#define DISK_MOUNTED 0x03 /* 磁盘已经初始化成功,但是尚未分析文件系统或者文件系统不支持 */
#define DISK_READY 0x10 /* 已经分析磁盘的文件系统并且能够支持 */
#define DISK_MISS_DIR 0x11 /* 文件的某个子目录未找到,可能是路径名错误 */
#define DISK_MISS_FILE 0x12 /* 文件没有找到,可能是文件已被删除或者文件名错误,可以再新建文件 */
#define DISK_OPEN_DIR 0x13 /* 已经找到子目录,并且已经打开,只能读取目录的内容,不能修改 */
#define DISK_OPEN_FILE 0x14 /* 已经打开文件,可以进行数据读写 */
#define DISK_OPEN_FILE 0x14 /* 已经打开文件,扇区模式,可以以扇区为单位进行数据读写 */
#define DISK_OPEN_FILE_B 0x15 /* 已经打开文件,字节模式,可以以字节为单位进行数据读写 */
/* ********************************************************************************************************************* */
/* FAT类型标志,适用于CMD_PARAM.Query.mDiskFat */
#define DISK_FS_UNKNOWN 0 /* 未知的文件系统 */
#define DISK_FAT12 1 /* FAT12文件系统 */
#define DISK_FAT16 2 /* FAT16文件系统 */
#define DISK_FAT32 3 /* FAT32文件系统 */
/* ********************************************************************************************************************* */
/* 文件属性,适用于CMD_PARAM.Modify.mFileAttr */
#define ATTR_READ_ONLY 0x01 /* 文件为只读属性 */
#define ATTR_HIDDEN 0x02 /* 文件为隐含属性 */
#define ATTR_SYSTEM 0x04 /* 文件为系统属性 */
#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 */
/* 只 隐 系 卷 目 存 未定义 */
/* 读 藏 统 标 录 档 */
/* 文件时间 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) ) /* 生成指定时分秒的文件时间数据 */
/* 文件日期 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 ) /* 生成指定年月日的文件日期数据 */
/* ********************************************************************************************************************* */
/* 文件名,适用于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 60 /* 最大路径长度,含所有斜杠分隔符和小数点间隔符以及路径结束符00H */
#endif
#if MAX_PATH_LEN > 62
#undef MAX_PATH_LEN
#define MAX_PATH_LEN 62
#endif
#ifndef MAX_BYTE_IO
#define MAX_BYTE_IO 60 /* 以字节为单位单次读写文件时的最大长度,超过该长度可以分多次读写 */
#endif
#if MAX_BYTE_IO > 61
#undef MAX_BYTE_IO
#define MAX_BYTE_IO 61
#endif
/* ********************************************************************************************************************* */
/* 外部命令码 */
#define CMD_QueryStatus 0x60 /* 查询当前模块的状态 */
#define CMD_DiskQuery 0x61 /* 查询磁盘信息 */
#define CMD_FileEnumer 0x63 /* 枚举文件,返回文件名 */
#define CMD_FileOpen 0x64 /* 打开文件 */
#define CMD_FileCreate 0x65 /* 新建文件并打开,如果文件已经存在则先删除后再新建 */
#define CMD_FileErase 0x66 /* 删除文件并关闭 */
#define CMD_FileClose 0x67 /* 关闭当前文件 */
#define CMD_FileQuery 0x68 /* 查询当前文件的信息 */
#define CMD_FileModify 0x69 /* 查询或者修改当前文件的信息 */
#define CMD_FileLocate 0x6A /* 移动当前文件指针 */
#define CMD_FileRead 0x6B /* 从当前文件读取数据 */
#define CMD_FileWrite 0x6C /* 向当前文件写入数据 */
#define CMD_ByteLocate 0x7A /* 以字节为单位移动当前文件指针 */
#define CMD_ByteRead 0x7B /* 以字节为单位从当前文件读取数据块 */
#define CMD_ByteWrite 0x7C /* 以字节为单位向当前文件写入数据块 */
#define CMD_BulkOnlyCmd 0x70 /* 执行基于BulkOnly协议的命令 */
#define CMD_DiskReady 0x71 /* 查询磁盘是否准备好 */
#define CMD_DiskSize 0x72 /* 查询磁盘容量 */
#define CMD_DirCreate 0x76 /* 新建目录并打开,如果目录已经存在则直接打开 */
#define CMD_FileReadLast 0x77 /* 从当前文件的尾部读取不足一个扇区长度的零碎数据 */
/* 辅助命令码 */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -