85 lines
2.5 KiB
C
85 lines
2.5 KiB
C
|
|
/*
|
|||
|
|
* launcher_fun.h
|
|||
|
|
*
|
|||
|
|
* Created on: Jul 28, 2025
|
|||
|
|
* Author: cc
|
|||
|
|
*/
|
|||
|
|
|
|||
|
|
#ifndef _BOOTLOAD_FUN_H_
|
|||
|
|
#define _BOOTLOAD_FUN_H_
|
|||
|
|
|
|||
|
|
#include "ch564.h"
|
|||
|
|
#include "uart.h"
|
|||
|
|
#include "mcu_flash.h"
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
#define BCOMM_CMD_Handshake 0xC0
|
|||
|
|
#define BCOMM_CMD_Jump 0xC1
|
|||
|
|
#define BCOMM_CMD_SetInfo 0xC2
|
|||
|
|
#define BCOMM_CMD_WriteFlash 0xC3
|
|||
|
|
#define BCOMM_CMD_ReadFlash 0xC4
|
|||
|
|
#define BCOMM_CMD_EraseFlash 0xC5
|
|||
|
|
#define BCOMM_CMD_WriteEEPROM 0xC6
|
|||
|
|
#define BCOMM_CMD_ReadEEPROM 0xC7
|
|||
|
|
#define BCOMM_CMD_EraseEEPROM 0xC8
|
|||
|
|
#define BCOMM_CMD_CheckData 0xC9
|
|||
|
|
|
|||
|
|
#define BCOMM_CMD_ReplySUCC 0x00
|
|||
|
|
#define BCOMM_CMD_ReplyFAIL 0x01
|
|||
|
|
|
|||
|
|
#define BCOMM_ParaSize 4096
|
|||
|
|
|
|||
|
|
|
|||
|
|
typedef enum
|
|||
|
|
{
|
|||
|
|
BCOMM_FMT_TXAddr,
|
|||
|
|
BCOMM_FMT_SN,
|
|||
|
|
BCOMM_FMT_TYPE,
|
|||
|
|
BCOMM_FMT_RXAddr,
|
|||
|
|
BCOMM_FMT_LEN_L,
|
|||
|
|
BCOMM_FMT_LEN_H,
|
|||
|
|
BCOMM_FMT_CKS,
|
|||
|
|
BCOMM_FMT_CMD,
|
|||
|
|
BCOMM_FMT_PARAM,
|
|||
|
|
}BOOTLOAD_COMM_FMT_e;
|
|||
|
|
|
|||
|
|
#define UPDATE_RECORD_INFO_Size 0x28
|
|||
|
|
|
|||
|
|
typedef struct {
|
|||
|
|
|
|||
|
|
uint32_t spiflash_fw_count; //<2F>ⲿflash <20>̼<EFBFBD>д<EFBFBD><D0B4><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t spiflash_fw_succ; //<2F>ⲿflash <20>̼<EFBFBD>д<EFBFBD><D0B4><EFBFBD>ɹ<EFBFBD><C9B9>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t spiflash_fw_fail; //<2F>ⲿflash <20>̼<EFBFBD>д<EFBFBD><D0B4>ʧ<EFBFBD><CAA7><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
|
|||
|
|
uint32_t spiflash_logic_count; //<2F>ⲿflash <20><><EFBFBD><EFBFBD>д<EFBFBD><D0B4><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t spiflash_logic_succ; //<2F>ⲿflash <20><><EFBFBD><EFBFBD>д<EFBFBD><D0B4><EFBFBD>ɹ<EFBFBD><C9B9>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t spiflash_logic_fail; //<2F>ⲿflash <20><><EFBFBD><EFBFBD>д<EFBFBD><D0B4>ʧ<EFBFBD><CAA7><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
|
|||
|
|
uint32_t mcuflash_fw_count; //MCU flash <20>̼<EFBFBD>д<EFBFBD><D0B4><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t mcuflash_fw_succ; //MCU flash <20>̼<EFBFBD>д<EFBFBD><D0B4><EFBFBD>ɹ<EFBFBD><C9B9>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t mcuflash_fw_fail; //MCU flash <20>̼<EFBFBD>д<EFBFBD><D0B4>ʧ<EFBFBD><CAA7><EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD>
|
|||
|
|
uint32_t mcuflash_fw_failcount; //MCU flash <20>̼<EFBFBD><CCBC><EFBFBD>ǰд<C7B0><D0B4>ʧ<EFBFBD>ܴ<EFBFBD><DCB4><EFBFBD><EFBFBD><EFBFBD>ÿ<EFBFBD>θ<EFBFBD><CEB8>¹̼<C2B9><CCBC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ü<EFBFBD><C3BC><EFBFBD>
|
|||
|
|
|
|||
|
|
}UPDATE_RECORD_T;
|
|||
|
|
|
|||
|
|
extern G_SYS_FEATURE_T g_app_feature;
|
|||
|
|
extern G_SYS_FEATURE_T g_mcu_app_feature;
|
|||
|
|
extern UPDATE_RECORD_T g_update_recode; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ
|
|||
|
|
|
|||
|
|
extern uint8_t g_jump_flag; //<2F><>ת<EFBFBD><D7AA>־λ
|
|||
|
|
extern uint32_t g_Boot_Tick; //Bootʱ<74><CAB1><EFBFBD><EFBFBD> <20><>λ<EFBFBD><CEBB>ms
|
|||
|
|
extern uint32_t g_Boot_Time; //Bootʱ<74><CAB1> <20><>λ<EFBFBD><CEBB>ms
|
|||
|
|
|
|||
|
|
uint16_t CRC16_Check(uint8_t * aStr, uint16_t len);
|
|||
|
|
uint8_t Launcher_Uart_Upgrade_Process(UART_t *g_rev);
|
|||
|
|
|
|||
|
|
uint8_t Read_APP_Feature(void);
|
|||
|
|
uint8_t MCU_APP_Write(void);
|
|||
|
|
uint8_t SPIFLASH_Read_Update_Recode(UPDATE_RECORD_T *info);
|
|||
|
|
uint8_t SPIFLASH_Write_Update_Recode(UPDATE_RECORD_T *info);
|
|||
|
|
|
|||
|
|
void Jump_APP(uint32_t addr);
|
|||
|
|
|
|||
|
|
#endif /* MCU_DRIVER_INC_LAUNCHER_FUN_H_ */
|