sdp.h 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632
  1. /** @file
  2. * @brief Service Discovery Protocol handling.
  3. */
  4. /*
  5. * Copyright (c) 2016 Intel Corporation
  6. *
  7. * SPDX-License-Identifier: Apache-2.0
  8. */
  9. #ifndef ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_
  10. #define ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_
  11. /**
  12. * @brief Service Discovery Protocol (SDP)
  13. * @defgroup bt_sdp Service Discovery Protocol (SDP)
  14. * @ingroup bluetooth
  15. * @{
  16. */
  17. #include <bluetooth/uuid.h>
  18. #include <bluetooth/conn.h>
  19. #ifdef __cplusplus
  20. extern "C" {
  21. #endif
  22. /*
  23. * All definitions are based on Bluetooth Assigned Numbers
  24. * of the Bluetooth Specification
  25. */
  26. /*
  27. * Service class identifiers of standard services and service groups
  28. */
  29. #define BT_SDP_SDP_SERVER_SVCLASS 0x1000
  30. #define BT_SDP_BROWSE_GRP_DESC_SVCLASS 0x1001
  31. #define BT_SDP_PUBLIC_BROWSE_GROUP 0x1002
  32. #define BT_SDP_SERIAL_PORT_SVCLASS 0x1101
  33. #define BT_SDP_LAN_ACCESS_SVCLASS 0x1102
  34. #define BT_SDP_DIALUP_NET_SVCLASS 0x1103
  35. #define BT_SDP_IRMC_SYNC_SVCLASS 0x1104
  36. #define BT_SDP_OBEX_OBJPUSH_SVCLASS 0x1105
  37. #define BT_SDP_OBEX_FILETRANS_SVCLASS 0x1106
  38. #define BT_SDP_IRMC_SYNC_CMD_SVCLASS 0x1107
  39. #define BT_SDP_HEADSET_SVCLASS 0x1108
  40. #define BT_SDP_CORDLESS_TELEPHONY_SVCLASS 0x1109
  41. #define BT_SDP_AUDIO_SOURCE_SVCLASS 0x110a
  42. #define BT_SDP_AUDIO_SINK_SVCLASS 0x110b
  43. #define BT_SDP_AV_REMOTE_TARGET_SVCLASS 0x110c
  44. #define BT_SDP_ADVANCED_AUDIO_SVCLASS 0x110d
  45. #define BT_SDP_AV_REMOTE_SVCLASS 0x110e
  46. #define BT_SDP_AV_REMOTE_CONTROLLER_SVCLASS 0x110f
  47. #define BT_SDP_INTERCOM_SVCLASS 0x1110
  48. #define BT_SDP_FAX_SVCLASS 0x1111
  49. #define BT_SDP_HEADSET_AGW_SVCLASS 0x1112
  50. #define BT_SDP_WAP_SVCLASS 0x1113
  51. #define BT_SDP_WAP_CLIENT_SVCLASS 0x1114
  52. #define BT_SDP_PANU_SVCLASS 0x1115
  53. #define BT_SDP_NAP_SVCLASS 0x1116
  54. #define BT_SDP_GN_SVCLASS 0x1117
  55. #define BT_SDP_DIRECT_PRINTING_SVCLASS 0x1118
  56. #define BT_SDP_REFERENCE_PRINTING_SVCLASS 0x1119
  57. #define BT_SDP_IMAGING_SVCLASS 0x111a
  58. #define BT_SDP_IMAGING_RESPONDER_SVCLASS 0x111b
  59. #define BT_SDP_IMAGING_ARCHIVE_SVCLASS 0x111c
  60. #define BT_SDP_IMAGING_REFOBJS_SVCLASS 0x111d
  61. #define BT_SDP_HANDSFREE_SVCLASS 0x111e
  62. #define BT_SDP_HANDSFREE_AGW_SVCLASS 0x111f
  63. #define BT_SDP_DIRECT_PRT_REFOBJS_SVCLASS 0x1120
  64. #define BT_SDP_REFLECTED_UI_SVCLASS 0x1121
  65. #define BT_SDP_BASIC_PRINTING_SVCLASS 0x1122
  66. #define BT_SDP_PRINTING_STATUS_SVCLASS 0x1123
  67. #define BT_SDP_HID_SVCLASS 0x1124
  68. #define BT_SDP_HCR_SVCLASS 0x1125
  69. #define BT_SDP_HCR_PRINT_SVCLASS 0x1126
  70. #define BT_SDP_HCR_SCAN_SVCLASS 0x1127
  71. #define BT_SDP_CIP_SVCLASS 0x1128
  72. #define BT_SDP_VIDEO_CONF_GW_SVCLASS 0x1129
  73. #define BT_SDP_UDI_MT_SVCLASS 0x112a
  74. #define BT_SDP_UDI_TA_SVCLASS 0x112b
  75. #define BT_SDP_AV_SVCLASS 0x112c
  76. #define BT_SDP_SAP_SVCLASS 0x112d
  77. #define BT_SDP_PBAP_PCE_SVCLASS 0x112e
  78. #define BT_SDP_PBAP_PSE_SVCLASS 0x112f
  79. #define BT_SDP_PBAP_SVCLASS 0x1130
  80. #define BT_SDP_MAP_MSE_SVCLASS 0x1132
  81. #define BT_SDP_MAP_MCE_SVCLASS 0x1133
  82. #define BT_SDP_MAP_SVCLASS 0x1134
  83. #define BT_SDP_GNSS_SVCLASS 0x1135
  84. #define BT_SDP_GNSS_SERVER_SVCLASS 0x1136
  85. #define BT_SDP_MPS_SC_SVCLASS 0x113a
  86. #define BT_SDP_MPS_SVCLASS 0x113b
  87. #define BT_SDP_PNP_INFO_SVCLASS 0x1200
  88. #define BT_SDP_GENERIC_NETWORKING_SVCLASS 0x1201
  89. #define BT_SDP_GENERIC_FILETRANS_SVCLASS 0x1202
  90. #define BT_SDP_GENERIC_AUDIO_SVCLASS 0x1203
  91. #define BT_SDP_GENERIC_TELEPHONY_SVCLASS 0x1204
  92. #define BT_SDP_UPNP_SVCLASS 0x1205
  93. #define BT_SDP_UPNP_IP_SVCLASS 0x1206
  94. #define BT_SDP_UPNP_PAN_SVCLASS 0x1300
  95. #define BT_SDP_UPNP_LAP_SVCLASS 0x1301
  96. #define BT_SDP_UPNP_L2CAP_SVCLASS 0x1302
  97. #define BT_SDP_VIDEO_SOURCE_SVCLASS 0x1303
  98. #define BT_SDP_VIDEO_SINK_SVCLASS 0x1304
  99. #define BT_SDP_VIDEO_DISTRIBUTION_SVCLASS 0x1305
  100. #define BT_SDP_HDP_SVCLASS 0x1400
  101. #define BT_SDP_HDP_SOURCE_SVCLASS 0x1401
  102. #define BT_SDP_HDP_SINK_SVCLASS 0x1402
  103. #define BT_SDP_GENERIC_ACCESS_SVCLASS 0x1800
  104. #define BT_SDP_GENERIC_ATTRIB_SVCLASS 0x1801
  105. #define BT_SDP_APPLE_AGENT_SVCLASS 0x2112
  106. /*
  107. * Attribute identifier codes
  108. */
  109. #define BT_SDP_SERVER_RECORD_HANDLE 0x0000
  110. /*
  111. * Possible values for attribute-id are listed below.
  112. * See SDP Spec, section "Service Attribute Definitions" for more details.
  113. */
  114. #define BT_SDP_ATTR_RECORD_HANDLE 0x0000
  115. #define BT_SDP_ATTR_SVCLASS_ID_LIST 0x0001
  116. #define BT_SDP_ATTR_RECORD_STATE 0x0002
  117. #define BT_SDP_ATTR_SERVICE_ID 0x0003
  118. #define BT_SDP_ATTR_PROTO_DESC_LIST 0x0004
  119. #define BT_SDP_ATTR_BROWSE_GRP_LIST 0x0005
  120. #define BT_SDP_ATTR_LANG_BASE_ATTR_ID_LIST 0x0006
  121. #define BT_SDP_ATTR_SVCINFO_TTL 0x0007
  122. #define BT_SDP_ATTR_SERVICE_AVAILABILITY 0x0008
  123. #define BT_SDP_ATTR_PROFILE_DESC_LIST 0x0009
  124. #define BT_SDP_ATTR_DOC_URL 0x000a
  125. #define BT_SDP_ATTR_CLNT_EXEC_URL 0x000b
  126. #define BT_SDP_ATTR_ICON_URL 0x000c
  127. #define BT_SDP_ATTR_ADD_PROTO_DESC_LIST 0x000d
  128. #define BT_SDP_ATTR_GROUP_ID 0x0200
  129. #define BT_SDP_ATTR_IP_SUBNET 0x0200
  130. #define BT_SDP_ATTR_VERSION_NUM_LIST 0x0200
  131. #define BT_SDP_ATTR_SUPPORTED_FEATURES_LIST 0x0200
  132. #define BT_SDP_ATTR_GOEP_L2CAP_PSM 0x0200
  133. #define BT_SDP_ATTR_SVCDB_STATE 0x0201
  134. #define BT_SDP_ATTR_MPSD_SCENARIOS 0x0200
  135. #define BT_SDP_ATTR_MPMD_SCENARIOS 0x0201
  136. #define BT_SDP_ATTR_MPS_DEPENDENCIES 0x0202
  137. #define BT_SDP_ATTR_SERVICE_VERSION 0x0300
  138. #define BT_SDP_ATTR_EXTERNAL_NETWORK 0x0301
  139. #define BT_SDP_ATTR_SUPPORTED_DATA_STORES_LIST 0x0301
  140. #define BT_SDP_ATTR_DATA_EXCHANGE_SPEC 0x0301
  141. #define BT_SDP_ATTR_NETWORK 0x0301
  142. #define BT_SDP_ATTR_FAX_CLASS1_SUPPORT 0x0302
  143. #define BT_SDP_ATTR_REMOTE_AUDIO_VOLUME_CONTROL 0x0302
  144. #define BT_SDP_ATTR_MCAP_SUPPORTED_PROCEDURES 0x0302
  145. #define BT_SDP_ATTR_FAX_CLASS20_SUPPORT 0x0303
  146. #define BT_SDP_ATTR_SUPPORTED_FORMATS_LIST 0x0303
  147. #define BT_SDP_ATTR_FAX_CLASS2_SUPPORT 0x0304
  148. #define BT_SDP_ATTR_AUDIO_FEEDBACK_SUPPORT 0x0305
  149. #define BT_SDP_ATTR_NETWORK_ADDRESS 0x0306
  150. #define BT_SDP_ATTR_WAP_GATEWAY 0x0307
  151. #define BT_SDP_ATTR_HOMEPAGE_URL 0x0308
  152. #define BT_SDP_ATTR_WAP_STACK_TYPE 0x0309
  153. #define BT_SDP_ATTR_SECURITY_DESC 0x030a
  154. #define BT_SDP_ATTR_NET_ACCESS_TYPE 0x030b
  155. #define BT_SDP_ATTR_MAX_NET_ACCESSRATE 0x030c
  156. #define BT_SDP_ATTR_IP4_SUBNET 0x030d
  157. #define BT_SDP_ATTR_IP6_SUBNET 0x030e
  158. #define BT_SDP_ATTR_SUPPORTED_CAPABILITIES 0x0310
  159. #define BT_SDP_ATTR_SUPPORTED_FEATURES 0x0311
  160. #define BT_SDP_ATTR_SUPPORTED_FUNCTIONS 0x0312
  161. #define BT_SDP_ATTR_TOTAL_IMAGING_DATA_CAPACITY 0x0313
  162. #define BT_SDP_ATTR_SUPPORTED_REPOSITORIES 0x0314
  163. #define BT_SDP_ATTR_MAS_INSTANCE_ID 0x0315
  164. #define BT_SDP_ATTR_SUPPORTED_MESSAGE_TYPES 0x0316
  165. #define BT_SDP_ATTR_PBAP_SUPPORTED_FEATURES 0x0317
  166. #define BT_SDP_ATTR_MAP_SUPPORTED_FEATURES 0x0317
  167. #define BT_SDP_ATTR_SPECIFICATION_ID 0x0200
  168. #define BT_SDP_ATTR_VENDOR_ID 0x0201
  169. #define BT_SDP_ATTR_PRODUCT_ID 0x0202
  170. #define BT_SDP_ATTR_VERSION 0x0203
  171. #define BT_SDP_ATTR_PRIMARY_RECORD 0x0204
  172. #define BT_SDP_ATTR_VENDOR_ID_SOURCE 0x0205
  173. #define BT_SDP_ATTR_HID_DEVICE_RELEASE_NUMBER 0x0200
  174. #define BT_SDP_ATTR_HID_PARSER_VERSION 0x0201
  175. #define BT_SDP_ATTR_HID_DEVICE_SUBCLASS 0x0202
  176. #define BT_SDP_ATTR_HID_COUNTRY_CODE 0x0203
  177. #define BT_SDP_ATTR_HID_VIRTUAL_CABLE 0x0204
  178. #define BT_SDP_ATTR_HID_RECONNECT_INITIATE 0x0205
  179. #define BT_SDP_ATTR_HID_DESCRIPTOR_LIST 0x0206
  180. #define BT_SDP_ATTR_HID_LANG_ID_BASE_LIST 0x0207
  181. #define BT_SDP_ATTR_HID_SDP_DISABLE 0x0208
  182. #define BT_SDP_ATTR_HID_BATTERY_POWER 0x0209
  183. #define BT_SDP_ATTR_HID_REMOTE_WAKEUP 0x020a
  184. #define BT_SDP_ATTR_HID_PROFILE_VERSION 0x020b
  185. #define BT_SDP_ATTR_HID_SUPERVISION_TIMEOUT 0x020c
  186. #define BT_SDP_ATTR_HID_NORMALLY_CONNECTABLE 0x020d
  187. #define BT_SDP_ATTR_HID_BOOT_DEVICE 0x020e
  188. /*
  189. * These identifiers are based on the SDP spec stating that
  190. * "base attribute id of the primary (universal) language must be 0x0100"
  191. *
  192. * Other languages should have their own offset; e.g.:
  193. * #define XXXLangBase yyyy
  194. * #define AttrServiceName_XXX 0x0000+XXXLangBase
  195. */
  196. #define BT_SDP_PRIMARY_LANG_BASE 0x0100
  197. #define BT_SDP_ATTR_SVCNAME_PRIMARY (0x0000 + BT_SDP_PRIMARY_LANG_BASE)
  198. #define BT_SDP_ATTR_SVCDESC_PRIMARY (0x0001 + BT_SDP_PRIMARY_LANG_BASE)
  199. #define BT_SDP_ATTR_PROVNAME_PRIMARY (0x0002 + BT_SDP_PRIMARY_LANG_BASE)
  200. /*
  201. * The Data representation in SDP PDUs (pps 339, 340 of BT SDP Spec)
  202. * These are the exact data type+size descriptor values
  203. * that go into the PDU buffer.
  204. *
  205. * The datatype (leading 5bits) + size descriptor (last 3 bits)
  206. * is 8 bits. The size descriptor is critical to extract the
  207. * right number of bytes for the data value from the PDU.
  208. *
  209. * For most basic types, the datatype+size descriptor is
  210. * straightforward. However for constructed types and strings,
  211. * the size of the data is in the next "n" bytes following the
  212. * 8 bits (datatype+size) descriptor. Exactly what the "n" is
  213. * specified in the 3 bits of the data size descriptor.
  214. *
  215. * TextString and URLString can be of size 2^{8, 16, 32} bytes
  216. * DataSequence and DataSequenceAlternates can be of size 2^{8, 16, 32}
  217. * The size are computed post-facto in the API and are not known apriori
  218. */
  219. #define BT_SDP_DATA_NIL 0x00
  220. #define BT_SDP_UINT8 0x08
  221. #define BT_SDP_UINT16 0x09
  222. #define BT_SDP_UINT32 0x0a
  223. #define BT_SDP_UINT64 0x0b
  224. #define BT_SDP_UINT128 0x0c
  225. #define BT_SDP_INT8 0x10
  226. #define BT_SDP_INT16 0x11
  227. #define BT_SDP_INT32 0x12
  228. #define BT_SDP_INT64 0x13
  229. #define BT_SDP_INT128 0x14
  230. #define BT_SDP_UUID_UNSPEC 0x18
  231. #define BT_SDP_UUID16 0x19
  232. #define BT_SDP_UUID32 0x1a
  233. #define BT_SDP_UUID128 0x1c
  234. #define BT_SDP_TEXT_STR_UNSPEC 0x20
  235. #define BT_SDP_TEXT_STR8 0x25
  236. #define BT_SDP_TEXT_STR16 0x26
  237. #define BT_SDP_TEXT_STR32 0x27
  238. #define BT_SDP_BOOL 0x28
  239. #define BT_SDP_SEQ_UNSPEC 0x30
  240. #define BT_SDP_SEQ8 0x35
  241. #define BT_SDP_SEQ16 0x36
  242. #define BT_SDP_SEQ32 0x37
  243. #define BT_SDP_ALT_UNSPEC 0x38
  244. #define BT_SDP_ALT8 0x3d
  245. #define BT_SDP_ALT16 0x3e
  246. #define BT_SDP_ALT32 0x3f
  247. #define BT_SDP_URL_STR_UNSPEC 0x40
  248. #define BT_SDP_URL_STR8 0x45
  249. #define BT_SDP_URL_STR16 0x46
  250. #define BT_SDP_URL_STR32 0x47
  251. #define BT_SDP_TYPE_DESC_MASK 0xf8
  252. #define BT_SDP_SIZE_DESC_MASK 0x07
  253. #define BT_SDP_SIZE_INDEX_OFFSET 5
  254. /** @brief SDP Generic Data Element Value. */
  255. struct bt_sdp_data_elem {
  256. uint8_t type;
  257. uint32_t data_size;
  258. uint32_t total_size;
  259. const void *data;
  260. };
  261. /** @brief SDP Attribute Value. */
  262. struct bt_sdp_attribute {
  263. uint16_t id; /* Attribute ID */
  264. struct bt_sdp_data_elem val; /* Attribute data */
  265. };
  266. /** @brief SDP Service Record Value. */
  267. struct bt_sdp_record {
  268. uint32_t handle; /* Redundant, for quick ref */
  269. struct bt_sdp_attribute *attrs; /* Base addr of attr array */
  270. size_t attr_count; /* Number of attributes */
  271. uint8_t index; /* Index of the record in LL */
  272. struct bt_sdp_record *next;
  273. };
  274. /*
  275. * --------------------------------------------------- ------------------
  276. * | Service Hdl | Attr list ptr | Attr count | Next | -> | Service Hdl | ...
  277. * --------------------------------------------------- ------------------
  278. */
  279. /** @def BT_SDP_ARRAY_8
  280. * @brief Declare an array of 8-bit elements in an attribute.
  281. */
  282. #define BT_SDP_ARRAY_8(...) ((uint8_t[]) {__VA_ARGS__})
  283. /** @def BT_SDP_ARRAY_16
  284. * @brief Declare an array of 16-bit elements in an attribute.
  285. */
  286. #define BT_SDP_ARRAY_16(...) ((uint16_t[]) {__VA_ARGS__})
  287. /** @def BT_SDP_ARRAY_32
  288. * @brief Declare an array of 32-bit elements in an attribute.
  289. */
  290. #define BT_SDP_ARRAY_32(...) ((uint32_t[]) {__VA_ARGS__})
  291. /** @def BT_SDP_TYPE_SIZE
  292. * @brief Declare a fixed-size data element header.
  293. *
  294. * @param _type Data element header containing type and size descriptors.
  295. */
  296. #define BT_SDP_TYPE_SIZE(_type) .type = _type, \
  297. .data_size = BIT(_type & BT_SDP_SIZE_DESC_MASK), \
  298. .total_size = BIT(_type & BT_SDP_SIZE_DESC_MASK) + 1
  299. /** @def BT_SDP_TYPE_SIZE_VAR
  300. * @brief Declare a variable-size data element header.
  301. *
  302. * @param _type Data element header containing type and size descriptors.
  303. * @param _size The actual size of the data.
  304. */
  305. #define BT_SDP_TYPE_SIZE_VAR(_type, _size) .type = _type, \
  306. .data_size = _size, \
  307. .total_size = BIT((_type & BT_SDP_SIZE_DESC_MASK) - \
  308. BT_SDP_SIZE_INDEX_OFFSET) + _size + 1
  309. /** @def BT_SDP_DATA_ELEM_LIST
  310. * @brief Declare a list of data elements.
  311. */
  312. #define BT_SDP_DATA_ELEM_LIST(...) ((struct bt_sdp_data_elem[]) {__VA_ARGS__})
  313. /** @def BT_SDP_NEW_SERVICE
  314. * @brief SDP New Service Record Declaration Macro.
  315. *
  316. * Helper macro to declare a new service record.
  317. * Default attributes: Record Handle, Record State,
  318. * Language Base, Root Browse Group
  319. *
  320. */
  321. #define BT_SDP_NEW_SERVICE \
  322. { \
  323. BT_SDP_ATTR_RECORD_HANDLE, \
  324. { BT_SDP_TYPE_SIZE(BT_SDP_UINT32), BT_SDP_ARRAY_32(0) } \
  325. }, \
  326. { \
  327. BT_SDP_ATTR_RECORD_STATE, \
  328. { BT_SDP_TYPE_SIZE(BT_SDP_UINT32), BT_SDP_ARRAY_32(0) } \
  329. }, \
  330. { \
  331. BT_SDP_ATTR_LANG_BASE_ATTR_ID_LIST, \
  332. { BT_SDP_TYPE_SIZE_VAR(BT_SDP_SEQ8, 9), \
  333. BT_SDP_DATA_ELEM_LIST( \
  334. { BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_8('n', 'e') }, \
  335. { BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_16(106) }, \
  336. { BT_SDP_TYPE_SIZE(BT_SDP_UINT16), \
  337. BT_SDP_ARRAY_16(BT_SDP_PRIMARY_LANG_BASE) } \
  338. ), \
  339. } \
  340. }, \
  341. { \
  342. BT_SDP_ATTR_BROWSE_GRP_LIST, \
  343. { BT_SDP_TYPE_SIZE_VAR(BT_SDP_SEQ8, 3), \
  344. BT_SDP_DATA_ELEM_LIST( \
  345. { BT_SDP_TYPE_SIZE(BT_SDP_UUID16), \
  346. BT_SDP_ARRAY_16(BT_SDP_PUBLIC_BROWSE_GROUP) }, \
  347. ), \
  348. } \
  349. }
  350. /** @def BT_SDP_LIST
  351. * @brief Generic SDP List Attribute Declaration Macro.
  352. *
  353. * Helper macro to declare a list attribute.
  354. *
  355. * @param _att_id List Attribute ID.
  356. * @param _data_elem_seq Data element sequence for the list.
  357. * @param _type_size SDP type and size descriptor.
  358. */
  359. #define BT_SDP_LIST(_att_id, _type_size, _data_elem_seq) \
  360. { \
  361. _att_id, { _type_size, _data_elem_seq } \
  362. }
  363. /** @def BT_SDP_SERVICE_ID
  364. * @brief SDP Service ID Attribute Declaration Macro.
  365. *
  366. * Helper macro to declare a service ID attribute.
  367. *
  368. * @param _uuid Service ID 16bit UUID.
  369. */
  370. #define BT_SDP_SERVICE_ID(_uuid) \
  371. { \
  372. BT_SDP_ATTR_SERVICE_ID, \
  373. { BT_SDP_TYPE_SIZE(BT_SDP_UUID16), &((struct bt_uuid_16) _uuid) } \
  374. }
  375. /** @def BT_SDP_SERVICE_NAME
  376. * @brief SDP Name Attribute Declaration Macro.
  377. *
  378. * Helper macro to declare a service name attribute.
  379. *
  380. * @param _name Service name as a string (up to 256 chars).
  381. */
  382. #define BT_SDP_SERVICE_NAME(_name) \
  383. { \
  384. BT_SDP_ATTR_SVCNAME_PRIMARY, \
  385. { BT_SDP_TYPE_SIZE_VAR(BT_SDP_TEXT_STR8, (sizeof(_name)-1)), _name } \
  386. }
  387. /** @def BT_SDP_SUPPORTED_FEATURES
  388. * @brief SDP Supported Features Attribute Declaration Macro.
  389. *
  390. * Helper macro to declare supported features of a profile/protocol.
  391. *
  392. * @param _features Feature mask as 16bit unsigned integer.
  393. */
  394. #define BT_SDP_SUPPORTED_FEATURES(_features) \
  395. { \
  396. BT_SDP_ATTR_SUPPORTED_FEATURES, \
  397. { BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_16(_features) } \
  398. }
  399. /** @def BT_SDP_RECORD
  400. * @brief SDP Service Declaration Macro.
  401. *
  402. * Helper macro to declare a service.
  403. *
  404. * @param _attrs List of attributes for the service record.
  405. */
  406. #define BT_SDP_RECORD(_attrs) \
  407. { \
  408. .attrs = _attrs, \
  409. .attr_count = ARRAY_SIZE((_attrs)), \
  410. }
  411. /* Server API */
  412. /** @brief Register a Service Record.
  413. *
  414. * Register a Service Record. Applications can make use of
  415. * macros such as BT_SDP_DECLARE_SERVICE, BT_SDP_LIST,
  416. * BT_SDP_SERVICE_ID, BT_SDP_SERVICE_NAME, etc.
  417. * A service declaration must start with BT_SDP_NEW_SERVICE.
  418. *
  419. * @param service Service record declared using BT_SDP_DECLARE_SERVICE.
  420. *
  421. * @return 0 in case of success or negative value in case of error.
  422. */
  423. int bt_sdp_register_service(struct bt_sdp_record *service);
  424. /* Client API */
  425. /** @brief Generic SDP Client Query Result data holder */
  426. struct bt_sdp_client_result {
  427. /* buffer containing unparsed SDP record result for given UUID */
  428. struct net_buf *resp_buf;
  429. /* flag pointing that there are more result chunks for given UUID */
  430. bool next_record_hint;
  431. /* Reference to UUID object on behalf one discovery was started */
  432. const struct bt_uuid *uuid;
  433. };
  434. /** @brief Helper enum to be used as return value of bt_sdp_discover_func_t.
  435. * The value informs the caller to perform further pending actions or stop them.
  436. */
  437. enum {
  438. BT_SDP_DISCOVER_UUID_STOP = 0,
  439. BT_SDP_DISCOVER_UUID_CONTINUE,
  440. };
  441. /** @typedef bt_sdp_discover_func_t
  442. *
  443. * @brief Callback type reporting to user that there is a resolved result
  444. * on remote for given UUID and the result record buffer can be used by user
  445. * for further inspection.
  446. *
  447. * A function of this type is given by the user to the bt_sdp_discover_params
  448. * object. It'll be called on each valid record discovery completion for given
  449. * UUID. When UUID resolution gives back no records then NULL is passed
  450. * to the user. Otherwise user can get valid record(s) and then the internal
  451. * hint 'next record' is set to false saying the UUID resolution is complete or
  452. * the hint can be set by caller to true meaning that next record is available
  453. * for given UUID.
  454. * The returned function value allows the user to control retrieving follow-up
  455. * resolved records if any. If the user doesn't want to read more resolved
  456. * records for given UUID since current record data fulfills its requirements
  457. * then should return BT_SDP_DISCOVER_UUID_STOP. Otherwise returned value means
  458. * more subcall iterations are allowable.
  459. *
  460. * @param conn Connection object identifying connection to queried remote.
  461. * @param result Object pointing to logical unparsed SDP record collected on
  462. * base of response driven by given UUID.
  463. *
  464. * @return BT_SDP_DISCOVER_UUID_STOP in case of no more need to read next
  465. * record data and continue discovery for given UUID. By returning
  466. * BT_SDP_DISCOVER_UUID_CONTINUE user allows this discovery continuation.
  467. */
  468. typedef uint8_t (*bt_sdp_discover_func_t)
  469. (struct bt_conn *conn, struct bt_sdp_client_result *result);
  470. /** @brief Main user structure used in SDP discovery of remote. */
  471. struct bt_sdp_discover_params {
  472. sys_snode_t _node;
  473. /** UUID (service) to be discovered on remote SDP entity */
  474. const struct bt_uuid *uuid;
  475. /** Discover callback to be called on resolved SDP record */
  476. bt_sdp_discover_func_t func;
  477. /** Memory buffer enabled by user for SDP query results */
  478. struct net_buf_pool *pool;
  479. };
  480. /** @brief Allows user to start SDP discovery session.
  481. *
  482. * The function performs SDP service discovery on remote server driven by user
  483. * delivered discovery parameters. Discovery session is made as soon as
  484. * no SDP transaction is ongoing between peers and if any then this one
  485. * is queued to be processed at discovery completion of previous one.
  486. * On the service discovery completion the callback function will be
  487. * called to get feedback to user about findings.
  488. *
  489. * @param conn Object identifying connection to remote.
  490. * @param params SDP discovery parameters.
  491. *
  492. * @return 0 in case of success or negative value in case of error.
  493. */
  494. int bt_sdp_discover(struct bt_conn *conn,
  495. const struct bt_sdp_discover_params *params);
  496. /** @brief Release waiting SDP discovery request.
  497. *
  498. * It can cancel valid waiting SDP client request identified by SDP discovery
  499. * parameters object.
  500. *
  501. * @param conn Object identifying connection to remote.
  502. * @param params SDP discovery parameters.
  503. *
  504. * @return 0 in case of success or negative value in case of error.
  505. */
  506. int bt_sdp_discover_cancel(struct bt_conn *conn,
  507. const struct bt_sdp_discover_params *params);
  508. /* Helper types & functions for SDP client to get essential data from server */
  509. /** @brief Protocols to be asked about specific parameters */
  510. enum bt_sdp_proto {
  511. BT_SDP_PROTO_RFCOMM = 0x0003,
  512. BT_SDP_PROTO_L2CAP = 0x0100,
  513. };
  514. /** @brief Give to user parameter value related to given stacked protocol UUID.
  515. *
  516. * API extracts specific parameter associated with given protocol UUID
  517. * available in Protocol Descriptor List attribute.
  518. *
  519. * @param buf Original buffered raw record data.
  520. * @param proto Known protocol to be checked like RFCOMM or L2CAP.
  521. * @param param On success populated by found parameter value.
  522. *
  523. * @return 0 on success when specific parameter associated with given protocol
  524. * value is found, or negative if error occurred during processing.
  525. */
  526. int bt_sdp_get_proto_param(const struct net_buf *buf, enum bt_sdp_proto proto,
  527. uint16_t *param);
  528. /** @brief Get additional parameter value related to given stacked protocol UUID.
  529. *
  530. * API extracts specific parameter associated with given protocol UUID
  531. * available in Additional Protocol Descriptor List attribute.
  532. *
  533. * @param buf Original buffered raw record data.
  534. * @param proto Known protocol to be checked like RFCOMM or L2CAP.
  535. * @param param_index There may be more than one parameter realted to the
  536. * given protocol UUID. This function returns the result that is
  537. * indexed by this parameter. It's value is from 0, 0 means the
  538. * first matched result, 1 means the second matched result.
  539. * @param[out] param On success populated by found parameter value.
  540. *
  541. * @return 0 on success when a specific parameter associated with a given protocol
  542. * value is found, or negative if error occurred during processing.
  543. */
  544. int bt_sdp_get_addl_proto_param(const struct net_buf *buf, enum bt_sdp_proto proto,
  545. uint8_t param_index, uint16_t *param);
  546. /** @brief Get profile version.
  547. *
  548. * Helper API extracting remote profile version number. To get it proper
  549. * generic profile parameter needs to be selected usually listed in SDP
  550. * Interoperability Requirements section for given profile specification.
  551. *
  552. * @param buf Original buffered raw record data.
  553. * @param profile Profile family identifier the profile belongs.
  554. * @param version On success populated by found version number.
  555. *
  556. * @return 0 on success, negative value if error occurred during processing.
  557. */
  558. int bt_sdp_get_profile_version(const struct net_buf *buf, uint16_t profile,
  559. uint16_t *version);
  560. /** @brief Get SupportedFeatures attribute value
  561. *
  562. * Allows if exposed by remote retrieve SupportedFeature attribute.
  563. *
  564. * @param buf Buffer holding original raw record data from remote.
  565. * @param features On success object to be populated with SupportedFeature
  566. * mask.
  567. *
  568. * @return 0 on success if feature found and valid, negative in case any error
  569. */
  570. int bt_sdp_get_features(const struct net_buf *buf, uint16_t *features);
  571. #ifdef __cplusplus
  572. }
  573. #endif
  574. /**
  575. * @}
  576. */
  577. #endif /* ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_ */