gap.h 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. /** @file
  2. * @brief Bluetooth Generic Access Profile defines and Assigned Numbers.
  3. */
  4. /*
  5. * Copyright (c) 2019 Nordic Semiconductor ASA
  6. *
  7. * SPDX-License-Identifier: Apache-2.0
  8. */
  9. #ifndef ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_
  10. #define ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_
  11. #ifdef __cplusplus
  12. extern "C" {
  13. #endif
  14. /**
  15. * @brief Bluetooth Generic Access Profile defines and Assigned Numbers.
  16. * @defgroup bt_gap_defines Defines and Assigned Numbers
  17. * @ingroup bluetooth
  18. * @{
  19. */
  20. /** Company Identifiers (see Bluetooth Assigned Numbers) */
  21. #define BT_COMP_ID_LF 0x05f1 /* The Linux Foundation */
  22. /** EIR/AD data type definitions */
  23. #define BT_DATA_FLAGS 0x01 /* AD flags */
  24. #define BT_DATA_UUID16_SOME 0x02 /* 16-bit UUID, more available */
  25. #define BT_DATA_UUID16_ALL 0x03 /* 16-bit UUID, all listed */
  26. #define BT_DATA_UUID32_SOME 0x04 /* 32-bit UUID, more available */
  27. #define BT_DATA_UUID32_ALL 0x05 /* 32-bit UUID, all listed */
  28. #define BT_DATA_UUID128_SOME 0x06 /* 128-bit UUID, more available */
  29. #define BT_DATA_UUID128_ALL 0x07 /* 128-bit UUID, all listed */
  30. #define BT_DATA_NAME_SHORTENED 0x08 /* Shortened name */
  31. #define BT_DATA_NAME_COMPLETE 0x09 /* Complete name */
  32. #define BT_DATA_TX_POWER 0x0a /* Tx Power */
  33. #define BT_DATA_SM_TK_VALUE 0x10 /* Security Manager TK Value */
  34. #define BT_DATA_SM_OOB_FLAGS 0x11 /* Security Manager OOB Flags */
  35. #define BT_DATA_SOLICIT16 0x14 /* Solicit UUIDs, 16-bit */
  36. #define BT_DATA_SOLICIT128 0x15 /* Solicit UUIDs, 128-bit */
  37. #define BT_DATA_SVC_DATA16 0x16 /* Service data, 16-bit UUID */
  38. #define BT_DATA_GAP_APPEARANCE 0x19 /* GAP appearance */
  39. #define BT_DATA_LE_BT_DEVICE_ADDRESS 0x1b /* LE Bluetooth Device Address */
  40. #define BT_DATA_LE_ROLE 0x1c /* LE Role */
  41. #define BT_DATA_SOLICIT32 0x1f /* Solicit UUIDs, 32-bit */
  42. #define BT_DATA_SVC_DATA32 0x20 /* Service data, 32-bit UUID */
  43. #define BT_DATA_SVC_DATA128 0x21 /* Service data, 128-bit UUID */
  44. #define BT_DATA_LE_SC_CONFIRM_VALUE 0x22 /* LE SC Confirmation Value */
  45. #define BT_DATA_LE_SC_RANDOM_VALUE 0x23 /* LE SC Random Value */
  46. #define BT_DATA_URI 0x24 /* URI */
  47. #define BT_DATA_CHANNEL_MAP_UPDATE_IND 0x28 /* Channel Map Update Indication */
  48. #define BT_DATA_MESH_PROV 0x29 /* Mesh Provisioning PDU */
  49. #define BT_DATA_MESH_MESSAGE 0x2a /* Mesh Networking PDU */
  50. #define BT_DATA_MESH_BEACON 0x2b /* Mesh Beacon */
  51. #define BT_DATA_BIG_INFO 0x2c /* BIGInfo */
  52. #define BT_DATA_BROADCAST_CODE 0x2d /* Broadcast Code */
  53. #define BT_DATA_MANUFACTURER_DATA 0xff /* Manufacturer Specific Data */
  54. #define BT_LE_AD_LIMITED 0x01 /* Limited Discoverable */
  55. #define BT_LE_AD_GENERAL 0x02 /* General Discoverable */
  56. #define BT_LE_AD_NO_BREDR 0x04 /* BR/EDR not supported */
  57. /* Defined GAP timers */
  58. #define BT_GAP_SCAN_FAST_INTERVAL 0x0060 /* 60 ms */
  59. #define BT_GAP_SCAN_FAST_WINDOW 0x0030 /* 30 ms */
  60. #define BT_GAP_SCAN_SLOW_INTERVAL_1 0x0800 /* 1.28 s */
  61. #define BT_GAP_SCAN_SLOW_WINDOW_1 0x0012 /* 11.25 ms */
  62. #define BT_GAP_SCAN_SLOW_INTERVAL_2 0x1000 /* 2.56 s */
  63. #define BT_GAP_SCAN_SLOW_WINDOW_2 0x0012 /* 11.25 ms */
  64. #define BT_GAP_ADV_FAST_INT_MIN_1 0x0030 /* 30 ms */
  65. #define BT_GAP_ADV_FAST_INT_MAX_1 0x0060 /* 60 ms */
  66. #define BT_GAP_ADV_FAST_INT_MIN_2 0x00a0 /* 100 ms */
  67. #define BT_GAP_ADV_FAST_INT_MAX_2 0x00f0 /* 150 ms */
  68. #define BT_GAP_ADV_SLOW_INT_MIN 0x0640 /* 1 s */
  69. #define BT_GAP_ADV_SLOW_INT_MAX 0x0780 /* 1.2 s */
  70. #define BT_GAP_PER_ADV_FAST_INT_MIN_1 0x0018 /* 30 ms */
  71. #define BT_GAP_PER_ADV_FAST_INT_MAX_1 0x0030 /* 60 ms */
  72. #define BT_GAP_PER_ADV_FAST_INT_MIN_2 0x0050 /* 100 ms */
  73. #define BT_GAP_PER_ADV_FAST_INT_MAX_2 0x0078 /* 150 ms */
  74. #define BT_GAP_PER_ADV_SLOW_INT_MIN 0x0320 /* 1 s */
  75. #define BT_GAP_PER_ADV_SLOW_INT_MAX 0x03C0 /* 1.2 s */
  76. #define BT_GAP_INIT_CONN_INT_MIN 0x0018 /* 30 ms */
  77. #define BT_GAP_INIT_CONN_INT_MAX 0x0028 /* 50 ms */
  78. /** LE PHY types */
  79. enum {
  80. /** Convenience macro for when no PHY is set. */
  81. BT_GAP_LE_PHY_NONE = 0,
  82. /** LE 1M PHY */
  83. BT_GAP_LE_PHY_1M = BIT(0),
  84. /** LE 2M PHY */
  85. BT_GAP_LE_PHY_2M = BIT(1),
  86. /** LE Coded PHY */
  87. BT_GAP_LE_PHY_CODED = BIT(2),
  88. };
  89. /** Advertising PDU types */
  90. enum {
  91. /** Scannable and connectable advertising. */
  92. BT_GAP_ADV_TYPE_ADV_IND = 0x00,
  93. /** Directed connectable advertising. */
  94. BT_GAP_ADV_TYPE_ADV_DIRECT_IND = 0x01,
  95. /** Non-connectable and scannable advertising. */
  96. BT_GAP_ADV_TYPE_ADV_SCAN_IND = 0x02,
  97. /** Non-connectable and non-scannable advertising. */
  98. BT_GAP_ADV_TYPE_ADV_NONCONN_IND = 0x03,
  99. /** Additional advertising data requested by an active scanner. */
  100. BT_GAP_ADV_TYPE_SCAN_RSP = 0x04,
  101. /** Extended advertising, see advertising properties. */
  102. BT_GAP_ADV_TYPE_EXT_ADV = 0x05,
  103. };
  104. /** Advertising PDU properties */
  105. enum {
  106. /** Connectable advertising. */
  107. BT_GAP_ADV_PROP_CONNECTABLE = BIT(0),
  108. /** Scannable advertising. */
  109. BT_GAP_ADV_PROP_SCANNABLE = BIT(1),
  110. /** Directed advertising. */
  111. BT_GAP_ADV_PROP_DIRECTED = BIT(2),
  112. /** Additional advertising data requested by an active scanner. */
  113. BT_GAP_ADV_PROP_SCAN_RESPONSE = BIT(3),
  114. /** Extended advertising. */
  115. BT_GAP_ADV_PROP_EXT_ADV = BIT(4),
  116. };
  117. /** Maximum advertising data length. */
  118. #define BT_GAP_ADV_MAX_ADV_DATA_LEN 31
  119. /** Maximum extended advertising data length.
  120. *
  121. * @note The maximum advertising data length that can be sent by an extended
  122. * advertiser is defined by the controller.
  123. */
  124. #define BT_GAP_ADV_MAX_EXT_ADV_DATA_LEN 1650
  125. #define BT_GAP_TX_POWER_INVALID 0x7f
  126. #define BT_GAP_RSSI_INVALID 0x7f
  127. #define BT_GAP_SID_INVALID 0xff
  128. #define BT_GAP_NO_TIMEOUT 0x0000
  129. /* The maximum allowed high duty cycle directed advertising timeout, 1.28
  130. * seconds in 10 ms unit.
  131. */
  132. #define BT_GAP_ADV_HIGH_DUTY_CYCLE_MAX_TIMEOUT 128
  133. #define BT_GAP_DATA_LEN_DEFAULT 0x001b /* 27 bytes */
  134. #define BT_GAP_DATA_LEN_MAX 0x00fb /* 251 bytes */
  135. #define BT_GAP_DATA_TIME_DEFAULT 0x0148 /* 328 us */
  136. #define BT_GAP_DATA_TIME_MAX 0x4290 /* 17040 us */
  137. #define BT_GAP_SID_MAX 0x0F
  138. #define BT_GAP_PER_ADV_MAX_SKIP 0x01F3
  139. #define BT_GAP_PER_ADV_MIN_TIMEOUT 0x000A
  140. #define BT_GAP_PER_ADV_MAX_TIMEOUT 0x4000
  141. /** Minimum Periodic Advertising Interval (N * 1.25 ms) */
  142. #define BT_GAP_PER_ADV_MIN_INTERVAL 0x0006
  143. /** Maximum Periodic Advertising Interval (N * 1.25 ms) */
  144. #define BT_GAP_PER_ADV_MAX_INTERVAL 0xFFFF
  145. /** Constant Tone Extension (CTE) types */
  146. enum {
  147. /** Angle of Arrival */
  148. BT_GAP_CTE_AOA = 0x00,
  149. /** Angle of Departure with 1 us slots */
  150. BT_GAP_CTE_AOD_1US = 0x01,
  151. /** Angle of Departure with 2 us slots */
  152. BT_GAP_CTE_AOD_2US = 0x02,
  153. /** No extensions */
  154. BT_GAP_CTE_NONE = 0xFF,
  155. };
  156. /** @brief Peripheral sleep clock accuracy (SCA) in ppm (parts per million) */
  157. enum {
  158. BT_GAP_SCA_UNKNOWN = 0,
  159. BT_GAP_SCA_251_500 = 0,
  160. BT_GAP_SCA_151_250 = 1,
  161. BT_GAP_SCA_101_150 = 2,
  162. BT_GAP_SCA_76_100 = 3,
  163. BT_GAP_SCA_51_75 = 4,
  164. BT_GAP_SCA_31_50 = 5,
  165. BT_GAP_SCA_21_30 = 6,
  166. BT_GAP_SCA_0_20 = 7,
  167. };
  168. /**
  169. * @}
  170. */
  171. #ifdef __cplusplus
  172. }
  173. #endif
  174. #endif /* ZEPHYR_INCLUDE_BLUETOOTH_GAP_H_ */