633 lines
23 KiB
C
633 lines
23 KiB
C
/** @file
|
|
* @brief Service Discovery Protocol handling.
|
|
*/
|
|
|
|
/*
|
|
* Copyright (c) 2016 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#ifndef ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_
|
|
#define ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_
|
|
|
|
/**
|
|
* @brief Service Discovery Protocol (SDP)
|
|
* @defgroup bt_sdp Service Discovery Protocol (SDP)
|
|
* @ingroup bluetooth
|
|
* @{
|
|
*/
|
|
|
|
#include <bluetooth/uuid.h>
|
|
#include <bluetooth/conn.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
* All definitions are based on Bluetooth Assigned Numbers
|
|
* of the Bluetooth Specification
|
|
*/
|
|
|
|
/*
|
|
* Service class identifiers of standard services and service groups
|
|
*/
|
|
#define BT_SDP_SDP_SERVER_SVCLASS 0x1000
|
|
#define BT_SDP_BROWSE_GRP_DESC_SVCLASS 0x1001
|
|
#define BT_SDP_PUBLIC_BROWSE_GROUP 0x1002
|
|
#define BT_SDP_SERIAL_PORT_SVCLASS 0x1101
|
|
#define BT_SDP_LAN_ACCESS_SVCLASS 0x1102
|
|
#define BT_SDP_DIALUP_NET_SVCLASS 0x1103
|
|
#define BT_SDP_IRMC_SYNC_SVCLASS 0x1104
|
|
#define BT_SDP_OBEX_OBJPUSH_SVCLASS 0x1105
|
|
#define BT_SDP_OBEX_FILETRANS_SVCLASS 0x1106
|
|
#define BT_SDP_IRMC_SYNC_CMD_SVCLASS 0x1107
|
|
#define BT_SDP_HEADSET_SVCLASS 0x1108
|
|
#define BT_SDP_CORDLESS_TELEPHONY_SVCLASS 0x1109
|
|
#define BT_SDP_AUDIO_SOURCE_SVCLASS 0x110a
|
|
#define BT_SDP_AUDIO_SINK_SVCLASS 0x110b
|
|
#define BT_SDP_AV_REMOTE_TARGET_SVCLASS 0x110c
|
|
#define BT_SDP_ADVANCED_AUDIO_SVCLASS 0x110d
|
|
#define BT_SDP_AV_REMOTE_SVCLASS 0x110e
|
|
#define BT_SDP_AV_REMOTE_CONTROLLER_SVCLASS 0x110f
|
|
#define BT_SDP_INTERCOM_SVCLASS 0x1110
|
|
#define BT_SDP_FAX_SVCLASS 0x1111
|
|
#define BT_SDP_HEADSET_AGW_SVCLASS 0x1112
|
|
#define BT_SDP_WAP_SVCLASS 0x1113
|
|
#define BT_SDP_WAP_CLIENT_SVCLASS 0x1114
|
|
#define BT_SDP_PANU_SVCLASS 0x1115
|
|
#define BT_SDP_NAP_SVCLASS 0x1116
|
|
#define BT_SDP_GN_SVCLASS 0x1117
|
|
#define BT_SDP_DIRECT_PRINTING_SVCLASS 0x1118
|
|
#define BT_SDP_REFERENCE_PRINTING_SVCLASS 0x1119
|
|
#define BT_SDP_IMAGING_SVCLASS 0x111a
|
|
#define BT_SDP_IMAGING_RESPONDER_SVCLASS 0x111b
|
|
#define BT_SDP_IMAGING_ARCHIVE_SVCLASS 0x111c
|
|
#define BT_SDP_IMAGING_REFOBJS_SVCLASS 0x111d
|
|
#define BT_SDP_HANDSFREE_SVCLASS 0x111e
|
|
#define BT_SDP_HANDSFREE_AGW_SVCLASS 0x111f
|
|
#define BT_SDP_DIRECT_PRT_REFOBJS_SVCLASS 0x1120
|
|
#define BT_SDP_REFLECTED_UI_SVCLASS 0x1121
|
|
#define BT_SDP_BASIC_PRINTING_SVCLASS 0x1122
|
|
#define BT_SDP_PRINTING_STATUS_SVCLASS 0x1123
|
|
#define BT_SDP_HID_SVCLASS 0x1124
|
|
#define BT_SDP_HCR_SVCLASS 0x1125
|
|
#define BT_SDP_HCR_PRINT_SVCLASS 0x1126
|
|
#define BT_SDP_HCR_SCAN_SVCLASS 0x1127
|
|
#define BT_SDP_CIP_SVCLASS 0x1128
|
|
#define BT_SDP_VIDEO_CONF_GW_SVCLASS 0x1129
|
|
#define BT_SDP_UDI_MT_SVCLASS 0x112a
|
|
#define BT_SDP_UDI_TA_SVCLASS 0x112b
|
|
#define BT_SDP_AV_SVCLASS 0x112c
|
|
#define BT_SDP_SAP_SVCLASS 0x112d
|
|
#define BT_SDP_PBAP_PCE_SVCLASS 0x112e
|
|
#define BT_SDP_PBAP_PSE_SVCLASS 0x112f
|
|
#define BT_SDP_PBAP_SVCLASS 0x1130
|
|
#define BT_SDP_MAP_MSE_SVCLASS 0x1132
|
|
#define BT_SDP_MAP_MCE_SVCLASS 0x1133
|
|
#define BT_SDP_MAP_SVCLASS 0x1134
|
|
#define BT_SDP_GNSS_SVCLASS 0x1135
|
|
#define BT_SDP_GNSS_SERVER_SVCLASS 0x1136
|
|
#define BT_SDP_MPS_SC_SVCLASS 0x113a
|
|
#define BT_SDP_MPS_SVCLASS 0x113b
|
|
#define BT_SDP_PNP_INFO_SVCLASS 0x1200
|
|
#define BT_SDP_GENERIC_NETWORKING_SVCLASS 0x1201
|
|
#define BT_SDP_GENERIC_FILETRANS_SVCLASS 0x1202
|
|
#define BT_SDP_GENERIC_AUDIO_SVCLASS 0x1203
|
|
#define BT_SDP_GENERIC_TELEPHONY_SVCLASS 0x1204
|
|
#define BT_SDP_UPNP_SVCLASS 0x1205
|
|
#define BT_SDP_UPNP_IP_SVCLASS 0x1206
|
|
#define BT_SDP_UPNP_PAN_SVCLASS 0x1300
|
|
#define BT_SDP_UPNP_LAP_SVCLASS 0x1301
|
|
#define BT_SDP_UPNP_L2CAP_SVCLASS 0x1302
|
|
#define BT_SDP_VIDEO_SOURCE_SVCLASS 0x1303
|
|
#define BT_SDP_VIDEO_SINK_SVCLASS 0x1304
|
|
#define BT_SDP_VIDEO_DISTRIBUTION_SVCLASS 0x1305
|
|
#define BT_SDP_HDP_SVCLASS 0x1400
|
|
#define BT_SDP_HDP_SOURCE_SVCLASS 0x1401
|
|
#define BT_SDP_HDP_SINK_SVCLASS 0x1402
|
|
#define BT_SDP_GENERIC_ACCESS_SVCLASS 0x1800
|
|
#define BT_SDP_GENERIC_ATTRIB_SVCLASS 0x1801
|
|
#define BT_SDP_APPLE_AGENT_SVCLASS 0x2112
|
|
|
|
/*
|
|
* Attribute identifier codes
|
|
*/
|
|
#define BT_SDP_SERVER_RECORD_HANDLE 0x0000
|
|
|
|
/*
|
|
* Possible values for attribute-id are listed below.
|
|
* See SDP Spec, section "Service Attribute Definitions" for more details.
|
|
*/
|
|
#define BT_SDP_ATTR_RECORD_HANDLE 0x0000
|
|
#define BT_SDP_ATTR_SVCLASS_ID_LIST 0x0001
|
|
#define BT_SDP_ATTR_RECORD_STATE 0x0002
|
|
#define BT_SDP_ATTR_SERVICE_ID 0x0003
|
|
#define BT_SDP_ATTR_PROTO_DESC_LIST 0x0004
|
|
#define BT_SDP_ATTR_BROWSE_GRP_LIST 0x0005
|
|
#define BT_SDP_ATTR_LANG_BASE_ATTR_ID_LIST 0x0006
|
|
#define BT_SDP_ATTR_SVCINFO_TTL 0x0007
|
|
#define BT_SDP_ATTR_SERVICE_AVAILABILITY 0x0008
|
|
#define BT_SDP_ATTR_PROFILE_DESC_LIST 0x0009
|
|
#define BT_SDP_ATTR_DOC_URL 0x000a
|
|
#define BT_SDP_ATTR_CLNT_EXEC_URL 0x000b
|
|
#define BT_SDP_ATTR_ICON_URL 0x000c
|
|
#define BT_SDP_ATTR_ADD_PROTO_DESC_LIST 0x000d
|
|
|
|
#define BT_SDP_ATTR_GROUP_ID 0x0200
|
|
#define BT_SDP_ATTR_IP_SUBNET 0x0200
|
|
#define BT_SDP_ATTR_VERSION_NUM_LIST 0x0200
|
|
#define BT_SDP_ATTR_SUPPORTED_FEATURES_LIST 0x0200
|
|
#define BT_SDP_ATTR_GOEP_L2CAP_PSM 0x0200
|
|
#define BT_SDP_ATTR_SVCDB_STATE 0x0201
|
|
|
|
#define BT_SDP_ATTR_MPSD_SCENARIOS 0x0200
|
|
#define BT_SDP_ATTR_MPMD_SCENARIOS 0x0201
|
|
#define BT_SDP_ATTR_MPS_DEPENDENCIES 0x0202
|
|
|
|
#define BT_SDP_ATTR_SERVICE_VERSION 0x0300
|
|
#define BT_SDP_ATTR_EXTERNAL_NETWORK 0x0301
|
|
#define BT_SDP_ATTR_SUPPORTED_DATA_STORES_LIST 0x0301
|
|
#define BT_SDP_ATTR_DATA_EXCHANGE_SPEC 0x0301
|
|
#define BT_SDP_ATTR_NETWORK 0x0301
|
|
#define BT_SDP_ATTR_FAX_CLASS1_SUPPORT 0x0302
|
|
#define BT_SDP_ATTR_REMOTE_AUDIO_VOLUME_CONTROL 0x0302
|
|
#define BT_SDP_ATTR_MCAP_SUPPORTED_PROCEDURES 0x0302
|
|
#define BT_SDP_ATTR_FAX_CLASS20_SUPPORT 0x0303
|
|
#define BT_SDP_ATTR_SUPPORTED_FORMATS_LIST 0x0303
|
|
#define BT_SDP_ATTR_FAX_CLASS2_SUPPORT 0x0304
|
|
#define BT_SDP_ATTR_AUDIO_FEEDBACK_SUPPORT 0x0305
|
|
#define BT_SDP_ATTR_NETWORK_ADDRESS 0x0306
|
|
#define BT_SDP_ATTR_WAP_GATEWAY 0x0307
|
|
#define BT_SDP_ATTR_HOMEPAGE_URL 0x0308
|
|
#define BT_SDP_ATTR_WAP_STACK_TYPE 0x0309
|
|
#define BT_SDP_ATTR_SECURITY_DESC 0x030a
|
|
#define BT_SDP_ATTR_NET_ACCESS_TYPE 0x030b
|
|
#define BT_SDP_ATTR_MAX_NET_ACCESSRATE 0x030c
|
|
#define BT_SDP_ATTR_IP4_SUBNET 0x030d
|
|
#define BT_SDP_ATTR_IP6_SUBNET 0x030e
|
|
#define BT_SDP_ATTR_SUPPORTED_CAPABILITIES 0x0310
|
|
#define BT_SDP_ATTR_SUPPORTED_FEATURES 0x0311
|
|
#define BT_SDP_ATTR_SUPPORTED_FUNCTIONS 0x0312
|
|
#define BT_SDP_ATTR_TOTAL_IMAGING_DATA_CAPACITY 0x0313
|
|
#define BT_SDP_ATTR_SUPPORTED_REPOSITORIES 0x0314
|
|
#define BT_SDP_ATTR_MAS_INSTANCE_ID 0x0315
|
|
#define BT_SDP_ATTR_SUPPORTED_MESSAGE_TYPES 0x0316
|
|
#define BT_SDP_ATTR_PBAP_SUPPORTED_FEATURES 0x0317
|
|
#define BT_SDP_ATTR_MAP_SUPPORTED_FEATURES 0x0317
|
|
|
|
#define BT_SDP_ATTR_SPECIFICATION_ID 0x0200
|
|
#define BT_SDP_ATTR_VENDOR_ID 0x0201
|
|
#define BT_SDP_ATTR_PRODUCT_ID 0x0202
|
|
#define BT_SDP_ATTR_VERSION 0x0203
|
|
#define BT_SDP_ATTR_PRIMARY_RECORD 0x0204
|
|
#define BT_SDP_ATTR_VENDOR_ID_SOURCE 0x0205
|
|
|
|
#define BT_SDP_ATTR_HID_DEVICE_RELEASE_NUMBER 0x0200
|
|
#define BT_SDP_ATTR_HID_PARSER_VERSION 0x0201
|
|
#define BT_SDP_ATTR_HID_DEVICE_SUBCLASS 0x0202
|
|
#define BT_SDP_ATTR_HID_COUNTRY_CODE 0x0203
|
|
#define BT_SDP_ATTR_HID_VIRTUAL_CABLE 0x0204
|
|
#define BT_SDP_ATTR_HID_RECONNECT_INITIATE 0x0205
|
|
#define BT_SDP_ATTR_HID_DESCRIPTOR_LIST 0x0206
|
|
#define BT_SDP_ATTR_HID_LANG_ID_BASE_LIST 0x0207
|
|
#define BT_SDP_ATTR_HID_SDP_DISABLE 0x0208
|
|
#define BT_SDP_ATTR_HID_BATTERY_POWER 0x0209
|
|
#define BT_SDP_ATTR_HID_REMOTE_WAKEUP 0x020a
|
|
#define BT_SDP_ATTR_HID_PROFILE_VERSION 0x020b
|
|
#define BT_SDP_ATTR_HID_SUPERVISION_TIMEOUT 0x020c
|
|
#define BT_SDP_ATTR_HID_NORMALLY_CONNECTABLE 0x020d
|
|
#define BT_SDP_ATTR_HID_BOOT_DEVICE 0x020e
|
|
|
|
/*
|
|
* These identifiers are based on the SDP spec stating that
|
|
* "base attribute id of the primary (universal) language must be 0x0100"
|
|
*
|
|
* Other languages should have their own offset; e.g.:
|
|
* #define XXXLangBase yyyy
|
|
* #define AttrServiceName_XXX 0x0000+XXXLangBase
|
|
*/
|
|
#define BT_SDP_PRIMARY_LANG_BASE 0x0100
|
|
|
|
#define BT_SDP_ATTR_SVCNAME_PRIMARY (0x0000 + BT_SDP_PRIMARY_LANG_BASE)
|
|
#define BT_SDP_ATTR_SVCDESC_PRIMARY (0x0001 + BT_SDP_PRIMARY_LANG_BASE)
|
|
#define BT_SDP_ATTR_PROVNAME_PRIMARY (0x0002 + BT_SDP_PRIMARY_LANG_BASE)
|
|
|
|
/*
|
|
* The Data representation in SDP PDUs (pps 339, 340 of BT SDP Spec)
|
|
* These are the exact data type+size descriptor values
|
|
* that go into the PDU buffer.
|
|
*
|
|
* The datatype (leading 5bits) + size descriptor (last 3 bits)
|
|
* is 8 bits. The size descriptor is critical to extract the
|
|
* right number of bytes for the data value from the PDU.
|
|
*
|
|
* For most basic types, the datatype+size descriptor is
|
|
* straightforward. However for constructed types and strings,
|
|
* the size of the data is in the next "n" bytes following the
|
|
* 8 bits (datatype+size) descriptor. Exactly what the "n" is
|
|
* specified in the 3 bits of the data size descriptor.
|
|
*
|
|
* TextString and URLString can be of size 2^{8, 16, 32} bytes
|
|
* DataSequence and DataSequenceAlternates can be of size 2^{8, 16, 32}
|
|
* The size are computed post-facto in the API and are not known apriori
|
|
*/
|
|
#define BT_SDP_DATA_NIL 0x00
|
|
#define BT_SDP_UINT8 0x08
|
|
#define BT_SDP_UINT16 0x09
|
|
#define BT_SDP_UINT32 0x0a
|
|
#define BT_SDP_UINT64 0x0b
|
|
#define BT_SDP_UINT128 0x0c
|
|
#define BT_SDP_INT8 0x10
|
|
#define BT_SDP_INT16 0x11
|
|
#define BT_SDP_INT32 0x12
|
|
#define BT_SDP_INT64 0x13
|
|
#define BT_SDP_INT128 0x14
|
|
#define BT_SDP_UUID_UNSPEC 0x18
|
|
#define BT_SDP_UUID16 0x19
|
|
#define BT_SDP_UUID32 0x1a
|
|
#define BT_SDP_UUID128 0x1c
|
|
#define BT_SDP_TEXT_STR_UNSPEC 0x20
|
|
#define BT_SDP_TEXT_STR8 0x25
|
|
#define BT_SDP_TEXT_STR16 0x26
|
|
#define BT_SDP_TEXT_STR32 0x27
|
|
#define BT_SDP_BOOL 0x28
|
|
#define BT_SDP_SEQ_UNSPEC 0x30
|
|
#define BT_SDP_SEQ8 0x35
|
|
#define BT_SDP_SEQ16 0x36
|
|
#define BT_SDP_SEQ32 0x37
|
|
#define BT_SDP_ALT_UNSPEC 0x38
|
|
#define BT_SDP_ALT8 0x3d
|
|
#define BT_SDP_ALT16 0x3e
|
|
#define BT_SDP_ALT32 0x3f
|
|
#define BT_SDP_URL_STR_UNSPEC 0x40
|
|
#define BT_SDP_URL_STR8 0x45
|
|
#define BT_SDP_URL_STR16 0x46
|
|
#define BT_SDP_URL_STR32 0x47
|
|
|
|
#define BT_SDP_TYPE_DESC_MASK 0xf8
|
|
#define BT_SDP_SIZE_DESC_MASK 0x07
|
|
#define BT_SDP_SIZE_INDEX_OFFSET 5
|
|
|
|
/** @brief SDP Generic Data Element Value. */
|
|
struct bt_sdp_data_elem {
|
|
uint8_t type;
|
|
uint32_t data_size;
|
|
uint32_t total_size;
|
|
const void *data;
|
|
};
|
|
|
|
/** @brief SDP Attribute Value. */
|
|
struct bt_sdp_attribute {
|
|
uint16_t id; /* Attribute ID */
|
|
struct bt_sdp_data_elem val; /* Attribute data */
|
|
};
|
|
|
|
/** @brief SDP Service Record Value. */
|
|
struct bt_sdp_record {
|
|
uint32_t handle; /* Redundant, for quick ref */
|
|
struct bt_sdp_attribute *attrs; /* Base addr of attr array */
|
|
size_t attr_count; /* Number of attributes */
|
|
uint8_t index; /* Index of the record in LL */
|
|
struct bt_sdp_record *next;
|
|
};
|
|
|
|
/*
|
|
* --------------------------------------------------- ------------------
|
|
* | Service Hdl | Attr list ptr | Attr count | Next | -> | Service Hdl | ...
|
|
* --------------------------------------------------- ------------------
|
|
*/
|
|
|
|
/** @def BT_SDP_ARRAY_8
|
|
* @brief Declare an array of 8-bit elements in an attribute.
|
|
*/
|
|
#define BT_SDP_ARRAY_8(...) ((uint8_t[]) {__VA_ARGS__})
|
|
|
|
/** @def BT_SDP_ARRAY_16
|
|
* @brief Declare an array of 16-bit elements in an attribute.
|
|
*/
|
|
#define BT_SDP_ARRAY_16(...) ((uint16_t[]) {__VA_ARGS__})
|
|
|
|
/** @def BT_SDP_ARRAY_32
|
|
* @brief Declare an array of 32-bit elements in an attribute.
|
|
*/
|
|
#define BT_SDP_ARRAY_32(...) ((uint32_t[]) {__VA_ARGS__})
|
|
|
|
/** @def BT_SDP_TYPE_SIZE
|
|
* @brief Declare a fixed-size data element header.
|
|
*
|
|
* @param _type Data element header containing type and size descriptors.
|
|
*/
|
|
#define BT_SDP_TYPE_SIZE(_type) .type = _type, \
|
|
.data_size = BIT(_type & BT_SDP_SIZE_DESC_MASK), \
|
|
.total_size = BIT(_type & BT_SDP_SIZE_DESC_MASK) + 1
|
|
|
|
/** @def BT_SDP_TYPE_SIZE_VAR
|
|
* @brief Declare a variable-size data element header.
|
|
*
|
|
* @param _type Data element header containing type and size descriptors.
|
|
* @param _size The actual size of the data.
|
|
*/
|
|
#define BT_SDP_TYPE_SIZE_VAR(_type, _size) .type = _type, \
|
|
.data_size = _size, \
|
|
.total_size = BIT((_type & BT_SDP_SIZE_DESC_MASK) - \
|
|
BT_SDP_SIZE_INDEX_OFFSET) + _size + 1
|
|
|
|
/** @def BT_SDP_DATA_ELEM_LIST
|
|
* @brief Declare a list of data elements.
|
|
*/
|
|
#define BT_SDP_DATA_ELEM_LIST(...) ((struct bt_sdp_data_elem[]) {__VA_ARGS__})
|
|
|
|
|
|
/** @def BT_SDP_NEW_SERVICE
|
|
* @brief SDP New Service Record Declaration Macro.
|
|
*
|
|
* Helper macro to declare a new service record.
|
|
* Default attributes: Record Handle, Record State,
|
|
* Language Base, Root Browse Group
|
|
*
|
|
*/
|
|
#define BT_SDP_NEW_SERVICE \
|
|
{ \
|
|
BT_SDP_ATTR_RECORD_HANDLE, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT32), BT_SDP_ARRAY_32(0) } \
|
|
}, \
|
|
{ \
|
|
BT_SDP_ATTR_RECORD_STATE, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT32), BT_SDP_ARRAY_32(0) } \
|
|
}, \
|
|
{ \
|
|
BT_SDP_ATTR_LANG_BASE_ATTR_ID_LIST, \
|
|
{ BT_SDP_TYPE_SIZE_VAR(BT_SDP_SEQ8, 9), \
|
|
BT_SDP_DATA_ELEM_LIST( \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_8('n', 'e') }, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_16(106) }, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT16), \
|
|
BT_SDP_ARRAY_16(BT_SDP_PRIMARY_LANG_BASE) } \
|
|
), \
|
|
} \
|
|
}, \
|
|
{ \
|
|
BT_SDP_ATTR_BROWSE_GRP_LIST, \
|
|
{ BT_SDP_TYPE_SIZE_VAR(BT_SDP_SEQ8, 3), \
|
|
BT_SDP_DATA_ELEM_LIST( \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UUID16), \
|
|
BT_SDP_ARRAY_16(BT_SDP_PUBLIC_BROWSE_GROUP) }, \
|
|
), \
|
|
} \
|
|
}
|
|
|
|
|
|
/** @def BT_SDP_LIST
|
|
* @brief Generic SDP List Attribute Declaration Macro.
|
|
*
|
|
* Helper macro to declare a list attribute.
|
|
*
|
|
* @param _att_id List Attribute ID.
|
|
* @param _data_elem_seq Data element sequence for the list.
|
|
* @param _type_size SDP type and size descriptor.
|
|
*/
|
|
#define BT_SDP_LIST(_att_id, _type_size, _data_elem_seq) \
|
|
{ \
|
|
_att_id, { _type_size, _data_elem_seq } \
|
|
}
|
|
|
|
/** @def BT_SDP_SERVICE_ID
|
|
* @brief SDP Service ID Attribute Declaration Macro.
|
|
*
|
|
* Helper macro to declare a service ID attribute.
|
|
*
|
|
* @param _uuid Service ID 16bit UUID.
|
|
*/
|
|
#define BT_SDP_SERVICE_ID(_uuid) \
|
|
{ \
|
|
BT_SDP_ATTR_SERVICE_ID, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UUID16), &((struct bt_uuid_16) _uuid) } \
|
|
}
|
|
|
|
/** @def BT_SDP_SERVICE_NAME
|
|
* @brief SDP Name Attribute Declaration Macro.
|
|
*
|
|
* Helper macro to declare a service name attribute.
|
|
*
|
|
* @param _name Service name as a string (up to 256 chars).
|
|
*/
|
|
#define BT_SDP_SERVICE_NAME(_name) \
|
|
{ \
|
|
BT_SDP_ATTR_SVCNAME_PRIMARY, \
|
|
{ BT_SDP_TYPE_SIZE_VAR(BT_SDP_TEXT_STR8, (sizeof(_name)-1)), _name } \
|
|
}
|
|
|
|
/** @def BT_SDP_SUPPORTED_FEATURES
|
|
* @brief SDP Supported Features Attribute Declaration Macro.
|
|
*
|
|
* Helper macro to declare supported features of a profile/protocol.
|
|
*
|
|
* @param _features Feature mask as 16bit unsigned integer.
|
|
*/
|
|
#define BT_SDP_SUPPORTED_FEATURES(_features) \
|
|
{ \
|
|
BT_SDP_ATTR_SUPPORTED_FEATURES, \
|
|
{ BT_SDP_TYPE_SIZE(BT_SDP_UINT16), BT_SDP_ARRAY_16(_features) } \
|
|
}
|
|
|
|
/** @def BT_SDP_RECORD
|
|
* @brief SDP Service Declaration Macro.
|
|
*
|
|
* Helper macro to declare a service.
|
|
*
|
|
* @param _attrs List of attributes for the service record.
|
|
*/
|
|
#define BT_SDP_RECORD(_attrs) \
|
|
{ \
|
|
.attrs = _attrs, \
|
|
.attr_count = ARRAY_SIZE((_attrs)), \
|
|
}
|
|
|
|
/* Server API */
|
|
|
|
/** @brief Register a Service Record.
|
|
*
|
|
* Register a Service Record. Applications can make use of
|
|
* macros such as BT_SDP_DECLARE_SERVICE, BT_SDP_LIST,
|
|
* BT_SDP_SERVICE_ID, BT_SDP_SERVICE_NAME, etc.
|
|
* A service declaration must start with BT_SDP_NEW_SERVICE.
|
|
*
|
|
* @param service Service record declared using BT_SDP_DECLARE_SERVICE.
|
|
*
|
|
* @return 0 in case of success or negative value in case of error.
|
|
*/
|
|
int bt_sdp_register_service(struct bt_sdp_record *service);
|
|
|
|
/* Client API */
|
|
|
|
/** @brief Generic SDP Client Query Result data holder */
|
|
struct bt_sdp_client_result {
|
|
/* buffer containing unparsed SDP record result for given UUID */
|
|
struct net_buf *resp_buf;
|
|
/* flag pointing that there are more result chunks for given UUID */
|
|
bool next_record_hint;
|
|
/* Reference to UUID object on behalf one discovery was started */
|
|
const struct bt_uuid *uuid;
|
|
};
|
|
|
|
/** @brief Helper enum to be used as return value of bt_sdp_discover_func_t.
|
|
* The value informs the caller to perform further pending actions or stop them.
|
|
*/
|
|
enum {
|
|
BT_SDP_DISCOVER_UUID_STOP = 0,
|
|
BT_SDP_DISCOVER_UUID_CONTINUE,
|
|
};
|
|
|
|
/** @typedef bt_sdp_discover_func_t
|
|
*
|
|
* @brief Callback type reporting to user that there is a resolved result
|
|
* on remote for given UUID and the result record buffer can be used by user
|
|
* for further inspection.
|
|
*
|
|
* A function of this type is given by the user to the bt_sdp_discover_params
|
|
* object. It'll be called on each valid record discovery completion for given
|
|
* UUID. When UUID resolution gives back no records then NULL is passed
|
|
* to the user. Otherwise user can get valid record(s) and then the internal
|
|
* hint 'next record' is set to false saying the UUID resolution is complete or
|
|
* the hint can be set by caller to true meaning that next record is available
|
|
* for given UUID.
|
|
* The returned function value allows the user to control retrieving follow-up
|
|
* resolved records if any. If the user doesn't want to read more resolved
|
|
* records for given UUID since current record data fulfills its requirements
|
|
* then should return BT_SDP_DISCOVER_UUID_STOP. Otherwise returned value means
|
|
* more subcall iterations are allowable.
|
|
*
|
|
* @param conn Connection object identifying connection to queried remote.
|
|
* @param result Object pointing to logical unparsed SDP record collected on
|
|
* base of response driven by given UUID.
|
|
*
|
|
* @return BT_SDP_DISCOVER_UUID_STOP in case of no more need to read next
|
|
* record data and continue discovery for given UUID. By returning
|
|
* BT_SDP_DISCOVER_UUID_CONTINUE user allows this discovery continuation.
|
|
*/
|
|
typedef uint8_t (*bt_sdp_discover_func_t)
|
|
(struct bt_conn *conn, struct bt_sdp_client_result *result);
|
|
|
|
/** @brief Main user structure used in SDP discovery of remote. */
|
|
struct bt_sdp_discover_params {
|
|
sys_snode_t _node;
|
|
/** UUID (service) to be discovered on remote SDP entity */
|
|
const struct bt_uuid *uuid;
|
|
/** Discover callback to be called on resolved SDP record */
|
|
bt_sdp_discover_func_t func;
|
|
/** Memory buffer enabled by user for SDP query results */
|
|
struct net_buf_pool *pool;
|
|
};
|
|
|
|
/** @brief Allows user to start SDP discovery session.
|
|
*
|
|
* The function performs SDP service discovery on remote server driven by user
|
|
* delivered discovery parameters. Discovery session is made as soon as
|
|
* no SDP transaction is ongoing between peers and if any then this one
|
|
* is queued to be processed at discovery completion of previous one.
|
|
* On the service discovery completion the callback function will be
|
|
* called to get feedback to user about findings.
|
|
*
|
|
* @param conn Object identifying connection to remote.
|
|
* @param params SDP discovery parameters.
|
|
*
|
|
* @return 0 in case of success or negative value in case of error.
|
|
*/
|
|
|
|
int bt_sdp_discover(struct bt_conn *conn,
|
|
const struct bt_sdp_discover_params *params);
|
|
|
|
/** @brief Release waiting SDP discovery request.
|
|
*
|
|
* It can cancel valid waiting SDP client request identified by SDP discovery
|
|
* parameters object.
|
|
*
|
|
* @param conn Object identifying connection to remote.
|
|
* @param params SDP discovery parameters.
|
|
*
|
|
* @return 0 in case of success or negative value in case of error.
|
|
*/
|
|
int bt_sdp_discover_cancel(struct bt_conn *conn,
|
|
const struct bt_sdp_discover_params *params);
|
|
|
|
|
|
/* Helper types & functions for SDP client to get essential data from server */
|
|
|
|
/** @brief Protocols to be asked about specific parameters */
|
|
enum bt_sdp_proto {
|
|
BT_SDP_PROTO_RFCOMM = 0x0003,
|
|
BT_SDP_PROTO_L2CAP = 0x0100,
|
|
};
|
|
|
|
/** @brief Give to user parameter value related to given stacked protocol UUID.
|
|
*
|
|
* API extracts specific parameter associated with given protocol UUID
|
|
* available in Protocol Descriptor List attribute.
|
|
*
|
|
* @param buf Original buffered raw record data.
|
|
* @param proto Known protocol to be checked like RFCOMM or L2CAP.
|
|
* @param param On success populated by found parameter value.
|
|
*
|
|
* @return 0 on success when specific parameter associated with given protocol
|
|
* value is found, or negative if error occurred during processing.
|
|
*/
|
|
int bt_sdp_get_proto_param(const struct net_buf *buf, enum bt_sdp_proto proto,
|
|
uint16_t *param);
|
|
|
|
/** @brief Get additional parameter value related to given stacked protocol UUID.
|
|
*
|
|
* API extracts specific parameter associated with given protocol UUID
|
|
* available in Additional Protocol Descriptor List attribute.
|
|
*
|
|
* @param buf Original buffered raw record data.
|
|
* @param proto Known protocol to be checked like RFCOMM or L2CAP.
|
|
* @param param_index There may be more than one parameter realted to the
|
|
* given protocol UUID. This function returns the result that is
|
|
* indexed by this parameter. It's value is from 0, 0 means the
|
|
* first matched result, 1 means the second matched result.
|
|
* @param[out] param On success populated by found parameter value.
|
|
*
|
|
* @return 0 on success when a specific parameter associated with a given protocol
|
|
* value is found, or negative if error occurred during processing.
|
|
*/
|
|
int bt_sdp_get_addl_proto_param(const struct net_buf *buf, enum bt_sdp_proto proto,
|
|
uint8_t param_index, uint16_t *param);
|
|
|
|
/** @brief Get profile version.
|
|
*
|
|
* Helper API extracting remote profile version number. To get it proper
|
|
* generic profile parameter needs to be selected usually listed in SDP
|
|
* Interoperability Requirements section for given profile specification.
|
|
*
|
|
* @param buf Original buffered raw record data.
|
|
* @param profile Profile family identifier the profile belongs.
|
|
* @param version On success populated by found version number.
|
|
*
|
|
* @return 0 on success, negative value if error occurred during processing.
|
|
*/
|
|
int bt_sdp_get_profile_version(const struct net_buf *buf, uint16_t profile,
|
|
uint16_t *version);
|
|
|
|
/** @brief Get SupportedFeatures attribute value
|
|
*
|
|
* Allows if exposed by remote retrieve SupportedFeature attribute.
|
|
*
|
|
* @param buf Buffer holding original raw record data from remote.
|
|
* @param features On success object to be populated with SupportedFeature
|
|
* mask.
|
|
*
|
|
* @return 0 on success if feature found and valid, negative in case any error
|
|
*/
|
|
int bt_sdp_get_features(const struct net_buf *buf, uint16_t *features);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#endif /* ZEPHYR_INCLUDE_BLUETOOTH_SDP_H_ */
|