1 /*
2 * Copyright 2023 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17 #define LOG_TAG "bluetooth-a2dp"
18
19 #include <bluetooth/log.h>
20 #include <inttypes.h>
21 #include <string.h>
22
23 #include <string>
24
25 #include "a2dp_aac.h"
26 #include "a2dp_aac_encoder.h"
27 #include "common/time_util.h"
28 #include "internal_include/bt_target.h"
29 #include "mmc/codec_client/codec_client.h"
30 #include "mmc/proto/mmc_config.pb.h"
31 #include "os/rand.h"
32 #include "osi/include/allocator.h"
33 #include "stack/include/bt_hdr.h"
34
35 const int A2DP_AAC_HEADER_LEN = 9;
36 const int A2DP_AAC_MAX_LEN_REPR = 4;
37 const int A2DP_AAC_MAX_PREFIX_SIZE =
38 AVDT_MEDIA_HDR_SIZE + A2DP_AAC_HEADER_LEN + A2DP_AAC_MAX_LEN_REPR;
39
40 using namespace bluetooth;
41
42 class FFmpegInterface {
43 public:
44 // Updates the context and configures codec parameters.
45 //
46 // Returns:
47 // The (fixed) input pcm frame size that the encoder accepts.
48 // Otherwise a negative errno on error.
prepare_context(int sample_rate,int channel_count,int bit_rate,int bit_depth,int effective_frame_size)49 int prepare_context(int sample_rate, int channel_count, int bit_rate, int bit_depth,
50 int effective_frame_size) {
51 clear_context();
52 client = new mmc::CodecClient;
53
54 mmc::AacEncoderParam param;
55 param.set_sample_rate(sample_rate);
56 param.set_channel_count(channel_count);
57 param.set_bit_rate(bit_rate);
58 param.set_bit_depth(bit_depth);
59 param.set_effective_frame_size(effective_frame_size);
60
61 mmc::ConfigParam config;
62 *config.mutable_a2dp_aac_encoder_param() = param;
63
64 int rc = client->init(config);
65 if (rc < 0) {
66 log::error("Init failed with error message, {}", strerror(-rc));
67 }
68 return rc;
69 }
70
clear_context()71 void clear_context() {
72 if (client) {
73 client->cleanup();
74 delete client;
75 client = nullptr;
76 }
77 }
78
79 // Returns a negative errno if the encoded frame was not produced.
80 // Otherwise returns the length of the encoded frame stored in `o_buf`.
encode_pcm(uint8_t * i_buf,int i_len,uint8_t * o_buf,int o_len)81 int encode_pcm(uint8_t* i_buf, int i_len, uint8_t* o_buf, int o_len) {
82 if (i_buf == nullptr || o_buf == nullptr) {
83 log::error("Buffer is null");
84 return -EINVAL;
85 }
86
87 if (!client) {
88 log::error("CodecClient does not init");
89 return -ENOENT;
90 }
91
92 int rc = client->transcode(i_buf, i_len, o_buf, o_len);
93
94 if (rc < 0) {
95 log::error("Encode failed with error message, {}", strerror(-rc));
96 }
97 return rc;
98 }
99
100 private:
101 mmc::CodecClient* client = nullptr;
102 };
103
104 typedef struct {
105 float counter;
106 uint32_t bytes_per_tick; /* pcm bytes read for each media task tick */
107 uint64_t last_frame_us;
108 } tA2DP_AAC_FEEDING_STATE;
109
110 typedef struct {
111 uint64_t session_start_us;
112 size_t media_read_total_expected_packets;
113 size_t media_read_total_expected_reads_count;
114 size_t media_read_total_expected_read_bytes;
115 size_t media_read_total_dropped_packets;
116 size_t media_read_total_actual_reads_count;
117 size_t media_read_total_actual_read_bytes;
118 } a2dp_aac_encoder_stats_t;
119
120 typedef struct {
121 a2dp_source_read_callback_t read_callback;
122 a2dp_source_enqueue_callback_t enqueue_callback;
123 tA2DP_ENCODER_INIT_PEER_PARAMS peer_params;
124 tA2DP_FEEDING_PARAMS feeding_params;
125 tA2DP_AAC_FEEDING_STATE aac_feeding_state;
126 uint16_t TxAaMtuSize;
127 uint32_t timestamp; // Timestamp embedded into the BT frames
128 uint32_t pcm_samples_per_frame;
129 uint32_t encoder_interval_ms;
130 a2dp_aac_encoder_stats_t stats;
131 } tA2DP_AAC_ENCODER_CB;
132
133 static void a2dp_aac_get_num_frame_iteration(uint8_t* num_of_iterations, uint8_t* num_of_frames,
134 uint64_t timestamp_us);
135 static void a2dp_aac_encode_frames(uint8_t nb_frame);
136 static bool a2dp_aac_read_feeding(uint8_t* read_buffer, uint32_t* bytes_read);
137 static uint16_t adjust_effective_mtu(const tA2DP_ENCODER_INIT_PEER_PARAMS& peer_params);
138
139 namespace {
140 tA2DP_AAC_ENCODER_CB a2dp_aac_encoder_cb;
141 FFmpegInterface codec_intf;
142 } // namespace
143
A2DP_LoadEncoderAac()144 bool A2DP_LoadEncoderAac() { return true; }
145
A2DP_UnloadEncoderAac(void)146 void A2DP_UnloadEncoderAac(void) {
147 codec_intf.clear_context();
148 a2dp_aac_encoder_cb = tA2DP_AAC_ENCODER_CB{};
149 }
150
a2dp_aac_encoder_init(const tA2DP_ENCODER_INIT_PEER_PARAMS * p_peer_params,A2dpCodecConfig * a2dp_codec_config,a2dp_source_read_callback_t read_callback,a2dp_source_enqueue_callback_t enqueue_callback)151 void a2dp_aac_encoder_init(const tA2DP_ENCODER_INIT_PEER_PARAMS* p_peer_params,
152 A2dpCodecConfig* a2dp_codec_config,
153 a2dp_source_read_callback_t read_callback,
154 a2dp_source_enqueue_callback_t enqueue_callback) {
155 uint8_t codec_info[AVDT_CODEC_SIZE];
156 if (!a2dp_codec_config->copyOutOtaCodecConfig(codec_info)) {
157 log::error("Cannot update the codec encoder for {}: invalid codec config",
158 a2dp_codec_config->name());
159 return;
160 }
161
162 uint16_t mtu = adjust_effective_mtu(*p_peer_params);
163
164 int max_bit_rate = A2DP_ComputeMaxBitRateAac(codec_info, mtu - A2DP_AAC_MAX_PREFIX_SIZE) / 8 * 8;
165 int bit_rate = std::min(A2DP_GetBitRateAac(codec_info) / 8 * 8, max_bit_rate);
166
167 tA2DP_SAMPLE_RATE sample_rate = A2DP_GetTrackSampleRateAac(codec_info);
168 tA2DP_CHANNEL_COUNT channel_count = A2DP_GetTrackChannelCountAac(codec_info);
169 tA2DP_BITS_PER_SAMPLE bits_per_sample = a2dp_codec_config->getAudioBitsPerSample();
170
171 int pcm_samples_per_frame =
172 codec_intf.prepare_context(sample_rate, channel_count, bit_rate, bits_per_sample, mtu);
173
174 if (pcm_samples_per_frame < 0) {
175 log::error("Failed to prepare context: {}", pcm_samples_per_frame);
176 codec_intf.clear_context();
177 return; // TODO(b/294165759): need to return an error
178 }
179
180 uint32_t encoder_interval_ms = pcm_samples_per_frame * 1000 / sample_rate;
181
182 a2dp_aac_encoder_cb = tA2DP_AAC_ENCODER_CB{
183 .read_callback = read_callback,
184 .enqueue_callback = enqueue_callback,
185 .TxAaMtuSize = mtu,
186 .peer_params = *p_peer_params,
187 .timestamp = bluetooth::os::GenerateRandom(), // (RFC 6416)
188 .feeding_params =
189 {
190 .sample_rate = sample_rate,
191 .bits_per_sample = bits_per_sample,
192 .channel_count = channel_count,
193 },
194 .aac_feeding_state =
195 tA2DP_AAC_FEEDING_STATE{
196 .bytes_per_tick = (sample_rate * bits_per_sample / 8 * channel_count *
197 encoder_interval_ms) /
198 1000,
199 },
200 .pcm_samples_per_frame = static_cast<uint32_t>(pcm_samples_per_frame),
201 .encoder_interval_ms = encoder_interval_ms,
202 .stats =
203 a2dp_aac_encoder_stats_t{
204 .session_start_us = bluetooth::common::time_get_os_boottime_us(),
205 },
206 };
207 }
208
a2dp_aac_encoder_cleanup()209 void a2dp_aac_encoder_cleanup() {
210 codec_intf.clear_context();
211 a2dp_aac_encoder_cb = tA2DP_AAC_ENCODER_CB{};
212 }
213
a2dp_aac_feeding_reset()214 void a2dp_aac_feeding_reset() {
215 auto frame_length = a2dp_aac_encoder_cb.pcm_samples_per_frame;
216 auto sample_rate = a2dp_aac_encoder_cb.feeding_params.sample_rate;
217 if (sample_rate == 0) {
218 log::warn("Sample rate is not configured");
219 return;
220 }
221
222 a2dp_aac_encoder_cb.encoder_interval_ms = frame_length * 1000 / sample_rate;
223
224 a2dp_aac_encoder_cb.aac_feeding_state = tA2DP_AAC_FEEDING_STATE{
225 .bytes_per_tick = (a2dp_aac_encoder_cb.feeding_params.sample_rate *
226 a2dp_aac_encoder_cb.feeding_params.bits_per_sample / 8 *
227 a2dp_aac_encoder_cb.feeding_params.channel_count *
228 a2dp_aac_encoder_cb.encoder_interval_ms) /
229 1000,
230 };
231
232 log::warn("PCM bytes {} per tick ({}ms)", a2dp_aac_encoder_cb.aac_feeding_state.bytes_per_tick,
233 a2dp_aac_encoder_cb.encoder_interval_ms);
234 }
235
a2dp_aac_feeding_flush()236 void a2dp_aac_feeding_flush() { a2dp_aac_encoder_cb.aac_feeding_state.counter = 0.0f; }
237
a2dp_aac_get_encoder_interval_ms()238 uint64_t a2dp_aac_get_encoder_interval_ms() { return a2dp_aac_encoder_cb.encoder_interval_ms; }
239
a2dp_aac_get_effective_frame_size()240 int a2dp_aac_get_effective_frame_size() { return a2dp_aac_encoder_cb.TxAaMtuSize; }
241
a2dp_aac_send_frames(uint64_t timestamp_us)242 void a2dp_aac_send_frames(uint64_t timestamp_us) {
243 uint8_t nb_frame = 0;
244 uint8_t nb_iterations = 0;
245
246 a2dp_aac_get_num_frame_iteration(&nb_iterations, &nb_frame, timestamp_us);
247 if (nb_frame == 0) {
248 return;
249 }
250
251 for (uint8_t counter = 0; counter < nb_iterations; counter++) {
252 a2dp_aac_encode_frames(nb_frame);
253 }
254 }
255
256 // Obtains the number of frames to send and number of iterations
257 // to be used. |num_of_iterations| and |num_of_frames| parameters
258 // are used as output param for returning the respective values.
a2dp_aac_get_num_frame_iteration(uint8_t * num_of_iterations,uint8_t * num_of_frames,uint64_t timestamp_us)259 static void a2dp_aac_get_num_frame_iteration(uint8_t* num_of_iterations, uint8_t* num_of_frames,
260 uint64_t timestamp_us) {
261 uint32_t result = 0;
262 uint8_t nof = 0;
263 uint8_t noi = 1;
264
265 uint32_t pcm_bytes_per_frame = a2dp_aac_encoder_cb.pcm_samples_per_frame *
266 a2dp_aac_encoder_cb.feeding_params.channel_count *
267 a2dp_aac_encoder_cb.feeding_params.bits_per_sample / 8;
268 log::verbose("pcm_bytes_per_frame {}", pcm_bytes_per_frame);
269
270 uint32_t us_this_tick = a2dp_aac_encoder_cb.encoder_interval_ms * 1000;
271 uint64_t now_us = timestamp_us;
272 if (a2dp_aac_encoder_cb.aac_feeding_state.last_frame_us != 0) {
273 us_this_tick = (now_us - a2dp_aac_encoder_cb.aac_feeding_state.last_frame_us);
274 }
275 a2dp_aac_encoder_cb.aac_feeding_state.last_frame_us = now_us;
276
277 a2dp_aac_encoder_cb.aac_feeding_state.counter +=
278 (float)a2dp_aac_encoder_cb.aac_feeding_state.bytes_per_tick * us_this_tick /
279 (a2dp_aac_encoder_cb.encoder_interval_ms * 1000);
280
281 result = a2dp_aac_encoder_cb.aac_feeding_state.counter / pcm_bytes_per_frame;
282 a2dp_aac_encoder_cb.aac_feeding_state.counter -= result * pcm_bytes_per_frame;
283 nof = result;
284
285 log::verbose("effective num of frames {}, iterations {}", nof, noi);
286
287 *num_of_frames = nof;
288 *num_of_iterations = noi;
289 }
290
a2dp_aac_encode_frames(uint8_t nb_frame)291 static void a2dp_aac_encode_frames(uint8_t nb_frame) {
292 uint8_t read_buffer[BT_DEFAULT_BUFFER_SIZE];
293 int pcm_bytes_per_frame = a2dp_aac_encoder_cb.pcm_samples_per_frame *
294 a2dp_aac_encoder_cb.feeding_params.channel_count *
295 a2dp_aac_encoder_cb.feeding_params.bits_per_sample / 8;
296 log::assert_that(pcm_bytes_per_frame <= static_cast<int>(sizeof(read_buffer)),
297 "assert failed: pcm_bytes_per_frame <= "
298 "static_cast<int>(sizeof(read_buffer))");
299
300 while (nb_frame) {
301 a2dp_aac_encoder_cb.stats.media_read_total_expected_packets++;
302
303 uint32_t bytes_read = 0;
304 if (!a2dp_aac_read_feeding(read_buffer, &bytes_read)) {
305 log::warn("Underflow {}", nb_frame);
306 a2dp_aac_encoder_cb.aac_feeding_state.counter +=
307 nb_frame * a2dp_aac_encoder_cb.pcm_samples_per_frame *
308 a2dp_aac_encoder_cb.feeding_params.channel_count *
309 a2dp_aac_encoder_cb.feeding_params.bits_per_sample / 8;
310 return;
311 }
312
313 BT_HDR* p_buf = (BT_HDR*)osi_calloc(BT_DEFAULT_BUFFER_SIZE);
314 p_buf->offset = AVDT_MEDIA_OFFSET;
315 p_buf->len = 0;
316 p_buf->layer_specific = 0;
317
318 int written =
319 codec_intf.encode_pcm(read_buffer, bytes_read, (uint8_t*)(p_buf + 1) + p_buf->offset,
320 BT_DEFAULT_BUFFER_SIZE - 1 - p_buf->offset);
321
322 if (written < 0) {
323 a2dp_aac_encoder_cb.stats.media_read_total_dropped_packets++;
324 osi_free(p_buf);
325 return;
326 }
327
328 if (written == 0) {
329 log::info("Dropped a frame, likely due to buffering");
330 a2dp_aac_encoder_cb.stats.media_read_total_dropped_packets++;
331 osi_free(p_buf);
332 continue;
333 }
334
335 p_buf->layer_specific++;
336 p_buf->len += written;
337 --nb_frame;
338
339 *((uint32_t*)(p_buf + 1)) = a2dp_aac_encoder_cb.timestamp;
340
341 a2dp_aac_encoder_cb.timestamp +=
342 p_buf->layer_specific * a2dp_aac_encoder_cb.pcm_samples_per_frame;
343
344 if (!a2dp_aac_encoder_cb.enqueue_callback(p_buf, 1, bytes_read)) {
345 return;
346 }
347 }
348 }
349
a2dp_aac_read_feeding(uint8_t * read_buffer,uint32_t * bytes_read)350 static bool a2dp_aac_read_feeding(uint8_t* read_buffer, uint32_t* bytes_read) {
351 uint32_t read_size = a2dp_aac_encoder_cb.pcm_samples_per_frame *
352 a2dp_aac_encoder_cb.feeding_params.channel_count *
353 a2dp_aac_encoder_cb.feeding_params.bits_per_sample / 8;
354
355 a2dp_aac_encoder_cb.stats.media_read_total_expected_reads_count++;
356 a2dp_aac_encoder_cb.stats.media_read_total_expected_read_bytes += read_size;
357
358 /* Read Data from UIPC channel */
359 uint32_t nb_byte_read = a2dp_aac_encoder_cb.read_callback(read_buffer, read_size);
360 a2dp_aac_encoder_cb.stats.media_read_total_actual_read_bytes += nb_byte_read;
361 *bytes_read = nb_byte_read;
362
363 if (nb_byte_read < read_size) {
364 if (nb_byte_read == 0) {
365 return false;
366 }
367
368 /* Fill the unfilled part of the read buffer with silence (0) */
369 std::fill_n((uint8_t*)read_buffer + nb_byte_read, read_size - nb_byte_read, 0x00);
370 nb_byte_read = read_size;
371 }
372 a2dp_aac_encoder_cb.stats.media_read_total_actual_reads_count++;
373
374 return true;
375 }
376
adjust_effective_mtu(const tA2DP_ENCODER_INIT_PEER_PARAMS & peer_params)377 static uint16_t adjust_effective_mtu(const tA2DP_ENCODER_INIT_PEER_PARAMS& peer_params) {
378 uint16_t mtu_size = BT_DEFAULT_BUFFER_SIZE - AVDT_MEDIA_OFFSET - sizeof(BT_HDR);
379 if (mtu_size > peer_params.peer_mtu) {
380 mtu_size = peer_params.peer_mtu;
381 }
382 log::verbose("original AVDTP MTU size: {}", mtu_size);
383 if (peer_params.is_peer_edr && !peer_params.peer_supports_3mbps) {
384 // This condition would be satisfied only if the remote device is
385 // EDR and supports only 2 Mbps, but the effective AVDTP MTU size
386 // exceeds the 2DH5 packet size.
387 log::verbose("The remote device is EDR but does not support 3 Mbps");
388 if (mtu_size > MAX_2MBPS_AVDTP_MTU) {
389 log::warn("Restricting AVDTP MTU size from {} to {}", mtu_size, MAX_2MBPS_AVDTP_MTU);
390 mtu_size = MAX_2MBPS_AVDTP_MTU;
391 }
392 }
393 return mtu_size;
394 }
395
debug_codec_dump(int fd)396 void A2dpCodecConfigAacSource::debug_codec_dump(int fd) {
397 a2dp_aac_encoder_stats_t* stats = &a2dp_aac_encoder_cb.stats;
398
399 A2dpCodecConfig::debug_codec_dump(fd);
400
401 auto codec_specific_1 = getCodecConfig().codec_specific_1;
402 dprintf(fd,
403 " AAC bitrate mode : %s "
404 "(0x%" PRIx64 ")\n",
405 ((codec_specific_1 & ~A2DP_AAC_VARIABLE_BIT_RATE_MASK) == 0 ? "Constant" : "Variable"),
406 codec_specific_1);
407 dprintf(fd, " Encoder interval (ms): %" PRIu64 "\n", a2dp_aac_get_encoder_interval_ms());
408 dprintf(fd, " Effective MTU: %d\n", a2dp_aac_get_effective_frame_size());
409 dprintf(fd,
410 " Packet counts (expected/dropped) : %zu / "
411 "%zu\n",
412 stats->media_read_total_expected_packets, stats->media_read_total_dropped_packets);
413
414 dprintf(fd,
415 " PCM read counts (expected/actual) : %zu / "
416 "%zu\n",
417 stats->media_read_total_expected_reads_count, stats->media_read_total_actual_reads_count);
418
419 dprintf(fd,
420 " PCM read bytes (expected/actual) : %zu / "
421 "%zu\n",
422 stats->media_read_total_expected_read_bytes, stats->media_read_total_actual_read_bytes);
423 }
424