component/bt: API clean up for the A2DP example

This commit is contained in:
wangmengyang 2016-12-26 17:26:54 +08:00
parent bc5bc0f026
commit 6163d214b3
6 changed files with 85 additions and 37 deletions

View File

@ -28,4 +28,5 @@ typedef enum {
esp_err_t esp_bt_gap_set_scan_mode(bt_scan_mode_t mode); esp_err_t esp_bt_gap_set_scan_mode(bt_scan_mode_t mode);
esp_err_t esp_bt_gap_set_device_name(const char *name);
#endif /* __ESP_GAP_BT_API_H__ */ #endif /* __ESP_GAP_BT_API_H__ */

View File

@ -15,6 +15,7 @@
#include "esp_gap_bt_api.h" #include "esp_gap_bt_api.h"
#include "bta_api.h" #include "bta_api.h"
#include "bt_trace.h" #include "bt_trace.h"
#include <string.h>
esp_err_t esp_bt_gap_set_scan_mode(bt_scan_mode_t mode) esp_err_t esp_bt_gap_set_scan_mode(bt_scan_mode_t mode)
{ {
@ -47,3 +48,16 @@ esp_err_t esp_bt_gap_set_scan_mode(bt_scan_mode_t mode)
return ESP_OK; return ESP_OK;
} }
esp_err_t esp_bt_gap_set_device_name(const char *name)
{
if (name == NULL || *name == '\0') {
return ESP_ERR_INVALID_ARG;
}
#define ESP_GAP_DEVICE_NAME_MAX (32)
char dev_name[ESP_GAP_DEVICE_NAME_MAX+1];
strncpy(dev_name, name, ESP_GAP_DEVICE_NAME_MAX);
dev_name[ESP_GAP_DEVICE_NAME_MAX] = '\0';
BTA_DmSetDeviceName(dev_name);
return ESP_OK;
}

View File

@ -466,7 +466,7 @@
#define BTM_DEFAULT_DISC_INTERVAL 0x0800 #define BTM_DEFAULT_DISC_INTERVAL 0x0800
#endif #endif
/* Default class of device /*
* {SERVICE_CLASS, MAJOR_CLASS, MINOR_CLASS} * {SERVICE_CLASS, MAJOR_CLASS, MINOR_CLASS}
* *
* SERVICE_CLASS:0x5A (Bit17 -Networking,Bit19 - Capturing,Bit20 -Object Transfer,Bit22 -Telephony) * SERVICE_CLASS:0x5A (Bit17 -Networking,Bit19 - Capturing,Bit20 -Object Transfer,Bit22 -Telephony)
@ -474,8 +474,20 @@
* MINOR_CLASS:0x0C - SMART_PHONE * MINOR_CLASS:0x0C - SMART_PHONE
* *
*/ */
#define BTA_DM_COD_SMARTPHONE {0x5A, 0x02, 0x0C}
/*
* {SERVICE_CLASS, MAJOR_CLASS, MINOR_CLASS}
*
* SERVICE_CLASS:0x2C (Bit21 - Audio, Bit19 - Capturing)
* MAJOR_CLASS:0x04 - Audio/Video
* MINOR_CLASS:0x05 - LoudSpeaker
*/
#define BTA_DM_COD_LOUDSPEAKER {0x2C, 0x04, 0x14}
/* Default class of device */
#ifndef BTA_DM_COD #ifndef BTA_DM_COD
#define BTA_DM_COD {0x5A, 0x02, 0x0C} #define BTA_DM_COD BTA_DM_COD_LOUDSPEAKER
#endif #endif
/* The number of SCO links. */ /* The number of SCO links. */

View File

@ -11,14 +11,11 @@
#include "EspAudioCom.h" #include "EspAudioCom.h"
#include "bt_app_common.h" #include "bt_app_common.h"
#include "btif_stack_manager.h" #include "esp_bt_stack_manager.h"
#include "esp_gap_bt_api.h" #include "esp_gap_bt_api.h"
#include "bta_api.h" #include "bta_api.h"
#include "esp_a2dp_api.h" #include "esp_a2dp_api.h"
/* utl_set_device_class() */
#include "utl.h"
typedef enum { typedef enum {
BT_APP_EVT_STACK_ON = 0xa0, BT_APP_EVT_STACK_ON = 0xa0,
BT_APP_EVT_MAX BT_APP_EVT_MAX
@ -48,23 +45,9 @@ static void bt_app_a2d_cb(uint32_t event, void *param)
static void bt_app_a2d_data_cb(uint8_t *data, uint32_t len) static void bt_app_a2d_data_cb(uint8_t *data, uint32_t len)
{ {
// uint32_t t_now = system_get_time(); EspAudioPlayerStreamWrite(data, len, 10);
// printf("t: %u, l %d\n", t_now, len);
EspAudioPlayerStreamWrite(data, len);
} }
static void btav_set_device_class(void)
{
tBTA_UTL_COD cod;
memset(&cod, 0, sizeof(tBTA_UTL_COD));
cod.major = BTM_COD_MAJOR_AUDIO;
cod.minor = BTM_COD_MINOR_LOUDSPEAKER;
cod.service = BTM_COD_SERVICE_CAPTURING | BTM_COD_SERVICE_AUDIO;
utl_set_device_class(&cod, BTA_UTL_SET_COD_ALL);
BT_APP_TRACE_ERROR("set class of device: major 0x%x, minor 0x%x, service 0x%x\n",
cod.major, cod.minor, cod.service);
}
static void bt_app_handle_evt(UINT16 event, void *p_param) static void bt_app_handle_evt(UINT16 event, void *p_param)
{ {
BT_APP_TRACE_EVENT("bt_app_handle_evt 0x%x\n", event); BT_APP_TRACE_EVENT("bt_app_handle_evt 0x%x\n", event);
@ -72,9 +55,8 @@ static void bt_app_handle_evt(UINT16 event, void *p_param)
switch (event) { switch (event) {
case BT_APP_EVT_STACK_ON: { case BT_APP_EVT_STACK_ON: {
char *dev_name = "ESP_SPEAKER"; char *dev_name = "ESP_SPEAKER";
BTM_SetTraceLevel(BT_TRACE_LEVEL_WARNING); // BTM_SetTraceLevel(BT_TRACE_LEVEL_WARNING);
btav_set_device_class(); esp_bt_gap_set_device_name(dev_name);
BTA_DmSetDeviceName(dev_name);
esp_a2d_register_callback(bt_app_a2d_cb); esp_a2d_register_callback(bt_app_a2d_cb);
esp_a2d_register_data_callback(bt_app_a2d_data_cb); esp_a2d_register_data_callback(bt_app_a2d_data_cb);
@ -115,13 +97,13 @@ static void bt_app_handle_evt(UINT16 event, void *p_param)
void app_main_entry(void) void app_main_entry(void)
{ {
bt_status_t init, enable; bt_status_t init, enable;
init = BTIF_InitStack(); init = esp_bt_init_stack();
if (init != BT_STATUS_SUCCESS) { if (init != ESP_OK) {
return; return;
} }
enable = BTIF_EnableStack(); enable = esp_bt_enable_stack();
if (enable != BT_STATUS_SUCCESS) { if (enable != ESP_OK) {
return; return;
} }

View File

@ -1,6 +1,6 @@
#include <stdbool.h> #include <stdbool.h>
#include <stdint.h> #include <stdint.h>
#include "btif_stack_manager.h" #include "esp_bt_stack_manager.h"
#include "stack_manager.h" #include "stack_manager.h"
#include "bt_defs.h" #include "bt_defs.h"
#include "bt_trace.h" #include "bt_trace.h"
@ -112,24 +112,49 @@ static bt_status_t event_clean_up_stack(void)
return BT_STATUS_SUCCESS; return BT_STATUS_SUCCESS;
} }
bt_status_t BTIF_InitStack(void) esp_err_t esp_bt_init_stack(void)
{ {
return event_init_stack(); bt_status_t status;
status = event_init_stack();
switch (status) {
case BT_STATUS_SUCCESS: return ESP_OK;
case BT_STATUS_DONE: return ESP_ERR_INVALID_STATE;
default: return ESP_FAIL;
}
} }
bt_status_t BTIF_EnableStack(void) esp_err_t esp_bt_deinit_stack(void)
{ {
return event_start_up_stack(); bt_status_t status;
status = event_clean_up_stack();
switch (status) {
case BT_STATUS_SUCCESS: return ESP_OK;
default: return ESP_ERR_INVALID_STATE;
}
} }
bt_status_t BTIF_DisableStack(void) esp_err_t esp_bt_enable_stack(void)
{ {
return event_shut_down_stack(); bt_status_t status;
status = event_start_up_stack();
switch (status) {
case BT_STATUS_SUCCESS: return ESP_OK;
case BT_STATUS_NOT_READY:
case BT_STATUS_DONE:
return ESP_ERR_INVALID_STATE;
default: return ESP_FAIL;
}
} }
bt_status_t BTIF_CleanUpStack(void) esp_err_t esp_bt_disable_stack(void)
{ {
return event_clean_up_stack(); bt_status_t status;
status = event_shut_down_stack();
switch (status) {
case BT_STATUS_SUCCESS: return ESP_OK;
case BT_STATUS_DONE: return ESP_ERR_INVALID_STATE;
default: return ESP_FAIL;
}
} }
bool stack_manager_is_stack_running(void) bool stack_manager_is_stack_running(void)

View File

@ -0,0 +1,14 @@
#ifndef __ESP_BT_STACK_MANAGER_H__
#define __ESP_BT_STACK_MANAGER_H__
#include "esp_err.h"
esp_err_t esp_bt_init_stack(void);
esp_err_t esp_bt_deinit_stack(void);
esp_err_t esp_bt_enable_stack(void);
esp_err_t esp_bt_disable_stack(void);
#endif /* __ESP_BT_STACK_MANAGER_H__ */