📄 ch375hf(4).h
字号:
#endif
#ifndef UINT8D
typedef unsigned char data UINT8D;
#endif
#ifndef UINT16D
typedef unsigned short data UINT16D;
#endif
#ifndef UINT32D
typedef unsigned long data UINT32D;
#endif
#ifndef UINT8I
typedef unsigned char idata UINT8I;
#endif
#ifndef UINT16I
typedef unsigned short idata UINT16I;
#endif
#ifndef UINT32I
typedef unsigned long idata UINT32I;
#endif
#ifndef UINT8X
typedef unsigned char xdata UINT8X;
#endif
#ifndef UINT16X
typedef unsigned short xdata UINT16X;
#endif
#ifndef UINT32X
typedef unsigned long xdata UINT32X;
#endif
#ifndef PUINT8
typedef unsigned char data *PUINT8;
#endif
#ifndef PUINT16
typedef unsigned short data *PUINT16;
#endif
#ifndef PUINT32
typedef unsigned long data *PUINT32;
#endif
#ifndef PUINT8I
typedef unsigned char idata *PUINT8I;
#endif
#ifndef PUINT16I
typedef unsigned short idata *PUINT16I;
#endif
#ifndef PUINT32I
typedef unsigned long idata *PUINT32I;
#endif
#ifndef PUINT8X
typedef unsigned char xdata *PUINT8X;
#endif
#ifndef PUINT16X
typedef unsigned short xdata *PUINT16X;
#endif
#ifndef PUINT32X
typedef unsigned long xdata *PUINT32X;
#endif
#ifndef UINT8V
typedef unsigned char volatile data UINT8V;
#endif
#ifndef UINT8XV
typedef unsigned char volatile xdata UINT8XV;
#endif
//-------------------------------------------------------------------------------------------------
// 错误码
//-------------------------------------------------------------------------------------------------
//
// 代码0XH用于USB设备方式的操作状态代码,由CH375返回,是USB设备模式的中断状态
#define ERR_USB_DAT_DOWN 0x02 // USB设备模式: 数据下传成功,上位机下传的数据已经在模块中
#define ERR_USB_DAT_UP 0x0A // USB设备模式: 数据上传成功,模块中的上传数据已经被上位机取走
// 代码1XH用于USB主机方式的操作状态代码,由CH375返回
#define ERR_USB_CONNECT 0x15 // 检测到USB设备连接事件,磁盘已经连接
#define ERR_USB_DISCON 0x16 // 检测到USB设备断开事件,磁盘已经断开
#define ERR_USB_DISK_ERR 0x1F // USB存储器操作失败,在初始化时可能是USB存储器不支持,在读写操作中可能是磁盘损坏或者已经断开
// 以下是阶段性的状态码,用于请求数据交换,不是最终的操作状态
#define USB_INT_DISK_READ 0x1D // USB存储器读数据块,只用于CMD_FileRead命令,请求数据读出
#define USB_INT_DISK_WRITE 0x1E // USB存储器写数据块,只用于CMD_FileWrite命令,请求数据写入
#define USB_INT_DISK_RETRY 0xEE // USB存储器读写数据块失败重试,只用于CMD_FileRead命令和CMD_FileRead命令,操作失败重试
// USB_INT_DISK_RETRY重试状态码要求用户端程序回改文件数据缓冲区指针,以便重新发送或者接收文件数据,
// 在USB_INT_DISK_RETRY重试状态码之后用户端程序将收到两个字节的数据,也就是一个16位的数据,指定需要回改指针的字节数,大端时高字节在前,小端时低字节在前
// 代码2XH-3XH用于USB主机方式的通讯失败代码,由CH375返回
//
// 以下是最终状态码
#define ERR_SUCCESS 0x00 // 操作成功
#define ERR_CH375_ERROR 0x81 // CH375硬件错误,可能需要复位CH375
#define ERR_DISK_DISCON 0x82 // 磁盘尚未连接,可能磁盘已经断开
#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 // 搜索到与通配符相匹配的文件名,文件名及其完整路径在命令缓冲区中,如果需要使用,应该打开该文件
// 其余错误代码未定义,可以发出命令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_OPEN_ROOT 0x12 // 已经打开根目录,扇区模式,只能以扇区为单位读写目录的内容,使用后必须关闭,注意FAT12/FAT16根目录是固定长度
#define DISK_OPEN_DIR 0x13 // 已经打开子目录,扇区模式,只能以扇区为单位读写目录的内容
#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 )
/* 文件属性 UINT8 */
/* bit0 bit1 bit2 bit3 bit4 bit5 bit6 bit7 */
/* 只 隐 系 卷 目 存 未定义 */
/* 读 藏 统 标 录 档 */
/* 文件时间 UINT16, CMD_PARAM.Modify.mFileTime */
/* Time = (Hour<<11) + (Minute<<5) + (Second>>1) */
#define MAKE_FILE_TIME( h, m, s ) ( (h<<11) + (m<<5) + (s>>1) ) /* 生成指定时分秒的文件时间数据 */
/* 文件日期 UINT16, 适用于CMD_PARAM.Modify.mFileDate */
/* Date = ((Year-1980)<<9) + (Month<<5) + Day */
#define MAKE_FILE_DATE( y, m, d ) ( ((y-1980)<<9) + (m<<5) + d ) // 生成指定年月日的文件日期数据
//#define MAKE_FILE_DATE( y, m, d ) ( ((y+20)<<9) + (m<<5) + d ) // 生成指定年月日的文件日期数据 (For 12C887)
//-------------------------------------------------------------------------------------------------
// 文件名
//-------------------------------------------------------------------------------------------------
// 适用于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 30 // 最大路径长度,含所有斜杠分隔符和小数点间隔符以及路径结束符00H
#endif
#ifndef MAX_BYTE_IO
#define MAX_BYTE_IO ( MAX_PATH_LEN - 1 ) // 以字节为单位单次读写文件时的最大长度,超过该长度可以分多次读写
#endif
/*
#ifndef MAX_PATH_LEN
#define MAX_PATH_LEN 65 // 最大路径长度,含所有斜杠分隔符和小数点间隔符以及路径结束符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 ) // 以字节为单位单次读写文件时的最大长度,超过该长度可以分多次读写,并口方式下最大值为61
#endif
#if MAX_BYTE_IO > 64
#undef MAX_BYTE_IO
#define MAX_BYTE_IO 64
#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_FileDirInfo 0x75 /* 存取当前已打开文件的目录信息 */
#define CMD_DirCreate 0x76 /* 新建目录并打开,如果目录已经存在则直接打开 */
#define CMD_FileReadLast 0x77 /* 从当前文件的尾部读取不足一个扇区长度的零碎数据 */
#define CMD_StreamRead 0x7E /* 数据流模式读文件,只支持串口,只支持文本 */
#define CMD_StreamWrite 0x7F /* 数据流模式写文件,只支持串口,只支持文本 */
//-------------------------------------------------------------------------------------------------
// USB设备方式命令码
//-------------------------------------------------------------------------------------------------
//
#define CMD_SetUsbId 0x12 /* USB设备模式: 设置USB设备的厂商VID和产品PID */
#define CMD_SetUsbMode 0x15 /* USB设备模式: 设置USB主机/设备工作模式,只支持串口 */
#define CMD_ReadUsbData 0x28 /* USB设备模式: 从模块的数据下传端点读取数据块 */
#define CMD_WriteUsbData 0x2B /* USB设备模式: 向模块的数据上传端点写入数据块 */
//-------------------------------------------------------------------------------------------------
// 辅助命令码
//-------------------------------------------------------------------------------------------------
//
#define CMD_GetVer 0x0A /* 获取当前模块的版本号 */
#define CMD_ResetInit 0x0B /* 复位并重新初始化CH375以及模块 */
#define CMD_BaudRate 0xA5 /* 设置串口通讯波特率 */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -