2019-12-02 15:29:55 +08:00
|
|
|
/*
|
2024-07-18 12:06:02 +08:00
|
|
|
* SPDX-FileCopyrightText: 2021-2024 Espressif Systems (Shanghai) CO LTD
|
2021-12-06 14:59:55 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Unlicense OR CC0-1.0
|
|
|
|
*/
|
2019-12-02 15:29:55 +08:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "nvs.h"
|
|
|
|
#include "nvs_flash.h"
|
|
|
|
#include "esp_system.h"
|
|
|
|
#include "esp_log.h"
|
|
|
|
#include "esp_bt.h"
|
|
|
|
#include "bt_app_core.h"
|
|
|
|
#include "esp_bt_main.h"
|
|
|
|
#include "esp_bt_device.h"
|
|
|
|
#include "esp_gap_bt_api.h"
|
|
|
|
#include "esp_hf_ag_api.h"
|
|
|
|
#include "bt_app_hf.h"
|
|
|
|
#include "gpio_pcm_config.h"
|
2020-08-20 15:31:45 +08:00
|
|
|
#include "esp_console.h"
|
|
|
|
#include "app_hf_msg_set.h"
|
2019-12-02 15:29:55 +08:00
|
|
|
|
2020-12-15 16:08:28 +08:00
|
|
|
#define BT_HF_AG_TAG "HF_AG_DEMO_MAIN"
|
2019-12-02 15:29:55 +08:00
|
|
|
|
2024-07-31 17:22:56 +08:00
|
|
|
static const char local_device_name[] = CONFIG_EXAMPLE_LOCAL_DEVICE_NAME;
|
|
|
|
|
2019-12-02 15:29:55 +08:00
|
|
|
/* event for handler "hf_ag_hdl_stack_up */
|
|
|
|
enum {
|
|
|
|
BT_APP_EVT_STACK_UP = 0,
|
|
|
|
};
|
|
|
|
|
2024-07-18 12:06:02 +08:00
|
|
|
static char *bda2str(esp_bd_addr_t bda, char *str, size_t size)
|
|
|
|
{
|
|
|
|
if (bda == NULL || str == NULL || size < 18) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8_t *p = bda;
|
|
|
|
sprintf(str, "%02x:%02x:%02x:%02x:%02x:%02x",
|
|
|
|
p[0], p[1], p[2], p[3], p[4], p[5]);
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
2019-12-02 15:29:55 +08:00
|
|
|
/* handler for bluetooth stack enabled events */
|
|
|
|
static void bt_hf_hdl_stack_evt(uint16_t event, void *p_param)
|
|
|
|
{
|
|
|
|
ESP_LOGD(BT_HF_TAG, "%s evt %d", __func__, event);
|
|
|
|
switch (event)
|
|
|
|
{
|
|
|
|
case BT_APP_EVT_STACK_UP:
|
|
|
|
{
|
2024-07-31 17:22:56 +08:00
|
|
|
esp_bt_gap_set_device_name(local_device_name);
|
2019-12-02 15:29:55 +08:00
|
|
|
|
2020-12-15 16:08:28 +08:00
|
|
|
esp_hf_ag_register_callback(bt_app_hf_cb);
|
2020-11-10 18:40:01 +11:00
|
|
|
|
2019-12-02 15:29:55 +08:00
|
|
|
// init and register for HFP_AG functions
|
2020-12-15 16:08:28 +08:00
|
|
|
esp_hf_ag_init();
|
2019-12-02 15:29:55 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Set default parameters for Legacy Pairing
|
|
|
|
* Use variable pin, input pin code when pairing
|
|
|
|
*/
|
|
|
|
esp_bt_pin_type_t pin_type = ESP_BT_PIN_TYPE_VARIABLE;
|
|
|
|
esp_bt_pin_code_t pin_code;
|
|
|
|
pin_code[0] = '0';
|
|
|
|
pin_code[1] = '0';
|
|
|
|
pin_code[2] = '0';
|
|
|
|
pin_code[3] = '0';
|
|
|
|
esp_bt_gap_set_pin(pin_type, 4, pin_code);
|
|
|
|
|
|
|
|
/* set discoverable and connectable mode, wait to be connected */
|
|
|
|
esp_bt_gap_set_scan_mode(ESP_BT_CONNECTABLE, ESP_BT_GENERAL_DISCOVERABLE);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
ESP_LOGE(BT_HF_TAG, "%s unhandled evt %d", __func__, event);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void app_main(void)
|
|
|
|
{
|
2024-07-18 12:06:02 +08:00
|
|
|
char bda_str[18] = {0};
|
2019-12-02 15:29:55 +08:00
|
|
|
/* Initialize NVS — it is used to store PHY calibration data */
|
|
|
|
esp_err_t ret = nvs_flash_init();
|
|
|
|
if (ret == ESP_ERR_NVS_NO_FREE_PAGES) {
|
|
|
|
ESP_ERROR_CHECK(nvs_flash_erase());
|
|
|
|
ret = nvs_flash_init();
|
|
|
|
}
|
|
|
|
ESP_ERROR_CHECK(ret);
|
|
|
|
ESP_ERROR_CHECK(esp_bt_controller_mem_release(ESP_BT_MODE_BLE));
|
|
|
|
|
|
|
|
esp_bt_controller_config_t bt_cfg = BT_CONTROLLER_INIT_CONFIG_DEFAULT();
|
2023-08-29 16:49:49 +08:00
|
|
|
if ((ret = esp_bt_controller_init(&bt_cfg)) != ESP_OK) {
|
2023-06-09 02:56:11 +08:00
|
|
|
ESP_LOGE(BT_HF_TAG, "%s initialize controller failed: %s", __func__, esp_err_to_name(ret));
|
2019-12-02 15:29:55 +08:00
|
|
|
return;
|
|
|
|
}
|
2023-08-29 16:49:49 +08:00
|
|
|
if ((ret = esp_bt_controller_enable(ESP_BT_MODE_CLASSIC_BT)) != ESP_OK) {
|
2023-06-09 02:56:11 +08:00
|
|
|
ESP_LOGE(BT_HF_TAG, "%s enable controller failed: %s", __func__, esp_err_to_name(ret));
|
2019-12-02 15:29:55 +08:00
|
|
|
return;
|
|
|
|
}
|
2023-08-29 16:49:49 +08:00
|
|
|
esp_bluedroid_config_t bluedroid_cfg = BT_BLUEDROID_INIT_CONFIG_DEFAULT();
|
|
|
|
if ((ret = esp_bluedroid_init_with_cfg(&bluedroid_cfg)) != ESP_OK) {
|
2023-06-09 02:56:11 +08:00
|
|
|
ESP_LOGE(BT_HF_TAG, "%s initialize bluedroid failed: %s", __func__, esp_err_to_name(ret));
|
2019-12-02 15:29:55 +08:00
|
|
|
return;
|
|
|
|
}
|
2023-08-29 16:49:49 +08:00
|
|
|
if ((ret = esp_bluedroid_enable()) != ESP_OK) {
|
2023-06-09 02:56:11 +08:00
|
|
|
ESP_LOGE(BT_HF_TAG, "%s enable bluedroid failed: %s", __func__, esp_err_to_name(ret));
|
2019-12-02 15:29:55 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-07-18 12:06:02 +08:00
|
|
|
ESP_LOGI(BT_HF_TAG, "Own address:[%s]", bda2str((uint8_t *)esp_bt_dev_get_address(), bda_str, sizeof(bda_str)));
|
2019-12-02 15:29:55 +08:00
|
|
|
/* create application task */
|
|
|
|
bt_app_task_start_up();
|
|
|
|
|
|
|
|
/* Bluetooth device name, connection mode and profile set up */
|
|
|
|
bt_app_work_dispatch(bt_hf_hdl_stack_evt, BT_APP_EVT_STACK_UP, NULL, 0, NULL);
|
|
|
|
|
2020-11-19 20:30:03 +08:00
|
|
|
#if CONFIG_BT_HFP_AUDIO_DATA_PATH_PCM
|
2019-12-02 15:29:55 +08:00
|
|
|
/* configure the PCM interface and PINs used */
|
|
|
|
app_gpio_pcm_io_cfg();
|
2020-11-19 20:30:03 +08:00
|
|
|
#endif
|
2019-12-02 15:29:55 +08:00
|
|
|
|
2024-04-15 20:01:30 +08:00
|
|
|
/* configure external chip for acoustic echo cancellation */
|
2019-12-02 15:29:55 +08:00
|
|
|
#if ACOUSTIC_ECHO_CANCELLATION_ENABLE
|
|
|
|
app_gpio_aec_io_cfg();
|
|
|
|
#endif /* ACOUSTIC_ECHO_CANCELLATION_ENABLE */
|
2020-08-20 15:31:45 +08:00
|
|
|
|
|
|
|
esp_console_repl_t *repl = NULL;
|
|
|
|
esp_console_repl_config_t repl_config = ESP_CONSOLE_REPL_CONFIG_DEFAULT();
|
|
|
|
esp_console_dev_uart_config_t uart_config = ESP_CONSOLE_DEV_UART_CONFIG_DEFAULT();
|
|
|
|
repl_config.prompt = "hfp_ag>";
|
|
|
|
|
|
|
|
// init console REPL environment
|
|
|
|
ESP_ERROR_CHECK(esp_console_new_repl_uart(&uart_config, &repl_config, &repl));
|
|
|
|
|
|
|
|
/* Register commands */
|
|
|
|
register_hfp_ag();
|
|
|
|
printf("\n ==================================================\n");
|
|
|
|
printf(" | Steps to test hfp_ag |\n");
|
|
|
|
printf(" | |\n");
|
|
|
|
printf(" | 1. Print 'help' to gain overview of commands |\n");
|
|
|
|
printf(" | 2. Setup a service level connection |\n");
|
|
|
|
printf(" | 3. Run hfp_ag to test |\n");
|
|
|
|
printf(" | |\n");
|
|
|
|
printf(" =================================================\n\n");
|
|
|
|
|
|
|
|
// start console REPL
|
|
|
|
ESP_ERROR_CHECK(esp_console_start_repl(repl));
|
2020-11-19 20:30:03 +08:00
|
|
|
}
|