This commit is contained in:
huxi
2025-12-03 11:12:34 +08:00
parent c23ae4f24c
commit bc195654bf
8163 changed files with 3799544 additions and 92 deletions
+263
View File
@@ -0,0 +1,263 @@
#ifdef SUPPORT_MS_EXTENSIONS
#pragma bss_seg(".testbox_update.data.bss")
#pragma data_seg(".testbox_update.data")
#pragma const_seg(".testbox_update.text.const")
#pragma code_seg(".testbox_update.text")
#endif
#include "update_loader_download.h"
#include "update.h"
#include "btctrler_task.h"
#include "app_config.h"
#include "clock.h"
#if TCFG_TEST_BOX_WIRELESS_EN
#if defined(CONFIG_SPP_AND_LE_CASE_ENABLE) || defined(CONFIG_HID_CASE_ENABLE)
#include "lib_profile_cfg.h"
#else
#include "bt_profile_cfg.h"
#endif
#if (RCSP_MODE == RCSP_MODE_WATCH)
#include "rcsp_task.h"
#endif
#define LOG_TAG "[TEST-UPDATE]"
#define LOG_INFO_ENABLE
#define LOG_ERROR_ENABLE
#include "debug.h"
extern u8 check_le_conn_disconnet_flag(void);
extern void ble_app_disconnect(void);
extern void ll_hci_destory(void);
extern void ram_protect_close(void);
extern void update_close_hw(void *filter_name);
extern void btctrler_testbox_update_msg_handle_register(void (*handle)(int));
extern void __bt_updata_reset_bt_bredrexm_addr(void);
extern int __bt_updata_save_connection_info(void);
extern const update_op_api_t lmp_ch_update_op;
extern const update_op_api_t ble_ll_ch_update_op;
static u8 ble_update_ready_jump_flag = 0;
extern void latch_reset(void);
static void testbox_bt_classic_update_private_param_fill(UPDATA_PARM *p)
{
}
static void testbox_bt_classic_update_before_jump_handle(int type)
{
if (CONFIG_UPDATE_ENABLE && CONFIG_UPDATE_BT_LMP_EN) {
#if TCFG_USER_TWS_ENABLE || TCFG_USER_BLE_ENABLE
log_info("close ble hw\n");
ll_hci_destory();
#endif
y_printf("\n >>>[test]:func = %s,line= %d\n", __FUNCTION__, __LINE__);
update_close_hw("bredr");
if (__bt_updata_save_connection_info()) {
log_error("bt save conn info fail!\n");
return;
}
ram_protect_close();
//note:last func will not return;
#if (defined CONFIG_CPU_BR36 || defined CONFIG_CPU_BR27 || defined CONFIG_CPU_BR28)
__bt_updata_reset_bt_bredrexm_addr(); //仅36、27、28使用跳转,后续CPU升级都直接reset
#else
cpu_reset();
#endif
}
}
static void testbox_bt_classic_update_state_cbk(int type, u32 state, void *priv)
{
update_ret_code_t *ret_code = (update_ret_code_t *)priv;
if (ret_code) {
log_info("state:%x err:%x\n", ret_code->stu, ret_code->err_code);
}
switch (state) {
case UPDATE_CH_EXIT:
if (UPDATE_DUAL_BANK_IS_SUPPORT()) {
if ((0 == ret_code->stu) && (0 == ret_code->err_code)) {
log_info("bt update succ\n");
update_result_set(UPDATA_SUCC);
} else {
log_info("bt update fail\n");
update_result_set(UPDATA_DEV_ERR);
}
} else {
if ((0 == ret_code->stu) && (0 == ret_code->err_code)) {
//update_mode_api(BT_UPDATA);
update_mode_api_v2(BT_UPDATA,
testbox_bt_classic_update_private_param_fill,
testbox_bt_classic_update_before_jump_handle);
}
}
break;
}
}
u8 ble_update_get_ready_jump_flag(void)
{
return ble_update_ready_jump_flag;
}
static void testbox_ble_update_private_param_fill(UPDATA_PARM *p)
{
u8 addr[6];
extern int le_controller_get_mac(void *addr);
if (BT_MODULES_IS_SUPPORT(BT_MODULE_LE) && CONFIG_UPDATE_ENABLE && CONFIG_UPDATE_BLE_TEST_EN) {
le_controller_get_mac(addr);
//memcpy(p->parm_priv, addr, 6);
update_param_priv_fill(p, addr, sizeof(addr));
puts("ble addr:\n");
put_buf(p->parm_priv, 6);
}
}
static void testbox_ble_update_before_jump_handle(int type)
{
if (BT_MODULES_IS_SUPPORT(BT_MODULE_LE) && CONFIG_UPDATE_ENABLE && CONFIG_UPDATE_BLE_TEST_EN) {
#if (CPU_CORE_NUM == 1)
local_irq_enable(); //解决ll_hci_destory内调用mutex_pend接口失败问题
#endif
ll_hci_destory();
#if (CPU_CORE_NUM == 1)
local_irq_disable();
#endif
}
#if CONFIG_UPDATE_JUMP_TO_MASK
y_printf(">>>[test]:latch reset update\n");
latch_reset();
#else
cpu_reset();
#endif
}
static void testbox_ble_update_state_cbk(int type, u32 state, void *priv)
{
update_ret_code_t *ret_code = (update_ret_code_t *)priv;
if (ret_code) {
printf("ret_code->stu:%d err_code:%d\n", ret_code->stu, ret_code->err_code);
}
switch (state) {
case UPDATE_CH_EXIT:
if (UPDATE_DUAL_BANK_IS_SUPPORT()) {
if ((0 == ret_code->stu) && (0 == ret_code->err_code)) {
log_info("bt update succ\n");
update_result_set(UPDATA_SUCC);
} else {
log_info("bt update fail\n");
update_result_set(UPDATA_DEV_ERR);
}
} else {
if ((0 == ret_code->stu) && (0 == ret_code->err_code)) {
/* #if TCFG_USER_BLE_ENABLE && (TCFG_BLE_DEMO_SELECT != DEF_BLE_DEMO_NULL) \ */
/* &&(TCFG_BLE_DEMO_SELECT != DEF_BLE_DEMO_ADV || defined(CONFIG_MESH_CASE_ENABLE))\ */
/* && (TCFG_BLE_DEMO_SELECT != DEF_BLE_DEMO_CLIENT) */
#if TCFG_USER_BLE_ENABLE
ble_update_ready_jump_flag = 1;
/* ble_app_disconnect(); */
#if (BT_AI_SEL_PROTOCOL & LE_AUDIO_CIS_RX_EN)
extern void le_hci_disconnect_all_connections(void);
extern void bt_le_audio_adv_enable(u8 enable);
le_hci_disconnect_all_connections();
bt_le_audio_adv_enable(0);
#endif
/* #if TCFG_BT_BLE_ADV_ENABLE */
extern void ble_module_enable(u8 en);
ble_module_enable(0);
/* #endif */
u8 cnt = 0;
while (!check_le_conn_disconnet_flag()) {
log_info("wait discon\n");
os_time_dly(2);
if (cnt++ > 5) {
break;
}
}
//update_mode_api(BLE_TEST_UPDATA);
update_mode_api_v2(BLE_TEST_UPDATA,
testbox_ble_update_private_param_fill,
testbox_ble_update_before_jump_handle);
#endif
}
}
break;
}
}
void testbox_update_msg_handle(int msg)
{
log_info("msg:%x\n", msg);
switch (msg) {
case MSG_BT_UPDATE_LOADER_DOWNLOAD_START:
if (CONFIG_UPDATE_ENABLE && CONFIG_UPDATE_BT_LMP_EN) {
// #if (RCSP_MODE == RCSP_MODE_WATCH)
// app_rcsp_task_prepare(0, RCSP_TASK_ACTION_WATCH_TRANSFER, 0);
// #endif
update_mode_info_t info = {
.type = BT_UPDATA,
.state_cbk = testbox_bt_classic_update_state_cbk,
.p_op_api = &lmp_ch_update_op,
.task_en = 1,
};
app_active_update_task_init(&info);
}
break;
#if TCFG_USER_BLE_ENABLE
case MSG_BLE_TEST_OTA_LOADER_DOWNLOAD_START:
if (CONFIG_UPDATE_ENABLE && CONFIG_UPDATE_BLE_TEST_EN) {
update_mode_info_t info = {
.type = BLE_TEST_UPDATA,
.state_cbk = testbox_ble_update_state_cbk,
.p_op_api = &ble_ll_ch_update_op,
.task_en = 1,
};
app_active_update_task_init(&info);
}
break;
#endif
default:
log_error("not support update msg:%x\n", msg);
break;
}
}
void testbox_update_init(void)
{
if (CONFIG_UPDATE_ENABLE && (CONFIG_UPDATE_BLE_TEST_EN || CONFIG_UPDATE_BT_LMP_EN)) {
log_info("testbox msg handle reg:%x\n", testbox_update_msg_handle);
btctrler_testbox_update_msg_handle_register(testbox_update_msg_handle);
}
}
#else // TCFG_TEST_BOX_WIRELESS_EN
void testbox_update_init(void)
{
}
u8 ble_update_get_ready_jump_flag(void)
{
return 0;
}
#endif // TCFG_TEST_BOX_WIRELESS_EN