1 /** @file
2  *  @brief Bluetooth Generic Access Profile defines and Assigned Numbers.
3  */
4 
5 /*
6  * Copyright (c) 2019 Nordic Semiconductor ASA
7  *
8  * SPDX-License-Identifier: Apache-2.0
9  */
10 
11 #ifndef ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_
12 #define ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_
13 
14 #include <zephyr/sys/util_macro.h>
15 #include <zephyr/bluetooth/byteorder.h>
16 
17 #ifdef __cplusplus
18 extern "C" {
19 #endif
20 
21 /**
22  * @brief Bluetooth Generic Access Profile defines and Assigned Numbers.
23  * @defgroup bt_gap_defines Defines and Assigned Numbers
24  * @ingroup bt_gap
25  * @{
26  */
27 
28 /**
29  * @name Company Identifiers (see Bluetooth Assigned Numbers)
30  * @{
31  */
32 #define BT_COMP_ID_LF           0x05f1 /**< The Linux Foundation */
33 /**
34  * @}
35  */
36 
37 /**
38  * @name EIR/AD data type definitions
39  * @{
40  */
41 #define BT_DATA_FLAGS                    0x01 /**< AD flags */
42 #define BT_DATA_UUID16_SOME              0x02 /**< 16-bit UUID, more available */
43 #define BT_DATA_UUID16_ALL               0x03 /**< 16-bit UUID, all listed */
44 #define BT_DATA_UUID32_SOME              0x04 /**< 32-bit UUID, more available */
45 #define BT_DATA_UUID32_ALL               0x05 /**< 32-bit UUID, all listed */
46 #define BT_DATA_UUID128_SOME             0x06 /**< 128-bit UUID, more available */
47 #define BT_DATA_UUID128_ALL              0x07 /**< 128-bit UUID, all listed */
48 #define BT_DATA_NAME_SHORTENED           0x08 /**< Shortened name */
49 #define BT_DATA_NAME_COMPLETE            0x09 /**< Complete name */
50 #define BT_DATA_TX_POWER                 0x0a /**< Tx Power */
51 #define BT_DATA_DEVICE_CLASS             0x0d /**< Class of Device */
52 #define BT_DATA_SIMPLE_PAIRING_HASH_C192 0x0e /**< Simple Pairing Hash C-192 */
53 #define BT_DATA_SIMPLE_PAIRING_RAND_C192 0x0f /**< Simple Pairing Randomizer R-192 */
54 #define BT_DATA_DEVICE_ID                0x10 /**< Device ID (Profile) */
55 #define BT_DATA_SM_TK_VALUE              0x10 /**< Security Manager TK Value */
56 #define BT_DATA_SM_OOB_FLAGS             0x11 /**< Security Manager OOB Flags */
57 #define BT_DATA_PERIPHERAL_INT_RANGE     0x12 /**< Peripheral Connection Interval Range */
58 #define BT_DATA_SOLICIT16                0x14 /**< Solicit UUIDs, 16-bit */
59 #define BT_DATA_SOLICIT128               0x15 /**< Solicit UUIDs, 128-bit */
60 #define BT_DATA_SVC_DATA16               0x16 /**< Service data, 16-bit UUID */
61 #define BT_DATA_PUB_TARGET_ADDR          0x17 /**< Public Target Address */
62 #define BT_DATA_RAND_TARGET_ADDR         0x18 /**< Random Target Address */
63 #define BT_DATA_GAP_APPEARANCE           0x19 /**< GAP appearance */
64 #define BT_DATA_ADV_INT                  0x1a /**< Advertising Interval */
65 #define BT_DATA_LE_BT_DEVICE_ADDRESS     0x1b /**< LE Bluetooth Device Address */
66 #define BT_DATA_LE_ROLE                  0x1c /**< LE Role */
67 #define BT_DATA_SIMPLE_PAIRING_HASH      0x1d /**< Simple Pairing Hash C256 */
68 #define BT_DATA_SIMPLE_PAIRING_RAND      0x1e /**< Simple Pairing Randomizer R256 */
69 #define BT_DATA_SOLICIT32                0x1f /**< Solicit UUIDs, 32-bit */
70 #define BT_DATA_SVC_DATA32               0x20 /**< Service data, 32-bit UUID */
71 #define BT_DATA_SVC_DATA128              0x21 /**< Service data, 128-bit UUID */
72 #define BT_DATA_LE_SC_CONFIRM_VALUE      0x22 /**< LE SC Confirmation Value */
73 #define BT_DATA_LE_SC_RANDOM_VALUE       0x23 /**< LE SC Random Value */
74 #define BT_DATA_URI                      0x24 /**< URI */
75 #define BT_DATA_INDOOR_POS               0x25 /**< Indoor Positioning */
76 #define BT_DATA_TRANS_DISCOVER_DATA      0x26 /**< Transport Discovery Data */
77 #define BT_DATA_LE_SUPPORTED_FEATURES    0x27 /**< LE Supported Features */
78 #define BT_DATA_CHANNEL_MAP_UPDATE_IND   0x28 /**< Channel Map Update Indication */
79 #define BT_DATA_MESH_PROV                0x29 /**< Mesh Provisioning PDU */
80 #define BT_DATA_MESH_MESSAGE             0x2a /**< Mesh Networking PDU */
81 #define BT_DATA_MESH_BEACON              0x2b /**< Mesh Beacon */
82 #define BT_DATA_BIG_INFO                 0x2c /**< BIGInfo */
83 #define BT_DATA_BROADCAST_CODE           0x2d /**< Broadcast Code */
84 #define BT_DATA_CSIS_RSI                 0x2e /**< CSIS Random Set ID type */
85 #define BT_DATA_ADV_INT_LONG             0x2f /**< Advertising Interval long */
86 #define BT_DATA_BROADCAST_NAME           0x30 /**< Broadcast Name */
87 #define BT_DATA_ENCRYPTED_AD_DATA        0x31 /**< Encrypted Advertising Data */
88 #define BT_DATA_PAWR_TIMING_INFO         0x32 /**< Periodic Advertising Response Timing Info */
89 #define BT_DATA_ESL                      0x34 /**< Electronic Shelf Label Profile */
90 #define BT_DATA_3D_INFO                  0x3D /**< 3D Information Data */
91 
92 #define BT_DATA_MANUFACTURER_DATA        0xff /**< Manufacturer Specific Data */
93 
94 #define BT_LE_AD_LIMITED                 0x01 /**< Limited Discoverable */
95 #define BT_LE_AD_GENERAL                 0x02 /**< General Discoverable */
96 #define BT_LE_AD_NO_BREDR                0x04 /**< BR/EDR not supported */
97 /**
98  * @}
99  */
100 
101 /**
102  * @name Appearance Values
103  *
104  * Last Modified on 2023-01-05
105  * @{
106  */
107 /** Generic Unknown */
108 #define BT_APPEARANCE_UNKNOWN                               0x0000
109 /** Generic Phone */
110 #define BT_APPEARANCE_GENERIC_PHONE                         0x0040
111 /** Generic Computer */
112 #define BT_APPEARANCE_GENERIC_COMPUTER                      0x0080
113 /** Desktop Workstation */
114 #define BT_APPEARANCE_COMPUTER_DESKTOP_WORKSTATION          0x0081
115 /** Server-class Computer */
116 #define BT_APPEARANCE_COMPUTER_SERVER_CLASS                 0x0082
117 /** Laptop */
118 #define BT_APPEARANCE_COMPUTER_LAPTOP                       0x0083
119 /** Handheld PC/PDA (clamshell) */
120 #define BT_APPEARANCE_COMPUTER_HANDHELD_PCPDA               0x0084
121 /** Palm­size PC/PDA */
122 #define BT_APPEARANCE_COMPUTER_PALMSIZE_PCPDA               0x0085
123 /** Wearable computer (watch size) */
124 #define BT_APPEARANCE_COMPUTER_WEARABLE_COMPUTER            0x0086
125 /** Tablet */
126 #define BT_APPEARANCE_COMPUTER_TABLET                       0x0087
127 /** Docking Station */
128 #define BT_APPEARANCE_COMPUTER_DOCKING_STATION              0x0088
129 /** All in One */
130 #define BT_APPEARANCE_COMPUTER_ALL_IN_ONE                   0x0089
131 /** Blade Server */
132 #define BT_APPEARANCE_COMPUTER_BLADE_SERVER                 0x008A
133 /** Convertible */
134 #define BT_APPEARANCE_COMPUTER_CONVERTIBLE                  0x008B
135 /** Detachable */
136 #define BT_APPEARANCE_COMPUTER_DETACHABLE                   0x008C
137 /** IoT Gateway */
138 #define BT_APPEARANCE_COMPUTER_IOT_GATEWAY                  0x008D
139 /** Mini PC */
140 #define BT_APPEARANCE_COMPUTER_MINI_PC                      0x008E
141 /** Stick PC */
142 #define BT_APPEARANCE_COMPUTER_STICK_PC                     0x008F
143 /** Generic Watch */
144 #define BT_APPEARANCE_GENERIC_WATCH                         0x00C0
145 /** Sports Watch */
146 #define BT_APPEARANCE_SPORTS_WATCH                          0x00C1
147 /** Smartwatch */
148 #define BT_APPEARANCE_SMARTWATCH                            0x00C2
149 /** Generic Clock */
150 #define BT_APPEARANCE_GENERIC_CLOCK                         0x0100
151 /** Generic Display */
152 #define BT_APPEARANCE_GENERIC_DISPLAY                       0x0140
153 /** Generic Remote Control */
154 #define BT_APPEARANCE_GENERIC_REMOTE                        0x0180
155 /** Generic Eye-glasses */
156 #define BT_APPEARANCE_GENERIC_EYEGLASSES                    0x01C0
157 /** Generic Tag */
158 #define BT_APPEARANCE_GENERIC_TAG                           0x0200
159 /** Generic Keyring */
160 #define BT_APPEARANCE_GENERIC_KEYRING                       0x0240
161 /** Generic Media Player */
162 #define BT_APPEARANCE_GENERIC_MEDIA_PLAYER                  0x0280
163 /** Generic Barcode Scanner */
164 #define BT_APPEARANCE_GENERIC_BARCODE_SCANNER               0x02C0
165 /** Generic Thermometer */
166 #define BT_APPEARANCE_GENERIC_THERMOMETER                   0x0300
167 /** Ear Thermometer */
168 #define BT_APPEARANCE_THERMOMETER_EAR                       0x0301
169 /** Generic Heart Rate Sensor */
170 #define BT_APPEARANCE_GENERIC_HEART_RATE                    0x0340
171 /** Heart Rate Belt */
172 #define BT_APPEARANCE_HEART_RATE_BELT                       0x0341
173 /** Generic Blood Pressure */
174 #define BT_APPEARANCE_GENERIC_BLOOD_PRESSURE                0x0380
175 /** Arm Blood Pressure */
176 #define BT_APPEARANCE_BLOOD_PRESSURE_ARM                    0x0381
177 /** Wrist Blood Pressure */
178 #define BT_APPEARANCE_BLOOD_PRESSURE_WRIST                  0x0382
179 /** Generic Human Interface Device */
180 #define BT_APPEARANCE_GENERIC_HID                           0x03C0
181 /** Keyboard */
182 #define BT_APPEARANCE_HID_KEYBOARD                          0x03C1
183 /** Mouse */
184 #define BT_APPEARANCE_HID_MOUSE                             0x03C2
185 /** Joystick */
186 #define BT_APPEARANCE_HID_JOYSTICK                          0x03C3
187 /** Gamepad */
188 #define BT_APPEARANCE_HID_GAMEPAD                           0x03C4
189 /** Digitizer Tablet */
190 #define BT_APPEARANCE_HID_DIGITIZER_TABLET                  0x03C5
191 /** Card Reader */
192 #define BT_APPEARANCE_HID_CARD_READER                       0x03C6
193 /** Digital Pen */
194 #define BT_APPEARANCE_HID_DIGITAL_PEN                       0x03C7
195 /** Barcode Scanner */
196 #define BT_APPEARANCE_HID_BARCODE_SCANNER                   0x03C8
197 /** Touchpad */
198 #define BT_APPEARANCE_HID_TOUCHPAD                          0x03C9
199 /** Presentation Remote */
200 #define BT_APPEARANCE_HID_PRESENTATION_REMOTE               0x03CA
201 /** Generic Glucose Meter */
202 #define BT_APPEARANCE_GENERIC_GLUCOSE                       0x0400
203 /** Generic Running Walking Sensor */
204 #define BT_APPEARANCE_GENERIC_WALKING                       0x0440
205 /** In-Shoe Running Walking Sensor */
206 #define BT_APPEARANCE_WALKING_IN_SHOE                       0x0441
207 /** On-Shoe Running Walking Sensor */
208 #define BT_APPEARANCE_WALKING_ON_SHOE                       0x0442
209 /** On-Hip Running Walking Sensor */
210 #define BT_APPEARANCE_WALKING_ON_HIP                        0x0443
211 /** Generic Cycling */
212 #define BT_APPEARANCE_GENERIC_CYCLING                       0x0480
213 /** Cycling Computer */
214 #define BT_APPEARANCE_CYCLING_COMPUTER                      0x0481
215 /** Speed Sensor */
216 #define BT_APPEARANCE_CYCLING_SPEED                         0x0482
217 /** Cadence Sensor */
218 #define BT_APPEARANCE_CYCLING_CADENCE                       0x0483
219 /** Power Sensor */
220 #define BT_APPEARANCE_CYCLING_POWER                         0x0484
221 /** Speed and Cadence Sensor */
222 #define BT_APPEARANCE_CYCLING_SPEED_CADENCE                 0x0485
223 /** Generic Control Device */
224 #define BT_APPEARANCE_GENERIC_CONTROL_DEVICE                0x04C0
225 /** Switch */
226 #define BT_APPEARANCE_CONTROL_SWITCH                        0x04C1
227 /** Multi-switch */
228 #define BT_APPEARANCE_CONTROL_MULTI_SWITCH                  0x04C2
229 /** Button */
230 #define BT_APPEARANCE_CONTROL_BUTTON                        0x04C3
231 /** Slider */
232 #define BT_APPEARANCE_CONTROL_SLIDER                        0x04C4
233 /** Rotary Switch */
234 #define BT_APPEARANCE_CONTROL_ROTARY_SWITCH                 0x04C5
235 /** Touch Panel */
236 #define BT_APPEARANCE_CONTROL_TOUCH_PANEL                   0x04C6
237 /** Single Switch */
238 #define BT_APPEARANCE_CONTROL_SINGLE_SWITCH                 0x04C7
239 /** Double Switch */
240 #define BT_APPEARANCE_CONTROL_DOUBLE_SWITCH                 0x04C8
241 /** Triple Switch */
242 #define BT_APPEARANCE_CONTROL_TRIPLE_SWITCH                 0x04C9
243 /** Battery Switch */
244 #define BT_APPEARANCE_CONTROL_BATTERY_SWITCH                0x04CA
245 /** Energy Harvesting Switch */
246 #define BT_APPEARANCE_CONTROL_ENERGY_HARVESTING_SWITCH      0x04CB
247 /** Push Button */
248 #define BT_APPEARANCE_CONTROL_PUSH_BUTTON                   0x04CC
249 /** Generic Network Device */
250 #define BT_APPEARANCE_GENERIC_NETWORK_DEVICE                0x0500
251 /** Access Point */
252 #define BT_APPEARANCE_NETWORK_ACCESS_POINT                  0x0501
253 /** Mesh Device */
254 #define BT_APPEARANCE_NETWORK_MESH_DEVICE                   0x0502
255 /** Mesh Network Proxy */
256 #define BT_APPEARANCE_NETWORK_MESH_PROXY                    0x0503
257 /** Generic Sensor */
258 #define BT_APPEARANCE_GENERIC_SENSOR                        0x0540
259 /** Motion Sensor */
260 #define BT_APPEARANCE_SENSOR_MOTION                         0x0541
261 /** Air quality Sensor */
262 #define BT_APPEARANCE_SENSOR_AIR_QUALITY                    0x0542
263 /** Temperature Sensor */
264 #define BT_APPEARANCE_SENSOR_TEMPERATURE                    0x0543
265 /** Humidity Sensor */
266 #define BT_APPEARANCE_SENSOR_HUMIDITY                       0x0544
267 /** Leak Sensor */
268 #define BT_APPEARANCE_SENSOR_LEAK                           0x0545
269 /** Smoke Sensor */
270 #define BT_APPEARANCE_SENSOR_SMOKE                          0x0546
271 /** Occupancy Sensor */
272 #define BT_APPEARANCE_SENSOR_OCCUPANCY                      0x0547
273 /** Contact Sensor */
274 #define BT_APPEARANCE_SENSOR_CONTACT                        0x0548
275 /** Carbon Monoxide Sensor */
276 #define BT_APPEARANCE_SENSOR_CARBON_MONOXIDE                0x0549
277 /** Carbon Dioxide Sensor */
278 #define BT_APPEARANCE_SENSOR_CARBON_DIOXIDE                 0x054A
279 /** Ambient Light Sensor */
280 #define BT_APPEARANCE_SENSOR_AMBIENT_LIGHT                  0x054B
281 /** Energy Sensor */
282 #define BT_APPEARANCE_SENSOR_ENERGY                         0x054C
283 /** Color Light Sensor */
284 #define BT_APPEARANCE_SENSOR_COLOR_LIGHT                    0x054D
285 /** Rain Sensor */
286 #define BT_APPEARANCE_SENSOR_RAIN                           0x054E
287 /** Fire Sensor */
288 #define BT_APPEARANCE_SENSOR_FIRE                           0x054F
289 /** Wind Sensor */
290 #define BT_APPEARANCE_SENSOR_WIND                           0x0550
291 /** Proximity Sensor */
292 #define BT_APPEARANCE_SENSOR_PROXIMITY                      0x0551
293 /** Multi-Sensor */
294 #define BT_APPEARANCE_SENSOR_MULTI                          0x0552
295 /** Flush Mounted Sensor */
296 #define BT_APPEARANCE_SENSOR_FLUSH_MOUNTED                  0x0553
297 /** Ceiling Mounted Sensor */
298 #define BT_APPEARANCE_SENSOR_CEILING_MOUNTED                0x0554
299 /** Wall Mounted Sensor */
300 #define BT_APPEARANCE_SENSOR_WALL_MOUNTED                   0x0555
301 /** Multisensor */
302 #define BT_APPEARANCE_MULTISENSOR                           0x0556
303 /** Energy Meter */
304 #define BT_APPEARANCE_SENSOR_ENERGY_METER                   0x0557
305 /** Flame Detector */
306 #define BT_APPEARANCE_SENSOR_FLAME_DETECTOR                 0x0558
307 /** Vehicle Tire Pressure Sensor */
308 #define BT_APPEARANCE_SENSOR_VEHICLE_TIRE_PRESSURE          0x0559
309 /** Generic Light Fixtures */
310 #define BT_APPEARANCE_GENERIC_LIGHT_FIXTURES                0x0580
311 /** Wall Light */
312 #define BT_APPEARANCE_LIGHT_FIXTURES_WALL                   0x0581
313 /** Ceiling Light */
314 #define BT_APPEARANCE_LIGHT_FIXTURES_CEILING                0x0582
315 /** Floor Light */
316 #define BT_APPEARANCE_LIGHT_FIXTURES_FLOOR                  0x0583
317 /** Cabinet Light */
318 #define BT_APPEARANCE_LIGHT_FIXTURES_CABINET                0x0584
319 /** Desk Light */
320 #define BT_APPEARANCE_LIGHT_FIXTURES_DESK                   0x0585
321 /** Troffer Light */
322 #define BT_APPEARANCE_LIGHT_FIXTURES_TROFFER                0x0586
323 /** Pendant Light */
324 #define BT_APPEARANCE_LIGHT_FIXTURES_PENDANT                0x0587
325 /** In-ground Light */
326 #define BT_APPEARANCE_LIGHT_FIXTURES_IN_GROUND              0x0588
327 /** Flood Light */
328 #define BT_APPEARANCE_LIGHT_FIXTURES_FLOOD                  0x0589
329 /** Underwater Light */
330 #define BT_APPEARANCE_LIGHT_FIXTURES_UNDERWATER             0x058A
331 /** Bollard with Light */
332 #define BT_APPEARANCE_LIGHT_FIXTURES_BOLLARD_WITH           0x058B
333 /** Pathway Light */
334 #define BT_APPEARANCE_LIGHT_FIXTURES_PATHWAY                0x058C
335 /** Garden Light */
336 #define BT_APPEARANCE_LIGHT_FIXTURES_GARDEN                 0x058D
337 /** Pole-top Light */
338 #define BT_APPEARANCE_LIGHT_FIXTURES_POLE_TOP               0x058E
339 /** Spotlight */
340 #define BT_APPEARANCE_SPOT_LIGHT                            0x058F
341 /** Linear Light */
342 #define BT_APPEARANCE_LIGHT_FIXTURES_LINEAR                 0x0590
343 /** Street Light */
344 #define BT_APPEARANCE_LIGHT_FIXTURES_STREET                 0x0591
345 /** Shelves Light */
346 #define BT_APPEARANCE_LIGHT_FIXTURES_SHELVES                0x0592
347 /** Bay Light */
348 #define BT_APPEARANCE_LIGHT_FIXTURES_BAY                    0x0593
349 /** Emergency Exit Light */
350 #define BT_APPEARANCE_LIGHT_FIXTURES_EMERGENCY_EXIT         0x0594
351 /** Light Controller */
352 #define BT_APPEARANCE_LIGHT_FIXTURES_CONTROLLER             0x0595
353 /** Light Driver */
354 #define BT_APPEARANCE_LIGHT_FIXTURES_DRIVER                 0x0596
355 /** Bulb */
356 #define BT_APPEARANCE_LIGHT_FIXTURES_BULB                   0x0597
357 /** Low-bay Light */
358 #define BT_APPEARANCE_LIGHT_FIXTURES_LOW_BAY                0x0598
359 /** High-bay Light */
360 #define BT_APPEARANCE_LIGHT_FIXTURES_HIGH_BAY               0x0599
361 /** Generic Fan */
362 #define BT_APPEARANCE_GENERIC_FAN                           0x05C0
363 /** Ceiling Fan */
364 #define BT_APPEARANCE_FAN_CEILING                           0x05C1
365 /** Axial Fan */
366 #define BT_APPEARANCE_FAN_AXIAL                             0x05C2
367 /** Exhaust Fan */
368 #define BT_APPEARANCE_FAN_EXHAUST                           0x05C3
369 /** Pedestal Fan */
370 #define BT_APPEARANCE_FAN_PEDESTAL                          0x05C4
371 /** Desk Fan */
372 #define BT_APPEARANCE_FAN_DESK                              0x05C5
373 /** Wall Fan */
374 #define BT_APPEARANCE_FAN_WALL                              0x05C6
375 /** Generic HVAC */
376 #define BT_APPEARANCE_GENERIC_HVAC                          0x0600
377 /** Thermostat */
378 #define BT_APPEARANCE_HVAC_THERMOSTAT                       0x0601
379 /** Humidifier */
380 #define BT_APPEARANCE_HVAC_HUMIDIFIER                       0x0602
381 /** De-humidifier */
382 #define BT_APPEARANCE_HVAC_DEHUMIDIFIER                     0x0603
383 /** Heater */
384 #define BT_APPEARANCE_HVAC_HEATER                           0x0604
385 /** Radiator */
386 #define BT_APPEARANCE_HVAC_RADIATOR                         0x0605
387 /** Boiler */
388 #define BT_APPEARANCE_HVAC_BOILER                           0x0606
389 /** Heat Pump */
390 #define BT_APPEARANCE_HVAC_HEAT_PUMP                        0x0607
391 /** Infrared Heater */
392 #define BT_APPEARANCE_HVAC_INFRARED_HEATER                  0x0608
393 /** Radiant Panel Heater */
394 #define BT_APPEARANCE_HVAC_RADIANT_PANEL_HEATER             0x0609
395 /** Fan Heater */
396 #define BT_APPEARANCE_HVAC_FAN_HEATER                       0x060A
397 /** Air Curtain */
398 #define BT_APPEARANCE_HVAC_AIR_CURTAIN                      0x060B
399 /** Generic Air Conditioning */
400 #define BT_APPEARANCE_GENERIC_AIR_CONDITIONING              0x0640
401 /** Generic Humidifier */
402 #define BT_APPEARANCE_GENERIC_HUMIDIFIER                    0x0680
403 /** Generic Heating */
404 #define BT_APPEARANCE_GENERIC_HEATING                       0x06C0
405 /** Radiator */
406 #define BT_APPEARANCE_HEATING_RADIATOR                      0x06C1
407 /** Boiler */
408 #define BT_APPEARANCE_HEATING_BOILER                        0x06C2
409 /** Heat Pump */
410 #define BT_APPEARANCE_HEATING_HEAT_PUMP                     0x06C3
411 /** Infrared Heater */
412 #define BT_APPEARANCE_HEATING_INFRARED_HEATER               0x06C4
413 /** Radiant Panel Heater */
414 #define BT_APPEARANCE_HEATING_RADIANT_PANEL_HEATER          0x06C5
415 /** Fan Heater */
416 #define BT_APPEARANCE_HEATING_FAN_HEATER                    0x06C6
417 /** Air Curtain */
418 #define BT_APPEARANCE_HEATING_AIR_CURTAIN                   0x06C7
419 /** Generic Access Control */
420 #define BT_APPEARANCE_GENERIC_ACCESS_CONTROL                0x0700
421 /** Access Door */
422 #define BT_APPEARANCE_CONTROL_ACCESS_DOOR                   0x0701
423 /** Garage Door */
424 #define BT_APPEARANCE_CONTROL_GARAGE_DOOR                   0x0702
425 /** Emergency Exit Door */
426 #define BT_APPEARANCE_CONTROL_EMERGENCY_EXIT_DOOR           0x0703
427 /** Access Lock */
428 #define BT_APPEARANCE_CONTROL_ACCESS_LOCK                   0x0704
429 /** Elevator */
430 #define BT_APPEARANCE_CONTROL_ELEVATOR                      0x0705
431 /** Window */
432 #define BT_APPEARANCE_CONTROL_WINDOW                        0x0706
433 /** Entrance Gate */
434 #define BT_APPEARANCE_CONTROL_ENTRANCE_GATE                 0x0707
435 /** Door Lock */
436 #define BT_APPEARANCE_CONTROL_DOOR_LOCK                     0x0708
437 /** Locker */
438 #define BT_APPEARANCE_CONTROL_LOCKER                        0x0709
439 /** Generic Motorized Device */
440 #define BT_APPEARANCE_GENERIC_MOTORIZED_DEVICE              0x0740
441 /** Motorized Gate */
442 #define BT_APPEARANCE_MOTORIZED_GATE                        0x0741
443 /** Awning */
444 #define BT_APPEARANCE_MOTORIZED_AWNING                      0x0742
445 /** Blinds or Shades */
446 #define BT_APPEARANCE_MOTORIZED_BLINDS_OR_SHADES            0x0743
447 /** Curtains */
448 #define BT_APPEARANCE_MOTORIZED_CURTAINS                    0x0744
449 /** Screen */
450 #define BT_APPEARANCE_MOTORIZED_SCREEN                      0x0745
451 /** Generic Power Device */
452 #define BT_APPEARANCE_GENERIC_POWER_DEVICE                  0x0780
453 /** Power Outlet */
454 #define BT_APPEARANCE_POWER_OUTLET                          0x0781
455 /** Power Strip */
456 #define BT_APPEARANCE_POWER_STRIP                           0x0782
457 /** Plug */
458 #define BT_APPEARANCE_POWER_PLUG                            0x0783
459 /** Power Supply */
460 #define BT_APPEARANCE_POWER_SUPPLY                          0x0784
461 /** LED Driver */
462 #define BT_APPEARANCE_POWER_LED_DRIVER                      0x0785
463 /** Fluorescent Lamp Gear */
464 #define BT_APPEARANCE_POWER_FLUORESCENT_LAMP_GEAR           0x0786
465 /** HID Lamp Gear */
466 #define BT_APPEARANCE_POWER_HID_LAMP_GEAR                   0x0787
467 /** Charge Case */
468 #define BT_APPEARANCE_POWER_CHARGE_CASE                     0x0788
469 /** Power Bank */
470 #define BT_APPEARANCE_POWER_POWER_BANK                      0x0789
471 /** Generic Light Source */
472 #define BT_APPEARANCE_GENERIC_LIGHT_SOURCE                  0x07C0
473 /** Incandescent Light Bulb */
474 #define BT_APPEARANCE_LIGHT_SOURCE_INCANDESCENT_BULB        0x07C1
475 /** LED Lamp */
476 #define BT_APPEARANCE_LIGHT_SOURCE_LED_LAMP                 0x07C2
477 /** HID Lamp */
478 #define BT_APPEARANCE_LIGHT_SOURCE_HID_LAMP                 0x07C3
479 /** Fluorescent Lamp */
480 #define BT_APPEARANCE_LIGHT_SOURCE_FLUORESCENT_LAMP         0x07C4
481 /** LED Array */
482 #define BT_APPEARANCE_LIGHT_SOURCE_LED_ARRAY                0x07C5
483 /** Multi-Color LED Array */
484 #define BT_APPEARANCE_LIGHT_SOURCE_MULTICOLOR_LED_ARRAY     0x07C6
485 /** Low voltage halogen */
486 #define BT_APPEARANCE_LIGHT_SOURCE_LOW_VOLTAGE_HALOGEN      0x07C7
487 /** Organic light emitting diode */
488 #define BT_APPEARANCE_LIGHT_SOURCE_OLED                     0x07C8
489 /** Generic Window Covering */
490 #define BT_APPEARANCE_GENERIC_WINDOW_COVERING               0x0800
491 /** Window Shades */
492 #define BT_APPEARANCE_WINDOW_SHADES                         0x0801
493 /** Window Blinds */
494 #define BT_APPEARANCE_WINDOW_BLINDS                         0x0802
495 /** Window Awning */
496 #define BT_APPEARANCE_WINDOW_AWNING                         0x0803
497 /** Window Curtain */
498 #define BT_APPEARANCE_WINDOW_CURTAIN                        0x0804
499 /** Exterior Shutter */
500 #define BT_APPEARANCE_WINDOW_EXTERIOR_SHUTTER               0x0805
501 /** Exterior Screen */
502 #define BT_APPEARANCE_WINDOW_EXTERIOR_SCREEN                0x0806
503 /** Generic Audio Sink */
504 #define BT_APPEARANCE_GENERIC_AUDIO_SINK                    0x0840
505 /** Standalone Speaker */
506 #define BT_APPEARANCE_AUDIO_SINK_STANDALONE_SPEAKER         0x0841
507 /** Soundbar */
508 #define BT_APPEARANCE_AUDIO_SINK_SOUNDBAR                   0x0842
509 /** Bookshelf Speaker */
510 #define BT_APPEARANCE_AUDIO_SINK_BOOKSHELF_SPEAKER          0x0843
511 /** Standmounted Speaker */
512 #define BT_APPEARANCE_AUDIO_SINK_STANDMOUNTED_SPEAKER       0x0844
513 /** Speakerphone */
514 #define BT_APPEARANCE_AUDIO_SINK_SPEAKERPHONE               0x0845
515 /** Generic Audio Source */
516 #define BT_APPEARANCE_GENERIC_AUDIO_SOURCE                  0x0880
517 /** Microphone */
518 #define BT_APPEARANCE_AUDIO_SOURCE_MICROPHONE               0x0881
519 /** Alarm */
520 #define BT_APPEARANCE_AUDIO_SOURCE_ALARM                    0x0882
521 /** Bell */
522 #define BT_APPEARANCE_AUDIO_SOURCE_BELL                     0x0883
523 /** Horn */
524 #define BT_APPEARANCE_AUDIO_SOURCE_HORN                     0x0884
525 /** Broadcasting Device */
526 #define BT_APPEARANCE_AUDIO_SOURCE_BROADCASTING_DEVICE      0x0885
527 /** Service Desk */
528 #define BT_APPEARANCE_AUDIO_SOURCE_SERVICE_DESK             0x0886
529 /** Kiosk */
530 #define BT_APPEARANCE_AUDIO_SOURCE_KIOSK                    0x0887
531 /** Broadcasting Room */
532 #define BT_APPEARANCE_AUDIO_SOURCE_BROADCASTING_ROOM        0x0888
533 /** Auditorium */
534 #define BT_APPEARANCE_AUDIO_SOURCE_AUDITORIUM               0x0889
535 /** Generic Motorized Vehicle */
536 #define BT_APPEARANCE_GENERIC_MOTORIZED_VEHICLE             0x08C0
537 /** Car */
538 #define BT_APPEARANCE_VEHICLE_CAR                           0x08C1
539 /** Large Goods Vehicle */
540 #define BT_APPEARANCE_VEHICLE_LARGE_GOODS                   0x08C2
541 /** 2-Wheeled Vehicle */
542 #define BT_APPEARANCE_VEHICLE_TWO_WHEELED                   0x08C3
543 /** Motorbike */
544 #define BT_APPEARANCE_VEHICLE_MOTORBIKE                     0x08C4
545 /** Scooter */
546 #define BT_APPEARANCE_VEHICLE_SCOOTER                       0x08C5
547 /** Moped */
548 #define BT_APPEARANCE_VEHICLE_MOPED                         0x08C6
549 /** 3-Wheeled Vehicle */
550 #define BT_APPEARANCE_VEHICLE_THREE_WHEELED                 0x08C7
551 /** Light Vehicle */
552 #define BT_APPEARANCE_VEHICLE_LIGHT                         0x08C8
553 /** Quad Bike */
554 #define BT_APPEARANCE_VEHICLE_QUAD_BIKE                     0x08C9
555 /** Minibus */
556 #define BT_APPEARANCE_VEHICLE_MINIBUS                       0x08CA
557 /** Bus */
558 #define BT_APPEARANCE_VEHICLE_BUS                           0x08CB
559 /** Trolley */
560 #define BT_APPEARANCE_VEHICLE_TROLLEY                       0x08CC
561 /** Agricultural Vehicle */
562 #define BT_APPEARANCE_VEHICLE_AGRICULTURAL                  0x08CD
563 /** Camper/Caravan */
564 #define BT_APPEARANCE_VEHICLE_CAMPER_OR_CARAVAN             0x08CE
565 /** Recreational Vehicle/Motor Home */
566 #define BT_APPEARANCE_VEHICLE_RECREATIONAL                  0x08CF
567 /** Generic Domestic Appliance */
568 #define BT_APPEARANCE_GENERIC_DOMESTIC_APPLIANCE            0x0900
569 /** Refrigerator */
570 #define BT_APPEARANCE_APPLIANCE_REFRIGERATOR                0x0901
571 /** Freezer */
572 #define BT_APPEARANCE_APPLIANCE_FREEZER                     0x0902
573 /** Oven */
574 #define BT_APPEARANCE_APPLIANCE_OVEN                        0x0903
575 /** Microwave */
576 #define BT_APPEARANCE_APPLIANCE_MICROWAVE                   0x0904
577 /** Toaster */
578 #define BT_APPEARANCE_APPLIANCE_TOASTER                     0x0905
579 /** Washing Machine */
580 #define BT_APPEARANCE_APPLIANCE_WASHING_MACHINE             0x0906
581 /** Dryer */
582 #define BT_APPEARANCE_APPLIANCE_DRYER                       0x0907
583 /** Coffee maker */
584 #define BT_APPEARANCE_APPLIANCE_COFFEE_MAKER                0x0908
585 /** Clothes iron */
586 #define BT_APPEARANCE_APPLIANCE_CLOTHES_IRON                0x0909
587 /** Curling iron */
588 #define BT_APPEARANCE_APPLIANCE_CURLING_IRON                0x090A
589 /** Hair dryer */
590 #define BT_APPEARANCE_APPLIANCE_HAIR_DRYER                  0x090B
591 /** Vacuum cleaner */
592 #define BT_APPEARANCE_APPLIANCE_VACUUM_CLEANER              0x090C
593 /** Robotic vacuum cleaner */
594 #define BT_APPEARANCE_APPLIANCE_ROBOTIC_VACUUM_CLEANER      0x090D
595 /** Rice cooker */
596 #define BT_APPEARANCE_APPLIANCE_RICE_COOKER                 0x090E
597 /** Clothes steamer */
598 #define BT_APPEARANCE_APPLIANCE_CLOTHES_STEAMER             0x090F
599 /** Generic Wearable Audio Device */
600 #define BT_APPEARANCE_GENERIC_WEARABLE_AUDIO_DEVICE         0x0940
601 /** Earbud */
602 #define BT_APPEARANCE_WEARABLE_AUDIO_DEVICE_EARBUD          0x0941
603 /** Headset */
604 #define BT_APPEARANCE_WEARABLE_AUDIO_DEVICE_HEADSET         0x0942
605 /** Headphones */
606 #define BT_APPEARANCE_WEARABLE_AUDIO_DEVICE_HEADPHONES      0x0943
607 /** Neck Band */
608 #define BT_APPEARANCE_WEARABLE_AUDIO_DEVICE_NECK_BAND       0x0944
609 /** Generic Aircraft */
610 #define BT_APPEARANCE_GENERIC_AIRCRAFT                      0x0980
611 /** Light Aircraft */
612 #define BT_APPEARANCE_AIRCRAFT_LIGHT                        0x0981
613 /** Microlight */
614 #define BT_APPEARANCE_AIRCRAFT_MICROLIGHT                   0x0982
615 /** Paraglider */
616 #define BT_APPEARANCE_AIRCRAFT_PARAGLIDER                   0x0983
617 /** Large Passenger Aircraft */
618 #define BT_APPEARANCE_AIRCRAFT_LARGE_PASSENGER              0x0984
619 /** Generic AV Equipment */
620 #define BT_APPEARANCE_GENERIC_AV_EQUIPMENT                  0x09C0
621 /** Amplifier */
622 #define BT_APPEARANCE_AV_EQUIPMENT_AMPLIFIER                0x09C1
623 /** Receiver */
624 #define BT_APPEARANCE_AV_EQUIPMENT_RECEIVER                 0x09C2
625 /** Radio */
626 #define BT_APPEARANCE_AV_EQUIPMENT_RADIO                    0x09C3
627 /** Tuner */
628 #define BT_APPEARANCE_AV_EQUIPMENT_TUNER                    0x09C4
629 /** Turntable */
630 #define BT_APPEARANCE_AV_EQUIPMENT_TURNTABLE                0x09C5
631 /** CD Player */
632 #define BT_APPEARANCE_AV_EQUIPMENT_CD_PLAYER                0x09C6
633 /** DVD Player */
634 #define BT_APPEARANCE_AV_EQUIPMENT_DVD_PLAYER               0x09C7
635 /** Bluray Player */
636 #define BT_APPEARANCE_AV_EQUIPMENT_BLURAY_PLAYER            0x09C8
637 /** Optical Disc Player */
638 #define BT_APPEARANCE_AV_EQUIPMENT_OPTICAL_DISC_PLAYER      0x09C9
639 /** Set-Top Box */
640 #define BT_APPEARANCE_AV_EQUIPMENT_SET_TOP_BOX              0x09CA
641 /** Generic Display Equipment */
642 #define BT_APPEARANCE_GENERIC_DISPLAY_EQUIPMENT             0x0A00
643 /** Television */
644 #define BT_APPEARANCE_DISPLAY_EQUIPMENT_TELEVISION          0x0A01
645 /** Monitor */
646 #define BT_APPEARANCE_DISPLAY_EQUIPMENT_MONITOR             0x0A02
647 /** Projector */
648 #define BT_APPEARANCE_DISPLAY_EQUIPMENT_PROJECTOR           0x0A03
649 /** Generic Hearing aid */
650 #define BT_APPEARANCE_GENERIC_HEARING_AID                   0x0A40
651 /** In-ear hearing aid */
652 #define BT_APPEARANCE_HEARING_AID_IN_EAR                    0x0A41
653 /** Behind-ear hearing aid */
654 #define BT_APPEARANCE_HEARING_AID_BEHIND_EAR                0x0A42
655 /** Cochlear Implant */
656 #define BT_APPEARANCE_HEARING_AID_COCHLEAR_IMPLANT          0x0A43
657 /** Generic Gaming */
658 #define BT_APPEARANCE_GENERIC_GAMING                        0x0A80
659 /** Home Video Game Console */
660 #define BT_APPEARANCE_HOME_VIDEO_GAME_CONSOLE               0x0A81
661 /** Portable handheld console */
662 #define BT_APPEARANCE_PORTABLE_HANDHELD_CONSOLE             0x0A82
663 /** Generic Signage */
664 #define BT_APPEARANCE_GENERIC_SIGNAGE                       0x0AC0
665 /** Digital Signage */
666 #define BT_APPEARANCE_SIGNAGE_DIGITAL                       0x0AC1
667 /** Electronic Label */
668 #define BT_APPEARANCE_SIGNAGE_ELECTRONIC_LABEL              0x0AC2
669 /** Generic Pulse Oximeter */
670 #define BT_APPEARANCE_GENERIC_PULSE_OXIMETER                0x0C40
671 /** Fingertip Pulse Oximeter */
672 #define BT_APPEARANCE_PULSE_OXIMETER_FINGERTIP              0x0C41
673 /** Wrist Worn Pulse Oximeter */
674 #define BT_APPEARANCE_PULSE_OXIMETER_WRIST                  0x0C42
675 /** Generic Weight Scale */
676 #define BT_APPEARANCE_GENERIC_WEIGHT_SCALE                  0x0C80
677 /** Generic Personal Mobility Device */
678 #define BT_APPEARANCE_GENERIC_PERSONAL_MOBILITY_DEVICE      0x0CC0
679 /** Powered Wheelchair */
680 #define BT_APPEARANCE_MOBILITY_POWERED_WHEELCHAIR           0x0CC1
681 /** Mobility Scooter */
682 #define BT_APPEARANCE_MOBILITY_SCOOTER                      0x0CC2
683 /** Continuous Glucose Monitor */
684 #define BT_APPEARANCE_CONTINUOUS_GLUCOSE_MONITOR            0x0D00
685 /** Generic Insulin Pump */
686 #define BT_APPEARANCE_GENERIC_INSULIN_PUMP                  0x0D40
687 /** Insulin Pump, durable pump */
688 #define BT_APPEARANCE_INSULIN_PUMP_DURABLE                  0x0D41
689 /** Insulin Pump, patch pump */
690 #define BT_APPEARANCE_INSULIN_PUMP_PATCH                    0x0D44
691 /** Insulin Pen */
692 #define BT_APPEARANCE_INSULIN_PEN                           0x0D48
693 /** Generic Medication Delivery */
694 #define BT_APPEARANCE_GENERIC_MEDICATION_DELIVERY           0x0D80
695 /** Generic Spirometer */
696 #define BT_APPEARANCE_GENERIC_SPIROMETER                    0x0DC0
697 /** Handheld Spirometer */
698 #define BT_APPEARANCE_SPIROMETER_HANDHELD                   0x0DC1
699 /** Generic Outdoor Sports Activity */
700 #define BT_APPEARANCE_GENERIC_OUTDOOR_SPORTS                0x1440
701 /** Location Display */
702 #define BT_APPEARANCE_OUTDOOR_SPORTS_LOCATION               0x1441
703 /** Location and Navigation Display */
704 #define BT_APPEARANCE_OUTDOOR_SPORTS_LOCATION_AND_NAV       0x1442
705 /** Location Pod */
706 #define BT_APPEARANCE_OUTDOOR_SPORTS_LOCATION_POD           0x1443
707 /** Location and Navigation Pod */
708 #define BT_APPEARANCE_OUTDOOR_SPORTS_LOCATION_POD_AND_NAV   0x1444
709 /**
710  * @}
711  */
712 
713 /**
714  * @name Defined GAP timers
715  * @{
716  */
717 #define BT_GAP_SCAN_FAST_INTERVAL_MIN           0x0030  /* 30 ms    */
718 #define BT_GAP_SCAN_FAST_INTERVAL               0x0060  /* 60 ms    */
719 #define BT_GAP_SCAN_FAST_WINDOW                 0x0030  /* 30 ms    */
720 #define BT_GAP_SCAN_SLOW_INTERVAL_1             0x0800  /* 1.28 s   */
721 #define BT_GAP_SCAN_SLOW_WINDOW_1               0x0012  /* 11.25 ms */
722 #define BT_GAP_SCAN_SLOW_INTERVAL_2             0x1000  /* 2.56 s   */
723 #define BT_GAP_SCAN_SLOW_WINDOW_2               0x0012  /* 11.25 ms */
724 #define BT_GAP_ADV_FAST_INT_MIN_1               0x0030  /* 30 ms    */
725 #define BT_GAP_ADV_FAST_INT_MAX_1               0x0060  /* 60 ms    */
726 #define BT_GAP_ADV_FAST_INT_MIN_2               0x00a0  /* 100 ms   */
727 #define BT_GAP_ADV_FAST_INT_MAX_2               0x00f0  /* 150 ms   */
728 #define BT_GAP_ADV_SLOW_INT_MIN                 0x0640  /* 1 s      */
729 #define BT_GAP_ADV_SLOW_INT_MAX                 0x0780  /* 1.2 s    */
730 #define BT_GAP_PER_ADV_FAST_INT_MIN_1           0x0018  /* 30 ms    */
731 #define BT_GAP_PER_ADV_FAST_INT_MAX_1           0x0030  /* 60 ms    */
732 #define BT_GAP_PER_ADV_FAST_INT_MIN_2           0x0050  /* 100 ms   */
733 #define BT_GAP_PER_ADV_FAST_INT_MAX_2           0x0078  /* 150 ms   */
734 #define BT_GAP_PER_ADV_SLOW_INT_MIN             0x0320  /* 1 s      */
735 #define BT_GAP_PER_ADV_SLOW_INT_MAX             0x03C0  /* 1.2 s    */
736 #define BT_GAP_INIT_CONN_INT_MIN                0x0018  /* 30 ms    */
737 #define BT_GAP_INIT_CONN_INT_MAX                0x0028  /* 50 ms    */
738 /**
739  * @}
740  */
741 
742 /** LE PHY types */
743 enum {
744 	/** Convenience macro for when no PHY is set. */
745 	BT_GAP_LE_PHY_NONE                    = 0,
746 	/** LE 1M PHY */
747 	BT_GAP_LE_PHY_1M                      = BIT(0),
748 	 /** LE 2M PHY */
749 	BT_GAP_LE_PHY_2M                      = BIT(1),
750 	/** LE Coded PHY */
751 	BT_GAP_LE_PHY_CODED                   = BIT(2),
752 };
753 
754 /** Advertising PDU types */
755 enum {
756 	/** Scannable and connectable advertising. */
757 	BT_GAP_ADV_TYPE_ADV_IND               = 0x00,
758 	/** Directed connectable advertising. */
759 	BT_GAP_ADV_TYPE_ADV_DIRECT_IND        = 0x01,
760 	/** Non-connectable and scannable advertising. */
761 	BT_GAP_ADV_TYPE_ADV_SCAN_IND          = 0x02,
762 	/** Non-connectable and non-scannable advertising. */
763 	BT_GAP_ADV_TYPE_ADV_NONCONN_IND       = 0x03,
764 	/** Additional advertising data requested by an active scanner. */
765 	BT_GAP_ADV_TYPE_SCAN_RSP              = 0x04,
766 	/** Extended advertising, see advertising properties. */
767 	BT_GAP_ADV_TYPE_EXT_ADV               = 0x05,
768 };
769 
770 /** Advertising PDU properties */
771 enum {
772 	/** Connectable advertising. */
773 	BT_GAP_ADV_PROP_CONNECTABLE           = BIT(0),
774 	/** Scannable advertising. */
775 	BT_GAP_ADV_PROP_SCANNABLE             = BIT(1),
776 	/** Directed advertising. */
777 	BT_GAP_ADV_PROP_DIRECTED              = BIT(2),
778 	/** Additional advertising data requested by an active scanner. */
779 	BT_GAP_ADV_PROP_SCAN_RESPONSE         = BIT(3),
780 	/** Extended advertising. */
781 	BT_GAP_ADV_PROP_EXT_ADV               = BIT(4),
782 };
783 
784 /** Maximum advertising data length. */
785 #define BT_GAP_ADV_MAX_ADV_DATA_LEN             31
786 /** Maximum extended advertising data length.
787  *
788  *  @note The maximum advertising data length that can be sent by an extended
789  *        advertiser is defined by the controller.
790  */
791 #define BT_GAP_ADV_MAX_EXT_ADV_DATA_LEN         1650
792 
793 #define BT_GAP_TX_POWER_INVALID                 0x7f
794 #define BT_GAP_RSSI_INVALID                     0x7f
795 #define BT_GAP_SID_INVALID                      0xff
796 #define BT_GAP_NO_TIMEOUT                       0x0000
797 
798 /* The maximum allowed high duty cycle directed advertising timeout, 1.28
799  * seconds in 10 ms unit.
800  */
801 #define BT_GAP_ADV_HIGH_DUTY_CYCLE_MAX_TIMEOUT  128
802 
803 /** Default data length */
804 #define BT_GAP_DATA_LEN_DEFAULT                 0x001b /* 27 bytes */
805 /** Maximum data length */
806 #define BT_GAP_DATA_LEN_MAX                     0x00fb /* 251 bytes */
807 
808 /** Default data time */
809 #define BT_GAP_DATA_TIME_DEFAULT                0x0148 /* 328 us */
810 /** Maximum data time */
811 #define BT_GAP_DATA_TIME_MAX                    0x4290 /* 17040 us */
812 
813 /** Maximum advertising set number */
814 #define BT_GAP_SID_MAX                          0x0F
815 /** Maximum number of consecutive periodic advertisement events that can be
816  *  skipped after a successful receive.
817  */
818 #define BT_GAP_PER_ADV_MAX_SKIP                 0x01F3
819 /** Minimum Periodic Advertising Timeout (N * 10 ms) */
820 #define BT_GAP_PER_ADV_MIN_TIMEOUT              0x000A /* 100 ms */
821 /** Maximum Periodic Advertising Timeout (N * 10 ms) */
822 #define BT_GAP_PER_ADV_MAX_TIMEOUT              0x4000 /* 163.84 s */
823 /** Minimum Periodic Advertising Interval (N * 1.25 ms) */
824 #define BT_GAP_PER_ADV_MIN_INTERVAL             0x0006 /* 7.5 ms */
825 /** Maximum Periodic Advertising Interval (N * 1.25 ms) */
826 #define BT_GAP_PER_ADV_MAX_INTERVAL             0xFFFF /* 81.91875 s */
827 
828 /**
829  * @brief Convert periodic advertising interval (N * 0.625 ms) to microseconds
830  *
831  * Value range of @p _interval is @ref BT_LE_ADV_INTERVAL_MIN to @ref BT_LE_ADV_INTERVAL_MAX
832  */
833 #define BT_GAP_ADV_INTERVAL_TO_US(_interval) ((uint32_t)((_interval) * 625U))
834 
835 /**
836  * @brief Convert periodic advertising interval (N * 0.625 ms) to milliseconds
837  *
838  * Value range of @p _interval is @ref BT_LE_ADV_INTERVAL_MIN to @ref BT_LE_ADV_INTERVAL_MAX
839  *
840  * @note When intervals cannot be represented in milliseconds, this will round down.
841  * For example BT_GAP_ADV_INTERVAL_TO_MS(0x0021) will become 20 ms instead of 20.625 ms
842  */
843 #define BT_GAP_ADV_INTERVAL_TO_MS(_interval) (BT_GAP_ADV_INTERVAL_TO_US(_interval) / USEC_PER_MSEC)
844 
845 /**
846  * @brief Convert isochronous interval (N * 1.25 ms) to microseconds
847  *
848  * Value range of @p _interval is @ref BT_HCI_ISO_INTERVAL_MIN to @ref BT_HCI_ISO_INTERVAL_MAX
849  */
850 #define BT_GAP_ISO_INTERVAL_TO_US(_interval) ((uint32_t)((_interval) * 1250U))
851 
852 /**
853  * @brief Convert isochronous interval (N * 1.25 ms) to milliseconds
854  *
855  * Value range of @p _interval is @ref BT_HCI_ISO_INTERVAL_MIN to @ref BT_HCI_ISO_INTERVAL_MAX
856  *
857  * @note When intervals cannot be represented in milliseconds, this will round down.
858  * For example BT_GAP_ISO_INTERVAL_TO_MS(0x0005) will become 6 ms instead of 6.25 ms
859  */
860 #define BT_GAP_ISO_INTERVAL_TO_MS(_interval) (BT_GAP_ISO_INTERVAL_TO_US(_interval) / USEC_PER_MSEC)
861 
862 /** @brief Convert periodic advertising interval (N * 1.25 ms) to microseconds *
863  *
864  * Value range of @p _interval is @ref BT_HCI_LE_PER_ADV_INTERVAL_MIN to @ref
865  * BT_HCI_LE_PER_ADV_INTERVAL_MAX
866  */
867 #define BT_GAP_PER_ADV_INTERVAL_TO_US(_interval) ((uint32_t)((_interval) * 1250U))
868 
869 /**
870  * @brief Convert periodic advertising interval (N * 1.25 ms) to milliseconds
871  *
872  * @note When intervals cannot be represented in milliseconds, this will round down.
873  * For example BT_GAP_PER_ADV_INTERVAL_TO_MS(0x0009) will become 11 ms instead of 11.25 ms
874  */
875 #define BT_GAP_PER_ADV_INTERVAL_TO_MS(_interval)                                                   \
876 	(BT_GAP_PER_ADV_INTERVAL_TO_US(_interval) / USEC_PER_MSEC)
877 
878 /**
879  * @brief Convert microseconds to advertising interval units (0.625 ms)
880  *
881  * Value range of @p _interval is 20000 to 1024000
882  *
883  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
884  * For example BT_GAP_US_TO_ADV_INTERVAL(21000) will become 20625 microseconds
885  */
886 #define BT_GAP_US_TO_ADV_INTERVAL(_interval) ((uint16_t)((_interval) / 625U))
887 
888 /**
889  * @brief Convert milliseconds to advertising interval units (0.625 ms)
890  *
891  * Value range of @p _interval is 20 to 1024
892  *
893  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
894  * For example BT_GAP_MS_TO_ADV_INTERVAL(21) will become 20.625 milliseconds
895  */
896 #define BT_GAP_MS_TO_ADV_INTERVAL(_interval)                                                       \
897 	(BT_GAP_US_TO_ADV_INTERVAL((_interval) * USEC_PER_MSEC))
898 
899 /**
900  * @brief Convert microseconds to periodic advertising interval units (1.25 ms)
901  *
902  * Value range of @p _interval is 7500 to 81918750
903  *
904  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
905  * For example BT_GAP_US_TO_PER_ADV_INTERVAL(11000) will become 10000 microseconds
906  */
907 #define BT_GAP_US_TO_PER_ADV_INTERVAL(_interval) ((uint16_t)((_interval) / 1250U))
908 
909 /**
910  * @brief Convert milliseconds to periodic advertising interval units (1.25 ms)
911  *
912  * Value range of @p _interval is 7.5 to 81918.75
913  *
914  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
915  * For example BT_GAP_MS_TO_PER_ADV_INTERVAL(11) will become 10 milliseconds
916  */
917 #define BT_GAP_MS_TO_PER_ADV_INTERVAL(_interval)                                                   \
918 	(BT_GAP_US_TO_PER_ADV_INTERVAL((_interval) * USEC_PER_MSEC))
919 
920 /**
921  * @brief Convert milliseconds to periodic advertising sync timeout units (10 ms)
922  *
923  * Value range of @p _timeout is 100 to 163840
924  *
925  * @note If @p _timeout is not a multiple of the unit, it will round down to nearest.
926  * For example BT_GAP_MS_TO_PER_ADV_SYNC_TIMEOUT(4005) will become 4000 milliseconds
927  */
928 #define BT_GAP_MS_TO_PER_ADV_SYNC_TIMEOUT(_timeout) ((uint16_t)((_timeout) / 10U))
929 
930 /**
931  * @brief Convert microseconds to periodic advertising sync timeout units (10 ms)
932  *
933  * Value range of @p _timeout is 100000 to 163840000
934  *
935  * @note If @p _timeout is not a multiple of the unit, it will round down to nearest.
936  * For example BT_GAP_MS_TO_PER_ADV_SYNC_TIMEOUT(4005000) will become 4000000 microseconds
937  */
938 #define BT_GAP_US_TO_PER_ADV_SYNC_TIMEOUT(_timeout)                                                \
939 	(BT_GAP_MS_TO_PER_ADV_SYNC_TIMEOUT((_timeout) / USEC_PER_MSEC))
940 
941 /**
942  * @brief Convert microseconds to scan interval units (0.625 ms)
943  *
944  * Value range of @p _interval is 2500 to 40959375 if @kconfig{CONFIG_BT_EXT_ADV} else
945  * 2500 to 10240000
946  *
947  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
948  * For example BT_GAP_US_TO_SCAN_INTERVAL(21000) will become 20625 microseconds
949  */
950 #define BT_GAP_US_TO_SCAN_INTERVAL(_interval) ((uint16_t)((_interval) / 625U))
951 
952 /**
953  * @brief Convert milliseconds to scan interval units (0.625 ms)
954  *
955  * Value range of @p _interval is 2.5 to 40959.375 if @kconfig{CONFIG_BT_EXT_ADV} else
956  * 2500 to 10240
957  *
958  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
959  * For example BT_GAP_MS_TO_SCAN_INTERVAL(21) will become 20.625 milliseconds
960  */
961 #define BT_GAP_MS_TO_SCAN_INTERVAL(_interval)                                                      \
962 	(BT_GAP_US_TO_SCAN_INTERVAL((_interval) * USEC_PER_MSEC))
963 
964 /**
965  * @brief Convert microseconds to scan window units (0.625 ms)
966  *
967  * Value range of @p _window is 2500 to 40959375 if @kconfig{CONFIG_BT_EXT_ADV} else
968  * 2500 to 10240000
969  *
970  * @note If @p _window is not a multiple of the unit, it will round down to nearest.
971  * For example BT_GAP_US_TO_SCAN_WINDOW(21000) will become 20625 microseconds
972  */
973 #define BT_GAP_US_TO_SCAN_WINDOW(_window) ((uint16_t)((_window) / 625U))
974 
975 /**
976  * @brief Convert milliseconds to scan window units (0.625 ms)
977  *
978  * Value range of @p _window is 2.5 to 40959.375 if @kconfig{CONFIG_BT_EXT_ADV} else
979  * 2500 to 10240
980  *
981  * @note If @p _window is not a multiple of the unit, it will round down to nearest.
982  * For example BT_GAP_MS_TO_SCAN_WINDOW(21) will become 20.625 milliseconds
983  */
984 #define BT_GAP_MS_TO_SCAN_WINDOW(_window) (BT_GAP_US_TO_SCAN_WINDOW((_window) * USEC_PER_MSEC))
985 
986 /**
987  * @brief Convert microseconds to connection interval units (1.25 ms)
988  *
989  * Value range of @p _interval is 7500 to 4000000
990  *
991  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
992  * For example BT_GAP_US_TO_CONN_INTERVAL(21000) will become 20000 microseconds
993  */
994 #define BT_GAP_US_TO_CONN_INTERVAL(_interval) ((uint16_t)((_interval) / 1250U))
995 
996 /**
997  * @brief Convert milliseconds to connection interval units (1.25 ms)
998  *
999  * Value range of @p _interval is 7.5 to 4000
1000  *
1001  * @note If @p _interval is not a multiple of the unit, it will round down to nearest.
1002  * For example BT_GAP_MS_TO_CONN_INTERVAL(21) will become 20 milliseconds
1003  */
1004 #define BT_GAP_MS_TO_CONN_INTERVAL(_interval)                                                      \
1005 	(BT_GAP_US_TO_CONN_INTERVAL((_interval) * USEC_PER_MSEC))
1006 
1007 /**
1008  * @brief Convert milliseconds to connection supervision timeout units (10 ms)
1009  *
1010  * Value range of @p _timeout is 100 to 32000
1011  *
1012  * @note If @p _timeout is not a multiple of the unit, it will round down to nearest.
1013  * For example BT_GAP_MS_TO_CONN_TIMEOUT(4005) will become 4000 milliseconds
1014  */
1015 #define BT_GAP_MS_TO_CONN_TIMEOUT(_timeout) ((uint16_t)((_timeout) / 10U))
1016 
1017 /**
1018  * @brief Convert microseconds to connection supervision timeout units (10 ms)
1019 
1020  * Value range of @p _timeout is 100000 to 32000000
1021  *
1022  * @note If @p _timeout is not a multiple of the unit, it will round down to nearest.
1023  * For example BT_GAP_MS_TO_CONN_TIMEOUT(4005000) will become 4000000 microseconds
1024  */
1025 #define BT_GAP_US_TO_CONN_TIMEOUT(_timeout) (BT_GAP_MS_TO_CONN_TIMEOUT((_timeout) / USEC_PER_MSEC))
1026 
1027 /**
1028  * @brief Convert milliseconds to connection event length units (0.625)
1029  *
1030  * Value range of @p _event_len is 0 to 40959375
1031  *
1032  * @note If @p _event_len is not a multiple of the unit, it will round down to nearest.
1033  * For example BT_GAP_US_TO_CONN_EVENT_LEN(21000) will become 20625 milliseconds
1034  */
1035 #define BT_GAP_US_TO_CONN_EVENT_LEN(_event_len) ((uint16_t)((_event_len) / 625U))
1036 
1037 /**
1038  * @brief Convert milliseconds to connection event length units (0.625)
1039  *
1040  * Value range of @p _event_len is 0 to 40959.375
1041  *
1042  * @note If @p _event_len is not a multiple of the unit, it will round down to nearest.
1043  * For example BT_GAP_MS_TO_CONN_EVENT_LEN(21) will become 20.625 milliseconds
1044  */
1045 #define BT_GAP_MS_TO_CONN_EVENT_LEN(_event_len)                                                    \
1046 	(BT_GAP_US_TO_CONN_EVENT_LEN((_event_len) * USEC_PER_MSEC))
1047 
1048 /** Constant Tone Extension (CTE) types */
1049 enum {
1050 	/** Angle of Arrival */
1051 	BT_GAP_CTE_AOA = 0x00,
1052 	/** Angle of Departure with 1 us slots */
1053 	BT_GAP_CTE_AOD_1US = 0x01,
1054 	/** Angle of Departure with 2 us slots */
1055 	BT_GAP_CTE_AOD_2US = 0x02,
1056 	/** No extensions */
1057 	BT_GAP_CTE_NONE = 0xFF,
1058 };
1059 
1060 /** @brief Peripheral sleep clock accuracy (SCA) in ppm (parts per million) */
1061 enum {
1062 	BT_GAP_SCA_UNKNOWN = 0,   /**< Unknown */
1063 	BT_GAP_SCA_251_500 = 0,   /**< 251 ppm to 500 ppm */
1064 	BT_GAP_SCA_151_250 = 1,   /**< 151 ppm to 250 ppm */
1065 	BT_GAP_SCA_101_150 = 2,   /**< 101 ppm to 150 ppm */
1066 	BT_GAP_SCA_76_100 = 3,    /**< 76 ppm to 100 ppm */
1067 	BT_GAP_SCA_51_75 = 4,     /**< 51 ppm to 75 ppm */
1068 	BT_GAP_SCA_31_50 = 5,     /**< 31 ppm to 50 ppm */
1069 	BT_GAP_SCA_21_30 = 6,     /**< 21 ppm to 30 ppm */
1070 	BT_GAP_SCA_0_20 = 7,      /**< 0 ppm to 20 ppm */
1071 };
1072 
1073 /**
1074  * @brief Encode 40 least significant bits of 64-bit LE Supported Features into array values
1075  *        in little-endian format.
1076  *
1077  * Helper macro to encode 40 least significant bits of 64-bit LE Supported Features value into
1078  * advertising data. The number of bits that are encoded is a number of LE Supported Features
1079  * defined by BT 5.3 Core specification.
1080  *
1081  * Example of how to encode the `0x000000DFF00DF00D` into advertising data.
1082  *
1083  * @code
1084  * BT_DATA_BYTES(BT_DATA_LE_SUPPORTED_FEATURES, BT_LE_SUPP_FEAT_40_ENCODE(0x000000DFF00DF00D))
1085  * @endcode
1086  *
1087  * @param w64 LE Supported Features value (64-bits)
1088  *
1089  * @return The comma separated values for LE Supported Features value that
1090  *         may be used directly as an argument for @ref BT_DATA_BYTES.
1091  */
1092 #define BT_LE_SUPP_FEAT_40_ENCODE(w64) BT_BYTES_LIST_LE40(w64)
1093 
1094 /** @brief Encode 4 least significant bytes of 64-bit LE Supported Features into
1095  *         4 bytes long array of values in little-endian format.
1096  *
1097  *  Helper macro to encode 64-bit LE Supported Features value into advertising
1098  *  data. The macro encodes 4 least significant bytes into advertising data.
1099  *  Other 4 bytes are not encoded.
1100  *
1101  *  Example of how to encode the `0x000000DFF00DF00D` into advertising data.
1102  *
1103  *  @code
1104  *  BT_DATA_BYTES(BT_DATA_LE_SUPPORTED_FEATURES, BT_LE_SUPP_FEAT_32_ENCODE(0x000000DFF00DF00D))
1105  *  @endcode
1106  *
1107  * @param w64 LE Supported Features value (64-bits)
1108  *
1109  * @return The comma separated values for LE Supported Features value that
1110  *         may be used directly as an argument for @ref BT_DATA_BYTES.
1111  */
1112 #define BT_LE_SUPP_FEAT_32_ENCODE(w64) BT_BYTES_LIST_LE32(w64)
1113 
1114 /**
1115  * @brief Encode 3 least significant bytes of 64-bit LE Supported Features into
1116  *        3 bytes long array of values in little-endian format.
1117  *
1118  * Helper macro to encode 64-bit LE Supported Features value into advertising
1119  * data. The macro encodes 3 least significant bytes into advertising data.
1120  * Other 5 bytes are not encoded.
1121  *
1122  * Example of how to encode the `0x000000DFF00DF00D` into advertising data.
1123  *
1124  * @code
1125  * BT_DATA_BYTES(BT_DATA_LE_SUPPORTED_FEATURES, BT_LE_SUPP_FEAT_24_ENCODE(0x000000DFF00DF00D))
1126  * @endcode
1127  *
1128  * @param w64 LE Supported Features value (64-bits)
1129  *
1130  * @return The comma separated values for LE Supported Features value that
1131  *         may be used directly as an argument for @ref BT_DATA_BYTES.
1132  */
1133 #define BT_LE_SUPP_FEAT_24_ENCODE(w64) BT_BYTES_LIST_LE24(w64)
1134 
1135 /**
1136  * @brief Encode 2 least significant bytes of 64-bit LE Supported Features into
1137  *        2 bytes long array of values in little-endian format.
1138  *
1139  * Helper macro to encode 64-bit LE Supported Features value into advertising
1140  * data. The macro encodes 3 least significant bytes into advertising data.
1141  * Other 6 bytes are not encoded.
1142  *
1143  * Example of how to encode the `0x000000DFF00DF00D` into advertising data.
1144  *
1145  * @code
1146  * BT_DATA_BYTES(BT_DATA_LE_SUPPORTED_FEATURES, BT_LE_SUPP_FEAT_16_ENCODE(0x000000DFF00DF00D))
1147  * @endcode
1148  *
1149  * @param w64 LE Supported Features value (64-bits)
1150  *
1151  * @return The comma separated values for LE Supported Features value that
1152  *         may be used directly as an argument for @ref BT_DATA_BYTES.
1153  */
1154 #define BT_LE_SUPP_FEAT_16_ENCODE(w64) BT_BYTES_LIST_LE16(w64)
1155 
1156 /**
1157  * @brief Encode the least significant byte of 64-bit LE Supported Features into
1158  *        single byte long array.
1159  *
1160  * Helper macro to encode 64-bit LE Supported Features value into advertising
1161  * data. The macro encodes the least significant byte into advertising data.
1162  * Other 7 bytes are not encoded.
1163  *
1164  * Example of how to encode the `0x000000DFF00DF00D` into advertising data.
1165  *
1166  * @code
1167  * BT_DATA_BYTES(BT_DATA_LE_SUPPORTED_FEATURES, BT_LE_SUPP_FEAT_8_ENCODE(0x000000DFF00DF00D))
1168  * @endcode
1169  *
1170  * @param w64 LE Supported Features value (64-bits)
1171  *
1172  * @return The value of least significant byte of LE Supported Features value
1173  *         that may be used directly as an argument for @ref BT_DATA_BYTES.
1174  */
1175 #define BT_LE_SUPP_FEAT_8_ENCODE(w64) \
1176 	(((w64) >> 0) & 0xFF)
1177 
1178 /**
1179  * @brief Validate whether LE Supported Features value does not use bits that are reserved for
1180  *        future use.
1181  *
1182  * Helper macro to check if @p w64 has zeros as bits 40-63. The macro is compliant with BT 5.3
1183  * Core Specification where bits 0-40 has assigned values. In case of invalid value, build time
1184  * error is reported.
1185  */
1186 #define BT_LE_SUPP_FEAT_VALIDATE(w64) \
1187 	BUILD_ASSERT(!((w64) & (~BIT64_MASK(40))), \
1188 		     "RFU bit in LE Supported Features are not zeros.")
1189 
1190 /**
1191  * @}
1192  */
1193 
1194 #ifdef __cplusplus
1195 }
1196 #endif
1197 
1198 #endif /* ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_ */
1199