1 /** @file
2  * @brief Audio/Video Distribution Transport Protocol header.
3  */
4 
5 /*
6  * Copyright (c) 2015-2016 Intel Corporation
7  * Copyright 2024 NXP
8  *
9  * SPDX-License-Identifier: Apache-2.0
10  */
11 #ifndef ZEPHYR_INCLUDE_BLUETOOTH_AVDTP_H_
12 #define ZEPHYR_INCLUDE_BLUETOOTH_AVDTP_H_
13 
14 #ifdef __cplusplus
15 extern "C" {
16 #endif
17 
18 /**
19  * @brief AVDTP error code
20  */
21 enum bt_avdtp_err_code {
22 	/** The response is success, it is not from avdtp spec. */
23 	BT_AVDTP_SUCCESS = 0x00,
24 	/** The request is time out without response, it is not from avdtp spec. */
25 	BT_AVDTP_TIME_OUT = 0xFF,
26 	/** The request packet header format error */
27 	BT_AVDTP_BAD_HEADER_FORMAT = 0x01,
28 	/** The request packet length is not match the assumed length */
29 	BT_AVDTP_BAD_LENGTH = 0x11,
30 	/** The requested command indicates an invalid ACP SEID (not addressable) */
31 	BT_AVDTP_BAD_ACP_SEID = 0x12,
32 	/** The SEP is in use */
33 	BT_AVDTP_SEP_IN_USE = 0x13,
34 	/** The SEP is not in use */
35 	BT_AVDTP_SEP_NOT_IN_USE = 0x14,
36 	/** The value of Service Category in the request packet is not defined in AVDTP */
37 	BT_AVDTP_BAD_SERV_CATEGORY = 0x17,
38 	/** The requested command has an incorrect payload format */
39 	BT_AVDTP_BAD_PAYLOAD_FORMAT = 0x18,
40 	/** The requested command is not supported by the device */
41 	BT_AVDTP_NOT_SUPPORTED_COMMAND = 0x19,
42 	/** The reconfigure command is an attempt to reconfigure a transport service codec_cap
43 	 * of the SEP. Reconfigure is only permitted for application service codec_cap
44 	 */
45 	BT_AVDTP_INVALID_CAPABILITIES = 0x1A,
46 	/** The requested Recovery Type is not defined in AVDTP */
47 	BT_AVDTP_BAD_RECOVERY_TYPE = 0x22,
48 	/** The format of Media Transport Capability is not correct */
49 	BT_AVDTP_BAD_MEDIA_TRANSPORT_FORMAT = 0x23,
50 	/** The format of Recovery Service Capability is not correct */
51 	BT_AVDTP_BAD_RECOVERY_FORMAT = 0x25,
52 	/** The format of Header Compression Service Capability is not correct */
53 	BT_AVDTP_BAD_ROHC_FORMAT = 0x26,
54 	/** The format of Content Protection Service Capability is not correct */
55 	BT_AVDTP_BAD_CP_FORMAT = 0x27,
56 	/** The format of Multiplexing Service Capability is not correct */
57 	BT_AVDTP_BAD_MULTIPLEXING_FORMAT = 0x28,
58 	/** Configuration not supported */
59 	BT_AVDTP_UNSUPPORTED_CONFIGURAION = 0x29,
60 	/** Indicates that the ACP state machine is in an invalid state in order to process the
61 	 * signal. This also includes the situation when an INT receives a request for the
62 	 * same command that it is currently expecting a response
63 	 */
64 	BT_AVDTP_BAD_STATE = 0x31,
65 };
66 
67 /** @brief Stream End Point Type */
68 enum bt_avdtp_sep_type {
69 	/** Source Role */
70 	BT_AVDTP_SOURCE = 0,
71 	/** Sink Role */
72 	BT_AVDTP_SINK = 1
73 };
74 
75 /** @brief Stream End Point Media Type */
76 enum bt_avdtp_media_type {
77 	/** Audio Media Type */
78 	BT_AVDTP_AUDIO = 0x00,
79 	/** Video Media Type */
80 	BT_AVDTP_VIDEO = 0x01,
81 	/** Multimedia Media Type */
82 	BT_AVDTP_MULTIMEDIA = 0x02
83 };
84 
85 /** @brief AVDTP stream endpoint information.
86  *  Don't need to care endianness because it is not used for data parsing.
87  */
88 struct bt_avdtp_sep_info {
89 	/** End Point usage status */
90 	uint8_t inuse: 1;
91 	/** Stream End Point ID that is the identifier of the stream endpoint */
92 	uint8_t id: 6;
93 	/** Reserved */
94 	uint8_t reserved: 1;
95 	/** Stream End-point Type that indicates if the stream end-point is SNK or SRC */
96 	enum bt_avdtp_sep_type tsep;
97 	/** Media-type of the End Point
98 	 * Only @ref BT_AVDTP_AUDIO is supported now.
99 	 */
100 	enum bt_avdtp_media_type media_type;
101 };
102 
103 /** @brief service category Type */
104 enum bt_avdtp_service_category {
105 	/** Media Transport */
106 	BT_AVDTP_SERVICE_MEDIA_TRANSPORT = 0x01,
107 	/** Reporting */
108 	BT_AVDTP_SERVICE_REPORTING = 0x02,
109 	/** Recovery */
110 	BT_AVDTP_SERVICE_MEDIA_RECOVERY = 0x03,
111 	/** Content Protection */
112 	BT_AVDTP_SERVICE_CONTENT_PROTECTION = 0x04,
113 	/** Header Compression */
114 	BT_AVDTP_SERVICE_HEADER_COMPRESSION = 0x05,
115 	/** Multiplexing */
116 	BT_AVDTP_SERVICE_MULTIPLEXING = 0x06,
117 	/** Media Codec */
118 	BT_AVDTP_SERVICE_MEDIA_CODEC = 0x07,
119 	/** Delay Reporting */
120 	BT_AVDTP_SERVICE_DELAY_REPORTING = 0x08,
121 };
122 
123 /** @brief AVDTP Stream End Point */
124 struct bt_avdtp_sep {
125 	/** Stream End Point information */
126 	struct bt_avdtp_sep_info sep_info;
127 	/** Media Transport Channel*/
128 	struct bt_l2cap_br_chan chan;
129 	/** the endpoint media data */
130 	void (*media_data_cb)(struct bt_avdtp_sep *sep, struct net_buf *buf);
131 	/* semaphore for lock/unlock */
132 	struct k_sem sem_lock;
133 	/** avdtp session */
134 	struct bt_avdtp *session;
135 	/** SEP state */
136 	uint8_t state;
137 	/* Internally used list node */
138 	sys_snode_t _node;
139 };
140 
141 #ifdef __cplusplus
142 }
143 #endif
144 
145 #endif /* ZEPHYR_INCLUDE_BLUETOOTH_AVDTP_H_ */
146