2905 lines
88 KiB
C++
2905 lines
88 KiB
C++
/***************************************************************************
|
|
*
|
|
* Copyright 2015-2019 BES.
|
|
* All rights reserved. All unpublished rights reserved.
|
|
*
|
|
* No part of this work may be used or reproduced in any form or by any
|
|
* means, or stored in a database or retrieval system, without prior written
|
|
* permission of BES.
|
|
*
|
|
* Use of this work is governed by a license granted by BES.
|
|
* This work contains confidential and proprietary information of
|
|
* BES. which is protected by copyright, trade secret,
|
|
* trademark and other intellectual property rights.
|
|
*
|
|
****************************************************************************/
|
|
#include "stdio.h"
|
|
#include "cmsis_os.h"
|
|
#include "list.h"
|
|
#include "string.h"
|
|
#include "hal_timer.h"
|
|
#include "hal_trace.h"
|
|
#include "hal_bootmode.h"
|
|
#include "hal_sleep.h"
|
|
#include "pmu.h"
|
|
#include "audioflinger.h"
|
|
#include "apps.h"
|
|
#include "app_thread.h"
|
|
#include "app_key.h"
|
|
#include "app_bt_media_manager.h"
|
|
#include "app_pwl.h"
|
|
#include "app_audio.h"
|
|
#include "app_overlay.h"
|
|
#include "app_battery.h"
|
|
#include "app_utils.h"
|
|
#include "app_status_ind.h"
|
|
#include "bt_drv_interface.h"
|
|
#include "besbt.h"
|
|
#include "norflash_api.h"
|
|
#include "nvrecord.h"
|
|
#include "nvrecord_dev.h"
|
|
#include "nvrecord_env.h"
|
|
#include "crash_dump_section.h"
|
|
#include "log_section.h"
|
|
#include "factory_section.h"
|
|
#include "a2dp_api.h"
|
|
#include "me_api.h"
|
|
#include "os_api.h"
|
|
#include "btapp.h"
|
|
#include "app_bt.h"
|
|
#include "bt_if.h"
|
|
#include "gapm_task.h"
|
|
#include "app_ble_include.h"
|
|
#include "app_bt_func.h"
|
|
#include "tgt_hardware.h"
|
|
#include "hal_i2c.h"
|
|
#ifdef __AI_VOICE__
|
|
#include "app_ai_if.h"
|
|
#include "app_ai_tws.h"
|
|
#include "ai_manager.h"
|
|
#include "app_ai_manager_api.h"
|
|
#endif
|
|
#include "app_tws_ibrt_cmd_handler.h"
|
|
#include "audio_process.h"
|
|
|
|
#ifdef __PC_CMD_UART__
|
|
#include "app_cmd.h"
|
|
#endif
|
|
|
|
#ifdef __FACTORY_MODE_SUPPORT__
|
|
#include "app_factory.h"
|
|
#include "app_factory_bt.h"
|
|
#endif
|
|
|
|
#ifdef __INTERCONNECTION__
|
|
#include "app_interconnection.h"
|
|
#include "app_interconnection_ble.h"
|
|
#include "app_interconnection_logic_protocol.h"
|
|
#include "app_ble_mode_switch.h"
|
|
#endif
|
|
|
|
#ifdef __INTERACTION__
|
|
#include "app_interaction.h"
|
|
#endif
|
|
|
|
#ifdef BISTO_ENABLED
|
|
#include "app_ai_manager_api.h"
|
|
#include "gsound_custom_reset.h"
|
|
#include "nvrecord_gsound.h"
|
|
#include "gsound_custom_actions.h"
|
|
#include "gsound_custom_ota.h"
|
|
#endif
|
|
|
|
#ifdef IBRT_OTA
|
|
#include "ota_bes.h"
|
|
#endif
|
|
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
#include "resources.h"
|
|
#include "app_media_player.h"
|
|
#endif
|
|
|
|
#ifdef VOICE_DATAPATH
|
|
#include "app_voicepath.h"
|
|
#endif
|
|
|
|
#ifdef BT_USB_AUDIO_DUAL_MODE
|
|
#include "btusb_audio.h"
|
|
#include "usbaudio_thread.h"
|
|
#endif
|
|
|
|
#ifdef TILE_DATAPATH
|
|
#include "tile_target_ble.h"
|
|
#endif
|
|
|
|
#if defined(IBRT)
|
|
#include "app_ibrt_if.h"
|
|
#include "app_ibrt_customif_ui.h"
|
|
#include "app_ibrt_ui_test.h"
|
|
#include "app_ibrt_voice_report.h"
|
|
#include "app_tws_if.h"
|
|
#include "app_ibrt_customif_cmd.h"
|
|
#endif
|
|
|
|
#ifdef GFPS_ENABLED
|
|
#include "app_gfps.h"
|
|
#endif
|
|
|
|
#ifdef BTIF_BLE_APP_DATAPATH_SERVER
|
|
#include "app_ble_cmd_handler.h"
|
|
#endif
|
|
|
|
#ifdef ANC_APP
|
|
#include "app_anc.h"
|
|
#endif
|
|
|
|
#ifdef __THIRDPARTY
|
|
#include "app_thirdparty.h"
|
|
#endif
|
|
|
|
#ifdef OTA_ENABLED
|
|
#include "nvrecord_ota.h"
|
|
#include "ota_common.h"
|
|
#endif
|
|
|
|
|
|
#ifdef WL_DET
|
|
#include "app_mic_alg.h"
|
|
#endif
|
|
|
|
#ifdef AUDIO_DEBUG_V0_1_0
|
|
extern "C" int speech_tuning_init(void);
|
|
#endif
|
|
|
|
#if (defined(BTUSB_AUDIO_MODE) || defined(BT_USB_AUDIO_DUAL_MODE))
|
|
extern "C" bool app_usbaudio_mode_on(void) ;
|
|
#endif
|
|
|
|
#ifdef BES_OTA_BASIC
|
|
extern "C" void ota_flash_init(void);
|
|
#endif
|
|
|
|
#define APP_BATTERY_LEVEL_LOWPOWERTHRESHOLD (1)
|
|
#define POWERON_PRESSMAXTIME_THRESHOLD_MS (5000)
|
|
|
|
#ifdef FPGA
|
|
uint32_t __ota_upgrade_log_start[100];
|
|
#endif
|
|
|
|
enum APP_POWERON_CASE_T {
|
|
APP_POWERON_CASE_NORMAL = 0,
|
|
APP_POWERON_CASE_DITHERING,
|
|
APP_POWERON_CASE_REBOOT,
|
|
APP_POWERON_CASE_ALARM,
|
|
APP_POWERON_CASE_CALIB,
|
|
APP_POWERON_CASE_BOTHSCAN,
|
|
APP_POWERON_CASE_CHARGING,
|
|
APP_POWERON_CASE_FACTORY,
|
|
APP_POWERON_CASE_TEST,
|
|
APP_POWERON_CASE_LINKLOSE_REBOOT,
|
|
APP_POWERON_CASE_INVALID,
|
|
|
|
APP_POWERON_CASE_NUM
|
|
};
|
|
|
|
#ifdef RB_CODEC
|
|
extern int rb_ctl_init();
|
|
extern bool rb_ctl_is_init_done(void);
|
|
extern void app_rbplay_audio_reset_pause_status(void);
|
|
#endif
|
|
|
|
#ifdef __SUPPORT_ANC_SINGLE_MODE_WITHOUT_BT__
|
|
extern bool app_pwr_key_monitor_get_val(void);
|
|
static bool anc_single_mode_on = false;
|
|
extern "C" bool anc_single_mode_is_on(void)
|
|
{
|
|
return anc_single_mode_on;
|
|
}
|
|
#endif
|
|
|
|
#ifdef __ANC_STICK_SWITCH_USE_GPIO__
|
|
extern bool app_anc_switch_get_val(void);
|
|
#endif
|
|
|
|
#ifdef GFPS_ENABLED
|
|
extern "C" void app_fast_pairing_timeout_timehandler(void);
|
|
#endif
|
|
|
|
uint8_t app_poweroff_flag = 0;
|
|
static enum APP_POWERON_CASE_T g_pwron_case = APP_POWERON_CASE_INVALID;
|
|
|
|
#ifndef APP_TEST_MODE
|
|
static uint8_t app_status_indication_init(void)
|
|
{
|
|
struct APP_PWL_CFG_T cfg;
|
|
hal_iomux_init((struct HAL_IOMUX_PIN_FUNCTION_MAP *)cfg_hw_pinmux_pwl, sizeof(cfg_hw_pinmux_pwl)/sizeof(struct HAL_IOMUX_PIN_FUNCTION_MAP));
|
|
memset(&cfg, 0, sizeof(struct APP_PWL_CFG_T));
|
|
app_pwl_open();
|
|
app_pwl_setup(APP_PWL_ID_0, &cfg);
|
|
app_pwl_setup(APP_PWL_ID_1, &cfg);
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#if defined(__BTIF_EARPHONE__) && defined(__BTIF_AUTOPOWEROFF__)
|
|
|
|
void PairingTransferToConnectable(void);
|
|
|
|
typedef void (*APP_10_SECOND_TIMER_CB_T)(void);
|
|
|
|
void app_pair_timerout(void);
|
|
void app_poweroff_timerout(void);
|
|
void CloseEarphone(void);
|
|
|
|
typedef struct
|
|
{
|
|
uint8_t timer_id;
|
|
uint8_t timer_en;
|
|
uint8_t timer_count;
|
|
uint8_t timer_period;
|
|
APP_10_SECOND_TIMER_CB_T cb;
|
|
}APP_10_SECOND_TIMER_STRUCT;
|
|
|
|
#define INIT_APP_TIMER(_id, _en, _count, _period, _cb) \
|
|
{ \
|
|
.timer_id = _id, \
|
|
.timer_en = _en, \
|
|
.timer_count = _count, \
|
|
.timer_period = _period, \
|
|
.cb = _cb, \
|
|
}
|
|
|
|
APP_10_SECOND_TIMER_STRUCT app_10_second_array[] =
|
|
{
|
|
INIT_APP_TIMER(APP_PAIR_TIMER_ID, 0, 0, 6, PairingTransferToConnectable),
|
|
INIT_APP_TIMER(APP_POWEROFF_TIMER_ID, 0, 0, 90, CloseEarphone),
|
|
#ifdef GFPS_ENABLED
|
|
INIT_APP_TIMER(APP_FASTPAIR_LASTING_TIMER_ID, 0, 0, APP_FAST_PAIRING_TIMEOUT_IN_SECOND/10,
|
|
app_fast_pairing_timeout_timehandler),
|
|
#endif
|
|
};
|
|
|
|
void app_stop_10_second_timer(uint8_t timer_id)
|
|
{
|
|
APP_10_SECOND_TIMER_STRUCT *timer = &app_10_second_array[timer_id];
|
|
|
|
timer->timer_en = 0;
|
|
timer->timer_count = 0;
|
|
}
|
|
|
|
void app_start_10_second_timer(uint8_t timer_id)
|
|
{
|
|
APP_10_SECOND_TIMER_STRUCT *timer = &app_10_second_array[timer_id];
|
|
|
|
timer->timer_en = 0;
|
|
timer->timer_count = 0;
|
|
}
|
|
|
|
void app_set_10_second_timer(uint8_t timer_id, uint8_t enable, uint8_t period)
|
|
{
|
|
APP_10_SECOND_TIMER_STRUCT *timer = &app_10_second_array[timer_id];
|
|
|
|
timer->timer_en = enable;
|
|
timer->timer_count = period;
|
|
}
|
|
|
|
void app_10_second_timer_check(void)
|
|
{
|
|
APP_10_SECOND_TIMER_STRUCT *timer = app_10_second_array;
|
|
unsigned int i;
|
|
|
|
for(i = 0; i < ARRAY_SIZE(app_10_second_array); i++) {
|
|
if (timer->timer_en) {
|
|
timer->timer_count++;
|
|
if (timer->timer_count >= timer->timer_period) {
|
|
timer->timer_en = 0;
|
|
if (timer->cb)
|
|
timer->cb();
|
|
}
|
|
}
|
|
timer++;
|
|
}
|
|
}
|
|
|
|
void CloseEarphone(void)
|
|
{
|
|
int activeCons;
|
|
osapi_lock_stack();
|
|
activeCons = btif_me_get_activeCons();
|
|
osapi_unlock_stack();
|
|
|
|
#ifdef ANC_APP
|
|
if(app_anc_work_status()) {
|
|
app_set_10_second_timer(APP_POWEROFF_TIMER_ID, 1, 30);
|
|
return;
|
|
}
|
|
#endif /* ANC_APP */
|
|
if(activeCons == 0) {
|
|
TRACE(0,"!!!CloseEarphone\n");
|
|
app_shutdown();
|
|
}
|
|
}
|
|
#endif /* #if defined(__BTIF_EARPHONE__) && defined(__BTIF_AUTOPOWEROFF__) */
|
|
|
|
int signal_send_to_main_thread(uint32_t signals);
|
|
uint8_t stack_ready_flag = 0;
|
|
void app_notify_stack_ready(uint8_t ready_flag)
|
|
{
|
|
TRACE(2,"app_notify_stack_ready %d %d", stack_ready_flag, ready_flag);
|
|
|
|
stack_ready_flag |= ready_flag;
|
|
|
|
#ifdef __IAG_BLE_INCLUDE__
|
|
if(stack_ready_flag == (STACK_READY_BT|STACK_READY_BLE))
|
|
#endif
|
|
{
|
|
signal_send_to_main_thread(0x3);
|
|
}
|
|
}
|
|
|
|
bool app_is_stack_ready(void)
|
|
{
|
|
bool ret = false;
|
|
|
|
if (stack_ready_flag == (STACK_READY_BT
|
|
#ifdef __IAG_BLE_INCLUDE__
|
|
| STACK_READY_BLE
|
|
#endif
|
|
))
|
|
{
|
|
ret = true;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
static void app_stack_ready_cb(void)
|
|
{
|
|
TRACE(0,"stack init done");
|
|
#ifdef BLE_ENABLE
|
|
app_ble_stub_user_init();
|
|
app_ble_start_connectable_adv(BLE_ADVERTISING_INTERVAL);
|
|
#endif
|
|
}
|
|
|
|
//#if (HF_CUSTOM_FEATURE_SUPPORT & HF_CUSTOM_FEATURE_BATTERY_REPORT) || (HF_SDK_FEATURES & HF_FEATURE_HF_INDICATORS)
|
|
#if defined(SUPPORT_BATTERY_REPORT) || defined(SUPPORT_HF_INDICATORS)
|
|
extern void app_hfp_set_battery_level(uint8_t level);
|
|
#endif
|
|
|
|
int app_status_battery_report(uint8_t level)
|
|
{
|
|
#ifdef __SUPPORT_ANC_SINGLE_MODE_WITHOUT_BT__
|
|
if (anc_single_mode_on) //anc power on,anc only mode
|
|
return 0;
|
|
#endif
|
|
#if defined(__BTIF_EARPHONE__)
|
|
if (app_is_stack_ready())
|
|
{
|
|
app_bt_state_checker();
|
|
}
|
|
app_10_second_timer_check();
|
|
#endif
|
|
if (level <= APP_BATTERY_LEVEL_LOWPOWERTHRESHOLD)
|
|
{
|
|
//add something
|
|
}
|
|
|
|
if (app_is_stack_ready())
|
|
{
|
|
// #if (HF_CUSTOM_FEATURE_SUPPORT & HF_CUSTOM_FEATURE_BATTERY_REPORT) || (HF_SDK_FEATURES & HF_FEATURE_HF_INDICATORS)
|
|
#if defined(SUPPORT_BATTERY_REPORT) || defined(SUPPORT_HF_INDICATORS)
|
|
#if defined(IBRT)
|
|
if (app_tws_ibrt_mobile_link_connected())
|
|
{
|
|
app_hfp_set_battery_level(level);
|
|
}
|
|
#else
|
|
app_hfp_set_battery_level(level);
|
|
#endif
|
|
#else
|
|
TRACE(1,"[%s] Can not enable SUPPORT_BATTERY_REPORT", __func__);
|
|
#endif
|
|
osapi_notify_evm();
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void stopAuto_Shutdowm_Timer(void);
|
|
void app_bt_power_off_customize()
|
|
{
|
|
#if(TWS_Sync_Shutdowm)
|
|
app_ibrt_poweroff_notify_force();
|
|
#endif
|
|
app_shutdown();
|
|
}
|
|
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
|
|
void app_status_set_num(const char* p)
|
|
{
|
|
media_Set_IncomingNumber(p);
|
|
}
|
|
|
|
static u8 last_voice_waring = APP_STATUS_INDICATION_NUM;
|
|
int app_voice_report_handler(APP_STATUS_INDICATION_T status, uint8_t device_id, uint8_t isMerging)
|
|
{
|
|
#if (defined(BTUSB_AUDIO_MODE) || defined(BT_USB_AUDIO_DUAL_MODE))
|
|
if(app_usbaudio_mode_on()) return 0;
|
|
#endif
|
|
TRACE(3,"%s %d",__func__, status);
|
|
AUD_ID_ENUM id = MAX_RECORD_NUM;
|
|
#ifdef __SUPPORT_ANC_SINGLE_MODE_WITHOUT_BT__
|
|
if(anc_single_mode_on)
|
|
return 0;
|
|
#endif
|
|
if(((last_voice_waring == APP_STATUS_INDICATION_POWERON)&&(status == APP_STATUS_INDICATION_POWERON))||
|
|
((last_voice_waring == APP_STATUS_INDICATION_BOTHSCAN)&&(status == APP_STATUS_INDICATION_BOTHSCAN))||
|
|
((last_voice_waring == APP_STATUS_INDICATION_BOTHSCAN)&&(status == APP_STATUS_INDICATION_DISCONNECTED))){
|
|
last_voice_waring = status;
|
|
return 0;
|
|
}
|
|
if (app_poweroff_flag == 1){
|
|
switch (status) {
|
|
case APP_STATUS_INDICATION_POWEROFF:
|
|
id = AUD_ID_POWER_OFF;
|
|
break;
|
|
default:
|
|
return 0;
|
|
break;
|
|
}
|
|
}else{
|
|
switch (status) {
|
|
case APP_STATUS_INDICATION_POWERON:
|
|
id = AUD_ID_POWER_ON;
|
|
break;
|
|
case APP_STATUS_INDICATION_POWEROFF:
|
|
id = AUD_ID_POWER_OFF;
|
|
break;
|
|
case APP_STATUS_INDICATION_CONNECTED:
|
|
id = AUD_ID_BT_CONNECTED;
|
|
break;
|
|
case APP_STATUS_INDICATION_DISCONNECTED:
|
|
id = AUD_ID_BT_DIS_CONNECT;
|
|
break;
|
|
case APP_STATUS_INDICATION_CALLNUMBER:
|
|
id = AUD_ID_BT_CALL_INCOMING_NUMBER;
|
|
break;
|
|
case APP_STATUS_INDICATION_CHARGENEED:
|
|
id = AUD_ID_BT_CHARGE_PLEASE;
|
|
break;
|
|
case APP_STATUS_INDICATION_FULLCHARGE:
|
|
id = AUD_ID_BT_CHARGE_FINISH;
|
|
break;
|
|
case APP_STATUS_INDICATION_PAIRSUCCEED:
|
|
id = AUD_ID_BT_PAIRING_SUC;
|
|
break;
|
|
case APP_STATUS_INDICATION_PAIRFAIL:
|
|
id = AUD_ID_BT_PAIRING_FAIL;
|
|
break;
|
|
|
|
case APP_STATUS_INDICATION_HANGUPCALL:
|
|
id = AUD_ID_BT_CALL_HUNG_UP;
|
|
break;
|
|
|
|
case APP_STATUS_INDICATION_REFUSECALL:
|
|
id = AUD_ID_BT_CALL_REFUSE;
|
|
isMerging = false;
|
|
break;
|
|
|
|
case APP_STATUS_INDICATION_ANSWERCALL:
|
|
id = AUD_ID_BT_CALL_ANSWER;
|
|
break;
|
|
|
|
case APP_STATUS_INDICATION_CLEARSUCCEED:
|
|
id = AUD_ID_BT_CLEAR_SUCCESS;
|
|
break;
|
|
|
|
case APP_STATUS_INDICATION_CLEARFAIL:
|
|
id = AUD_ID_BT_CLEAR_FAIL;
|
|
break;
|
|
case APP_STATUS_INDICATION_INCOMINGCALL:
|
|
id = AUD_ID_BT_CALL_INCOMING_CALL;
|
|
break;
|
|
case APP_STATUS_INDICATION_BOTHSCAN:
|
|
id = AUD_ID_BT_PAIR_ENABLE;
|
|
break;
|
|
case APP_STATUS_INDICATION_WARNING:
|
|
id = AUD_ID_BT_WARNING;
|
|
break;
|
|
case APP_STATUS_INDICATION_ALEXA_START:
|
|
id = AUDIO_ID_BT_ALEXA_START;
|
|
break;
|
|
case APP_STATUS_INDICATION_ALEXA_STOP:
|
|
id = AUDIO_ID_BT_ALEXA_STOP;
|
|
break;
|
|
case APP_STATUS_INDICATION_GSOUND_MIC_OPEN:
|
|
id = AUDIO_ID_BT_GSOUND_MIC_OPEN;
|
|
break;
|
|
case APP_STATUS_INDICATION_GSOUND_MIC_CLOSE:
|
|
id = AUDIO_ID_BT_GSOUND_MIC_CLOSE;
|
|
break;
|
|
case APP_STATUS_INDICATION_GSOUND_NC:
|
|
id = AUDIO_ID_BT_GSOUND_NC;
|
|
break;
|
|
#ifdef __BT_WARNING_TONE_MERGE_INTO_STREAM_SBC__
|
|
case APP_STATUS_RING_WARNING:
|
|
id = AUD_ID_RING_WARNING;
|
|
break;
|
|
#endif
|
|
case APP_STATUS_INDICATION_MUTE:
|
|
id = AUDIO_ID_BT_MUTE;
|
|
break;
|
|
#ifdef __INTERACTION__
|
|
case APP_STATUS_INDICATION_FINDME:
|
|
id = AUD_ID_BT_FINDME;
|
|
break;
|
|
#endif
|
|
case APP_STATUS_INDICATION_FIND_MY_BUDS:
|
|
id = AUDIO_ID_FIND_MY_BUDS;
|
|
break;
|
|
case APP_STATUS_INDICATION_TILE_FIND:
|
|
id = AUDIO_ID_FIND_TILE;
|
|
break;
|
|
case APP_STATUS_INDICATION_DUDU:
|
|
id = AUDIO_ID_BT_DUDU;
|
|
break;
|
|
case APP_STATUS_INDICATION_DU:
|
|
id = AUDIO_ID_BT_DU;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
uint16_t aud_pram = 0;
|
|
if (isMerging){
|
|
aud_pram |= PROMOT_ID_BIT_MASK_MERGING;
|
|
}
|
|
#ifdef BT_USB_AUDIO_DUAL_MODE
|
|
if(!btusb_is_usb_mode())
|
|
{
|
|
#if defined(IBRT)
|
|
app_ibrt_if_voice_report_handler(id, aud_pram);
|
|
#else
|
|
trigger_media_play(id, device_id, aud_pram);
|
|
#endif
|
|
}
|
|
|
|
#else
|
|
#if defined(IBRT)
|
|
aud_pram |= PROMOT_ID_BIT_MASK_CHNLSEl_ALL;
|
|
app_ibrt_if_voice_report_handler(id, aud_pram);
|
|
#else
|
|
trigger_media_play(id, device_id, aud_pram);
|
|
#endif
|
|
#endif
|
|
|
|
return 0;
|
|
}
|
|
|
|
extern "C" int app_voice_report(APP_STATUS_INDICATION_T status, uint8_t device_id)
|
|
{
|
|
return app_voice_report_handler(status, device_id, true);
|
|
}
|
|
|
|
extern "C" int app_voice_report_generic(APP_STATUS_INDICATION_T status, uint8_t device_id, uint8_t isMerging)
|
|
{
|
|
return app_voice_report_handler(status, device_id, isMerging);
|
|
}
|
|
|
|
extern "C" int app_voice_stop(APP_STATUS_INDICATION_T status, uint8_t device_id)
|
|
{
|
|
AUD_ID_ENUM id = MAX_RECORD_NUM;
|
|
|
|
TRACE(2,"%s %d", __func__, status);
|
|
|
|
if (status == APP_STATUS_INDICATION_FIND_MY_BUDS)
|
|
id = AUDIO_ID_FIND_MY_BUDS;
|
|
|
|
if (id != MAX_RECORD_NUM)
|
|
trigger_media_stop(id, device_id);
|
|
|
|
return 0;
|
|
}
|
|
|
|
#endif
|
|
#if 1//!defined(BLE_ONLY_ENABLED)
|
|
|
|
static void app_poweron_normal(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
g_pwron_case = APP_POWERON_CASE_NORMAL;
|
|
|
|
signal_send_to_main_thread(0x2);
|
|
}
|
|
static void app_poweron_scan(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
g_pwron_case = APP_POWERON_CASE_BOTHSCAN;
|
|
|
|
signal_send_to_main_thread(0x2);
|
|
}
|
|
#endif
|
|
|
|
#if 0//def __ENGINEER_MODE_SUPPORT__
|
|
#if !defined(BLE_ONLY_ENABLED)
|
|
static void app_poweron_factorymode(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT);
|
|
app_factorymode_enter();
|
|
}
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
static bool g_pwron_finished = false;
|
|
static void app_poweron_finished(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
g_pwron_finished = true;
|
|
signal_send_to_main_thread(0x2);
|
|
}
|
|
#endif
|
|
|
|
void app_poweron_wait_finished(void)
|
|
{
|
|
#ifndef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
if (!g_pwron_finished)
|
|
#endif
|
|
{
|
|
osSignalWait(0x2, osWaitForever);
|
|
}
|
|
}
|
|
|
|
#if defined(__POWERKEY_CTRL_ONOFF_ONLY__)
|
|
void app_bt_key_shutdown(APP_KEY_STATUS *status, void *param);
|
|
const APP_KEY_HANDLE pwron_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_UP}, "power on: shutdown" , app_bt_key_shutdown, NULL},
|
|
};
|
|
#elif defined(__ENGINEER_MODE_SUPPORT__)
|
|
const APP_KEY_HANDLE pwron_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITUP}, "power on: normal" , app_poweron_normal, NULL},
|
|
#if !defined(BLE_ONLY_ENABLED)
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITLONGPRESS}, "power on: both scan" , app_poweron_scan , NULL},
|
|
// {{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITLONGLONGPRESS},"power on: factory mode", app_poweron_factorymode , NULL},
|
|
#endif
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITFINISHED}, "power on: finished" , app_poweron_finished , NULL},
|
|
};
|
|
#else
|
|
const APP_KEY_HANDLE pwron_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITUP}, "power on: normal" , app_poweron_normal, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITLONGPRESS}, "power on: both scan" , app_poweron_scan , NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_INITFINISHED}, "power on: finished" , app_poweron_finished , NULL},
|
|
};
|
|
#endif
|
|
|
|
#ifndef APP_TEST_MODE
|
|
static void app_poweron_key_init(void)
|
|
{
|
|
uint8_t i = 0;
|
|
TRACE(1,"%s",__func__);
|
|
|
|
for (i=0; i<(sizeof(pwron_key_handle_cfg)/sizeof(APP_KEY_HANDLE)); i++){
|
|
app_key_handle_registration(&pwron_key_handle_cfg[i]);
|
|
}
|
|
}
|
|
|
|
static uint8_t app_poweron_wait_case(void)
|
|
{
|
|
|
|
#ifdef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
g_pwron_case = APP_POWERON_CASE_NORMAL;
|
|
#else
|
|
uint32_t stime = 0, etime = 0;
|
|
|
|
TRACE(1,"poweron_wait_case enter:%d", g_pwron_case);
|
|
if (g_pwron_case == APP_POWERON_CASE_INVALID){
|
|
stime = hal_sys_timer_get();
|
|
osSignalWait(0x2, POWERON_PRESSMAXTIME_THRESHOLD_MS);
|
|
etime = hal_sys_timer_get();
|
|
}
|
|
TRACE(2,"powon raw case:%d time:%d", g_pwron_case, TICKS_TO_MS(etime - stime));
|
|
#endif
|
|
return g_pwron_case;
|
|
|
|
}
|
|
#endif
|
|
|
|
static void app_wait_stack_ready(void)
|
|
{
|
|
uint32_t stime, etime;
|
|
stime = hal_sys_timer_get();
|
|
osSignalWait(0x3, 1000);
|
|
etime = hal_sys_timer_get();
|
|
TRACE(1,"app_wait_stack_ready: wait:%d ms", TICKS_TO_MS(etime - stime));
|
|
|
|
app_stack_ready_cb();
|
|
}
|
|
|
|
extern "C" int system_shutdown(void);
|
|
int app_shutdown(void)
|
|
{
|
|
system_shutdown();
|
|
return 0;
|
|
}
|
|
|
|
int system_reset(void);
|
|
int app_reset(void)
|
|
{
|
|
system_reset();
|
|
return 0;
|
|
}
|
|
|
|
static void app_postponed_reset_timer_handler(void const *param);
|
|
osTimerDef(APP_POSTPONED_RESET_TIMER, app_postponed_reset_timer_handler);
|
|
static osTimerId app_postponed_reset_timer = NULL;
|
|
#define APP_RESET_PONTPONED_TIME_IN_MS 2000
|
|
static void app_postponed_reset_timer_handler(void const *param)
|
|
{
|
|
// hal_cmu_sys_reboot();
|
|
app_reset();
|
|
}
|
|
|
|
void app_start_postponed_reset(void)
|
|
{
|
|
if (NULL == app_postponed_reset_timer)
|
|
{
|
|
app_postponed_reset_timer = osTimerCreate(osTimer(APP_POSTPONED_RESET_TIMER), osTimerOnce, NULL);
|
|
}
|
|
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_ENTER_HIDE_BOOT);
|
|
|
|
osTimerStart(app_postponed_reset_timer, APP_RESET_PONTPONED_TIME_IN_MS);
|
|
}
|
|
|
|
void app_bt_key_shutdown(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
#ifdef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT);
|
|
app_reset();
|
|
#else
|
|
app_shutdown();
|
|
#endif
|
|
}
|
|
|
|
void app_bt_key_enter_testmode(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s\n",__FUNCTION__);
|
|
|
|
if(app_status_indication_get() == APP_STATUS_INDICATION_BOTHSCAN){
|
|
#ifdef __FACTORY_MODE_SUPPORT__
|
|
app_factorymode_bt_signalingtest(status, param);
|
|
#endif
|
|
}
|
|
}
|
|
|
|
void app_bt_key_enter_nosignal_mode(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s\n",__FUNCTION__);
|
|
if(app_status_indication_get() == APP_STATUS_INDICATION_BOTHSCAN){
|
|
#ifdef __FACTORY_MODE_SUPPORT__
|
|
app_factorymode_bt_nosignalingtest(status, param);
|
|
#endif
|
|
}
|
|
}
|
|
|
|
extern "C" void OS_NotifyEvm(void);
|
|
|
|
#define PRESS_KEY_TO_ENTER_OTA_INTERVEL (15000) // press key 15s enter to ota
|
|
#define PRESS_KEY_TO_ENTER_OTA_REPEAT_CNT ((PRESS_KEY_TO_ENTER_OTA_INTERVEL - 2000) / 500)
|
|
void app_otaMode_enter(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s",__func__);
|
|
|
|
hal_norflash_disable_protection(HAL_NORFLASH_ID_0);
|
|
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_ENTER_HIDE_BOOT);
|
|
#ifdef __KMATE106__
|
|
app_status_indication_set(APP_STATUS_INDICATION_OTA);
|
|
app_voice_report(APP_STATUS_INDICATION_WARNING, 0);
|
|
osDelay(1200);
|
|
#endif
|
|
hal_cmu_sys_reboot();
|
|
}
|
|
|
|
#ifdef __USB_COMM__
|
|
void app_usb_cdc_comm_key_handler(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d", __func__, status->code, status->event);
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT);
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_CDC_COMM);
|
|
pmu_usb_config(PMU_USB_CONFIG_TYPE_DEVICE);
|
|
hal_cmu_reset_set(HAL_CMU_MOD_GLOBAL);
|
|
}
|
|
#endif
|
|
|
|
#if 0
|
|
void app_dfu_key_handler(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s ",__func__);
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT);
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_FORCE_USB_DLD);
|
|
pmu_usb_config(PMU_USB_CONFIG_TYPE_DEVICE);
|
|
hal_cmu_reset_set(HAL_CMU_MOD_GLOBAL);
|
|
}
|
|
#else
|
|
void app_dfu_key_handler(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s ",__func__);
|
|
hal_sw_bootmode_clear(0xffffffff);
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_FORCE_USB_DLD | HAL_SW_BOOTMODE_SKIP_FLASH_BOOT);
|
|
pmu_usb_config(PMU_USB_CONFIG_TYPE_DEVICE);
|
|
hal_cmu_reset_set(HAL_CMU_MOD_GLOBAL);
|
|
}
|
|
#endif
|
|
|
|
void app_ota_key_handler(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
static uint32_t time = hal_sys_timer_get();
|
|
static uint16_t cnt = 0;
|
|
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
|
|
if (TICKS_TO_MS(hal_sys_timer_get() - time) > 600) // 600 = (repeat key intervel)500 + (margin)100
|
|
cnt = 0;
|
|
else
|
|
cnt++;
|
|
|
|
if (cnt == PRESS_KEY_TO_ENTER_OTA_REPEAT_CNT) {
|
|
app_otaMode_enter(NULL, NULL);
|
|
}
|
|
|
|
time = hal_sys_timer_get();
|
|
}
|
|
extern "C" void app_bt_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
#define DEBUG_CODE_USE 0
|
|
switch(status->event)
|
|
{
|
|
case APP_KEY_EVENT_CLICK:
|
|
TRACE(0,"first blood!");
|
|
#if DEBUG_CODE_USE
|
|
if (status->code == APP_KEY_CODE_PWR)
|
|
{
|
|
#ifdef __INTERCONNECTION__
|
|
// add favorite music
|
|
// app_interconnection_handle_favorite_music_through_ccmp(1);
|
|
|
|
// ask for ota update
|
|
ota_update_request();
|
|
return;
|
|
#else
|
|
static int m = 0;
|
|
if (m == 0) {
|
|
m = 1;
|
|
hal_iomux_set_analog_i2c();
|
|
}
|
|
else {
|
|
m = 0;
|
|
hal_iomux_set_uart0();
|
|
}
|
|
#endif
|
|
}
|
|
#endif
|
|
break;
|
|
case APP_KEY_EVENT_DOUBLECLICK:
|
|
TRACE(0,"double kill");
|
|
#if DEBUG_CODE_USE
|
|
if (status->code == APP_KEY_CODE_PWR)
|
|
{
|
|
#ifdef __INTERCONNECTION__
|
|
// play favorite music
|
|
app_interconnection_handle_favorite_music_through_ccmp(2);
|
|
#else
|
|
app_otaMode_enter(NULL, NULL);
|
|
#endif
|
|
return;
|
|
}
|
|
#endif
|
|
break;
|
|
case APP_KEY_EVENT_TRIPLECLICK:
|
|
TRACE(0,"triple kill");
|
|
if (status->code == APP_KEY_CODE_PWR)
|
|
{
|
|
|
|
#ifndef __BT_ONE_BRING_TWO__
|
|
if(btif_me_get_activeCons() < 1){
|
|
#else
|
|
if(btif_me_get_activeCons() < 2){
|
|
#endif
|
|
app_bt_accessmode_set(BTIF_BT_DEFAULT_ACCESS_MODE_PAIR);
|
|
#ifdef __INTERCONNECTION__
|
|
app_interceonnection_start_discoverable_adv(INTERCONNECTION_BLE_FAST_ADVERTISING_INTERVAL,
|
|
APP_INTERCONNECTION_FAST_ADV_TIMEOUT_IN_MS);
|
|
return;
|
|
#endif
|
|
#ifdef GFPS_ENABLED
|
|
app_enter_fastpairing_mode();
|
|
#endif
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
return;
|
|
}
|
|
break;
|
|
case APP_KEY_EVENT_ULTRACLICK:
|
|
TRACE(0,"ultra kill");
|
|
break;
|
|
case APP_KEY_EVENT_RAMPAGECLICK:
|
|
TRACE(0,"rampage kill!you are crazy!");
|
|
break;
|
|
|
|
case APP_KEY_EVENT_UP:
|
|
break;
|
|
}
|
|
#if 0//def __FACTORY_MODE_SUPPORT__
|
|
if (app_status_indication_get() == APP_STATUS_INDICATION_BOTHSCAN && (status->event == APP_KEY_EVENT_DOUBLECLICK)){
|
|
app_factorymode_languageswitch_proc();
|
|
}else
|
|
#endif
|
|
{
|
|
#ifdef __SUPPORT_ANC_SINGLE_MODE_WITHOUT_BT__
|
|
if(!anc_single_mode_on)
|
|
#endif
|
|
bt_key_send(status);
|
|
}
|
|
}
|
|
|
|
#ifdef RB_CODEC
|
|
extern bool app_rbcodec_check_hfp_active(void );
|
|
void app_switch_player_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
|
|
if(!rb_ctl_is_init_done()) {
|
|
TRACE(0,"rb ctl not init done");
|
|
return ;
|
|
}
|
|
|
|
if( app_rbcodec_check_hfp_active() ) {
|
|
app_bt_key(status,param);
|
|
return;
|
|
}
|
|
|
|
app_rbplay_audio_reset_pause_status();
|
|
|
|
if(app_rbplay_mode_switch()) {
|
|
app_voice_report(APP_STATUS_INDICATION_POWERON, 0);
|
|
app_rbcodec_ctr_play_onoff(true);
|
|
} else {
|
|
app_rbcodec_ctr_play_onoff(false);
|
|
app_voice_report(APP_STATUS_INDICATION_POWEROFF, 0);
|
|
}
|
|
return ;
|
|
|
|
}
|
|
#endif
|
|
|
|
void app_voice_assistant_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
#if defined(BISTO_ENABLED) || defined(__AI_VOICE__)
|
|
if (app_ai_manager_is_in_multi_ai_mode())
|
|
{
|
|
if (app_ai_manager_spec_get_status_is_in_invalid()) {
|
|
TRACE(0,"AI feature has been diabled");
|
|
return;
|
|
}
|
|
|
|
#ifdef MAI_TYPE_REBOOT_WITHOUT_OEM_APP
|
|
if (app_ai_manager_get_spec_update_flag()) {
|
|
TRACE(0,"device reboot is ongoing...");
|
|
return;
|
|
}
|
|
#endif
|
|
|
|
if (app_ai_manager_is_need_reboot())
|
|
{
|
|
TRACE(1, "%s ai need to reboot", __func__);
|
|
return;
|
|
}
|
|
|
|
if(app_ai_manager_voicekey_is_enable()) {
|
|
if (AI_SPEC_GSOUND == app_ai_manager_get_current_spec()) {
|
|
#ifdef BISTO_ENABLED
|
|
gsound_custom_actions_handle_key(status, param);
|
|
#endif
|
|
} else if(AI_SPEC_INIT != app_ai_manager_get_current_spec()) {
|
|
app_ai_key_event_handle(status, 0);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
app_ai_key_event_handle(status, 0);
|
|
#if defined(BISTO_ENABLED)
|
|
gsound_custom_actions_handle_key(status, param);
|
|
#endif
|
|
}
|
|
#endif
|
|
}
|
|
|
|
#ifdef IS_MULTI_AI_ENABLED
|
|
void app_voice_gva_onoff_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
uint8_t current_ai_spec = app_ai_manager_get_current_spec();
|
|
|
|
TRACE(2,"%s current_ai_spec %d", __func__, current_ai_spec);
|
|
if (current_ai_spec == AI_SPEC_INIT)
|
|
{
|
|
app_ai_manager_enable(true, AI_SPEC_GSOUND);
|
|
}
|
|
else if(current_ai_spec == AI_SPEC_GSOUND)
|
|
{
|
|
app_ai_manager_enable(false, AI_SPEC_GSOUND);
|
|
}
|
|
else if(current_ai_spec == AI_SPEC_AMA)
|
|
{
|
|
app_ai_manager_switch_spec(AI_SPEC_GSOUND);
|
|
}
|
|
app_ble_refresh_adv_state(BLE_ADVERTISING_INTERVAL);
|
|
}
|
|
|
|
void app_voice_ama_onoff_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
uint8_t current_ai_spec = app_ai_manager_get_current_spec();
|
|
|
|
TRACE(2,"%s current_ai_spec %d", __func__, current_ai_spec);
|
|
if (current_ai_spec == AI_SPEC_INIT)
|
|
{
|
|
app_ai_manager_enable(true, AI_SPEC_AMA);
|
|
}
|
|
else if(current_ai_spec == AI_SPEC_AMA)
|
|
{
|
|
app_ai_manager_enable(false, AI_SPEC_AMA);
|
|
}
|
|
else if(current_ai_spec == AI_SPEC_GSOUND)
|
|
{
|
|
app_ai_manager_switch_spec(AI_SPEC_AMA);
|
|
}
|
|
app_ble_refresh_adv_state(BLE_ADVERTISING_INTERVAL);
|
|
}
|
|
#endif
|
|
|
|
#if defined(BT_USB_AUDIO_DUAL_MODE_TEST) && defined(BT_USB_AUDIO_DUAL_MODE)
|
|
extern "C" void test_btusb_switch(void);
|
|
void app_btusb_audio_dual_mode_test(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(0,"test_btusb_switch");
|
|
test_btusb_switch();
|
|
}
|
|
#endif
|
|
|
|
extern void switch_dualmic_status(void);
|
|
|
|
void app_switch_dualmic_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
switch_dualmic_status();
|
|
}
|
|
|
|
#ifdef POWERKEY_I2C_SWITCH
|
|
extern void app_factorymode_i2c_switch(APP_KEY_STATUS *status, void *param);
|
|
#endif
|
|
|
|
#ifdef TILE_DATAPATH
|
|
extern "C" void app_tile_key_handler(APP_KEY_STATUS *status, void *param);
|
|
#endif
|
|
|
|
#ifdef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
#if defined(__APP_KEY_FN_STYLE_A__)
|
|
const APP_KEY_HANDLE app_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_UP},"bt function key",app_bt_key_shutdown, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_LONGPRESS},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_UP},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_DOUBLECLICK},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_UP},"bt volume up key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_LONGPRESS},"bt play backward key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN3,APP_KEY_EVENT_UP},"bt volume down key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN3,APP_KEY_EVENT_LONGPRESS},"bt play forward key",app_bt_key, NULL},
|
|
#ifdef SUPPORT_SIRI
|
|
{{APP_KEY_CODE_NONE ,APP_KEY_EVENT_NONE},"none function key",app_bt_key, NULL},
|
|
#endif
|
|
|
|
};
|
|
#else //#elif defined(__APP_KEY_FN_STYLE_B__)
|
|
const APP_KEY_HANDLE app_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_UP},"bt function key",app_bt_key_shutdown, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_LONGPRESS},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_UP},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_DOUBLECLICK},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_REPEAT},"bt volume up key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_UP},"bt play backward key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN3,APP_KEY_EVENT_REPEAT},"bt volume down key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN3,APP_KEY_EVENT_UP},"bt play forward key",app_bt_key, NULL},
|
|
#ifdef SUPPORT_SIRI
|
|
{{APP_KEY_CODE_NONE ,APP_KEY_EVENT_NONE},"none function key",app_bt_key, NULL},
|
|
#endif
|
|
|
|
};
|
|
#endif
|
|
#else
|
|
#if defined(__APP_KEY_FN_STYLE_A__)
|
|
//--
|
|
const APP_KEY_HANDLE app_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGLONGPRESS},"bt function key",app_bt_key_shutdown, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGPRESS},"bt function key",app_bt_key, NULL},
|
|
#if defined(BT_USB_AUDIO_DUAL_MODE_TEST) && defined(BT_USB_AUDIO_DUAL_MODE)
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt function key",app_bt_key, NULL},
|
|
#ifdef RB_CODEC
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt function key",app_switch_player_key, NULL},
|
|
#else
|
|
//{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"btusb mode switch key.",app_btusb_audio_dual_mode_test, NULL},
|
|
#endif
|
|
#endif
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_DOUBLECLICK},"bt function key",app_bt_key, NULL},
|
|
#ifdef TILE_DATAPATH
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_TRIPLECLICK},"bt function key",app_tile_key_handler, NULL},
|
|
#else
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_TRIPLECLICK},"bt function key",app_bt_key, NULL},
|
|
#endif
|
|
#if RAMPAGECLICK_TEST_MODE
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_ULTRACLICK},"bt function key",app_bt_key_enter_nosignal_mode, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_RAMPAGECLICK},"bt function key",app_bt_key_enter_testmode, NULL},
|
|
#endif
|
|
#ifdef POWERKEY_I2C_SWITCH
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_RAMPAGECLICK},"bt i2c key",app_factorymode_i2c_switch, NULL},
|
|
#endif
|
|
//{{APP_KEY_CODE_FN1,APP_KEY_EVENT_UP},"bt volume up key",app_bt_key, NULL},
|
|
//{{APP_KEY_CODE_FN1,APP_KEY_EVENT_LONGPRESS},"bt play backward key",app_bt_key, NULL},
|
|
#if defined(APP_LINEIN_A2DP_SOURCE)||defined(APP_I2S_A2DP_SOURCE)
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_DOUBLECLICK},"bt mode src snk key",app_bt_key, NULL},
|
|
#endif
|
|
//{{APP_KEY_CODE_FN2,APP_KEY_EVENT_UP},"bt volume down key",app_bt_key, NULL},
|
|
//{{APP_KEY_CODE_FN2,APP_KEY_EVENT_LONGPRESS},"bt play forward key",app_bt_key, NULL},
|
|
//{{APP_KEY_CODE_FN15,APP_KEY_EVENT_UP},"bt volume down key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt function key",app_bt_key, NULL},
|
|
|
|
#ifdef SUPPORT_SIRI
|
|
{{APP_KEY_CODE_NONE ,APP_KEY_EVENT_NONE},"none function key",app_bt_key, NULL},
|
|
#endif
|
|
#if defined( __BT_ANC_KEY__)&&defined(ANC_APP)
|
|
#if defined(IBRT)
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt anc key",app_anc_key, NULL},
|
|
#else
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_CLICK},"bt anc key",app_anc_key, NULL},
|
|
#endif
|
|
#endif
|
|
#ifdef TILE_DATAPATH
|
|
{{APP_KEY_CODE_TILE, APP_KEY_EVENT_DOWN}, "tile function key", app_tile_key_handler, NULL},
|
|
{{APP_KEY_CODE_TILE, APP_KEY_EVENT_UP}, "tile function key", app_tile_key_handler, NULL},
|
|
#endif
|
|
|
|
#if defined(VOICE_DATAPATH) || defined(__AI_VOICE__)
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_FIRST_DOWN}, "google assistant key", app_voice_assistant_key, NULL},
|
|
#if defined(IS_GSOUND_BUTTION_HANDLER_WORKAROUND_ENABLED) || defined(PUSH_AND_HOLD_ENABLED) || defined(__TENCENT_VOICE__)
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_UP}, "google assistant key", app_voice_assistant_key, NULL},
|
|
#endif
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_UP_AFTER_LONGPRESS}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_LONGPRESS}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_CLICK}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_DOUBLECLICK}, "google assistant key", app_voice_assistant_key, NULL},
|
|
#endif
|
|
#ifdef IS_MULTI_AI_ENABLED
|
|
{{APP_KEY_CODE_FN13, APP_KEY_EVENT_CLICK}, "gva on-off key", app_voice_gva_onoff_key, NULL},
|
|
{{APP_KEY_CODE_FN14, APP_KEY_EVENT_CLICK}, "ama on-off key", app_voice_ama_onoff_key, NULL},
|
|
#endif
|
|
#if defined(BT_USB_AUDIO_DUAL_MODE_TEST) && defined(BT_USB_AUDIO_DUAL_MODE)
|
|
{{APP_KEY_CODE_FN15, APP_KEY_EVENT_CLICK}, "btusb mode switch key.", app_btusb_audio_dual_mode_test, NULL},
|
|
#endif
|
|
};
|
|
#else //#elif defined(__APP_KEY_FN_STYLE_B__)
|
|
const APP_KEY_HANDLE app_key_handle_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGLONGPRESS},"bt function key",app_bt_key_shutdown, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGPRESS},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_DOUBLECLICK},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_TRIPLECLICK},"bt function key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_ULTRACLICK},"bt function key",app_bt_key_enter_nosignal_mode, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_RAMPAGECLICK},"bt function key",app_bt_key_enter_testmode, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_REPEAT},"bt volume up key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_UP},"bt play backward key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_REPEAT},"bt volume down key",app_bt_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_UP},"bt play forward key",app_bt_key, NULL},
|
|
#ifdef SUPPORT_SIRI
|
|
{{APP_KEY_CODE_NONE ,APP_KEY_EVENT_NONE},"none function key",app_bt_key, NULL},
|
|
#endif
|
|
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_FIRST_DOWN}, "google assistant key", app_voice_assistant_key, NULL},
|
|
#if defined(IS_GSOUND_BUTTION_HANDLER_WORKAROUND_ENABLED) || defined(PUSH_AND_HOLD_ENABLED)
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_UP}, "google assistant key", app_voice_assistant_key, NULL},
|
|
#endif
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_UP_AFTER_LONGPRESS}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_LONGPRESS}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_CLICK}, "google assistant key", app_voice_assistant_key, NULL},
|
|
{{APP_KEY_CODE_GOOGLE, APP_KEY_EVENT_DOUBLECLICK}, "google assistant key", app_voice_assistant_key, NULL},
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
extern struct BT_DEVICE_T app_bt_device;
|
|
extern uint8_t avrcp_get_media_status(void);
|
|
/******************************delay_report_tone_timer*********************************************************/
|
|
APP_STATUS_INDICATION_T delay_report_tone_num = APP_STATUS_INDICATION_NUM;
|
|
osTimerId delay_report_toneid = NULL;
|
|
void startdelay_report_tone(int ms,APP_STATUS_INDICATION_T status);
|
|
void stopdelay_report_tone(void);
|
|
static void delay_report_tonefun(const void *);
|
|
osTimerDef(defdelay_report_tone,delay_report_tonefun);
|
|
void delay_report_toneinit(void)
|
|
{
|
|
delay_report_toneid = osTimerCreate(osTimer(defdelay_report_tone),osTimerOnce,(void *)0);
|
|
}
|
|
static void delay_report_tonefun(const void *)
|
|
{
|
|
TRACE(3,"\n\n!!!!!!enter %s,delay_report_tone_num = %d \n\n",__func__,delay_report_tone_num);
|
|
if(MobileLinkLose_reboot){
|
|
return;
|
|
}
|
|
//static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
//uint8_t default_mobileaddr[6] = {0x0,0x0,0x0,0x0,0x0,0x0};
|
|
//DUMP8("%02x ", p_ibrt_ctrl->mobile_addr.address, 6);
|
|
//app_status_indication_set(APP_STATUS_INDICATION_TWS_CONNECTED);
|
|
if(Curr_Is_Master()){
|
|
app_ibrt_sync_volume_info();
|
|
}
|
|
if(delay_report_tone_num == APP_STATUS_INDICATION_DUDU){
|
|
if(Curr_Is_Master()&&(avrcp_get_media_status() != 1)&&(app_bt_device.hfchan_call[BT_DEVICE_ID_1] == BTIF_HF_CALL_NONE)){
|
|
app_voice_report(delay_report_tone_num,0);
|
|
/*if((!memcmp(default_mobileaddr,p_ibrt_ctrl->mobile_addr.address,6))&&(p_ibrt_ctrl->access_mode == 0x3)){
|
|
TRACE(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA");
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}*/
|
|
if((nv_record_get_paired_dev_count()==1)){
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
}
|
|
}
|
|
delay_report_tone_num = APP_STATUS_INDICATION_NUM;
|
|
}
|
|
|
|
void startdelay_report_tone(int ms,APP_STATUS_INDICATION_T status)
|
|
{
|
|
TRACE(3,"\n\n !!!!!!!!!!start %s\n\n",__func__);
|
|
delay_report_tone_num = status;
|
|
osTimerStart(delay_report_toneid,ms);
|
|
}
|
|
|
|
/********************************delay_report_tone_timer*******************************************************/
|
|
|
|
/******************************low_latlatency_delay_switch_timer*********************************************************/
|
|
uint8_t latency_mode_is_open = false;
|
|
|
|
osTimerId low_latlatency_delay_switchid = NULL;
|
|
void startlow_latlatency_delay_switch(int ms);
|
|
void stoplow_latlatency_delay_switch(void);
|
|
static void low_latlatency_delay_switchfun(const void *);
|
|
osTimerDef(deflow_latlatency_delay_switch,low_latlatency_delay_switchfun);
|
|
void low_latlatency_delay_switchinit(void)
|
|
{
|
|
low_latlatency_delay_switchid = osTimerCreate(osTimer(deflow_latlatency_delay_switch),osTimerOnce,(void *)0);
|
|
}
|
|
|
|
void app_ibrt_ui_test_mtu_change_sync_notify(void)
|
|
{
|
|
extern volatile uint8_t avdtp_playback_delay_sbc_mtu;
|
|
extern volatile uint8_t avdtp_playback_delay_aac_mtu;
|
|
|
|
TRACE(3,"SWITC GAME MODE !!!latency_mode_is_open = %d###",latency_mode_is_open);
|
|
if(!latency_mode_is_open)
|
|
{
|
|
avdtp_playback_delay_sbc_mtu = 32;
|
|
avdtp_playback_delay_aac_mtu = 3;
|
|
app_ibrt_if_force_audio_retrigger_slave_sync();
|
|
}
|
|
else
|
|
{
|
|
avdtp_playback_delay_sbc_mtu = 50;
|
|
avdtp_playback_delay_aac_mtu = 6;
|
|
app_ibrt_if_force_audio_retrigger_slave_sync();
|
|
}
|
|
latency_mode_is_open = !latency_mode_is_open;
|
|
TRACE(3,"set SBC_MTU=%d AAC_MTU=%d\n", avdtp_playback_delay_sbc_mtu, avdtp_playback_delay_aac_mtu);
|
|
}
|
|
|
|
static void low_latlatency_delay_switchfun(const void *)
|
|
{
|
|
extern volatile uint8_t avdtp_playback_delay_sbc_mtu;
|
|
extern volatile uint8_t avdtp_playback_delay_aac_mtu;
|
|
|
|
latency_mode_is_open = !latency_mode_is_open;
|
|
if(latency_mode_is_open){
|
|
avdtp_playback_delay_sbc_mtu = 32;
|
|
avdtp_playback_delay_aac_mtu = 3;
|
|
TRACE(3,"%s latency_mode_is_open!!",__func__);
|
|
}else{
|
|
avdtp_playback_delay_sbc_mtu = 50;
|
|
avdtp_playback_delay_aac_mtu = 6;
|
|
TRACE(3,"%s latency_mode_is_close!!",__func__);
|
|
}
|
|
app_ibrt_if_force_audio_retrigger();
|
|
app_ibrt_customif_test3_cmd_send(&latency_mode_is_open,1);
|
|
}
|
|
|
|
void startlow_latlatency_delay_switch(int ms)
|
|
{
|
|
osTimerStart(low_latlatency_delay_switchid,ms);
|
|
}
|
|
|
|
void stoplow_latlatency_delay_switch(void)
|
|
{
|
|
osTimerStop(low_latlatency_delay_switchid);
|
|
|
|
}
|
|
|
|
|
|
|
|
/********************************low_latlatency_delay_switch_timer*******************************************************/
|
|
|
|
|
|
|
|
void app_latency_switch_key_handler(void)
|
|
{
|
|
|
|
if((btif_me_get_activeCons() > 0)&&(app_bt_device.hfchan_call[BT_DEVICE_ID_1] == BTIF_HF_CALL_NONE)&&(app_bt_device.hfchan_callSetup[BT_DEVICE_ID_1] == BTIF_HF_CALL_SETUP_NONE))
|
|
{
|
|
if(latency_mode_is_open){
|
|
app_voice_report(APP_STATUS_INDICATION_ALEXA_STOP,0);//close latlatency mode
|
|
}else{
|
|
app_voice_report(APP_STATUS_INDICATION_ALEXA_START,0);//close latlatency mode
|
|
}
|
|
startlow_latlatency_delay_switch(1500);
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* handling of touch events when the devices are turned on
|
|
|
|
* Both pods active:
|
|
|
|
* Right Ear:
|
|
* Single tap : Play/Pause
|
|
* Double tap : Next track
|
|
* Hold : ANC on/off
|
|
* Triple tap : Volume Up
|
|
*
|
|
* Left Ear:
|
|
* Single tap : Play/Pause
|
|
* Double tap : Previous track
|
|
* Hold : ANC on/off
|
|
* Triple tap : Volume Down
|
|
|
|
* Single pod active:
|
|
|
|
* Single tap : Play/Pause
|
|
* Double tap : Next track
|
|
* Hold : Previous track
|
|
* Triple tap : Volume Up
|
|
* Quad tap : Volume Down
|
|
|
|
|
|
|
|
* We use app_ibrt_if_start_user_action for handling actions, as this will apply locally if we are link master
|
|
* OR send it over the link to the other bud if we are not
|
|
*/
|
|
|
|
void send_vol_up(void){
|
|
uint8_t action[] = {IBRT_ACTION_LOCAL_VOLUP};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}
|
|
void send_play_pause(void){
|
|
if (app_bt_device.a2dp_play_pause_flag!=0) {
|
|
uint8_t action[] = {IBRT_ACTION_PAUSE};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}else {
|
|
uint8_t action[] = {IBRT_ACTION_PLAY};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}
|
|
}
|
|
void send_vol_down(void){
|
|
uint8_t action[] = {IBRT_ACTION_LOCAL_VOLDN};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}
|
|
|
|
void send_next_track(void){
|
|
uint8_t action[] = {IBRT_ACTION_FORWARD};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}
|
|
|
|
void send_prev_track(void){
|
|
uint8_t action[] = {IBRT_ACTION_BACKWARD};
|
|
app_ibrt_if_start_user_action(action, sizeof(action));
|
|
}
|
|
void app_key_single_tap(APP_KEY_STATUS *status, void *param){
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
|
|
if (!app_tws_ibrt_tws_link_connected()){
|
|
//No other bud paired
|
|
TRACE(0,"Handling %s in single bud mode",__func__);
|
|
send_play_pause();
|
|
}else {
|
|
//Bud's are working as a pair
|
|
if (app_tws_is_left_side()){
|
|
TRACE(0,"Handling %s as left bud",__func__);
|
|
//Lefty
|
|
send_play_pause();
|
|
}else {
|
|
TRACE(0,"Handling %s as right bud",__func__);
|
|
//Righty
|
|
send_play_pause();
|
|
}
|
|
}
|
|
|
|
}
|
|
void app_key_double_tap(APP_KEY_STATUS *status, void *param){
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
|
|
if (!app_tws_ibrt_tws_link_connected()){
|
|
//No other bud paired
|
|
TRACE(0,"Handling %s in single bud mode",__func__);
|
|
send_next_track();
|
|
}else {
|
|
//Bud's are working as a pair
|
|
if (app_tws_is_left_side()){
|
|
TRACE(0,"Handling %s as left bud",__func__);
|
|
//Lefty
|
|
send_prev_track();
|
|
}else {
|
|
TRACE(0,"Handling %s as right bud",__func__);
|
|
//Righty
|
|
send_next_track();
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
void app_key_triple_tap(APP_KEY_STATUS *status, void *param){
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
|
|
if (!app_tws_ibrt_tws_link_connected()){
|
|
//No other bud paired
|
|
TRACE(0,"Handling %s in single bud mode",__func__);
|
|
send_vol_up();
|
|
}else {
|
|
//Bud's are working as a pair
|
|
if (app_tws_is_left_side()){
|
|
TRACE(0,"Handling %s as left bud",__func__);
|
|
//Lefty
|
|
send_vol_down();
|
|
}else {
|
|
TRACE(0,"Handling %s as right bud",__func__);
|
|
//Righty
|
|
send_vol_up();
|
|
}
|
|
}
|
|
|
|
}
|
|
void app_key_quad_tap(APP_KEY_STATUS *status, void *param){
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
|
|
if (!app_tws_ibrt_tws_link_connected()){
|
|
//No other bud paired
|
|
TRACE(0,"Handling %s in single bud mode",__func__);
|
|
send_vol_down();
|
|
}else {
|
|
//Bud's are working as a pair
|
|
if (app_tws_is_left_side()){
|
|
TRACE(0,"Handling %s as left bud",__func__);
|
|
//Lefty
|
|
}else {
|
|
TRACE(0,"Handling %s as right bud",__func__);
|
|
//Righty
|
|
}
|
|
}
|
|
}
|
|
|
|
void app_key_long_press_down(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(2,"%s event %d", __func__, status->event);
|
|
|
|
if (!app_tws_ibrt_tws_link_connected()){
|
|
//No other bud paired
|
|
TRACE(0,"Handling %s in single bud mode",__func__);
|
|
send_prev_track();
|
|
}else {
|
|
//Bud's are working as a pair
|
|
app_anc_key(status,param);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
void app_key_reboot(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(1,"%s ",__func__);
|
|
hal_cmu_sys_reboot();
|
|
}
|
|
|
|
|
|
void app_key_init(void)
|
|
{
|
|
uint8_t i = 0;
|
|
TRACE(1,"%s",__func__);
|
|
|
|
const APP_KEY_HANDLE key_cfg[] = {
|
|
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"",app_key_single_tap, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_DOUBLECLICK},"",app_key_double_tap, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_TRIPLECLICK},"",app_key_triple_tap, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_ULTRACLICK},"",app_key_quad_tap, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGPRESS},"",app_key_long_press_down, NULL},
|
|
};
|
|
|
|
app_key_handle_clear();
|
|
for (i=0; i<(sizeof(key_cfg)/sizeof(APP_KEY_HANDLE)); i++){
|
|
app_key_handle_registration(&key_cfg[i]);
|
|
}
|
|
}
|
|
|
|
void app_key_init_on_charging(void)
|
|
{
|
|
uint8_t i = 0;
|
|
const APP_KEY_HANDLE key_cfg[] = {
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGLONGPRESS},"long press reboot",app_key_reboot, NULL},
|
|
// {{APP_KEY_CODE_PWR,APP_KEY_EVENT_CLICK},"bt function key",app_dfu_key_handler, NULL},
|
|
#ifdef __USB_COMM__
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_LONGPRESS},"usb cdc key",app_usb_cdc_comm_key_handler, NULL},
|
|
#endif
|
|
};
|
|
|
|
TRACE(1,"%s",__func__);
|
|
for (i=0; i<(sizeof(key_cfg)/sizeof(APP_KEY_HANDLE)); i++){
|
|
app_key_handle_registration(&key_cfg[i]);
|
|
}
|
|
}
|
|
|
|
void stopAuto_Shutdowm_Timer(void);
|
|
|
|
bool MobileLinkLose_reboot = false;
|
|
bool IsMobileLinkLossing = FALSE;
|
|
bool IsTwsLinkLossing = FALSE;
|
|
bool enterpairing_flag = false;
|
|
bool IsTwsLinkdiscon = false;
|
|
bool reconnect_fail_fail_flag= false;
|
|
static void app_enterpairing_timehandler(void const *param);
|
|
osTimerDef (APP_ENTERPAIRING_TIMER, app_enterpairing_timehandler);
|
|
static osTimerId enterpairing_timer = NULL;
|
|
static void app_enterpairing_timehandler(void const *param)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
static app_ibrt_ui_t *p_ui_ctrl = app_ibrt_ui_get_ctx();
|
|
TRACE(3,"xqd log --%s\n", __func__);
|
|
TRACE(3,"MyLog: is_tws_con = %d, nv_role = 0x%x", app_tws_ibrt_tws_link_connected(), p_ibrt_ctrl->nv_role);
|
|
reconnect_fail_fail_flag = true;
|
|
enterpairing_flag = false;
|
|
if(IsMobileLinkLossing)
|
|
{
|
|
TRACE(3,"xqd---log:return evt 0!!!\n");
|
|
return;
|
|
}
|
|
if(p_ui_ctrl->box_state == IBRT_IN_BOX_CLOSED){
|
|
TRACE(3,"xqd---log:return evt 1!!!\n");
|
|
return;
|
|
}
|
|
if((app_battery_is_charging())||((app_device_bt_is_connected())&&(app_tws_ibrt_mobile_link_connected())&&(app_tws_ibrt_mobile_link_connected())))return;
|
|
|
|
if (app_tws_ibrt_mobile_link_connected() || app_tws_ibrt_slave_ibrt_link_connected()) {
|
|
TRACE(3,"xqd---log:return evt 2!!!\n");
|
|
return;
|
|
}
|
|
|
|
if (app_ibrt_ui_get_enter_pairing_mode()) {
|
|
TRACE(3,"xqd---log:return evt 3!!!\n");
|
|
if((IBRT_UNKNOW != p_ibrt_ctrl->nv_role)&&(nv_record_get_paired_dev_count()>=2)){
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
return;
|
|
}
|
|
|
|
if(app_tws_ibrt_tws_link_connected() && (p_ibrt_ctrl->current_role == IBRT_MASTER))
|
|
{
|
|
TRACE(3,"xqd---log:return evt 4!!!\n");
|
|
|
|
//p_ui_ctrl->config.enter_pairing_on_reconnect_mobile_failed = true;
|
|
//p_ui_ctrl->config.nv_slave_enter_pairing_on_mobile_disconnect = true;
|
|
//app_ibrt_if_enter_freeman_pairing();
|
|
//app_ibrt_if_enter_pairing_after_tws_connected();
|
|
app_ibrt_ui_set_enter_pairing_mode(IBRT_CONNECT_MOBILE_FAILED);
|
|
app_ibrt_ui_judge_scan_type(IBRT_CONNECTE_TRIGGER,MOBILE_LINK, 0);
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
else if ((!app_tws_ibrt_tws_link_connected()) && (p_ibrt_ctrl->nv_role == IBRT_MASTER)&&(p_ibrt_ctrl->access_mode != 0x3))
|
|
{
|
|
TRACE(3,"xqd---log:return evt 5!!!\n");
|
|
app_ibrt_ui_set_enter_pairing_mode(IBRT_CONNECT_MOBILE_FAILED);
|
|
app_ibrt_ui_judge_scan_type(IBRT_CONNECTE_TRIGGER,MOBILE_LINK, 0);
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
else if((!app_tws_ibrt_tws_link_connected()) && (p_ibrt_ctrl->nv_role == IBRT_SLAVE))
|
|
{
|
|
app_ibrt_ui_set_enter_pairing_mode(IBRT_CONNECT_MOBILE_FAILED);
|
|
app_ibrt_ui_judge_scan_type(IBRT_CONNECTE_TRIGGER, MOBILE_LINK, 0);
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
}
|
|
|
|
}
|
|
void app_enterpairing_timer_start(void)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
TRACE(3,"xqd log --app_enterpairing_timer_start, enterpairing_flag = %d,nv_role = %d\n", enterpairing_flag,p_ibrt_ctrl->nv_role);
|
|
if(p_ibrt_ctrl->nv_role == IBRT_UNKNOW)return;
|
|
|
|
enterpairing_flag = true;
|
|
|
|
osTimerStop(enterpairing_timer);
|
|
osTimerStart(enterpairing_timer, 11000);
|
|
}
|
|
void app_enterpairing_timer_stop(void)
|
|
{
|
|
TRACE(3,"xqd log --app_enterpairing_timer_stop\n");
|
|
if(enterpairing_flag)
|
|
osTimerStop(enterpairing_timer);
|
|
}
|
|
void app_enterpairing_timer_open(void)
|
|
{
|
|
if(NULL == enterpairing_timer)
|
|
{
|
|
enterpairing_timer = osTimerCreate (osTimer(APP_ENTERPAIRING_TIMER), osTimerOnce, (void *)0);
|
|
}
|
|
|
|
}
|
|
extern bool IsMobileLinkLossing;
|
|
extern bool IsTwsLinkLossing;
|
|
bool LINKLOSE_REBOOT_ENABLE = false;
|
|
|
|
osTimerId Auto_Shutdowm_Timerid = NULL;
|
|
void startAuto_Shutdowm_Timer(int ms);
|
|
|
|
static void Auto_Shutdowm_Timerfun(const void *);
|
|
osTimerDef(defAuto_Shutdowm_Timer,Auto_Shutdowm_Timerfun);
|
|
void Auto_Shutdowm_Timerinit(void)
|
|
{
|
|
Auto_Shutdowm_Timerid = osTimerCreate(osTimer(defAuto_Shutdowm_Timer),osTimerPeriodic,(void *)0);
|
|
startAuto_Shutdowm_Timer(5000);
|
|
}
|
|
extern struct btdevice_volume *btdevice_volume_p;
|
|
|
|
static void Auto_Shutdowm_Timerfun(const void *)
|
|
{
|
|
static uint32_t auto_shutdown_cnt = 0;
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
static app_ibrt_ui_t *p_ui_ctrl = app_ibrt_ui_get_ctx();
|
|
struct nvrecord_env_t *nvrecord_env;
|
|
nv_record_env_get(&nvrecord_env);
|
|
static uint8_t trace_cnt = 0;
|
|
APP_BATTERY_MV_T currvolt =0;
|
|
//static uint8_t charge_full_timeout_cnt = 0;
|
|
trace_cnt ++;
|
|
if(trace_cnt >= 2){
|
|
trace_cnt = 0;
|
|
/*
|
|
TRACE(0,"xqd---log:curr_role = %d,nv_role = %d,box_state = %d,access_mode = %d,channel = %d",p_ibrt_ctrl->current_role,p_ibrt_ctrl->nv_role,p_ui_ctrl->box_state,p_ibrt_ctrl->access_mode,tgt_tws_get_channel_is_right());
|
|
TRACE(0,"curr_avrcp_status = %d£¬localbat = %d,slave_bat = %d",avrcp_get_media_status(),p_ibrt_ctrl->local_battery_volt,p_ibrt_ctrl->peer_battery_volt);
|
|
TRACE(0,"a2dp vol : %d", btdevice_volume_p->a2dp_vol);
|
|
// TRACE(0,"hfp vol: %d", btdevice_volume_p->hfp_vol);
|
|
TRACE(0,"qxw---nv_ibrt_mode addr:");
|
|
DUMP8("0x%x ", nvrecord_env->ibrt_mode.record.bdAddr.address, 6);
|
|
TRACE(0,"qxw---peer addr:");
|
|
DUMP8("%02x ", p_ibrt_ctrl->peer_addr.address, 6);
|
|
TRACE(0,"qxw---local addr:");
|
|
DUMP8("%02x ", p_ibrt_ctrl->local_addr.address, 6);
|
|
TRACE(0,"qxw---nv_master addr:");
|
|
DUMP8("%02x ", nvrecord_env->master_bdaddr.address, 6);
|
|
TRACE(0,"qxw---nv_slave addr:");
|
|
DUMP8("%02x ", nvrecord_env->slave_bdaddr.address, 6);*/
|
|
//TRACE(2,"charge_gpio statu:%d,chargefull_gpio statu:%d,curr_charge status = %d!",hal_gpio_pin_get_val((enum HAL_GPIO_PIN_T)cfg_hw_charge_indication_cfg.pin),hal_gpio_pin_get_val((enum HAL_GPIO_PIN_T)cfg_hw_charge_full_indication_cfg.pin),app_battery_is_charging());
|
|
}
|
|
|
|
//TRACE(3,"GIOI25 = %d,charge sta = %d!!!!!",hal_gpio_pin_get_val((enum HAL_GPIO_PIN_T)app_battery_charger_full_indicator_cfg.pin),app_battery_is_charging());
|
|
if(app_battery_is_charging()){
|
|
if((p_ui_ctrl->box_state != IBRT_IN_BOX_CLOSED)){
|
|
app_ibrt_ui_event_entry(IBRT_CLOSE_BOX_EVENT);
|
|
}
|
|
}
|
|
app_battery_get_info(&currvolt, NULL, NULL);
|
|
if(p_ui_ctrl->box_state == IBRT_OUT_BOX){
|
|
if(app_device_bt_is_connected())
|
|
{
|
|
IsMobileLinkLossing = FALSE;
|
|
IsTwsLinkLossing = FALSE;
|
|
MobileLinkLose_reboot = FALSE;
|
|
}
|
|
if((!app_device_bt_is_connected())&& p_ibrt_ctrl->current_role != BTIF_BCR_SLAVE)
|
|
{
|
|
auto_shutdown_cnt++;
|
|
if(auto_shutdown_cnt == Auto_Shutdowm_TIME/5)
|
|
{
|
|
TRACE(0,"xqd---shutdown!!@@@@@@!!");
|
|
auto_shutdown_cnt = 0;
|
|
app_bt_power_off_customize();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
auto_shutdown_cnt = 0;
|
|
}
|
|
/*if((auto_shutdown_cnt % 4 == 0)&&(MobileLinkLose_reboot)&&(!app_qxw_bt_is_connected())&&(p_ibrt_ctrl->current_role != BTIF_BCR_SLAVE)){
|
|
app_ibrt_if_event_entry(IBRT_PHONE_CONNECT_EVENT);
|
|
}*/
|
|
}else{
|
|
auto_shutdown_cnt = 0;
|
|
}
|
|
|
|
#if(QXW_TOUCH_INEAR_DET)
|
|
last_tws_con_status = app_tws_ibrt_tws_link_connected();
|
|
#endif
|
|
}
|
|
|
|
void startAuto_Shutdowm_Timer(int ms)
|
|
{
|
|
osTimerStart(Auto_Shutdowm_Timerid,ms);
|
|
}
|
|
void stopAuto_Shutdowm_Timer(void)
|
|
{
|
|
TRACE(0,"%s",__func__);
|
|
osTimerStop(Auto_Shutdowm_Timerid);
|
|
}
|
|
|
|
/********************************Auto_Shutdowm_Timer_timer*******************************************************/
|
|
extern void touch_reset(void);
|
|
/*******************************once_delay_event_Timer__timer*********************************************************/
|
|
uint8_t once_event_case = 0;
|
|
osTimerId once_delay_event_Timer_id = NULL;
|
|
void startonce_delay_event_Timer_(int ms);
|
|
void stoponce_delay_event_Timer_(void);
|
|
static void once_delay_event_Timer_fun(const void *);
|
|
osTimerDef(defonce_delay_event_Timer_,once_delay_event_Timer_fun);
|
|
void once_delay_event_Timer_init(void)
|
|
{
|
|
TRACE(3,"%s",__func__);
|
|
once_delay_event_Timer_id = osTimerCreate(osTimer(defonce_delay_event_Timer_),osTimerOnce,(void *)0);
|
|
}
|
|
static void once_delay_event_Timer_fun(const void *)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
if((p_ibrt_ctrl->current_role == IBRT_SLAVE))
|
|
{
|
|
once_event_case = 0;
|
|
TRACE(3,"delay_report_tonefun RETURN!!!");
|
|
return;
|
|
}
|
|
TRACE(3,"\n\n!!!!!!enter %s,mobile_link = %d,event = %d\n\n",__func__,app_tws_ibrt_mobile_link_connected(),once_event_case);
|
|
switch(once_event_case)
|
|
{
|
|
case 1:
|
|
if(/*(avrcp_get_media_status() != 1)&&*/(app_bt_device.a2dp_state[BT_DEVICE_ID_1] == 1)&&(app_bt_device.hfchan_callSetup[BT_DEVICE_ID_1] == 0)&&
|
|
(p_ibrt_ctrl->current_role == IBRT_MASTER))
|
|
app_voice_report(APP_STATUS_INDICATION_CONNECTED,0);
|
|
break;
|
|
case 2:
|
|
if((IsMobileLinkLossing || app_device_bt_is_connected()))break;
|
|
app_voice_report(APP_STATUS_INDICATION_DISCONNECTED,0);
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
//once_event_case = 3;
|
|
// startonce_delay_event_Timer_(2000);
|
|
break;
|
|
case 3:
|
|
if(IsMobileLinkLossing)
|
|
{
|
|
return;
|
|
}
|
|
if((app_device_bt_is_connected()))return;
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
if(p_ibrt_ctrl->nv_role == IBRT_MASTER)
|
|
{
|
|
app_ibrt_if_enter_pairing_after_tws_connected();
|
|
}
|
|
else if(p_ibrt_ctrl->nv_role == IBRT_SLAVE)
|
|
{
|
|
app_ibrt_ui_set_enter_pairing_mode(IBRT_CONNECT_MOBILE_FAILED);
|
|
app_ibrt_ui_judge_scan_type(IBRT_CONNECTE_TRIGGER,MOBILE_LINK, 0);
|
|
}
|
|
else if(p_ibrt_ctrl->nv_role == IBRT_UNKNOW)
|
|
{
|
|
app_ibrt_ui_judge_scan_type(IBRT_FREEMAN_PAIR_TRIGGER,NO_LINK_TYPE, IBRT_UI_NO_ERROR);
|
|
app_ibrt_ui_set_freeman_enable();
|
|
}
|
|
break;
|
|
|
|
case 4:
|
|
if(!app_device_bt_is_connected()){
|
|
app_voice_report_generic(APP_STATUS_INDICATION_DISCONNECTED, 0,0);
|
|
}
|
|
LINKLOSE_REBOOT_ENABLE = true;
|
|
break;
|
|
case 5:
|
|
if(!app_device_bt_is_connected()&&!app_tws_ibrt_tws_link_connected()){
|
|
app_voice_report_generic(APP_STATUS_INDICATION_DISCONNECTED, 0,0);
|
|
}
|
|
LINKLOSE_REBOOT_ENABLE = true;
|
|
break;
|
|
case 8:
|
|
app_ibrt_sync_volume_info();
|
|
break;
|
|
case 9:
|
|
break;
|
|
default:
|
|
break;
|
|
|
|
}
|
|
once_event_case = 0;
|
|
}
|
|
|
|
void startonce_delay_event_Timer_(int ms)
|
|
{
|
|
TRACE(3,"\n\n !!!!!!!!!!start %s\n\n",__func__);
|
|
osTimerStart(once_delay_event_Timer_id,ms);
|
|
}
|
|
void stoponce_delay_event_Timer_(void)
|
|
{
|
|
TRACE(3,"\n\n!!!!!!!!!! stop %s\n\n",__func__);
|
|
osTimerStop(once_delay_event_Timer_id);
|
|
}
|
|
|
|
/********************************once_delay_event_Timer__timer*******************************************************/
|
|
/***********************************************************************************************/
|
|
#include "hal_gpio.h"
|
|
#include "tgt_hardware.h"
|
|
extern struct BT_DEVICE_T app_bt_device;
|
|
extern void hal_gpio_pin_set(enum HAL_GPIO_PIN_T pin);
|
|
|
|
|
|
bool Curr_Is_Master(void)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
if(p_ibrt_ctrl->current_role == IBRT_MASTER)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
bool Curr_Is_Slave(void)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
if(p_ibrt_ctrl->current_role == IBRT_SLAVE)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
uint8_t get_curr_role(void)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
return p_ibrt_ctrl->current_role;
|
|
}
|
|
|
|
uint8_t get_nv_role(void)
|
|
{
|
|
static ibrt_ctrl_t *p_ibrt_ctrl = app_tws_ibrt_get_bt_ctrl_ctx();
|
|
return p_ibrt_ctrl->nv_role;
|
|
}
|
|
|
|
extern bt_status_t LinkDisconnectDirectly(bool PowerOffFlag);
|
|
void a2dp_suspend_music_force(void);
|
|
|
|
bool app_is_power_off_in_progress(void)
|
|
{
|
|
return app_poweroff_flag?TRUE:FALSE;
|
|
}
|
|
|
|
#if GFPS_ENABLED
|
|
#define APP_GFPS_BATTERY_TIMEROUT_VALUE (10000)
|
|
static void app_gfps_battery_show_timeout_timer_cb(void const *n);
|
|
osTimerDef (GFPS_BATTERY_SHOW_TIMEOUT_TIMER, app_gfps_battery_show_timeout_timer_cb);
|
|
static osTimerId app_gfps_battery_show_timer_id = NULL;
|
|
#include "app_gfps.h"
|
|
static void app_gfps_battery_show_timeout_timer_cb(void const *n)
|
|
{
|
|
TRACE(1,"%s", __func__);
|
|
app_gfps_set_battery_datatype(HIDE_UI_INDICATION);
|
|
}
|
|
|
|
void app_gfps_battery_show_timer_start()
|
|
{
|
|
if (app_gfps_battery_show_timer_id == NULL)
|
|
app_gfps_battery_show_timer_id = osTimerCreate(osTimer(GFPS_BATTERY_SHOW_TIMEOUT_TIMER), osTimerOnce, NULL);
|
|
osTimerStart(app_gfps_battery_show_timer_id, APP_GFPS_BATTERY_TIMEROUT_VALUE);
|
|
}
|
|
|
|
void app_gfps_battery_show_timer_stop()
|
|
{
|
|
if (app_gfps_battery_show_timer_id)
|
|
osTimerStop(app_gfps_battery_show_timer_id);
|
|
}
|
|
#endif
|
|
|
|
int app_deinit(int deinit_case)
|
|
{
|
|
int nRet = 0;
|
|
TRACE(2,"%s case:%d",__func__, deinit_case);
|
|
app_tws_if_trigger_role_switch();
|
|
osDelay(200); // This is a hack; a hackkitttyy hack. To wait for the tws exchange to occur
|
|
#ifdef WL_DET
|
|
app_mic_alg_audioloop(false,APP_SYSFREQ_78M);
|
|
#endif
|
|
|
|
#ifdef __PC_CMD_UART__
|
|
app_cmd_close();
|
|
#endif
|
|
#if (defined(BTUSB_AUDIO_MODE) || defined(BT_USB_AUDIO_DUAL_MODE))
|
|
if(app_usbaudio_mode_on()) return 0;
|
|
#endif
|
|
if (!deinit_case){
|
|
app_poweroff_flag = 1;
|
|
#if defined(APP_LINEIN_A2DP_SOURCE)
|
|
app_audio_sendrequest(APP_A2DP_SOURCE_LINEIN_AUDIO, (uint8_t)APP_BT_SETTING_CLOSE,0);
|
|
#endif
|
|
#if defined(APP_I2S_A2DP_SOURCE)
|
|
app_audio_sendrequest(APP_A2DP_SOURCE_I2S_AUDIO, (uint8_t)APP_BT_SETTING_CLOSE,0);
|
|
#endif
|
|
app_status_indication_filter_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
app_audio_sendrequest(APP_BT_STREAM_INVALID, (uint8_t)APP_BT_SETTING_CLOSEALL, 0);
|
|
osDelay(500);
|
|
LinkDisconnectDirectly(true);
|
|
osDelay(500);
|
|
app_status_indication_set(APP_STATUS_INDICATION_POWEROFF);
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_voice_report(APP_STATUS_INDICATION_POWEROFF, 0);
|
|
#endif
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO1,THIRDPARTY_DEINIT);
|
|
#endif
|
|
#if FPGA==0
|
|
nv_record_flash_flush();
|
|
norflash_api_flush_all();
|
|
#if defined(DUMP_LOG_ENABLE)
|
|
log_dump_flush_all();
|
|
#endif
|
|
#endif
|
|
osDelay(1000);
|
|
af_close();
|
|
}
|
|
|
|
return nRet;
|
|
}
|
|
|
|
#ifdef APP_TEST_MODE
|
|
extern void app_test_init(void);
|
|
int app_init(void)
|
|
{
|
|
int nRet = 0;
|
|
//uint8_t pwron_case = APP_POWERON_CASE_INVALID;
|
|
TRACE(1,"%s",__func__);
|
|
app_poweroff_flag = 0;
|
|
|
|
app_sysfreq_req(APP_SYSFREQ_USER_APP_INIT, APP_SYSFREQ_52M);
|
|
list_init();
|
|
af_open();
|
|
app_os_init();
|
|
app_pwl_open();
|
|
app_audio_open();
|
|
app_audio_manager_open();
|
|
app_overlay_open();
|
|
if (app_key_open(true))
|
|
{
|
|
nRet = -1;
|
|
goto exit;
|
|
}
|
|
|
|
app_test_init();
|
|
exit:
|
|
app_sysfreq_req(APP_SYSFREQ_USER_APP_INIT, APP_SYSFREQ_32K);
|
|
return nRet;
|
|
}
|
|
#else /* !defined(APP_TEST_MODE) */
|
|
|
|
int app_bt_connect2tester_init(void)
|
|
{
|
|
btif_device_record_t rec;
|
|
bt_bdaddr_t tester_addr;
|
|
uint8_t i;
|
|
bool find_tester = false;
|
|
struct nvrecord_env_t *nvrecord_env;
|
|
btdevice_profile *btdevice_plf_p;
|
|
nv_record_env_get(&nvrecord_env);
|
|
|
|
if (nvrecord_env->factory_tester_status.status != NVRAM_ENV_FACTORY_TESTER_STATUS_DEFAULT)
|
|
return 0;
|
|
|
|
if (!nvrec_dev_get_dongleaddr(&tester_addr)){
|
|
nv_record_open(section_usrdata_ddbrecord);
|
|
for (i = 0; nv_record_enum_dev_records(i, &rec) == BT_STS_SUCCESS; i++) {
|
|
if (!memcmp(rec.bdAddr.address, tester_addr.address, BTIF_BD_ADDR_SIZE)){
|
|
find_tester = true;
|
|
}
|
|
}
|
|
if(i==0 && !find_tester){
|
|
memset(&rec, 0, sizeof(btif_device_record_t));
|
|
memcpy(rec.bdAddr.address, tester_addr.address, BTIF_BD_ADDR_SIZE);
|
|
nv_record_add(section_usrdata_ddbrecord, &rec);
|
|
btdevice_plf_p = (btdevice_profile *)app_bt_profile_active_store_ptr_get(rec.bdAddr.address);
|
|
nv_record_btdevicerecord_set_hfp_profile_active_state(btdevice_plf_p, true);
|
|
nv_record_btdevicerecord_set_a2dp_profile_active_state(btdevice_plf_p, true);
|
|
}
|
|
if (find_tester && i>2){
|
|
nv_record_ddbrec_delete(&tester_addr);
|
|
nvrecord_env->factory_tester_status.status = NVRAM_ENV_FACTORY_TESTER_STATUS_TEST_PASS;
|
|
nv_record_env_set(nvrecord_env);
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int app_nvrecord_rebuild(void)
|
|
{
|
|
struct nvrecord_env_t *nvrecord_env;
|
|
nv_record_env_get(&nvrecord_env);
|
|
|
|
nv_record_sector_clear();
|
|
nv_record_env_init();
|
|
nv_record_update_factory_tester_status(NVRAM_ENV_FACTORY_TESTER_STATUS_TEST_PASS);
|
|
nv_record_env_set(nvrecord_env);
|
|
nv_record_flash_flush();
|
|
|
|
return 0;
|
|
}
|
|
|
|
#if (defined(BTUSB_AUDIO_MODE) || defined(BT_USB_AUDIO_DUAL_MODE))
|
|
#include "app_audio.h"
|
|
#include "usb_audio_frm_defs.h"
|
|
#include "usb_audio_app.h"
|
|
|
|
static bool app_usbaudio_mode = false;
|
|
|
|
extern "C" void btusbaudio_entry(void);
|
|
void app_usbaudio_entry(void)
|
|
{
|
|
btusbaudio_entry();
|
|
app_usbaudio_mode = true ;
|
|
}
|
|
|
|
bool app_usbaudio_mode_on(void)
|
|
{
|
|
return app_usbaudio_mode;
|
|
}
|
|
|
|
void app_usb_key(APP_KEY_STATUS *status, void *param)
|
|
{
|
|
TRACE(3,"%s %d,%d",__func__, status->code, status->event);
|
|
|
|
}
|
|
|
|
const APP_KEY_HANDLE app_usb_handle_cfg[] = {
|
|
{{APP_KEY_CODE_FN1,APP_KEY_EVENT_UP},"USB HID FN1 UP key",app_usb_key, NULL},
|
|
{{APP_KEY_CODE_FN2,APP_KEY_EVENT_UP},"USB HID FN2 UP key",app_usb_key, NULL},
|
|
{{APP_KEY_CODE_PWR,APP_KEY_EVENT_UP},"USB HID PWR UP key",app_usb_key, NULL},
|
|
};
|
|
|
|
void app_usb_key_init(void)
|
|
{
|
|
uint8_t i = 0;
|
|
TRACE(1,"%s",__func__);
|
|
for (i=0; i<(sizeof(app_usb_handle_cfg)/sizeof(APP_KEY_HANDLE)); i++){
|
|
app_key_handle_registration(&app_usb_handle_cfg[i]);
|
|
}
|
|
}
|
|
#endif /* (defined(BTUSB_AUDIO_MODE) || defined(BT_USB_AUDIO_DUAL_MODE)) */
|
|
|
|
//#define OS_HAS_CPU_STAT 1
|
|
#if OS_HAS_CPU_STAT
|
|
extern "C" void rtx_show_all_threads_usage(void);
|
|
#define _CPU_STATISTICS_PEROID_ 6000
|
|
#define CPU_USAGE_TIMER_TMO_VALUE (_CPU_STATISTICS_PEROID_/3)
|
|
static void cpu_usage_timer_handler(void const *param);
|
|
osTimerDef(cpu_usage_timer, cpu_usage_timer_handler);
|
|
static osTimerId cpu_usage_timer_id = NULL;
|
|
static void cpu_usage_timer_handler(void const *param)
|
|
{
|
|
rtx_show_all_threads_usage();
|
|
}
|
|
#endif
|
|
|
|
#ifdef USER_REBOOT_PLAY_MUSIC_AUTO
|
|
bool a2dp_need_to_play = false;
|
|
#endif
|
|
extern void btif_me_write_bt_sleep_enable(uint8_t sleep_en);
|
|
|
|
int btdrv_tportopen(void);
|
|
|
|
|
|
void app_ibrt_init(void)
|
|
{
|
|
app_bt_global_handle_init();
|
|
#if defined(IBRT)
|
|
ibrt_config_t config;
|
|
app_tws_ibrt_init();
|
|
app_ibrt_ui_init();
|
|
app_ibrt_ui_test_init();
|
|
app_ibrt_if_config_load(&config);
|
|
app_ibrt_customif_ui_start();
|
|
#ifdef IBRT_SEARCH_UI
|
|
app_tws_ibrt_start(&config, true);
|
|
app_ibrt_search_ui_init(false,IBRT_NONE_EVENT);
|
|
#else
|
|
app_tws_ibrt_start(&config, false);
|
|
#endif
|
|
|
|
#ifdef POWER_ON_ENTER_TWS_PAIRING_ENABLED
|
|
app_ibrt_ui_event_entry(IBRT_TWS_PAIRING_EVENT);
|
|
#endif
|
|
|
|
#endif
|
|
}
|
|
|
|
#ifdef GFPS_ENABLED
|
|
static void app_tell_battery_info_handler(uint8_t *batteryValueCount,
|
|
uint8_t *batteryValue)
|
|
{
|
|
GFPS_BATTERY_STATUS_E status;
|
|
if (app_battery_is_charging())
|
|
{
|
|
status = BATTERY_CHARGING;
|
|
}
|
|
else
|
|
{
|
|
status = BATTERY_NOT_CHARGING;
|
|
}
|
|
|
|
// TODO: add the charger case's battery level
|
|
#ifdef IBRT
|
|
if (app_tws_ibrt_tws_link_connected())
|
|
{
|
|
*batteryValueCount = 2;
|
|
}
|
|
else
|
|
{
|
|
*batteryValueCount = 1;
|
|
}
|
|
#else
|
|
*batteryValueCount = 1;
|
|
#endif
|
|
|
|
TRACE(2,"%s,*batteryValueCount is %d",__func__,*batteryValueCount);
|
|
if (1 == *batteryValueCount)
|
|
{
|
|
batteryValue[0] = ((app_battery_current_level()+1) * 10) | (status << 7);
|
|
}
|
|
else
|
|
{
|
|
batteryValue[0] = ((app_battery_current_level()+1) * 10) | (status << 7);
|
|
batteryValue[1] = ((app_battery_current_level()+1) * 10) | (status << 7);
|
|
|
|
}
|
|
}
|
|
#endif
|
|
/*
|
|
#define regaddr0 0x40
|
|
#define regaddr1 0x41
|
|
#define regaddr2 0x42
|
|
#define regaddr3 0x43
|
|
|
|
#define regaddr4 0xc8
|
|
|
|
#define decice_firstreg 0x00
|
|
*/
|
|
void touch_evt_handler(enum HAL_GPIO_PIN_T pin)
|
|
{
|
|
TRACE(3,"SCL_TOUCH !!!!");
|
|
|
|
/*
|
|
unsigned char keyEventBUff0 ;
|
|
unsigned char keyEventBUff1 ;
|
|
unsigned char keyEventBUff2 ;
|
|
unsigned char keyEventBUff3 ;
|
|
unsigned char temp = 0;
|
|
//hal_gpio_i2c_simple_recv((unsigned char)0x60, 0x40, 1,&keyEventBUff,4);
|
|
I2C_ReadByte(regaddr0,&keyEventBUff0);
|
|
I2C_ReadByte(regaddr1,&keyEventBUff1);
|
|
I2C_ReadByte(regaddr2,&keyEventBUff2);
|
|
I2C_ReadByte(regaddr3,&keyEventBUff3);
|
|
unsigned char firstaddr;
|
|
|
|
I2C_ReadByte(decice_firstreg,&firstaddr);
|
|
TRACE(3,"0X00 REG = 0x%x",firstaddr);
|
|
unsigned char keyEventBUff4byte[4] ;
|
|
I2C_Read4Byte(regaddr0,keyEventBUff4byte);
|
|
|
|
I2C_ReadByte(0xC8,&temp);
|
|
temp |= 0x01;
|
|
I2C_WriteByte(0xC8,temp);
|
|
TRACE(3,"REG0X40 = 0x%x, REG0X41 = 0x%x, REG0X42 = 0x%x, REG0X43 = 0x%x",keyEventBUff0,keyEventBUff1,keyEventBUff2,keyEventBUff3);
|
|
TRACE(3,"keyEventBUff4BYTE :");
|
|
DUMP8("0x%02x ",keyEventBUff4byte,4);
|
|
|
|
uint8_t keyEventBUff0[4];
|
|
uint8_t keyEventBUff4[1];
|
|
|
|
touch_key_i2c_read(regaddr0,&keyEventBUff0[0],1);
|
|
touch_key_i2c_read(regaddr1,&keyEventBUff0[1],1);
|
|
touch_key_i2c_read(regaddr2,&keyEventBUff0[2],1);
|
|
touch_key_i2c_read(regaddr3,&keyEventBUff0[3],1);
|
|
touch_key_i2c_read(regaddr4,keyEventBUff4,1);
|
|
TRACE(3,"keyEventBUff0 :");
|
|
DUMP8("0x%02x ",keyEventBUff0,4);
|
|
TRACE(3,"keyEventBUff1 :");
|
|
DUMP8("0x%02x ",keyEventBUff4,1);
|
|
keyEventBUff4[0] |= 0x1;
|
|
touch_key_i2c_write(0,regaddr4,1,keyEventBUff4);
|
|
*/
|
|
}
|
|
|
|
|
|
/******************************LED_status_timer*********************************************************/
|
|
osTimerId LED_statusid = NULL;
|
|
void startLED_status(int ms);
|
|
void stopLED_status(void);
|
|
static void LED_statusfun(const void *);
|
|
osTimerDef(defLED_status,LED_statusfun);
|
|
void LED_statusinit(void)
|
|
{
|
|
LED_statusid = osTimerCreate(osTimer(defLED_status),osTimerOnce,(void *)0);
|
|
}
|
|
static void LED_statusfun(const void *)
|
|
{
|
|
//TRACE("\n\n!!!!!!enter %s\n\n",__func__);
|
|
if((Curr_Is_Slave()||app_device_bt_is_connected())&&(!app_battery_is_charging())){
|
|
app_status_indication_set(APP_STATUS_INDICATION_CONNECTED);
|
|
}else if(!app_device_bt_is_connected()&&(!app_battery_is_charging())){
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
}else if(app_battery_is_charging()){
|
|
app_status_indication_set(APP_STATUS_INDICATION_CHARGING);
|
|
}
|
|
//unsigned char firstaddr;
|
|
//I2C_ReadByte(decice_firstreg,&firstaddr);
|
|
//TRACE(3,"0X00 REG = 0x%x",firstaddr);
|
|
startLED_status(1000);
|
|
}
|
|
|
|
void startLED_status(int ms)
|
|
{
|
|
//TRACE("\n\n !!!!!!!!!!start %s\n\n",__func__);
|
|
osTimerStart(LED_statusid,ms);
|
|
}
|
|
void stopLED_status(void)
|
|
{
|
|
//TRACE("\n\n!!!!!!!!!! stop %s\n\n",__func__);
|
|
osTimerStop(LED_statusid);
|
|
}
|
|
|
|
/********************************LED_status_timer*******************************************************/
|
|
|
|
|
|
|
|
/********************************TOUCH_INT_TEST_timer*******************************************************/
|
|
|
|
void user_io_timer_init(void)
|
|
{
|
|
//app_mute_ctrl_init();
|
|
LED_statusinit();
|
|
//pwrkey_detinit();
|
|
Auto_Shutdowm_Timerinit();
|
|
delay_report_toneinit();
|
|
once_delay_event_Timer_init();
|
|
//app_i2c_demo_init();
|
|
//tou_io_init();
|
|
}
|
|
|
|
extern uint32_t __coredump_section_start[];
|
|
extern uint32_t __ota_upgrade_log_start[];
|
|
extern uint32_t __log_dump_start[];
|
|
extern uint32_t __crash_dump_start[];
|
|
extern uint32_t __custom_parameter_start[];
|
|
extern uint32_t __lhdc_license_start[];
|
|
extern uint32_t __aud_start[];
|
|
extern uint32_t __userdata_start[];
|
|
extern uint32_t __factory_start[];
|
|
|
|
#if defined(A2DP_LHDC_ON)
|
|
extern "C"
|
|
{
|
|
typedef struct bes_bt_local_info_t
|
|
{
|
|
uint8_t bt_addr[BTIF_BD_ADDR_SIZE];
|
|
const char *bt_name;
|
|
uint8_t bt_len;
|
|
uint8_t ble_addr[BTIF_BD_ADDR_SIZE];
|
|
const char *ble_name;
|
|
uint8_t ble_len;
|
|
} bes_bt_local_info;
|
|
|
|
typedef int (*LHDC_GET_BT_INFO)(bes_bt_local_info *bt_info);
|
|
extern bool lhdcSetLicenseKeyTable(uint8_t * licTable, LHDC_GET_BT_INFO pFunc);
|
|
}
|
|
extern int bes_bt_local_info_get(bes_bt_local_info *local_info);
|
|
|
|
void lhdc_license_check()
|
|
{
|
|
uint8_t lhdc_license_key = 0;
|
|
uint8_t *lhdc_license_data=(uint8_t * )__lhdc_license_start + 0x98;
|
|
TRACE(5,"lhdc_license_data:%p, lhdc license %02x %02x %02x %02x",lhdc_license_data,
|
|
lhdc_license_data[0],lhdc_license_data[1],lhdc_license_data[2],lhdc_license_data[3]);
|
|
|
|
app_overlay_select(APP_OVERLAY_A2DP_LHDC);
|
|
TRACE(1, "current_overlay = %d", app_get_current_overlay());
|
|
|
|
lhdc_license_key = lhdcSetLicenseKeyTable(lhdc_license_data, bes_bt_local_info_get);
|
|
TRACE(0, "lhdc_license_key:%d", lhdc_license_key);
|
|
|
|
if(lhdc_license_key)
|
|
{
|
|
TRACE(0, "LHDC OK");
|
|
}
|
|
else
|
|
{
|
|
TRACE(0, "LHDC ERROR");
|
|
}
|
|
}
|
|
#endif
|
|
|
|
int app_init(void)
|
|
{
|
|
int nRet = 0;
|
|
struct nvrecord_env_t *nvrecord_env;
|
|
#ifdef POWER_ON_ENTER_TWS_PAIRING_ENABLED
|
|
bool need_check_key = false;
|
|
#else
|
|
bool need_check_key = false;
|
|
#endif
|
|
uint8_t pwron_case = APP_POWERON_CASE_INVALID;
|
|
#ifdef BT_USB_AUDIO_DUAL_MODE
|
|
uint8_t usb_plugin = 0;
|
|
#endif
|
|
#ifdef IBRT_SEARCH_UI
|
|
bool is_charging_poweron=false;
|
|
#endif
|
|
TRACE(0,"please check all sections sizes and heads is correct ........");
|
|
TRACE(2,"__coredump_section_start: %p length: 0x%x", __coredump_section_start, CORE_DUMP_SECTION_SIZE);
|
|
TRACE(2,"__ota_upgrade_log_start: %p length: 0x%x", __ota_upgrade_log_start, OTA_UPGRADE_LOG_SIZE);
|
|
TRACE(2,"__log_dump_start: %p length: 0x%x", __log_dump_start, LOG_DUMP_SECTION_SIZE);
|
|
TRACE(2,"__crash_dump_start: %p length: 0x%x", __crash_dump_start, CRASH_DUMP_SECTION_SIZE);
|
|
TRACE(2,"__custom_parameter_start: %p length: 0x%x", __custom_parameter_start, CUSTOM_PARAMETER_SECTION_SIZE);
|
|
TRACE(2,"__lhdc_license_start: %p length: 0x%x", __lhdc_license_start, LHDC_LICENSE_SECTION_SIZE);
|
|
TRACE(2,"__userdata_start: %p length: 0x%x", __userdata_start, USERDATA_SECTION_SIZE*2);
|
|
TRACE(2,"__aud_start: %p length: 0x%x", __aud_start, AUD_SECTION_SIZE);
|
|
TRACE(2,"__factory_start: %p length: 0x%x", __factory_start, FACTORY_SECTION_SIZE);
|
|
|
|
TRACE(0,"app_init\n");
|
|
app_tws_set_side_from_gpio();
|
|
#ifdef __RPC_ENABLE__
|
|
extern int rpc_service_setup(void);
|
|
rpc_service_setup();
|
|
#endif
|
|
|
|
#ifdef IBRT
|
|
// init tws interface
|
|
app_tws_if_init();
|
|
#endif // #ifdef IBRT
|
|
|
|
nv_record_init();
|
|
factory_section_init();
|
|
|
|
#ifdef ANC_APP
|
|
app_anc_ios_init();
|
|
#endif
|
|
app_sysfreq_req(APP_SYSFREQ_USER_APP_INIT, APP_SYSFREQ_104M);
|
|
#if defined(MCU_HIGH_PERFORMANCE_MODE)
|
|
TRACE(1,"sys freq calc : %d\n", hal_sys_timer_calc_cpu_freq(5, 0));
|
|
#endif
|
|
list_init();
|
|
nRet = app_os_init();
|
|
if (nRet) {
|
|
goto exit;
|
|
}
|
|
#if OS_HAS_CPU_STAT
|
|
cpu_usage_timer_id = osTimerCreate(osTimer(cpu_usage_timer), osTimerPeriodic, NULL);
|
|
if (cpu_usage_timer_id != NULL) {
|
|
osTimerStart(cpu_usage_timer_id, CPU_USAGE_TIMER_TMO_VALUE);
|
|
}
|
|
#endif
|
|
|
|
//app_status_indication_init();
|
|
|
|
#ifdef BTADDR_FOR_DEBUG
|
|
gen_bt_addr_for_debug();
|
|
#endif
|
|
|
|
#ifdef FORCE_SIGNALINGMODE
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_TEST_NOSIGNALINGMODE);
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_TEST_MODE | HAL_SW_BOOTMODE_TEST_SIGNALINGMODE);
|
|
#elif defined FORCE_NOSIGNALINGMODE
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_TEST_SIGNALINGMODE);
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_TEST_MODE | HAL_SW_BOOTMODE_TEST_NOSIGNALINGMODE);
|
|
#endif
|
|
|
|
if (hal_sw_bootmode_get() & HAL_SW_BOOTMODE_REBOOT_FROM_CRASH){
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT_FROM_CRASH);
|
|
TRACE(0,"Crash happened!!!");
|
|
#ifdef VOICE_DATAPATH
|
|
gsound_dump_set_flag(true);
|
|
#endif
|
|
}
|
|
|
|
if (hal_sw_bootmode_get() & HAL_SW_BOOTMODE_REBOOT){
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_REBOOT);
|
|
pwron_case = APP_POWERON_CASE_REBOOT;
|
|
need_check_key = false;
|
|
TRACE(0,"Initiative REBOOT happens!!!");
|
|
#ifdef USER_REBOOT_PLAY_MUSIC_AUTO
|
|
if(hal_sw_bootmode_get() & HAL_SW_BOOTMODE_LOCAL_PLAYER)
|
|
{
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_LOCAL_PLAYER);
|
|
a2dp_need_to_play = true;
|
|
TRACE(0,"a2dp_need_to_play = true");
|
|
}
|
|
#endif
|
|
}
|
|
|
|
if (hal_sw_bootmode_get() & HAL_SW_BOOTMODE_TEST_MODE){
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_TEST_MODE);
|
|
pwron_case = APP_POWERON_CASE_TEST;
|
|
need_check_key = false;
|
|
TRACE(0,"To enter test mode!!!");
|
|
}
|
|
|
|
|
|
#ifdef BT_USB_AUDIO_DUAL_MODE
|
|
usb_os_init();
|
|
#endif
|
|
nRet = app_battery_open();
|
|
TRACE(1,"Yin BATTERY %d",nRet);
|
|
if (pwron_case != APP_POWERON_CASE_TEST){
|
|
#ifdef USER_REBOOT_PLAY_MUSIC_AUTO
|
|
TRACE(0,"hal_sw_bootmode_clear HAL_SW_BOOTMODE_LOCAL_PLAYER!!!!!!");
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_LOCAL_PLAYER);
|
|
#endif
|
|
switch (nRet) {
|
|
case APP_BATTERY_OPEN_MODE_NORMAL:
|
|
nRet = 0;
|
|
break;
|
|
case APP_BATTERY_OPEN_MODE_CHARGING:
|
|
app_status_indication_set(APP_STATUS_INDICATION_CHARGING);
|
|
TRACE(0,"CHARGING!");
|
|
app_battery_start();
|
|
|
|
app_key_open(false);
|
|
app_key_init_on_charging();
|
|
nRet = 0;
|
|
#if defined(BT_USB_AUDIO_DUAL_MODE)
|
|
usb_plugin = 1;
|
|
#elif defined(BTUSB_AUDIO_MODE)
|
|
goto exit;
|
|
#endif
|
|
goto exit;
|
|
break;
|
|
case APP_BATTERY_OPEN_MODE_CHARGING_PWRON:
|
|
TRACE(0,"CHARGING PWRON!");
|
|
#ifdef IBRT_SEARCH_UI
|
|
is_charging_poweron=true;
|
|
#endif
|
|
app_status_indication_set(APP_STATUS_INDICATION_CHARGING);
|
|
need_check_key = false;
|
|
nRet = 0;
|
|
break;
|
|
case APP_BATTERY_OPEN_MODE_INVALID:
|
|
default:
|
|
nRet = -1;
|
|
goto exit;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (app_key_open(need_check_key)){
|
|
TRACE(0,"PWR KEY DITHER!");
|
|
nRet = -1;
|
|
goto exit;
|
|
}
|
|
|
|
hal_sw_bootmode_set(HAL_SW_BOOTMODE_REBOOT);
|
|
app_poweron_key_init();
|
|
#if defined(_AUTO_TEST_)
|
|
AUTO_TEST_SEND("Power on.");
|
|
#endif
|
|
app_bt_init();
|
|
af_open();
|
|
app_audio_open();
|
|
app_audio_manager_open();
|
|
app_overlay_open();
|
|
|
|
nv_record_env_init();
|
|
nvrec_dev_data_open();
|
|
factory_section_open();
|
|
|
|
/*****************************************************************************/
|
|
// app_bt_connect2tester_init();
|
|
nv_record_env_get(&nvrecord_env);
|
|
|
|
|
|
#ifdef AUDIO_LOOPBACK
|
|
|
|
#ifdef WL_DET
|
|
app_mic_alg_audioloop(true,APP_SYSFREQ_78M);
|
|
#endif
|
|
|
|
while(1);
|
|
#endif
|
|
|
|
#ifdef BISTO_ENABLED
|
|
nv_record_gsound_rec_init();
|
|
#endif
|
|
|
|
#ifdef BLE_ENABLE
|
|
app_ble_mode_init();
|
|
app_ble_customif_init();
|
|
#ifdef IBRT
|
|
app_ble_force_switch_adv(BLE_SWITCH_USER_IBRT, false);
|
|
#endif // #ifdef IBRT
|
|
#endif
|
|
|
|
audio_process_init();
|
|
#ifdef __PC_CMD_UART__
|
|
app_cmd_open();
|
|
#endif
|
|
#ifdef AUDIO_DEBUG_V0_1_0
|
|
speech_tuning_init();
|
|
#endif
|
|
#ifdef ANC_APP
|
|
app_anc_open_module();
|
|
#endif
|
|
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_play_audio_set_lang(nvrecord_env->media_language.language);
|
|
#endif
|
|
app_bt_stream_volume_ptr_update(NULL);
|
|
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_init();
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO2,THIRDPARTY_INIT);
|
|
#endif
|
|
|
|
// TODO: freddie->unify all of the OTA modules
|
|
#if defined(IBRT_OTA)
|
|
ota_flash_init();
|
|
#endif
|
|
|
|
#ifdef OTA_ENABLED
|
|
/// init OTA common module
|
|
ota_common_init_handler();
|
|
#endif // OTA_ENABLED
|
|
|
|
#ifdef IBRT
|
|
// for TWS side decision, the last bit is 1:right, 0:left
|
|
if (app_tws_is_unknown_side())
|
|
{
|
|
//app_tws_set_side_from_addr(factory_section_get_bt_address());
|
|
app_tws_set_side_from_gpio();
|
|
}
|
|
#endif
|
|
|
|
|
|
btdrv_start_bt();
|
|
#if defined (__GMA_VOICE__) && defined(IBRT_SEARCH_UI)
|
|
app_ibrt_reconfig_btAddr_from_nv();
|
|
#endif
|
|
|
|
if (pwron_case != APP_POWERON_CASE_TEST) {
|
|
BesbtInit();
|
|
app_wait_stack_ready();
|
|
bt_drv_extra_config_after_init();
|
|
bt_generate_ecdh_key_pair();
|
|
app_bt_start_custom_function_in_bt_thread((uint32_t)0,
|
|
0, (uint32_t)app_ibrt_init);
|
|
}
|
|
#if defined(BLE_ENABLE) && defined(IBRT)
|
|
app_ble_force_switch_adv(BLE_SWITCH_USER_IBRT, true);
|
|
#endif
|
|
app_sysfreq_req(APP_SYSFREQ_USER_APP_INIT, APP_SYSFREQ_52M);
|
|
TRACE(1,"\n\n\nbt_stack_init_done:%d\n\n\n", pwron_case);
|
|
|
|
if (pwron_case == APP_POWERON_CASE_REBOOT){
|
|
app_status_indication_init();
|
|
user_io_timer_init();
|
|
app_status_indication_set(APP_STATUS_INDICATION_POWERON);
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_voice_report(APP_STATUS_INDICATION_POWERON, 0);
|
|
#endif
|
|
app_bt_start_custom_function_in_bt_thread((uint32_t)1,
|
|
0, (uint32_t)btif_me_write_bt_sleep_enable);
|
|
btdrv_set_lpo_times();
|
|
|
|
#if defined(IBRT_OTA)
|
|
bes_ota_init();
|
|
#endif
|
|
//app_bt_accessmode_set(BTIF_BAM_NOT_ACCESSIBLE);
|
|
#if defined(IBRT)
|
|
#ifdef IBRT_SEARCH_UI
|
|
if(is_charging_poweron==false)
|
|
{
|
|
if(IBRT_UNKNOW == nvrecord_env->ibrt_mode.mode)
|
|
{
|
|
TRACE(0,"ibrt_ui_log:power on unknow mode");
|
|
app_ibrt_enter_limited_mode();
|
|
//if(app_tws_is_right_side())
|
|
if(1)
|
|
{
|
|
TRACE(0,"app_start_tws_serching_direactly");
|
|
app_start_tws_serching_direactly();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
TRACE(1,"ibrt_ui_log:power on %d fetch out", nvrecord_env->ibrt_mode.mode);
|
|
app_ibrt_ui_event_entry(IBRT_FETCH_OUT_EVENT);
|
|
}
|
|
//startLED_status(1000);
|
|
once_event_case = 9;
|
|
startonce_delay_event_Timer_(1000);
|
|
//startpwrkey_det(200);
|
|
}
|
|
#elif defined(IS_MULTI_AI_ENABLED)
|
|
//when ama and bisto switch, earphone need reconnect with peer, master need reconnect with phone
|
|
uint8_t box_action = app_ai_tws_reboot_get_box_action();
|
|
if (box_action != 0xFF)
|
|
{
|
|
TRACE(2, "%s box_actionstate %d", __func__, box_action);
|
|
app_ibrt_ui_event_entry(box_action|IBRT_SKIP_FALSE_TRIGGER_MASK);
|
|
}
|
|
#endif
|
|
#else
|
|
app_bt_accessmode_set(BTIF_BAM_NOT_ACCESSIBLE);
|
|
#endif
|
|
|
|
app_key_init();
|
|
app_battery_start();
|
|
#if defined(__BTIF_EARPHONE__) && defined(__BTIF_AUTOPOWEROFF__)
|
|
app_start_10_second_timer(APP_POWEROFF_TIMER_ID);
|
|
#endif
|
|
|
|
#if defined(__IAG_BLE_INCLUDE__) && defined(BTIF_BLE_APP_DATAPATH_SERVER)
|
|
BLE_custom_command_init();
|
|
#endif
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO1,THIRDPARTY_INIT);
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO1,THIRDPARTY_START);
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO2,THIRDPARTY_BT_CONNECTABLE);
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO3,THIRDPARTY_START);
|
|
#endif
|
|
#if defined( __BTIF_EARPHONE__) && defined(__BTIF_BT_RECONNECT__)
|
|
#if !defined(IBRT)
|
|
app_bt_profile_connect_manager_opening_reconnect();
|
|
#endif
|
|
#endif
|
|
}
|
|
#ifdef __ENGINEER_MODE_SUPPORT__
|
|
else if(pwron_case == APP_POWERON_CASE_TEST){
|
|
app_status_indication_init();
|
|
app_factorymode_set(true);
|
|
app_status_indication_set(APP_STATUS_INDICATION_POWERON);
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_voice_report(APP_STATUS_INDICATION_POWERON, 0);
|
|
#endif
|
|
#ifdef __WATCHER_DOG_RESET__
|
|
app_wdt_close();
|
|
#endif
|
|
TRACE(0,"!!!!!ENGINEER_MODE!!!!!\n");
|
|
nRet = 0;
|
|
app_nvrecord_rebuild();
|
|
app_factorymode_key_init();
|
|
if (hal_sw_bootmode_get() & HAL_SW_BOOTMODE_TEST_SIGNALINGMODE){
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_TEST_MASK);
|
|
app_factorymode_bt_signalingtest(NULL, NULL);
|
|
}
|
|
if (hal_sw_bootmode_get() & HAL_SW_BOOTMODE_TEST_NOSIGNALINGMODE){
|
|
hal_sw_bootmode_clear(HAL_SW_BOOTMODE_TEST_MASK);
|
|
app_factorymode_bt_nosignalingtest(NULL, NULL);
|
|
}
|
|
}
|
|
#endif
|
|
else{
|
|
user_io_timer_init();
|
|
app_status_indication_init();
|
|
app_status_indication_set(APP_STATUS_INDICATION_POWERON);
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_voice_report(APP_STATUS_INDICATION_POWERON, 0);
|
|
#endif
|
|
if (need_check_key){
|
|
pwron_case = app_poweron_wait_case();
|
|
}
|
|
else
|
|
{
|
|
pwron_case = APP_POWERON_CASE_NORMAL;
|
|
}
|
|
if (need_check_key)
|
|
{
|
|
#ifndef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
app_poweron_wait_finished();
|
|
#endif
|
|
}
|
|
if (pwron_case != APP_POWERON_CASE_INVALID && pwron_case != APP_POWERON_CASE_DITHERING){
|
|
TRACE(1,"power on case:%d\n", pwron_case);
|
|
nRet = 0;
|
|
#ifndef __POWERKEY_CTRL_ONOFF_ONLY__
|
|
//app_status_indication_set(APP_STATUS_INDICATION_INITIAL);
|
|
#endif
|
|
app_bt_start_custom_function_in_bt_thread((uint32_t)1,
|
|
0, (uint32_t)btif_me_write_bt_sleep_enable);
|
|
btdrv_set_lpo_times();
|
|
|
|
#ifdef IBRT_OTA
|
|
bes_ota_init();
|
|
#endif
|
|
|
|
#ifdef __INTERCONNECTION__
|
|
app_interconnection_init();
|
|
#endif
|
|
|
|
#ifdef __INTERACTION__
|
|
app_interaction_init();
|
|
#endif
|
|
|
|
#if defined(__IAG_BLE_INCLUDE__) && defined(BTIF_BLE_APP_DATAPATH_SERVER)
|
|
BLE_custom_command_init();
|
|
#endif
|
|
#ifdef GFPS_ENABLED
|
|
app_gfps_set_battery_info_acquire_handler(app_tell_battery_info_handler);
|
|
app_gfps_set_battery_datatype(SHOW_UI_INDICATION);
|
|
#endif
|
|
osDelay(500);
|
|
|
|
switch (pwron_case) {
|
|
case APP_POWERON_CASE_CALIB:
|
|
break;
|
|
case APP_POWERON_CASE_BOTHSCAN:
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
#ifdef MEDIA_PLAYER_SUPPORT
|
|
app_voice_report(APP_STATUS_INDICATION_BOTHSCAN,0);
|
|
#endif
|
|
#if defined( __BTIF_EARPHONE__)
|
|
#if defined(IBRT)
|
|
#ifdef IBRT_SEARCH_UI
|
|
if(false==is_charging_poweron)
|
|
app_ibrt_enter_limited_mode();
|
|
#endif
|
|
#else
|
|
app_bt_accessmode_set(BTIF_BT_DEFAULT_ACCESS_MODE_PAIR);
|
|
#endif
|
|
#ifdef GFPS_ENABLED
|
|
app_enter_fastpairing_mode();
|
|
#endif
|
|
#if defined(__BTIF_AUTOPOWEROFF__)
|
|
app_start_10_second_timer(APP_PAIR_TIMER_ID);
|
|
#endif
|
|
#endif
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO2,THIRDPARTY_BT_DISCOVERABLE);
|
|
#endif
|
|
break;
|
|
case APP_POWERON_CASE_NORMAL:
|
|
#if defined( __BTIF_EARPHONE__ ) && !defined(__EARPHONE_STAY_BOTH_SCAN__)
|
|
#if defined(IBRT)
|
|
#ifdef IBRT_SEARCH_UI
|
|
app_status_indication_set(APP_STATUS_INDICATION_BOTHSCAN);
|
|
if(is_charging_poweron==false)
|
|
{
|
|
startLED_status(1000);
|
|
once_event_case = 9;
|
|
startonce_delay_event_Timer_(1000);
|
|
if(IBRT_UNKNOW == nvrecord_env->ibrt_mode.mode)
|
|
{
|
|
TRACE(0,"ibrt_ui_log:power on unknow mode");
|
|
app_ibrt_enter_limited_mode();
|
|
if(app_tws_is_right_side()){
|
|
app_start_tws_serching_direactly();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
TRACE(1,"ibrt_ui_log:power on %d fetch out", nvrecord_env->ibrt_mode.mode);
|
|
app_ibrt_ui_event_entry(IBRT_FETCH_OUT_EVENT);
|
|
// app_status_indication_set(APP_STATUS_INDICATION_CHARGING);
|
|
//break;
|
|
}
|
|
//startpwrkey_det(200);
|
|
}
|
|
#elif defined(IS_MULTI_AI_ENABLED)
|
|
//when ama and bisto switch, earphone need reconnect with peer, master need reconnect with phone
|
|
//app_ibrt_ui_event_entry(IBRT_OPEN_BOX_EVENT);
|
|
//TRACE(1,"ibrt_ui_log:power on %d fetch out", nvrecord_env->ibrt_mode.mode);
|
|
//app_ibrt_ui_event_entry(IBRT_FETCH_OUT_EVENT);
|
|
#endif
|
|
#else
|
|
app_bt_accessmode_set(BTIF_BAM_NOT_ACCESSIBLE);
|
|
#endif
|
|
#endif
|
|
case APP_POWERON_CASE_REBOOT:
|
|
case APP_POWERON_CASE_ALARM:
|
|
default:
|
|
//app_status_indication_set(APP_STATUS_INDICATION_PAGESCAN);
|
|
#if defined( __BTIF_EARPHONE__) && defined(__BTIF_BT_RECONNECT__) && !defined(IBRT)
|
|
app_bt_profile_connect_manager_opening_reconnect();
|
|
#endif
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO2,THIRDPARTY_BT_CONNECTABLE);
|
|
#endif
|
|
|
|
break;
|
|
}
|
|
|
|
app_key_init();
|
|
app_battery_start();
|
|
|
|
#if defined(A2DP_LHDC_ON)
|
|
lhdc_license_check();
|
|
#endif
|
|
|
|
#if defined(__BTIF_EARPHONE__) && defined(__BTIF_AUTOPOWEROFF__)
|
|
app_start_10_second_timer(APP_POWEROFF_TIMER_ID);
|
|
#endif
|
|
#ifdef __THIRDPARTY
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO1,THIRDPARTY_INIT);
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO1,THIRDPARTY_START);
|
|
app_thirdparty_specific_lib_event_handle(THIRDPARTY_FUNC_NO3,THIRDPARTY_START);
|
|
#endif
|
|
|
|
#ifdef RB_CODEC
|
|
rb_ctl_init();
|
|
#endif
|
|
}else{
|
|
af_close();
|
|
app_key_close();
|
|
nRet = -1;
|
|
}
|
|
}
|
|
exit:
|
|
|
|
#ifdef IS_MULTI_AI_ENABLED
|
|
app_ai_tws_clear_reboot_box_state();
|
|
#endif
|
|
|
|
#ifdef __BT_DEBUG_TPORTS__
|
|
{
|
|
extern void bt_enable_tports(void);
|
|
bt_enable_tports();
|
|
//hal_iomux_tportopen();
|
|
}
|
|
#endif
|
|
|
|
#ifdef ANC_APP
|
|
app_anc_set_init_done();
|
|
#endif
|
|
#ifdef BT_USB_AUDIO_DUAL_MODE
|
|
if(usb_plugin)
|
|
{
|
|
btusb_switch(BTUSB_MODE_USB);
|
|
}
|
|
else
|
|
{
|
|
btusb_switch(BTUSB_MODE_BT);
|
|
}
|
|
#else //BT_USB_AUDIO_DUAL_MODE
|
|
#if defined(BTUSB_AUDIO_MODE)
|
|
if(pwron_case == APP_POWERON_CASE_CHARGING) {
|
|
#ifdef __WATCHER_DOG_RESET__
|
|
app_wdt_close();
|
|
#endif
|
|
af_open();
|
|
app_key_handle_clear();
|
|
app_usb_key_init();
|
|
app_usbaudio_entry();
|
|
}
|
|
|
|
#endif // BTUSB_AUDIO_MODE
|
|
#endif // BT_USB_AUDIO_DUAL_MODE
|
|
app_sysfreq_req(APP_SYSFREQ_USER_APP_INIT, APP_SYSFREQ_32K);
|
|
|
|
return nRet;
|
|
}
|
|
|
|
#endif /* APP_TEST_MODE */
|