• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /******************************************************************************
2  *
3  *  Copyright 2016 The Android Open Source Project
4  *  Copyright 2009-2012 Broadcom Corporation
5  *
6  *  Licensed under the Apache License, Version 2.0 (the "License");
7  *  you may not use this file except in compliance with the License.
8  *  You may obtain a copy of the License at:
9  *
10  *  http://www.apache.org/licenses/LICENSE-2.0
11  *
12  *  Unless required by applicable law or agreed to in writing, software
13  *  distributed under the License is distributed on an "AS IS" BASIS,
14  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  *  See the License for the specific language governing permissions and
16  *  limitations under the License.
17  *
18  ******************************************************************************/
19 
20 #define LOG_TAG "a2dp_sbc_encoder"
21 
22 #include "a2dp_sbc_encoder.h"
23 
24 #include <limits.h>
25 #include <stdio.h>
26 #include <string.h>
27 
28 #include "a2dp_sbc.h"
29 #include "a2dp_sbc_up_sample.h"
30 #include "common/time_util.h"
31 #include "embdrv/sbc/encoder/include/sbc_encoder.h"
32 #include "osi/include/allocator.h"
33 #include "osi/include/log.h"
34 #include "osi/include/osi.h"
35 #include "stack/include/bt_hdr.h"
36 
37 /* Buffer pool */
38 #define A2DP_SBC_BUFFER_SIZE BT_DEFAULT_BUFFER_SIZE
39 
40 // A2DP SBC encoder interval in milliseconds.
41 #define A2DP_SBC_ENCODER_INTERVAL_MS 20
42 
43 /* High quality quality setting @ 44.1 khz */
44 #define A2DP_SBC_DEFAULT_BITRATE 328
45 
46 #define A2DP_SBC_NON_EDR_MAX_RATE 229
47 
48 #define A2DP_SBC_MAX_PCM_ITER_NUM_PER_TICK 3
49 
50 #define A2DP_SBC_MAX_HQ_FRAME_SIZE_44_1 119
51 #define A2DP_SBC_MAX_HQ_FRAME_SIZE_48 115
52 
53 /* Define the bitrate step when trying to match bitpool value */
54 #define A2DP_SBC_BITRATE_STEP 5
55 
56 /* Readability constants */
57 #define A2DP_SBC_FRAME_HEADER_SIZE_BYTES 4  // A2DP Spec v1.3, 12.4, Table 12.12
58 #define A2DP_SBC_SCALE_FACTOR_BITS 4        // A2DP Spec v1.3, 12.4, Table 12.13
59 
60 /* offset */
61 #if (BTA_AV_CO_CP_SCMS_T == TRUE)
62 /* A2DP header will contain a CP header of size 1 */
63 #define A2DP_HDR_SIZE 2
64 #define A2DP_SBC_OFFSET (AVDT_MEDIA_OFFSET + A2DP_SBC_MPL_HDR_LEN + 1)
65 #else
66 #define A2DP_HDR_SIZE 1
67 #define A2DP_SBC_OFFSET (AVDT_MEDIA_OFFSET + A2DP_SBC_MPL_HDR_LEN)
68 #endif
69 
70 typedef struct {
71   uint32_t aa_frame_counter;
72   int32_t aa_feed_counter;
73   int32_t aa_feed_residue;
74   float counter;
75   uint32_t bytes_per_tick; /* pcm bytes read each media task tick */
76   uint64_t last_frame_us;
77 } tA2DP_SBC_FEEDING_STATE;
78 
79 typedef struct {
80   uint64_t session_start_us;
81 
82   size_t media_read_total_expected_packets;
83   size_t media_read_total_expected_reads_count;
84   size_t media_read_total_expected_read_bytes;
85 
86   size_t media_read_total_dropped_packets;
87   size_t media_read_total_actual_reads_count;
88   size_t media_read_total_actual_read_bytes;
89 
90   size_t media_read_total_expected_frames;
91   size_t media_read_total_dropped_frames;
92 } a2dp_sbc_encoder_stats_t;
93 
94 typedef struct {
95   a2dp_source_read_callback_t read_callback;
96   a2dp_source_enqueue_callback_t enqueue_callback;
97   uint16_t TxAaMtuSize;
98   uint8_t tx_sbc_frames;
99   tA2DP_ENCODER_INIT_PEER_PARAMS peer_params;
100   uint32_t timestamp;       /* Timestamp for the A2DP frames */
101   SBC_ENC_PARAMS sbc_encoder_params;
102   tA2DP_FEEDING_PARAMS feeding_params;
103   tA2DP_SBC_FEEDING_STATE feeding_state;
104   int16_t pcmBuffer[SBC_MAX_PCM_BUFFER_SIZE];
105 
106   a2dp_sbc_encoder_stats_t stats;
107 } tA2DP_SBC_ENCODER_CB;
108 
109 static tA2DP_SBC_ENCODER_CB a2dp_sbc_encoder_cb;
110 
111 static void a2dp_sbc_encoder_update(A2dpCodecConfig* a2dp_codec_config,
112                                     bool* p_restart_input,
113                                     bool* p_restart_output,
114                                     bool* p_config_updated);
115 static bool a2dp_sbc_read_feeding(uint32_t* bytes);
116 static void a2dp_sbc_encode_frames(uint8_t nb_frame);
117 static void a2dp_sbc_get_num_frame_iteration(uint8_t* num_of_iterations,
118                                              uint8_t* num_of_frames,
119                                              uint64_t timestamp_us);
120 static uint16_t adjust_effective_mtu(
121     const tA2DP_ENCODER_INIT_PEER_PARAMS& peer_params);
122 static uint8_t calculate_max_frames_per_packet(void);
123 static uint16_t a2dp_sbc_source_rate(bool is_peer_edr);
124 static uint32_t a2dp_sbc_frame_length(void);
125 
A2DP_LoadEncoderSbc(void)126 bool A2DP_LoadEncoderSbc(void) {
127   // Nothing to do - the library is statically linked
128   return true;
129 }
130 
A2DP_UnloadEncoderSbc(void)131 void A2DP_UnloadEncoderSbc(void) {
132   // Nothing to do - the library is statically linked
133 }
134 
a2dp_sbc_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)135 void a2dp_sbc_encoder_init(const tA2DP_ENCODER_INIT_PEER_PARAMS* p_peer_params,
136                            A2dpCodecConfig* a2dp_codec_config,
137                            a2dp_source_read_callback_t read_callback,
138                            a2dp_source_enqueue_callback_t enqueue_callback) {
139   memset(&a2dp_sbc_encoder_cb, 0, sizeof(a2dp_sbc_encoder_cb));
140 
141   a2dp_sbc_encoder_cb.stats.session_start_us =
142       bluetooth::common::time_get_os_boottime_us();
143 
144   a2dp_sbc_encoder_cb.read_callback = read_callback;
145   a2dp_sbc_encoder_cb.enqueue_callback = enqueue_callback;
146   a2dp_sbc_encoder_cb.peer_params = *p_peer_params;
147   a2dp_sbc_encoder_cb.timestamp = 0;
148 
149   // NOTE: Ignore the restart_input / restart_output flags - this initization
150   // happens when the audio session is (re)started.
151   bool restart_input = false;
152   bool restart_output = false;
153   bool config_updated = false;
154   a2dp_sbc_encoder_update(a2dp_codec_config, &restart_input, &restart_output,
155                           &config_updated);
156 }
157 
158 // Update the A2DP SBC encoder.
159 // |a2dp_codec_config| is the A2DP codec to use for the update.
a2dp_sbc_encoder_update(A2dpCodecConfig * a2dp_codec_config,bool * p_restart_input,bool * p_restart_output,bool * p_config_updated)160 static void a2dp_sbc_encoder_update(A2dpCodecConfig* a2dp_codec_config,
161                                     bool* p_restart_input,
162                                     bool* p_restart_output,
163                                     bool* p_config_updated) {
164   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
165   uint8_t codec_info[AVDT_CODEC_SIZE];
166   uint16_t s16SamplingFreq;
167   int16_t s16BitPool = 0;
168   int16_t s16BitRate;
169   int16_t s16FrameLen;
170   uint8_t protect = 0;
171   int min_bitpool;
172   int max_bitpool;
173 
174   *p_restart_input = false;
175   *p_restart_output = false;
176   *p_config_updated = false;
177   if (!a2dp_codec_config->copyOutOtaCodecConfig(codec_info)) {
178     LOG_ERROR(
179         "%s: Cannot update the codec encoder for %s: "
180         "invalid codec config",
181         __func__, a2dp_codec_config->name().c_str());
182     return;
183   }
184   const uint8_t* p_codec_info = codec_info;
185   min_bitpool = A2DP_GetMinBitpoolSbc(p_codec_info);
186   max_bitpool = A2DP_GetMaxBitpoolSbc(p_codec_info);
187 
188   // The feeding parameters
189   tA2DP_FEEDING_PARAMS* p_feeding_params = &a2dp_sbc_encoder_cb.feeding_params;
190   p_feeding_params->sample_rate = A2DP_GetTrackSampleRateSbc(p_codec_info);
191   p_feeding_params->bits_per_sample =
192       a2dp_codec_config->getAudioBitsPerSample();
193   p_feeding_params->channel_count = A2DP_GetTrackChannelCountSbc(p_codec_info);
194   LOG_INFO("%s: sample_rate=%u bits_per_sample=%u channel_count=%u", __func__,
195            p_feeding_params->sample_rate, p_feeding_params->bits_per_sample,
196            p_feeding_params->channel_count);
197   a2dp_sbc_feeding_reset();
198 
199   // The codec parameters
200   p_encoder_params->s16ChannelMode = A2DP_GetChannelModeCodeSbc(p_codec_info);
201   p_encoder_params->s16NumOfSubBands =
202       A2DP_GetNumberOfSubbandsSbc(p_codec_info);
203   p_encoder_params->s16NumOfBlocks = A2DP_GetNumberOfBlocksSbc(p_codec_info);
204   p_encoder_params->s16AllocationMethod =
205       A2DP_GetAllocationMethodCodeSbc(p_codec_info);
206   p_encoder_params->s16SamplingFreq =
207       A2DP_GetSamplingFrequencyCodeSbc(p_codec_info);
208   p_encoder_params->s16NumOfChannels =
209       A2DP_GetTrackChannelCountSbc(p_codec_info);
210 
211   // Reset invalid parameters
212   if (!p_encoder_params->s16NumOfSubBands) {
213     LOG_WARN("%s: SubBands are set to 0, resetting to max (%d)", __func__,
214              SBC_MAX_NUM_OF_SUBBANDS);
215     p_encoder_params->s16NumOfSubBands = SBC_MAX_NUM_OF_SUBBANDS;
216   }
217   if (!p_encoder_params->s16NumOfBlocks) {
218     LOG_WARN("%s: Blocks are set to 0, resetting to max (%d)", __func__,
219              SBC_MAX_NUM_OF_BLOCKS);
220     p_encoder_params->s16NumOfBlocks = SBC_MAX_NUM_OF_BLOCKS;
221   }
222   if (!p_encoder_params->s16NumOfChannels) {
223     LOG_WARN("%s: Channels are set to 0, resetting to max (%d)", __func__,
224              SBC_MAX_NUM_OF_CHANNELS);
225     p_encoder_params->s16NumOfChannels = SBC_MAX_NUM_OF_CHANNELS;
226   }
227 
228   if (p_encoder_params->s16SamplingFreq == SBC_sf16000)
229     s16SamplingFreq = 16000;
230   else if (p_encoder_params->s16SamplingFreq == SBC_sf32000)
231     s16SamplingFreq = 32000;
232   else if (p_encoder_params->s16SamplingFreq == SBC_sf44100)
233     s16SamplingFreq = 44100;
234   else
235     s16SamplingFreq = 48000;
236 
237   // Set the initial target bit rate
238   const tA2DP_ENCODER_INIT_PEER_PARAMS& peer_params =
239       a2dp_sbc_encoder_cb.peer_params;
240   p_encoder_params->u16BitRate = a2dp_sbc_source_rate(peer_params.is_peer_edr);
241 
242   a2dp_sbc_encoder_cb.TxAaMtuSize = adjust_effective_mtu(peer_params);
243   LOG_INFO("%s: MTU=%d, peer_mtu=%d min_bitpool=%d max_bitpool=%d", __func__,
244            a2dp_sbc_encoder_cb.TxAaMtuSize, peer_params.peer_mtu, min_bitpool,
245            max_bitpool);
246   LOG_INFO(
247       "%s: ChannelMode=%d, NumOfSubBands=%d, NumOfBlocks=%d, "
248       "AllocationMethod=%d, BitRate=%d, SamplingFreq=%d BitPool=%d",
249       __func__, p_encoder_params->s16ChannelMode,
250       p_encoder_params->s16NumOfSubBands, p_encoder_params->s16NumOfBlocks,
251       p_encoder_params->s16AllocationMethod, p_encoder_params->u16BitRate,
252       s16SamplingFreq, p_encoder_params->s16BitPool);
253 
254   do {
255     if ((p_encoder_params->s16ChannelMode == SBC_JOINT_STEREO) ||
256         (p_encoder_params->s16ChannelMode == SBC_STEREO)) {
257       s16BitPool = (int16_t)((p_encoder_params->u16BitRate *
258                               p_encoder_params->s16NumOfSubBands * 1000 /
259                               s16SamplingFreq) -
260                              ((32 + (4 * p_encoder_params->s16NumOfSubBands *
261                                      p_encoder_params->s16NumOfChannels) +
262                                ((p_encoder_params->s16ChannelMode - 2) *
263                                 p_encoder_params->s16NumOfSubBands)) /
264                               p_encoder_params->s16NumOfBlocks));
265 
266       s16FrameLen = 4 +
267                     (4 * p_encoder_params->s16NumOfSubBands *
268                      p_encoder_params->s16NumOfChannels) /
269                         8 +
270                     (((p_encoder_params->s16ChannelMode - 2) *
271                       p_encoder_params->s16NumOfSubBands) +
272                      (p_encoder_params->s16NumOfBlocks * s16BitPool)) /
273                         8;
274 
275       s16BitRate = (8 * s16FrameLen * s16SamplingFreq) /
276                    (p_encoder_params->s16NumOfSubBands *
277                     p_encoder_params->s16NumOfBlocks * 1000);
278 
279       if (s16BitRate > p_encoder_params->u16BitRate) s16BitPool--;
280 
281       if (p_encoder_params->s16NumOfSubBands == 8)
282         s16BitPool = (s16BitPool > 255) ? 255 : s16BitPool;
283       else
284         s16BitPool = (s16BitPool > 128) ? 128 : s16BitPool;
285     } else {
286       s16BitPool =
287           (int16_t)(((p_encoder_params->s16NumOfSubBands *
288                       p_encoder_params->u16BitRate * 1000) /
289                      (s16SamplingFreq * p_encoder_params->s16NumOfChannels)) -
290                     (((32 / p_encoder_params->s16NumOfChannels) +
291                       (4 * p_encoder_params->s16NumOfSubBands)) /
292                      p_encoder_params->s16NumOfBlocks));
293 
294       p_encoder_params->s16BitPool =
295           (s16BitPool > (16 * p_encoder_params->s16NumOfSubBands))
296               ? (16 * p_encoder_params->s16NumOfSubBands)
297               : s16BitPool;
298     }
299 
300     if (s16BitPool < 0) s16BitPool = 0;
301 
302     LOG_VERBOSE("%s: bitpool candidate: %d (%d kbps)", __func__, s16BitPool,
303                 p_encoder_params->u16BitRate);
304 
305     if (s16BitPool > max_bitpool) {
306       LOG_VERBOSE("%s: computed bitpool too large (%d)", __func__, s16BitPool);
307       /* Decrease bitrate */
308       p_encoder_params->u16BitRate -= A2DP_SBC_BITRATE_STEP;
309       /* Record that we have decreased the bitrate */
310       protect |= 1;
311     } else if (s16BitPool < min_bitpool) {
312       LOG_WARN("%s: computed bitpool too small (%d)", __func__, s16BitPool);
313 
314       /* Increase bitrate */
315       uint16_t previous_u16BitRate = p_encoder_params->u16BitRate;
316       p_encoder_params->u16BitRate += A2DP_SBC_BITRATE_STEP;
317       /* Record that we have increased the bitrate */
318       protect |= 2;
319       /* Check over-flow */
320       if (p_encoder_params->u16BitRate < previous_u16BitRate) protect |= 3;
321     } else {
322       break;
323     }
324     /* In case we have already increased and decreased the bitrate, just stop */
325     if (protect == 3) {
326       LOG_ERROR("%s: could not find bitpool in range", __func__);
327       break;
328     }
329   } while (true);
330 
331   /* Finally update the bitpool in the encoder structure */
332   p_encoder_params->s16BitPool = s16BitPool;
333 
334   LOG_INFO("%s: final bit rate %d, final bit pool %d", __func__,
335            p_encoder_params->u16BitRate, p_encoder_params->s16BitPool);
336 
337   /* Reset the SBC encoder */
338   SBC_Encoder_Init(&a2dp_sbc_encoder_cb.sbc_encoder_params);
339   a2dp_sbc_encoder_cb.tx_sbc_frames = calculate_max_frames_per_packet();
340 }
341 
a2dp_sbc_encoder_cleanup(void)342 void a2dp_sbc_encoder_cleanup(void) {
343   memset(&a2dp_sbc_encoder_cb, 0, sizeof(a2dp_sbc_encoder_cb));
344 }
345 
a2dp_sbc_feeding_reset(void)346 void a2dp_sbc_feeding_reset(void) {
347   /* By default, just clear the entire state */
348   memset(&a2dp_sbc_encoder_cb.feeding_state, 0,
349          sizeof(a2dp_sbc_encoder_cb.feeding_state));
350 
351   a2dp_sbc_encoder_cb.feeding_state.bytes_per_tick =
352       (a2dp_sbc_encoder_cb.feeding_params.sample_rate *
353        a2dp_sbc_encoder_cb.feeding_params.bits_per_sample / 8 *
354        a2dp_sbc_encoder_cb.feeding_params.channel_count *
355        A2DP_SBC_ENCODER_INTERVAL_MS) /
356       1000;
357 
358   LOG_INFO("%s: PCM bytes per tick %u", __func__,
359            a2dp_sbc_encoder_cb.feeding_state.bytes_per_tick);
360 }
361 
a2dp_sbc_feeding_flush(void)362 void a2dp_sbc_feeding_flush(void) {
363   a2dp_sbc_encoder_cb.feeding_state.counter = 0.0f;
364   a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue = 0;
365 }
366 
a2dp_sbc_get_encoder_interval_ms(void)367 uint64_t a2dp_sbc_get_encoder_interval_ms(void) {
368   return A2DP_SBC_ENCODER_INTERVAL_MS;
369 }
370 
a2dp_sbc_get_effective_frame_size()371 int a2dp_sbc_get_effective_frame_size() {
372   return a2dp_sbc_encoder_cb.TxAaMtuSize;
373 }
374 
a2dp_sbc_send_frames(uint64_t timestamp_us)375 void a2dp_sbc_send_frames(uint64_t timestamp_us) {
376   uint8_t nb_frame = 0;
377   uint8_t nb_iterations = 0;
378 
379   a2dp_sbc_get_num_frame_iteration(&nb_iterations, &nb_frame, timestamp_us);
380   LOG_VERBOSE("%s: Sending %d frames per iteration, %d iterations", __func__,
381               nb_frame, nb_iterations);
382   if (nb_frame == 0) return;
383 
384   for (uint8_t counter = 0; counter < nb_iterations; counter++) {
385     // Transcode frame and enqueue
386     a2dp_sbc_encode_frames(nb_frame);
387   }
388 }
389 
390 // Obtains the number of frames to send and number of iterations
391 // to be used. |num_of_iterations| and |num_of_frames| parameters
392 // are used as output param for returning the respective values.
a2dp_sbc_get_num_frame_iteration(uint8_t * num_of_iterations,uint8_t * num_of_frames,uint64_t timestamp_us)393 static void a2dp_sbc_get_num_frame_iteration(uint8_t* num_of_iterations,
394                                              uint8_t* num_of_frames,
395                                              uint64_t timestamp_us) {
396   uint8_t nof = 0;
397   uint8_t noi = 1;
398 
399   uint32_t projected_nof = 0;
400   uint32_t pcm_bytes_per_frame =
401       a2dp_sbc_encoder_cb.sbc_encoder_params.s16NumOfSubBands *
402       a2dp_sbc_encoder_cb.sbc_encoder_params.s16NumOfBlocks *
403       a2dp_sbc_encoder_cb.feeding_params.channel_count *
404       a2dp_sbc_encoder_cb.feeding_params.bits_per_sample / 8;
405   LOG_VERBOSE("%s: pcm_bytes_per_frame %u", __func__, pcm_bytes_per_frame);
406 
407   uint32_t us_this_tick = A2DP_SBC_ENCODER_INTERVAL_MS * 1000;
408   uint64_t now_us = timestamp_us;
409   if (a2dp_sbc_encoder_cb.feeding_state.last_frame_us != 0)
410     us_this_tick = (now_us - a2dp_sbc_encoder_cb.feeding_state.last_frame_us);
411   a2dp_sbc_encoder_cb.feeding_state.last_frame_us = now_us;
412 
413   a2dp_sbc_encoder_cb.feeding_state.counter +=
414       (float)a2dp_sbc_encoder_cb.feeding_state.bytes_per_tick *
415       (float)us_this_tick / (A2DP_SBC_ENCODER_INTERVAL_MS * 1000);
416 
417   /* Calculate the number of frames pending for this media tick */
418   projected_nof =
419       a2dp_sbc_encoder_cb.feeding_state.counter / (float)pcm_bytes_per_frame;
420   // Update the stats
421   a2dp_sbc_encoder_cb.stats.media_read_total_expected_frames += projected_nof;
422 
423   if (projected_nof > MAX_PCM_FRAME_NUM_PER_TICK) {
424     LOG_WARN("%s: limiting frames to be sent from %d to %d", __func__,
425              projected_nof, MAX_PCM_FRAME_NUM_PER_TICK);
426 
427     // Update the stats
428     size_t delta = projected_nof - MAX_PCM_FRAME_NUM_PER_TICK;
429     a2dp_sbc_encoder_cb.stats.media_read_total_dropped_frames += delta;
430 
431     projected_nof = MAX_PCM_FRAME_NUM_PER_TICK;
432   }
433 
434   LOG_VERBOSE("%s: frames for available PCM data %u", __func__, projected_nof);
435 
436   if (a2dp_sbc_encoder_cb.peer_params.is_peer_edr) {
437     if (!a2dp_sbc_encoder_cb.tx_sbc_frames) {
438       LOG_ERROR("%s: tx_sbc_frames not updated, update from here", __func__);
439       a2dp_sbc_encoder_cb.tx_sbc_frames = calculate_max_frames_per_packet();
440     }
441 
442     nof = a2dp_sbc_encoder_cb.tx_sbc_frames;
443     if (!nof) {
444       LOG_ERROR("%s: number of frames not updated, set calculated values",
445                 __func__);
446       nof = projected_nof;
447       noi = 1;
448     } else {
449       if (nof < projected_nof) {
450         noi = projected_nof / nof;  // number of iterations would vary
451         if (noi > A2DP_SBC_MAX_PCM_ITER_NUM_PER_TICK) {
452           LOG_ERROR("%s: Audio Congestion (iterations:%d > max (%d))", __func__,
453                     noi, A2DP_SBC_MAX_PCM_ITER_NUM_PER_TICK);
454           noi = A2DP_SBC_MAX_PCM_ITER_NUM_PER_TICK;
455           a2dp_sbc_encoder_cb.feeding_state.counter =
456               noi * nof * (float)pcm_bytes_per_frame;
457         }
458         projected_nof = nof;
459       } else {
460         noi = 1;  // number of iterations is 1
461         LOG_VERBOSE("%s: reducing frames for available PCM data", __func__);
462         nof = projected_nof;
463       }
464     }
465   } else {
466     // For BR cases nof will be same as the value retrieved at projected_nof
467     LOG_VERBOSE("%s: headset BR, number of frames %u", __func__, nof);
468     if (projected_nof > MAX_PCM_FRAME_NUM_PER_TICK) {
469       LOG_ERROR("%s: Audio Congestion (frames: %d > max (%d))", __func__,
470                 projected_nof, MAX_PCM_FRAME_NUM_PER_TICK);
471 
472       // Update the stats
473       size_t delta = projected_nof - MAX_PCM_FRAME_NUM_PER_TICK;
474       a2dp_sbc_encoder_cb.stats.media_read_total_dropped_frames += delta;
475 
476       projected_nof = MAX_PCM_FRAME_NUM_PER_TICK;
477       a2dp_sbc_encoder_cb.feeding_state.counter =
478           (float)noi * (float)projected_nof * (float)pcm_bytes_per_frame;
479     }
480     nof = projected_nof;
481   }
482   a2dp_sbc_encoder_cb.feeding_state.counter -=
483       noi * nof * (float)pcm_bytes_per_frame;
484   LOG_VERBOSE("%s: effective num of frames %u, iterations %u", __func__, nof,
485               noi);
486 
487   *num_of_frames = nof;
488   *num_of_iterations = noi;
489 }
490 
a2dp_sbc_encode_frames(uint8_t nb_frame)491 static void a2dp_sbc_encode_frames(uint8_t nb_frame) {
492   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
493   uint8_t remain_nb_frame = nb_frame;
494   uint16_t blocm_x_subband =
495       p_encoder_params->s16NumOfSubBands * p_encoder_params->s16NumOfBlocks;
496 
497   uint8_t last_frame_len = 0;
498 
499   while (nb_frame) {
500     BT_HDR* p_buf = (BT_HDR*)osi_malloc(A2DP_SBC_BUFFER_SIZE);
501     uint32_t bytes_read = 0;
502 
503     p_buf->offset = A2DP_SBC_OFFSET;
504     p_buf->len = 0;
505     p_buf->layer_specific = 0;
506     a2dp_sbc_encoder_cb.stats.media_read_total_expected_packets++;
507 
508     do {
509       /* Fill allocated buffer with 0 */
510       memset(a2dp_sbc_encoder_cb.pcmBuffer, 0,
511              blocm_x_subband * p_encoder_params->s16NumOfChannels);
512       //
513       // Read the PCM data and encode it. If necessary, upsample the data.
514       //
515       uint32_t num_bytes = 0;
516       if (a2dp_sbc_read_feeding(&num_bytes)) {
517         uint8_t* output = (uint8_t*)(p_buf + 1) + p_buf->offset + p_buf->len;
518         int16_t* input = a2dp_sbc_encoder_cb.pcmBuffer;
519         uint16_t output_len = SBC_Encode(p_encoder_params, input, output);
520         last_frame_len = output_len;
521 
522         /* Update SBC frame length */
523         p_buf->len += output_len;
524         nb_frame--;
525         p_buf->layer_specific++;
526 
527         bytes_read += num_bytes;
528       } else {
529         LOG_WARN("%s: underflow %d, %d", __func__, nb_frame,
530                  a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue);
531         a2dp_sbc_encoder_cb.feeding_state.counter +=
532             nb_frame * p_encoder_params->s16NumOfSubBands *
533             p_encoder_params->s16NumOfBlocks *
534             a2dp_sbc_encoder_cb.feeding_params.channel_count *
535             a2dp_sbc_encoder_cb.feeding_params.bits_per_sample / 8;
536         /* no more pcm to read */
537         nb_frame = 0;
538       }
539     } while (
540         ((p_buf->len + last_frame_len) < a2dp_sbc_encoder_cb.TxAaMtuSize) &&
541         (p_buf->layer_specific < 0x0F) && nb_frame);
542 
543     if (p_buf->len) {
544       /*
545        * Timestamp of the media packet header represent the TS of the
546        * first SBC frame, i.e the timestamp before including this frame.
547        */
548       *((uint32_t*)(p_buf + 1)) = a2dp_sbc_encoder_cb.timestamp;
549 
550       a2dp_sbc_encoder_cb.timestamp += p_buf->layer_specific * blocm_x_subband;
551 
552       uint8_t done_nb_frame = remain_nb_frame - nb_frame;
553       remain_nb_frame = nb_frame;
554       if (!a2dp_sbc_encoder_cb.enqueue_callback(p_buf, done_nb_frame,
555                                                 bytes_read))
556         return;
557     } else {
558       a2dp_sbc_encoder_cb.stats.media_read_total_dropped_packets++;
559       osi_free(p_buf);
560     }
561   }
562 }
563 
a2dp_sbc_read_feeding(uint32_t * bytes_read)564 static bool a2dp_sbc_read_feeding(uint32_t* bytes_read) {
565   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
566   uint16_t blocm_x_subband =
567       p_encoder_params->s16NumOfSubBands * p_encoder_params->s16NumOfBlocks;
568   uint32_t read_size;
569   uint32_t sbc_sampling = 48000;
570   uint32_t src_samples;
571   uint16_t bytes_needed = blocm_x_subband * p_encoder_params->s16NumOfChannels *
572                           a2dp_sbc_encoder_cb.feeding_params.bits_per_sample /
573                           8;
574   static uint16_t up_sampled_buffer[SBC_MAX_NUM_FRAME * SBC_MAX_NUM_OF_BLOCKS *
575                                     SBC_MAX_NUM_OF_CHANNELS *
576                                     SBC_MAX_NUM_OF_SUBBANDS * 2];
577   static uint16_t read_buffer[SBC_MAX_NUM_FRAME * SBC_MAX_NUM_OF_BLOCKS *
578                               SBC_MAX_NUM_OF_CHANNELS *
579                               SBC_MAX_NUM_OF_SUBBANDS];
580   uint32_t src_size_used;
581   uint32_t dst_size_used;
582   bool fract_needed;
583   int32_t fract_max;
584   int32_t fract_threshold;
585   uint32_t nb_byte_read;
586 
587   /* Get the SBC sampling rate */
588   switch (p_encoder_params->s16SamplingFreq) {
589     case SBC_sf48000:
590       sbc_sampling = 48000;
591       break;
592     case SBC_sf44100:
593       sbc_sampling = 44100;
594       break;
595     case SBC_sf32000:
596       sbc_sampling = 32000;
597       break;
598     case SBC_sf16000:
599       sbc_sampling = 16000;
600       break;
601   }
602 
603   a2dp_sbc_encoder_cb.stats.media_read_total_expected_reads_count++;
604   if (sbc_sampling == a2dp_sbc_encoder_cb.feeding_params.sample_rate) {
605     read_size =
606         bytes_needed - a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue;
607     a2dp_sbc_encoder_cb.stats.media_read_total_expected_read_bytes += read_size;
608     nb_byte_read = a2dp_sbc_encoder_cb.read_callback(
609         ((uint8_t*)a2dp_sbc_encoder_cb.pcmBuffer) +
610             a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue,
611         read_size);
612     a2dp_sbc_encoder_cb.stats.media_read_total_actual_read_bytes +=
613         nb_byte_read;
614 
615     *bytes_read = nb_byte_read;
616     if (nb_byte_read != read_size) {
617       a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue += nb_byte_read;
618       return false;
619     }
620     a2dp_sbc_encoder_cb.stats.media_read_total_actual_reads_count++;
621     a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue = 0;
622     return true;
623   }
624 
625   /*
626    * Some Feeding PCM frequencies require to split the number of sample
627    * to read.
628    * E.g 128 / 6 = 21.3333 => read 22 and 21 and 21 => max = 2; threshold = 0
629    */
630   fract_needed = false; /* Default */
631   switch (a2dp_sbc_encoder_cb.feeding_params.sample_rate) {
632     case 32000:
633     case 8000:
634       fract_needed = true;
635       fract_max = 2;       /* 0, 1 and 2 */
636       fract_threshold = 0; /* Add one for the first */
637       break;
638     case 16000:
639       fract_needed = true;
640       fract_max = 2;       /* 0, 1 and 2 */
641       fract_threshold = 1; /* Add one for the first two frames*/
642       break;
643   }
644 
645   /* Compute number of sample to read from source */
646   src_samples = blocm_x_subband;
647   src_samples *= a2dp_sbc_encoder_cb.feeding_params.sample_rate;
648   src_samples /= sbc_sampling;
649 
650   /* The previous division may have a remainder not null */
651   if (fract_needed) {
652     if (a2dp_sbc_encoder_cb.feeding_state.aa_feed_counter <= fract_threshold) {
653       src_samples++; /* for every read before threshold add one sample */
654     }
655 
656     /* do nothing if counter >= threshold */
657     a2dp_sbc_encoder_cb.feeding_state.aa_feed_counter++; /* one more read */
658     if (a2dp_sbc_encoder_cb.feeding_state.aa_feed_counter > fract_max) {
659       a2dp_sbc_encoder_cb.feeding_state.aa_feed_counter = 0;
660     }
661   }
662 
663   /* Compute number of bytes to read from source */
664   read_size = src_samples;
665   read_size *= a2dp_sbc_encoder_cb.feeding_params.channel_count;
666   read_size *= (a2dp_sbc_encoder_cb.feeding_params.bits_per_sample / 8);
667   a2dp_sbc_encoder_cb.stats.media_read_total_expected_read_bytes += read_size;
668 
669   /* Read Data from UIPC channel */
670   nb_byte_read =
671       a2dp_sbc_encoder_cb.read_callback((uint8_t*)read_buffer, read_size);
672   a2dp_sbc_encoder_cb.stats.media_read_total_actual_read_bytes += nb_byte_read;
673 
674   if (nb_byte_read < read_size) {
675     if (nb_byte_read == 0) return false;
676 
677     /* Fill the unfilled part of the read buffer with silence (0) */
678     memset(((uint8_t*)read_buffer) + nb_byte_read, 0, read_size - nb_byte_read);
679     nb_byte_read = read_size;
680   }
681   a2dp_sbc_encoder_cb.stats.media_read_total_actual_reads_count++;
682 
683   /* Initialize PCM up-sampling engine */
684   a2dp_sbc_init_up_sample(a2dp_sbc_encoder_cb.feeding_params.sample_rate,
685                           sbc_sampling,
686                           a2dp_sbc_encoder_cb.feeding_params.bits_per_sample,
687                           a2dp_sbc_encoder_cb.feeding_params.channel_count);
688 
689   /*
690    * Re-sample the read buffer.
691    * The output PCM buffer will be stereo, 16 bit per sample.
692    */
693   dst_size_used = a2dp_sbc_up_sample(
694       (uint8_t*)read_buffer,
695       (uint8_t*)up_sampled_buffer +
696           a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue,
697       nb_byte_read, sizeof(up_sampled_buffer) -
698                         a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue,
699       &src_size_used);
700 
701   /* update the residue */
702   a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue += dst_size_used;
703 
704   /* only copy the pcm sample when we have up-sampled enough PCM */
705   if (a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue < bytes_needed)
706     return false;
707 
708   /* Copy the output pcm samples in SBC encoding buffer */
709   memcpy((uint8_t*)a2dp_sbc_encoder_cb.pcmBuffer, (uint8_t*)up_sampled_buffer,
710          bytes_needed);
711   /* update the residue */
712   a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue -= bytes_needed;
713 
714   if (a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue != 0) {
715     memcpy((uint8_t*)up_sampled_buffer,
716            (uint8_t*)up_sampled_buffer + bytes_needed,
717            a2dp_sbc_encoder_cb.feeding_state.aa_feed_residue);
718   }
719   return true;
720 }
721 
adjust_effective_mtu(const tA2DP_ENCODER_INIT_PEER_PARAMS & peer_params)722 static uint16_t adjust_effective_mtu(
723     const tA2DP_ENCODER_INIT_PEER_PARAMS& peer_params) {
724   uint16_t mtu_size = A2DP_SBC_BUFFER_SIZE - A2DP_SBC_OFFSET - sizeof(BT_HDR);
725   if (mtu_size > peer_params.peer_mtu) {
726     mtu_size = peer_params.peer_mtu;
727   }
728   LOG_VERBOSE("%s: original AVDTP MTU size: %d", __func__, mtu_size);
729   if (peer_params.is_peer_edr && !peer_params.peer_supports_3mbps) {
730     // This condition would be satisfied only if the remote device is
731     // EDR and supports only 2 Mbps, but the effective AVDTP MTU size
732     // exceeds the 2DH5 packet size.
733     LOG_VERBOSE("%s: The remote device is EDR but does not support 3 Mbps",
734                 __func__);
735     if (mtu_size > MAX_2MBPS_AVDTP_MTU) {
736       LOG_WARN("%s: Restricting AVDTP MTU size from %d to %d", __func__,
737                mtu_size, MAX_2MBPS_AVDTP_MTU);
738       mtu_size = MAX_2MBPS_AVDTP_MTU;
739     }
740   }
741   return mtu_size;
742 }
743 
calculate_max_frames_per_packet(void)744 static uint8_t calculate_max_frames_per_packet(void) {
745   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
746   uint16_t result = 0;
747   uint32_t frame_len;
748 
749   a2dp_sbc_encoder_cb.TxAaMtuSize =
750       adjust_effective_mtu(a2dp_sbc_encoder_cb.peer_params);
751   const uint16_t& effective_mtu_size = a2dp_sbc_encoder_cb.TxAaMtuSize;
752 
753   if (!p_encoder_params->s16NumOfSubBands) {
754     LOG_ERROR("%s: SubBands are set to 0, resetting to %d", __func__,
755               SBC_MAX_NUM_OF_SUBBANDS);
756     p_encoder_params->s16NumOfSubBands = SBC_MAX_NUM_OF_SUBBANDS;
757   }
758   if (!p_encoder_params->s16NumOfBlocks) {
759     LOG_ERROR("%s: Blocks are set to 0, resetting to %d", __func__,
760               SBC_MAX_NUM_OF_BLOCKS);
761     p_encoder_params->s16NumOfBlocks = SBC_MAX_NUM_OF_BLOCKS;
762   }
763   if (!p_encoder_params->s16NumOfChannels) {
764     LOG_ERROR("%s: Channels are set to 0, resetting to %d", __func__,
765               SBC_MAX_NUM_OF_CHANNELS);
766     p_encoder_params->s16NumOfChannels = SBC_MAX_NUM_OF_CHANNELS;
767   }
768 
769   frame_len = a2dp_sbc_frame_length();
770 
771   LOG_VERBOSE("%s: Effective Tx MTU to be considered: %d", __func__,
772               effective_mtu_size);
773 
774   switch (p_encoder_params->s16SamplingFreq) {
775     case SBC_sf44100:
776       if (frame_len == 0) {
777         LOG_ERROR("%s: Calculating frame length, resetting it to default %d",
778                   __func__, A2DP_SBC_MAX_HQ_FRAME_SIZE_44_1);
779         frame_len = A2DP_SBC_MAX_HQ_FRAME_SIZE_44_1;
780       }
781       result = (effective_mtu_size - A2DP_HDR_SIZE) / frame_len;
782       LOG_VERBOSE("%s: Max number of SBC frames: %d", __func__, result);
783       break;
784 
785     case SBC_sf48000:
786       if (frame_len == 0) {
787         LOG_ERROR("%s: Calculating frame length, resetting it to default %d",
788                   __func__, A2DP_SBC_MAX_HQ_FRAME_SIZE_48);
789         frame_len = A2DP_SBC_MAX_HQ_FRAME_SIZE_48;
790       }
791       result = (effective_mtu_size - A2DP_HDR_SIZE) / frame_len;
792       LOG_VERBOSE("%s: Max number of SBC frames: %d", __func__, result);
793       break;
794 
795     default:
796       LOG_ERROR("%s: Max number of SBC frames: %d", __func__, result);
797       break;
798   }
799   return result;
800 }
801 
a2dp_sbc_source_rate(bool is_peer_edr)802 static uint16_t a2dp_sbc_source_rate(bool is_peer_edr) {
803   uint16_t rate = A2DP_SBC_DEFAULT_BITRATE;
804 
805   /* restrict bitrate if a2dp link is non-edr */
806   if (!is_peer_edr) {
807     rate = A2DP_SBC_NON_EDR_MAX_RATE;
808     LOG_VERBOSE("%s: non-edr a2dp sink detected, restrict rate to %d", __func__,
809                 rate);
810   }
811 
812   return rate;
813 }
814 
a2dp_sbc_frame_length(void)815 static uint32_t a2dp_sbc_frame_length(void) {
816   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
817   uint32_t frame_len = 0;
818 
819   LOG_VERBOSE(
820       "%s: channel mode: %d, sub-band: %d, number of block: %d, "
821       "bitpool: %d, sampling frequency: %d, num channels: %d",
822       __func__, p_encoder_params->s16ChannelMode,
823       p_encoder_params->s16NumOfSubBands, p_encoder_params->s16NumOfBlocks,
824       p_encoder_params->s16BitPool, p_encoder_params->s16SamplingFreq,
825       p_encoder_params->s16NumOfChannels);
826 
827   switch (p_encoder_params->s16ChannelMode) {
828     case SBC_MONO:
829       FALLTHROUGH_INTENDED; /* FALLTHROUGH */
830     case SBC_DUAL:
831       frame_len = A2DP_SBC_FRAME_HEADER_SIZE_BYTES +
832                   ((uint32_t)(A2DP_SBC_SCALE_FACTOR_BITS *
833                               p_encoder_params->s16NumOfSubBands *
834                               p_encoder_params->s16NumOfChannels) /
835                    CHAR_BIT) +
836                   ((uint32_t)(p_encoder_params->s16NumOfBlocks *
837                               p_encoder_params->s16NumOfChannels *
838                               p_encoder_params->s16BitPool) /
839                    CHAR_BIT);
840       break;
841     case SBC_STEREO:
842       frame_len = A2DP_SBC_FRAME_HEADER_SIZE_BYTES +
843                   ((uint32_t)(A2DP_SBC_SCALE_FACTOR_BITS *
844                               p_encoder_params->s16NumOfSubBands *
845                               p_encoder_params->s16NumOfChannels) /
846                    CHAR_BIT) +
847                   ((uint32_t)(p_encoder_params->s16NumOfBlocks *
848                               p_encoder_params->s16BitPool) /
849                    CHAR_BIT);
850       break;
851     case SBC_JOINT_STEREO:
852       frame_len = A2DP_SBC_FRAME_HEADER_SIZE_BYTES +
853                   ((uint32_t)(A2DP_SBC_SCALE_FACTOR_BITS *
854                               p_encoder_params->s16NumOfSubBands *
855                               p_encoder_params->s16NumOfChannels) /
856                    CHAR_BIT) +
857                   ((uint32_t)(p_encoder_params->s16NumOfSubBands +
858                               (p_encoder_params->s16NumOfBlocks *
859                                p_encoder_params->s16BitPool)) /
860                    CHAR_BIT);
861       break;
862     default:
863       LOG_VERBOSE("%s: Invalid channel number: %d", __func__,
864                   p_encoder_params->s16ChannelMode);
865       break;
866   }
867   LOG_VERBOSE("%s: calculated frame length: %d", __func__, frame_len);
868   return frame_len;
869 }
870 
a2dp_sbc_get_bitrate()871 uint32_t a2dp_sbc_get_bitrate() {
872   SBC_ENC_PARAMS* p_encoder_params = &a2dp_sbc_encoder_cb.sbc_encoder_params;
873   LOG_INFO("%s: bit rate %d ", __func__, p_encoder_params->u16BitRate);
874   return p_encoder_params->u16BitRate * 1000;
875 }
876 
debug_codec_dump(int fd)877 void A2dpCodecConfigSbcSource::debug_codec_dump(int fd) {
878   a2dp_sbc_encoder_stats_t* stats = &a2dp_sbc_encoder_cb.stats;
879 
880   A2dpCodecConfig::debug_codec_dump(fd);
881 
882   uint8_t codec_info[AVDT_CODEC_SIZE];
883   if (copyOutOtaCodecConfig(codec_info)) {
884     dprintf(fd,
885             "  SBC Block length                                        : %d\n",
886             A2DP_GetNumberOfBlocksSbc(codec_info));
887     dprintf(fd,
888             "  SBC Number of subbands                                  : %d\n",
889             A2DP_GetNumberOfSubbandsSbc(codec_info));
890     dprintf(fd,
891             "  SBC Allocation method                                   : %d\n",
892             A2DP_GetAllocationMethodCodeSbc(codec_info));
893     dprintf(
894         fd,
895         "  SBC Bitpool (min/max)                                   : %d / %d\n",
896         A2DP_GetMinBitpoolSbc(codec_info), A2DP_GetMaxBitpoolSbc(codec_info));
897   }
898 
899   dprintf(fd, "  Encoder interval (ms): %" PRIu64 "\n",
900           a2dp_sbc_get_encoder_interval_ms());
901   dprintf(fd, "  Effective MTU: %d\n", a2dp_sbc_get_effective_frame_size());
902   dprintf(fd,
903           "  Packet counts (expected/dropped)                        : %zu / "
904           "%zu\n",
905           stats->media_read_total_expected_packets,
906           stats->media_read_total_dropped_packets);
907 
908   dprintf(fd,
909           "  PCM read counts (expected/actual)                       : %zu / "
910           "%zu\n",
911           stats->media_read_total_expected_reads_count,
912           stats->media_read_total_actual_reads_count);
913 
914   dprintf(fd,
915           "  PCM read bytes (expected/actual)                        : %zu / "
916           "%zu\n",
917           stats->media_read_total_expected_read_bytes,
918           stats->media_read_total_actual_read_bytes);
919 
920   dprintf(fd,
921           "  Frames counts (expected/dropped)                        : %zu / "
922           "%zu\n",
923           stats->media_read_total_expected_frames,
924           stats->media_read_total_dropped_frames);
925 }
926