#ifndef _APP_SOUND_BOX_ #define _APP_SOUND_BOX_ #include "typedef.h" #include "sdfile.h" #include "fs.h" #include "asm/sfc_norflash_api.h" /* * 波特率默认为 115200 * 对于物理串口,且是异步形式的协议,封包方式如下 * * CRC是 CRC16(L + T + SQ + DATA) * 其中,L是指(T+SQ+DATA)的长度 * DATA包含CMD与具体的数据流 * * +----+----+----+--+--+---+---+----+---....---+ * | 5A | AA | A5 | CRC | L | T | SQ | DATA | * +----+----+----+--+--+---+---+----+---....---+ * * T 表示包的类型,其中 * 0x00 -- 表示回复,其中SQ是对应需要回应的包的序号 * 无论哪种模式下,回复包都用该种类型 * 0x12 -- 表示配置文件通道,是主动发送数据 * 例如,在配置工具中,PC往小机或者小机往PC主动发都用这个 */ /*T 表示包的类型*/ #define REPLY_STYLE 0x00 //无论哪种模式下,回复包都用该种类型 #define INITIATIVE_STYLE 0x12 //主动发送数据的包用该类型 /* *0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+ | VERSION |AT| X| X| X| X| X| X| X| X| X| X| X| +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+ */ #define PROTOCOL_VER_AT_NEW 0x0001 //使用新模式 #define PROTOCOL_VER_AT_OLD 0x0011 //使用旧模式 /*该文件所属文件ID为0*/ #define CFG_TOOL_FILEID 0x00000000 /*该文件所属文件ID为0*/ #if ((defined CONFIG_NEW_CFG_TOOL_ENABLE) && (defined CONFIG_SOUNDBOX)) #define CFG_TOOL_FILE SDFILE_RES_ROOT_PATH"cfg_tool.bin" #else #define CFG_TOOL_FILE SDFILE_APP_ROOT_PATH"cfg_tool.bin" #endif /*旧调音工具eq文件所属文件ID为1*/ #define CFG_OLD_EQ_FILEID 0x00000001 #define CFG_OLD_EQ_FILE SDFILE_RES_ROOT_PATH"eq_cfg_hw.bin" /*旧调音工具混响文件所属文件ID为2*/ #define CFG_OLD_EFFECT_FILEID 0x00000002 #define CFG_OLD_EFFECT_FILE SDFILE_RES_ROOT_PATH"effects_cfg.bin" /*新调音工具eq文件所属文件ID为3*/ #define CFG_EQ_FILEID 0x00000003 #define CFG_EQ_FILE SDFILE_RES_ROOT_PATH"eq_cfg_hw.bin" /*****************************************************************/ /****PC与小机使用到的CMD,CMD包含在DATA中,为DATA的第一个Byte*****/ /*****************************************************************/ #define ONLINE_SUB_OP_QUERY_BASIC_INFO 0x00000023 //查询固件的基本信息 #define ONLINE_SUB_OP_QUERY_FILE_SIZE 0x0000000B //查询文件大小 #define ONLINE_SUB_OP_QUERY_FILE_CONTENT 0x0000000C //读取文件内容 #define ONLINE_SUB_OP_PREPARE_WRITE_FILE 0x00000022 //准备写入文件 #define ONLINE_SUB_OP_READ_ADDR_RANGE 0x00000027 //读取地址范围内容 #define ONLINE_SUB_OP_ERASE_ADDR_RANGE 0x00000024 //擦除地址范围内容 #define ONLINE_SUB_OP_WRITE_ADDR_RANGE 0x00000025 //写入地址范围内容 #define ONLINE_SUB_OP_ENTER_UPGRADE_MODE 0x00000026 //进入升级模式 /*收到其他工具的数据*/ #define DEFAULT_ACTION 0x000000FF //其他工具的数据 /*****************************************************************/ /*****小机接收PC的DATA,具体携带的数据,依据命令不同而不同**********/ /*****************************************************************/ //查询固件的基本信息 typedef struct { uint32_t cmd_id; //命令号,为0x23 } R_QUERY_BASIC_INFO; //查询文件大小 typedef struct { uint32_t cmd_id; //命令号,为0x0B uint32_t file_id; //查询的文件的ID,配置文件的ID为0 } R_QUERY_FILE_SIZE; //读取文件内容 typedef struct { uint32_t cmd_id; //命令号,为0x0C uint32_t file_id; //文件ID uint32_t offset; //偏移 uint32_t size; } R_QUERY_FILE_CONTENT; //准备写入文件 typedef struct { uint32_t cmd_id; //命令号,为0x22 uint32_t file_id; //文件ID uint32_t size; //文件大小 } R_PREPARE_WRITE_FILE; //读取地址范围内容 typedef struct { uint32_t cmd_id; //命令号,为0x23 uint32_t addr; //flash的物理地址 uint32_t size; //读取的范围大小 } R_READ_ADDR_RANGE; //擦除地址范围内容 typedef struct { uint32_t cmd_id; //命令号,为0x24 uint32_t addr; //起始地址 uint32_t size; //擦除大小 } R_ERASE_ADDR_RANGE; //写入地址范围内容 typedef struct { uint32_t cmd_id; //命令号,为0x25 uint32_t addr; //物理地址 uint32_t size; //内容大小 /*uint8_t body[0];*/ //具体内容,大小为size } R_WRITE_ADDR_RANGE; //进入升级模式 typedef struct { uint32_t cmd_id; //命令号,为0x26 } R_ENTER_UPGRADE_MODE; /*****************************************************************/ /*******小机返回PC发送的DATA,具体的内容,依据命令不同而不同********/ /*****************************************************************/ //(1)查询固件的基本信息 typedef struct { uint16_t protocolVer; //协议版本,目前为1 char progCrc[32]; //固件的CRC,返回字符串,\0 结尾 char sdkName[32]; //SDK名字,\0 结尾 char pid[16]; //PID,\0 结尾(注意最长是16字节,16字节的时候,末尾不需要0) char vid[16]; //VID,\0 结尾 } S_QUERY_BASIC_INFO; /***************************/ // 其中 protocolVer 格式如下: // 小端格式 // 低位 -> 高位 /* *0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+ | VERSION |AT| X| X| X| X| X| X| X| X| X| X| X| +--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+ */ // X 表示未使用 // VERSION 目前为 1 // AT 表示是否禁用ATK, //(2)查询文件大小 typedef struct { uint32_t file_size; //文件大小 } S_QUERY_FILE_SIZE; //(3)读取文件内容 /* * 返回:具体的文件内容,长度为命令中的size参数 * 注:PC工具在获取配置文件的大小后,会自行决定拆分成几次命令读取 */ //(4)准备写入文件 /* * 例如,cfg_tool.bin 本身的物理地址可能是 100,而擦除单元是 4K(4096),cfg_tool.bin 本身大小是 3999 字节,则 * file_addr = 100, file_size = 3999, earse_unit = 4096。 * 注意,接下来,PC 端会读取```[0, 8192)```这个范围的内容,修改掉```[100,4099]```的内容,然后再通过其他命令, * 把```[0,8192)```这范围的内容写回去。 */ typedef struct { uint32_t file_addr; //配置文件真实物理地址 uint32_t file_size; //配置文件(cfg_tool.bin)本身的大小 uint32_t earse_unit; //flash 擦除单元(如 4K 的时候,填 4096) } S_PREPARE_WRITE_FILE; //(5)读取地址范围内容 /* * 返回:具体的文件内容,长度为命令中的size参数 * 注:PC工具在获取配置文件的大小后,会自行决定拆分成几次命令读取 */ //(6)擦除地址范围内容 /* *返回两个字节的内容,"FA"或者"OK",表示失败或者成功 */ //(7)写入地址范围内容 /* *返回两个字节的内容,"FA"或者"OK",表示失败或者成功 */ //(8)进入升级模式 /* *小机收到命令后,进入升级模式 */ #if (TCFG_SOUNDBOX_TOOL_ENABLE || TCFG_ONLINE_ENABLE) /*usb或者串口收到的数据流通过这个接口传入进行数据解析*/ void online_cfg_tool_data_deal(void *buf, u32 len); /*传入data 组包发送给PC*/ void all_assemble_package_send_to_pc(u8 id, u8 sq, u8 *buf, u32 len); #endif struct tool_interface { u8 id; void (*tool_message_deal)(u8 *buf, u32 len); }; #define REGISTER_DETECT_TARGET(interface) \ static struct tool_interface interface SEC_USED(.tool_interface) extern struct tool_interface tool_interface_begin[]; extern struct tool_interface tool_interface_end[]; #define list_for_each_tool_interface(p) \ for (p = tool_interface_begin; p < tool_interface_end; p++) #endif