Select one of the symbols to view example projects that use it.
 
Outline
#define _BT_COMMON_H_
#include <assert.h>
#include <stdbool.h>
#include "bt_user_config.h"
#include "esp_log.h"
#define FALSE
#define TRUE
#define BLUFI_INCLUDED
#define BLUFI_INCLUDED
#include "esp_bt_defs.h"
#include "esp_bt_main.h"
#include "esp_gatt_defs.h"
#define ESP_BLE_HOST_STATUS_ENABLED
#define ESP_BLE_HOST_STATUS_CHECK
#define ESP_BLE_HOST_STATUS_ENABLED
#define ESP_BLE_HOST_STATUS_CHECK
#define BT_QUEUE_CONGEST_SIZE
#define BTC_INITIAL_TRACE_LEVEL
#define OSI_INITIAL_TRACE_LEVEL
#define BLUFI_INITIAL_TRACE_LEVEL
#define BT_BLE_DYNAMIC_ENV_MEMORY
#define BTC_DYNAMIC_MEMORY
#define BT_BLE_DYNAMIC_ENV_MEMORY
#define BTC_DYNAMIC_MEMORY
#define HEAP_MEMORY_DEBUG
#define HEAP_MEMORY_DEBUG
#define BT_BLE_DYNAMIC_ENV_MEMORY
#define HEAP_ALLOCATION_FROM_SPIRAM_FIRST
#define HEAP_ALLOCATION_FROM_SPIRAM_FIRST
#define HEAP_ALLOCATION_FAILS_ABORT
#define HEAP_ALLOCATION_FAILS_ABORT
#define BT_HCI_LOG_INCLUDED
#define BT_HCI_LOG_INCLUDED
#define HCI_LOG_DATA_BUFFER_SIZE
#define HCI_BUFFER_SIZE
#define HCI_LOG_ADV_BUFFER_SIZE
#define HCI_LOG_ADV_BUFFER_SIZE
#define TASK_PINNED_TO_CORE
#define BT_TASK_MAX_PRIORITIES
#define BT_BTC_TASK_STACK_SIZE
#define BT_TRACE_LEVEL_NONE
#define BT_TRACE_LEVEL_ERROR
#define BT_TRACE_LEVEL_WARNING
#define BT_TRACE_LEVEL_API
#define BT_TRACE_LEVEL_EVENT
#define BT_TRACE_LEVEL_DEBUG
#define BT_TRACE_LEVEL_VERBOSE
#define MAX_TRACE_LEVEL
#define LOG_LOCAL_LEVEL
#define LOG_LOCAL_LEVEL
#define LOG_LOCAL_LEVEL_MAPPING
#define LOG_LOCAL_LEVEL_MAPPING
#define MAX
#define BT_LOG_LEVEL_CHECK
#define BT_PRINT_E
#define BT_PRINT_W
#define BT_PRINT_I
#define BT_PRINT_D
#define BT_PRINT_V
#define BTC_TRACE_ERROR
#define BTC_TRACE_WARNING
#define BTC_TRACE_API
#define BTC_TRACE_EVENT
#define BTC_TRACE_DEBUG
#define BTC_TRACE_VERBOSE
#define OSI_TRACE_ERROR
#define OSI_TRACE_WARNING
#define OSI_TRACE_API
#define OSI_TRACE_EVENT
#define OSI_TRACE_DEBUG
#define OSI_TRACE_VERBOSE
#define BLUFI_TRACE_ERROR
#define BLUFI_TRACE_WARNING
#define BLUFI_TRACE_API
#define BLUFI_TRACE_EVENT
#define BLUFI_TRACE_DEBUG
#define BLUFI_TRACE_VERBOSE
#define BTC_TRACE_ERROR
#define BTC_TRACE_WARNING
#define BTC_TRACE_API
#define BTC_TRACE_EVENT
#define BTC_TRACE_DEBUG
#define BTC_TRACE_VERBOSE
#define OSI_TRACE_ERROR
#define OSI_TRACE_WARNING
#define OSI_TRACE_API
#define OSI_TRACE_EVENT
#define OSI_TRACE_DEBUG
#define OSI_TRACE_VERBOSE
#define BLUFI_TRACE_ERROR
#define BLUFI_TRACE_WARNING
#define BLUFI_TRACE_API
#define BLUFI_TRACE_EVENT
#define BLUFI_TRACE_DEBUG
#define BLUFI_TRACE_VERBOSE
bt_status_t
UINT8
UINT16
UINT32
UINT64
BOOLEAN
#define MAX_UUID_SIZE
tBT_UUID
#define BD_ADDR_LEN
BD_ADDR
Files
loading...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/bt/common/include/bt_common.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * SPDX-FileCopyrightText: 2015-2024 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 *//* ... */ #ifndef _BT_COMMON_H_ #define _BT_COMMON_H_ #include <assert.h> #include <stdbool.h> #include "bt_user_config.h" #include "esp_log.h" #ifndef FALSE #define FALSE false #endif #ifndef TRUE #define TRUE true #endif #if (UC_BT_BLUFI_ENABLE) #define BLUFI_INCLUDED TRUE #else #define BLUFI_INCLUDED FALSE #endif #ifdef CONFIG_BT_BLUEDROID_ENABLED #include "esp_bt_defs.h" #include "esp_bt_main.h" #include "esp_gatt_defs.h" #define ESP_BLE_HOST_STATUS_ENABLED ESP_BLUEDROID_STATUS_ENABLED #define ESP_BLE_HOST_STATUS_CHECK(status) ESP_BLUEDROID_STATUS_CHECK(status)/* ... */ #else #define ESP_BLE_HOST_STATUS_ENABLED 0 #define ESP_BLE_HOST_STATUS_CHECK(status) do {} while (0)/* ... */ #endif #ifndef BT_QUEUE_CONGEST_SIZE #define BT_QUEUE_CONGEST_SIZE 40 #endif #define BTC_INITIAL_TRACE_LEVEL UC_BT_LOG_BTC_TRACE_LEVEL #define OSI_INITIAL_TRACE_LEVEL UC_BT_LOG_OSI_TRACE_LEVEL #define BLUFI_INITIAL_TRACE_LEVEL UC_BT_LOG_BLUFI_TRACE_LEVEL // MEMORY #if UC_BT_BLE_DYNAMIC_ENV_MEMORY #define BT_BLE_DYNAMIC_ENV_MEMORY TRUE #define BTC_DYNAMIC_MEMORY TRUE/* ... */ #else #define BT_BLE_DYNAMIC_ENV_MEMORY FALSE #define BTC_DYNAMIC_MEMORY FALSE/* ... */ #endif #if UC_BT_BLUEDROID_MEM_DEBUG #define HEAP_MEMORY_DEBUG TRUE #else #define HEAP_MEMORY_DEBUG FALSE #endif #ifndef BT_BLE_DYNAMIC_ENV_MEMORY #define BT_BLE_DYNAMIC_ENV_MEMORY FALSE #endif #if UC_HEAP_ALLOCATION_FROM_SPIRAM_FIRST #define HEAP_ALLOCATION_FROM_SPIRAM_FIRST TRUE #else #define HEAP_ALLOCATION_FROM_SPIRAM_FIRST FALSE #endif #if UC_BT_ABORT_WHEN_ALLOCATION_FAILS #define HEAP_ALLOCATION_FAILS_ABORT TRUE #else #define HEAP_ALLOCATION_FAILS_ABORT FALSE #endif // HCI LOG #if UC_BT_HCI_LOG_DEBUG_EN #define BT_HCI_LOG_INCLUDED UC_BT_HCI_LOG_DEBUG_EN #else #define BT_HCI_LOG_INCLUDED FALSE #endif #if UC_BT_HCI_LOG_DATA_BUFFER_SIZE #define HCI_LOG_DATA_BUFFER_SIZE UC_BT_HCI_LOG_DATA_BUFFER_SIZE #else #define HCI_BUFFER_SIZE (5) #endif #if UC_BT_HCI_ADV_BUFFER_SIZE #define HCI_LOG_ADV_BUFFER_SIZE UC_BT_HCI_LOG_ADV_BUFFER_SIZE #else #define HCI_LOG_ADV_BUFFER_SIZE (5) #endif /* OS Configuration from User config (eg: sdkconfig) */ #define TASK_PINNED_TO_CORE UC_TASK_PINNED_TO_CORE #define BT_TASK_MAX_PRIORITIES configMAX_PRIORITIES #define BT_BTC_TASK_STACK_SIZE UC_BTC_TASK_STACK_SIZE /* Define trace levels */ #define BT_TRACE_LEVEL_NONE UC_TRACE_LEVEL_NONE /* No trace messages to be generated */ #define BT_TRACE_LEVEL_ERROR UC_TRACE_LEVEL_ERROR /* Error condition trace messages */ #define BT_TRACE_LEVEL_WARNING UC_TRACE_LEVEL_WARNING /* Warning condition trace messages */ #define BT_TRACE_LEVEL_API UC_TRACE_LEVEL_API /* API traces */ #define BT_TRACE_LEVEL_EVENT UC_TRACE_LEVEL_EVENT /* Debug messages for events */ #define BT_TRACE_LEVEL_DEBUG UC_TRACE_LEVEL_DEBUG /* Full debug messages */ #define BT_TRACE_LEVEL_VERBOSE UC_TRACE_LEVEL_VERBOSE /* Verbose debug messages */ #define MAX_TRACE_LEVEL UC_TRACE_LEVEL_VERBOSE11 defines #ifndef LOG_LOCAL_LEVEL #ifndef BOOTLOADER_BUILD #define LOG_LOCAL_LEVEL UC_LOG_DEFAULT_LEVEL #else #define LOG_LOCAL_LEVEL UC_BOOTLOADER_LOG_LEVEL #endif/* ... */ #endif // Mapping between ESP_LOG_LEVEL and BT_TRACE_LEVEL #if (LOG_LOCAL_LEVEL >= 4) #define LOG_LOCAL_LEVEL_MAPPING (LOG_LOCAL_LEVEL+1) #else #define LOG_LOCAL_LEVEL_MAPPING LOG_LOCAL_LEVEL #endif #define MAX(a, b) ((a) > (b) ? (a) : (b)) #define BT_LOG_LEVEL_CHECK(LAYER, LEVEL) (MAX(LAYER##_INITIAL_TRACE_LEVEL, LOG_LOCAL_LEVEL_MAPPING) >= BT_TRACE_LEVEL_##LEVEL) #define BT_PRINT_E(tag, format, ...) {esp_log_write(ESP_LOG_ERROR, tag, LOG_FORMAT(E, format), esp_log_timestamp(), tag, ##__VA_ARGS__); } #define BT_PRINT_W(tag, format, ...) {esp_log_write(ESP_LOG_WARN, tag, LOG_FORMAT(W, format), esp_log_timestamp(), tag, ##__VA_ARGS__); } #define BT_PRINT_I(tag, format, ...) {esp_log_write(ESP_LOG_INFO, tag, LOG_FORMAT(I, format), esp_log_timestamp(), tag, ##__VA_ARGS__); } #define BT_PRINT_D(tag, format, ...) {esp_log_write(ESP_LOG_DEBUG, tag, LOG_FORMAT(D, format), esp_log_timestamp(), tag, ##__VA_ARGS__); } #define BT_PRINT_V(tag, format, ...) {esp_log_write(ESP_LOG_VERBOSE, tag, LOG_FORMAT(V, format), esp_log_timestamp(), tag, ##__VA_ARGS__); }7 defines #if !UC_BT_STACK_NO_LOG /* define traces for BTC */ #define BTC_TRACE_ERROR(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_ERROR && BT_LOG_LEVEL_CHECK(BTC, ERROR)) BT_PRINT_E("BT_BTC", fmt, ## args);} #define BTC_TRACE_WARNING(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_WARNING && BT_LOG_LEVEL_CHECK(BTC, WARNING)) BT_PRINT_W("BT_BTC", fmt, ## args);} #define BTC_TRACE_API(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_API && BT_LOG_LEVEL_CHECK(BTC,API)) BT_PRINT_I("BT_BTC", fmt, ## args);} #define BTC_TRACE_EVENT(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_EVENT && BT_LOG_LEVEL_CHECK(BTC,EVENT)) BT_PRINT_D("BT_BTC", fmt, ## args);} #define BTC_TRACE_DEBUG(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_DEBUG && BT_LOG_LEVEL_CHECK(BTC,DEBUG)) BT_PRINT_D("BT_BTC", fmt, ## args);} #define BTC_TRACE_VERBOSE(fmt, args...) {if (BTC_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_VERBOSE && BT_LOG_LEVEL_CHECK(BTC,VERBOSE)) BT_PRINT_V("BT_BTC", fmt, ## args);} /* define traces for OSI */ #define OSI_TRACE_ERROR(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_ERROR && BT_LOG_LEVEL_CHECK(OSI, ERROR)) BT_PRINT_E("BT_OSI", fmt, ## args);} #define OSI_TRACE_WARNING(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_WARNING && BT_LOG_LEVEL_CHECK(OSI, WARNING)) BT_PRINT_W("BT_OSI", fmt, ## args);} #define OSI_TRACE_API(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_API && BT_LOG_LEVEL_CHECK(OSI,API)) BT_PRINT_I("BT_OSI", fmt, ## args);} #define OSI_TRACE_EVENT(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_EVENT && BT_LOG_LEVEL_CHECK(OSI,EVENT)) BT_PRINT_D("BT_OSI", fmt, ## args);} #define OSI_TRACE_DEBUG(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_DEBUG && BT_LOG_LEVEL_CHECK(OSI,DEBUG)) BT_PRINT_D("BT_OSI", fmt, ## args);} #define OSI_TRACE_VERBOSE(fmt, args...) {if (OSI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_VERBOSE && BT_LOG_LEVEL_CHECK(OSI,VERBOSE)) BT_PRINT_V("BT_OSI", fmt, ## args);} /* define traces for BLUFI */ #define BLUFI_TRACE_ERROR(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_ERROR && BT_LOG_LEVEL_CHECK(BLUFI, ERROR)) BT_PRINT_E("BT_BLUFI", fmt, ## args);} #define BLUFI_TRACE_WARNING(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_WARNING && BT_LOG_LEVEL_CHECK(BLUFI, WARNING)) BT_PRINT_W("BT_BLUFI", fmt, ## args);} #define BLUFI_TRACE_API(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_API && BT_LOG_LEVEL_CHECK(BLUFI,API)) BT_PRINT_I("BT_BLUFI", fmt, ## args);} #define BLUFI_TRACE_EVENT(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_EVENT && BT_LOG_LEVEL_CHECK(BLUFI,EVENT)) BT_PRINT_D("BT_BLUFI", fmt, ## args);} #define BLUFI_TRACE_DEBUG(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_DEBUG && BT_LOG_LEVEL_CHECK(BLUFI,DEBUG)) BT_PRINT_D("BT_BLUFI", fmt, ## args);} #define BLUFI_TRACE_VERBOSE(fmt, args...) {if (BLUFI_INITIAL_TRACE_LEVEL >= BT_TRACE_LEVEL_VERBOSE && BT_LOG_LEVEL_CHECK(BLUFI,VERBOSE)) BT_PRINT_V("BT_BLUFI", fmt, ## args);}18 defines /* ... */ #else /* define traces for BTC */ #define BTC_TRACE_ERROR(fmt, args...) #define BTC_TRACE_WARNING(fmt, args...) #define BTC_TRACE_API(fmt, args...) #define BTC_TRACE_EVENT(fmt, args...) #define BTC_TRACE_DEBUG(fmt, args...) #define BTC_TRACE_VERBOSE(fmt, args...) /* define traces for OSI */ #define OSI_TRACE_ERROR(fmt, args...) #define OSI_TRACE_WARNING(fmt, args...) #define OSI_TRACE_API(fmt, args...) #define OSI_TRACE_EVENT(fmt, args...) #define OSI_TRACE_DEBUG(fmt, args...) #define OSI_TRACE_VERBOSE(fmt, args...) /* define traces for BLUFI */ #define BLUFI_TRACE_ERROR(fmt, args...) #define BLUFI_TRACE_WARNING(fmt, args...) #define BLUFI_TRACE_API(fmt, args...) #define BLUFI_TRACE_EVENT(fmt, args...) #define BLUFI_TRACE_DEBUG(fmt, args...) #define BLUFI_TRACE_VERBOSE(fmt, args...)18 defines /* ... */ #endif /** Bluetooth Error Status */ /** We need to build on this */ /* relate to ESP_BT_STATUS_xxx in esp_bt_defs.h */ typedef enum { BT_STATUS_SUCCESS = 0, BT_STATUS_FAIL, BT_STATUS_NOT_READY, BT_STATUS_NOMEM, BT_STATUS_BUSY, BT_STATUS_DONE, /* request already completed */ BT_STATUS_UNSUPPORTED, BT_STATUS_PARM_INVALID, BT_STATUS_UNHANDLED, BT_STATUS_AUTH_FAILURE, BT_STATUS_RMT_DEV_DOWN, BT_STATUS_AUTH_REJECTED, BT_STATUS_INVALID_STATIC_RAND_ADDR, BT_STATUS_PENDING, BT_STATUS_UNACCEPT_CONN_INTERVAL, BT_STATUS_PARAM_OUT_OF_RANGE, BT_STATUS_TIMEOUT, BT_STATUS_MEMORY_FULL, BT_STATUS_EIR_TOO_LARGE, }{ ... } bt_status_t; typedef uint8_t UINT8; typedef uint16_t UINT16; typedef uint32_t UINT32; typedef uint64_t UINT64; typedef bool BOOLEAN; /* Maximum UUID size - 16 bytes, and structure to hold any type of UUID. */ #define MAX_UUID_SIZE 16 typedef struct { #define LEN_UUID_16 2 #define LEN_UUID_32 4 #define LEN_UUID_128 16 UINT16 len; union { UINT16 uuid16; UINT32 uuid32; UINT8 uuid128[MAX_UUID_SIZE]; }{ ... } uu; }{ ... } tBT_UUID; /* Common Bluetooth field definitions */ #define BD_ADDR_LEN 6 /* Device address length */ typedef UINT8 BD_ADDR[BD_ADDR_LEN]; /* Device address */ /* ... */ #endif /* _BT_COMMON_H_ */
Details
Show:
from
Types: Columns:
This file uses the notable symbols shown below. Click anywhere in the file to view more details.