431 lines
12 KiB
C
431 lines
12 KiB
C
#include "system/includes.h"
|
||
#include "media/includes.h"
|
||
#include "tone_player.h"
|
||
#include "earphone.h"
|
||
|
||
#include "app_config.h"
|
||
#include "app_action.h"
|
||
#include "app_task.h"
|
||
|
||
#include "btstack/avctp_user.h"
|
||
#include "btstack/btstack_task.h"
|
||
#include "btctrler/btctrler_task.h"
|
||
#include "btstack/frame_queque.h"
|
||
#include "user_cfg.h"
|
||
// #include "aec_user.h"
|
||
#include "classic/hci_lmp.h"
|
||
#include "bt_common.h"
|
||
#include "bt_ble.h"
|
||
#include "bt_tws.h"
|
||
#include "pbg_user.h"
|
||
#include "btstack/bluetooth.h"
|
||
#include "colorful_lights/colorful_lights.h"
|
||
|
||
#include "app_chargestore.h"
|
||
#include "jl_kws/jl_kws_api.h"
|
||
|
||
#include "asm/charge.h"
|
||
#include "app_charge.h"
|
||
#include "ui_manage.h"
|
||
|
||
#include "app_chargestore.h"
|
||
#include "app_umidigi_chargestore.h"
|
||
#include "app_testbox.h"
|
||
#include "app_online_cfg.h"
|
||
#include "app_main.h"
|
||
#include "app_power_manage.h"
|
||
#include "gSensor/gSensor_manage.h"
|
||
#include "key_event_deal.h"
|
||
#include "classic/tws_api.h"
|
||
#include "asm/pwm_led.h"
|
||
#include "ir_sensor/ir_manage.h"
|
||
#include "in_ear_detect/in_ear_manage.h"
|
||
#include "vol_sync.h"
|
||
#include "bt_background.h"
|
||
#include "default_event_handler.h"
|
||
#include "debug.h"
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
//宏定义
|
||
#define LOG_TAG_CONST EARPHONE
|
||
#define LOG_TAG "[EARPHONE]"
|
||
#define LOG_ERROR_ENABLE
|
||
#define LOG_DEBUG_ENABLE
|
||
#define LOG_INFO_ENABLE
|
||
|
||
|
||
#if(USE_DMA_UART_TEST) //使用dm串口测试时不能同时打开
|
||
#define MY_SNIFF_EN 0
|
||
#else
|
||
#define MY_SNIFF_EN 1 //默认打开
|
||
#endif
|
||
|
||
#define ENABLE_XLOG 1
|
||
#ifdef xlog
|
||
#undef xlog
|
||
#endif
|
||
#if ENABLE_XLOG
|
||
#define xlog(format, ...) printf("[XT:%s] " format, __func__, ##__VA_ARGS__)
|
||
#else
|
||
#define xlog(format, ...) ((void)0)
|
||
#endif
|
||
//
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
//变量
|
||
extern u8 init_ok;
|
||
extern u8 sniff_out;
|
||
unsigned char xtell_bl_state=0; //存放经典蓝牙的连接状态,0断开,1是连接
|
||
u8 bt_newname =0;
|
||
unsigned char xt_ble_new_name[9] = "CM-11111";
|
||
static u16 play_poweron_ok_timer_id = 0;
|
||
//
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
|
||
|
||
|
||
extern int bt_hci_event_handler(struct bt_event *bt);
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
/*
|
||
* 模式状态机, 通过start_app()控制状态切换
|
||
*/
|
||
/* extern int audio_mic_init(); */
|
||
|
||
static int state_machine(struct application *app, enum app_state state, struct intent *it){
|
||
int error = 0;
|
||
static u8 tone_player_err = 0;
|
||
xlog("bt_state_machine=%d\n", state);
|
||
switch (state) {
|
||
case APP_STA_CREATE:
|
||
xlog("APP_STA_CREATE\n");
|
||
/* set_adjust_conn_dac_check(0); */
|
||
|
||
break;
|
||
case APP_STA_START:
|
||
xlog("APP_STA_START\n");
|
||
if (!it) {
|
||
xlog("APP_STA_START:it none\n");
|
||
break;
|
||
}
|
||
switch (it->action) {
|
||
case ACTION_EARPHONE_MAIN:
|
||
xlog("ble init\n");
|
||
/*
|
||
* handler 初始化
|
||
*/
|
||
clk_set("sys", BT_NORMAL_HZ);
|
||
u32 sys_clk = clk_get("sys");
|
||
bt_pll_para(TCFG_CLOCK_OSC_HZ, sys_clk, 0, 0);
|
||
/* bredr_set_dut_enble(1, 1); */
|
||
bt_function_select_init();
|
||
bredr_handle_register();
|
||
EARPHONE_STATE_INIT();
|
||
btstack_init();
|
||
sys_auto_shut_down_enable();
|
||
bt_sniff_feature_init();
|
||
sys_auto_sniff_controle(MY_SNIFF_EN, NULL);
|
||
app_var.dev_volume = -1;
|
||
break;
|
||
case ACTION_A2DP_START: //蓝牙音频传输协议
|
||
xlog("ACTION_A2DP_START\n");
|
||
break;
|
||
case ACTION_BY_KEY_MODE:
|
||
xlog("ACTION_BY_KEY_MODE\n");
|
||
break;
|
||
case ACTION_TONE_PLAY:
|
||
xlog("ACTION_TONE_PLAY\n");
|
||
// STATUS *p_tone = get_tone_config();
|
||
// tone_play_index(p_tone->bt_init_ok, 1);
|
||
break;
|
||
case ACTION_DO_NOTHING:
|
||
xlog("ACTION_DO_NOTHING\n");
|
||
break;
|
||
}
|
||
break;
|
||
case APP_STA_PAUSE:
|
||
xlog("APP_STA_PAUSE\n");
|
||
break;
|
||
case APP_STA_RESUME:
|
||
xlog("APP_STA_RESUME\n");
|
||
//恢复前台运行
|
||
sys_auto_shut_down_disable();
|
||
sys_key_event_enable();
|
||
break;
|
||
case APP_STA_STOP:
|
||
xlog("APP_STA_STOP\n");
|
||
break;
|
||
case APP_STA_DESTROY:
|
||
xlog("APP_STA_DESTROY\n");
|
||
r_printf("APP_STA_DESTROY\n");
|
||
if (!app_var.goto_poweroff_flag) {
|
||
bt_app_exit(NULL);
|
||
}
|
||
break;
|
||
}
|
||
xlog("state machine error\n");
|
||
return error;
|
||
}
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
//handle
|
||
|
||
static void play_poweron_ok_timer(void *priv)
|
||
{
|
||
app_var.wait_timer_do = 0;
|
||
|
||
log_d("\n-------play_poweron_ok_timer-------\n", priv);
|
||
if (is_dac_power_off()) {
|
||
#if TCFG_USER_TWS_ENABLE
|
||
bt_tws_poweron();
|
||
#else
|
||
bt_wait_connect_and_phone_connect_switch(0);
|
||
#endif
|
||
return;
|
||
}
|
||
|
||
app_var.wait_timer_do = sys_timeout_add(priv, play_poweron_ok_timer, 100);
|
||
}
|
||
|
||
static void play_bt_connect_dly(void *priv)
|
||
{
|
||
app_var.wait_timer_do = 0;
|
||
|
||
log_d("\n-------play_bt_connect_dly-------\n", priv);
|
||
|
||
if (!app_var.goto_poweroff_flag) {
|
||
STATUS *p_tone = get_tone_config();
|
||
tone_play_index(p_tone->bt_connect_ok, 1);
|
||
}
|
||
}
|
||
|
||
|
||
|
||
static int bt_connction_status_event_handler(struct bt_event *bt)
|
||
{
|
||
STATUS *p_tone = get_tone_config();
|
||
u8 *phone_number = NULL;
|
||
|
||
switch (bt->event) {
|
||
case BT_STATUS_INIT_OK:
|
||
/*
|
||
* 蓝牙初始化完成
|
||
*/
|
||
log_info("BT_STATUS_INIT_OK\n");
|
||
init_ok = 1;
|
||
__set_sbc_cap_bitpool(38);
|
||
|
||
#if (TCFG_USER_BLE_ENABLE)
|
||
if (BT_MODE_IS(BT_BQB)) {
|
||
ble_bqb_test_thread_init();
|
||
} else {
|
||
#if !TCFG_WIRELESS_MIC_ENABLE
|
||
bt_ble_init();
|
||
#endif
|
||
}
|
||
#endif
|
||
bt_init_ok_search_index();
|
||
#if TCFG_TEST_BOX_ENABLE
|
||
testbox_set_bt_init_ok(1);
|
||
#endif
|
||
|
||
#if ((CONFIG_BT_MODE == BT_BQB)||(CONFIG_BT_MODE == BT_PER))
|
||
bt_wait_phone_connect_control(1);
|
||
#else
|
||
if (is_dac_power_off()) {
|
||
bt_wait_connect_and_phone_connect_switch(0);
|
||
} else {
|
||
app_var.wait_timer_do = sys_timeout_add(NULL, play_poweron_ok_timer, 100);
|
||
}
|
||
#endif
|
||
|
||
/*if (app_var.play_poweron_tone) {
|
||
tone_play_index(p_tone->power_on, 1);
|
||
}*/
|
||
break;
|
||
|
||
case BT_STATUS_SECOND_CONNECTED:
|
||
clear_current_poweron_memory_search_index(0);
|
||
case BT_STATUS_FIRST_CONNECTED:
|
||
log_info("BT_STATUS_CONNECTED\n");
|
||
xtell_bl_state = 1; //蓝牙连接成功 置1
|
||
if(strcmp(xt_ble_new_name,"CM-1111") != 0){
|
||
//蓝牙连接成功
|
||
bt_newname =1;
|
||
u8 temp[5]={0xBB,0xBE,0x02,0x04,0x00};
|
||
temp[4] = xtell_bl_state; //经典蓝牙连接状态
|
||
send_data_to_ble_client(&temp,5);
|
||
}
|
||
earphone_change_pwr_mode(PWR_DCDC15, 3000);
|
||
sys_auto_shut_down_disable();
|
||
|
||
ui_update_status(STATUS_BT_CONN); //单台在此处设置连接状态,对耳的连接状态需要同步,在bt_tws.c中去设置
|
||
|
||
/* tone_play(TONE_CONN); */
|
||
/*os_time_dly(40); // for test*/
|
||
log_info("tone status:%d\n", tone_get_status());
|
||
if (get_call_status() == BT_CALL_HANGUP) {
|
||
if (app_var.phone_dly_discon_time) {
|
||
sys_timeout_del(app_var.phone_dly_discon_time);
|
||
app_var.phone_dly_discon_time = 0;
|
||
} else {
|
||
app_var.wait_timer_do = sys_timeout_add(NULL, play_bt_connect_dly, 1600);
|
||
/* tone_play_index(p_tone->bt_connect_ok, 1); */
|
||
}
|
||
}
|
||
|
||
/*int timeout = 5000 + rand32() % 10000;
|
||
sys_timeout_add(NULL, connect_phone_test, timeout);*/
|
||
break;
|
||
case BT_STATUS_FIRST_DISCONNECT:
|
||
case BT_STATUS_SECOND_DISCONNECT:
|
||
log_info("BT_STATUS_DISCONNECT\n");
|
||
xtell_bl_state = 0; //断开蓝牙 清0
|
||
//蓝牙断开连接
|
||
if(bt_newname){ //已经改成新蓝牙名字,断开才播报
|
||
bt_newname=0;
|
||
u8 temp[5]={0xBB,0xBE,0x02,0x04,0x00};
|
||
temp[4] = xtell_bl_state; //经典蓝牙连接状态
|
||
send_data_to_ble_client(&temp,5);
|
||
}
|
||
if (app_var.goto_poweroff_flag) {
|
||
/*关机不播断开提示音*/
|
||
/*关机时不改UI*/
|
||
break;
|
||
}
|
||
// bt_discon_dly_handle(NULL);
|
||
break;
|
||
|
||
//phone status deal
|
||
case BT_STATUS_PHONE_INCOME:
|
||
break;
|
||
case BT_STATUS_PHONE_OUT:
|
||
|
||
break;
|
||
case BT_STATUS_PHONE_ACTIVE:
|
||
break;
|
||
case BT_STATUS_PHONE_HANGUP:
|
||
break;
|
||
case BT_STATUS_PHONE_NUMBER:
|
||
break;
|
||
case BT_STATUS_INBAND_RINGTONE: //铃声
|
||
break;
|
||
case BT_STATUS_CALL_VOL_CHANGE:
|
||
|
||
break;
|
||
case BT_STATUS_SNIFF_STATE_UPDATE:
|
||
log_info(" BT_STATUS_SNIFF_STATE_UPDATE %d\n", bt->value); //0退出SNIFF
|
||
if (bt->value == 0) {
|
||
sniff_out = 1;
|
||
sys_auto_sniff_controle(MY_SNIFF_EN, bt->args);
|
||
} else {
|
||
sys_auto_sniff_controle(0, bt->args);
|
||
}
|
||
break;
|
||
|
||
case BT_STATUS_LAST_CALL_TYPE_CHANGE:
|
||
break;
|
||
|
||
case BT_STATUS_CONN_A2DP_CH:
|
||
case BT_STATUS_CONN_HFP_CH:
|
||
|
||
if ((!is_1t2_connection()) && (get_current_poweron_memory_search_index(NULL))) { //回连下一个device
|
||
if (get_esco_coder_busy_flag()) {
|
||
clear_current_poweron_memory_search_index(0);
|
||
} else {
|
||
user_send_cmd_prepare(USER_CTRL_START_CONNECTION, 0, NULL);
|
||
}
|
||
}
|
||
break;
|
||
case BT_STATUS_PHONE_MANUFACTURER:
|
||
break;
|
||
case BT_STATUS_VOICE_RECOGNITION:
|
||
|
||
break;
|
||
case BT_STATUS_AVRCP_INCOME_OPID:
|
||
log_info("BT_STATUS_AVRCP_INCOME_OPID:%d\n", bt->value);
|
||
break;
|
||
default:
|
||
log_info(" BT STATUS DEFAULT\n");
|
||
break;
|
||
}
|
||
return 0;
|
||
}
|
||
|
||
|
||
|
||
static int event_handler(struct application *app, struct sys_event *event)
|
||
{
|
||
if (SYS_EVENT_REMAP(event)) {
|
||
g_printf("****SYS_EVENT_REMAP**** \n");
|
||
return 0;
|
||
}
|
||
|
||
switch (event->type) {
|
||
case SYS_KEY_EVENT:
|
||
break;
|
||
case SYS_BT_EVENT:
|
||
/*
|
||
* 蓝牙事件处理
|
||
*/
|
||
if ((u32)event->arg == SYS_BT_EVENT_TYPE_CON_STATUS) {
|
||
printf("in event_handler:bt_connction_status_event_handler");
|
||
bt_connction_status_event_handler(&event->u.bt);
|
||
} else if ((u32)event->arg == SYS_BT_EVENT_TYPE_HCI_STATUS) {
|
||
bt_hci_event_handler(&event->u.bt);
|
||
}
|
||
break;
|
||
case SYS_DEVICE_EVENT:
|
||
/*
|
||
* 系统设备事件处理
|
||
*/
|
||
if ((u32)event->arg == DEVICE_EVENT_FROM_CHARGE) {
|
||
|
||
} else if ((u32)event->arg == DEVICE_EVENT_FROM_POWER) {
|
||
return app_power_event_handler(&event->u.dev);
|
||
}
|
||
#if TCFG_UMIDIGI_BOX_ENABLE
|
||
else if ((u32)event->arg == DEVICE_EVENT_UMIDIGI_CHARGE_STORE) {
|
||
app_umidigi_chargestore_event_handler(&event->u.umidigi_chargestore);
|
||
}
|
||
#endif
|
||
#if TCFG_TEST_BOX_ENABLE
|
||
else if ((u32)event->arg == DEVICE_EVENT_TEST_BOX) {
|
||
app_testbox_event_handler(&event->u.testbox);
|
||
}
|
||
#endif
|
||
break;
|
||
|
||
default:
|
||
return false;
|
||
}
|
||
|
||
SYS_EVENT_HANDLER_SPECIFIC(event);
|
||
#ifdef CONFIG_BT_BACKGROUND_ENABLE
|
||
if (app) {
|
||
default_event_handler(event);
|
||
}
|
||
#endif
|
||
return false;
|
||
|
||
}
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||
|
||
static const struct application_operation app_handler_ops = {
|
||
.state_machine = state_machine,
|
||
.event_handler = event_handler,
|
||
};
|
||
|
||
|
||
/*
|
||
* 注册earphone模式
|
||
*/
|
||
REGISTER_APPLICATION(app_handler) = {
|
||
.name = "handler",
|
||
.action = ACTION_EARPHONE_MAIN,
|
||
.ops = &app_handler_ops,
|
||
.state = APP_STA_DESTROY,
|
||
};
|