Go to the documentation of this file.
45 #define VLC_STATIC_SIZE 64
48 #define VLC_STATIC_SIZE 512
86 #define PARAM_BLOCKSIZE (1 << 7)
87 #define PARAM_MATRIX (1 << 6)
88 #define PARAM_OUTSHIFT (1 << 5)
89 #define PARAM_QUANTSTEP (1 << 4)
90 #define PARAM_FIR (1 << 3)
91 #define PARAM_IIR (1 << 2)
92 #define PARAM_HUFFOFFSET (1 << 1)
93 #define PARAM_PRESENCE (1 << 0)
185 return channel_layout && ((channel_layout &
mask) == channel_layout);
224 unsigned int substr,
unsigned int ch)
233 sign_huff_offset -= 7 << lsb_bits;
236 sign_huff_offset -= 1 << sign_shift;
238 return sign_huff_offset;
245 unsigned int substr,
unsigned int pos)
250 for (mat = 0; mat <
s->num_primitive_matrices; mat++)
251 if (
s->lsb_bypass[mat])
257 int quant_step_size =
s->quant_step_size[
channel];
258 int lsb_bits = cp->
huff_lsbs - quant_step_size;
272 result *= 1 << quant_step_size;
307 if (
mh.group1_bits == 0) {
311 if (
mh.group2_bits >
mh.group1_bits) {
313 "Channel group 2 cannot have more bits per sample than group 1.\n");
317 if (
mh.group2_samplerate &&
mh.group2_samplerate !=
mh.group1_samplerate) {
319 "Channel groups with differing sample rates are not currently supported.\n");
323 if (
mh.group1_samplerate == 0) {
329 "Sampling rate %d is greater than the supported maximum (%d).\n",
335 "Block size %d is greater than the supported maximum (%d).\n",
341 "Block size pow2 %d is greater than the supported maximum (%d).\n",
346 if (
mh.num_substreams == 0)
354 "%d substreams (more than the "
355 "maximum supported by the decoder)",
374 if (
mh.group1_bits > 16)
391 if (
mh.stream_type != 0xbb) {
393 "unexpected stream_type %X in MLP",
397 if ((substr = (
mh.num_substreams > 1)))
401 if (
mh.stream_type != 0xba) {
403 "unexpected stream_type %X in !MLP",
407 if ((substr = (
mh.num_substreams > 1)))
409 if (
mh.num_substreams > 2)
410 if (
mh.channel_layout_thd_stream2)
441 if (
mh.num_substreams > 2 &&
447 if (
mh.num_substreams > 1 &&
453 if (
mh.num_substreams > 0)
454 switch (
mh.channel_modifier_thd_stream0) {
482 int min_channel, max_channel, max_matrix_channel, noise_type;
489 if (sync_word != 0x31ea >> 1) {
491 "restart header sync incorrect (got 0x%04x)\n", sync_word);
506 max_matrix_channel =
get_bits(gbp, 4);
508 if (max_matrix_channel > std_max_matrix_channel) {
510 "Max matrix channel cannot be greater than %d.\n",
511 std_max_matrix_channel);
515 if (max_channel != max_matrix_channel) {
517 "Max channel must be equal max matrix channel.\n");
525 "%d channels (more than the "
526 "maximum supported by the decoder)",
531 if (min_channel > max_channel) {
533 "Substream min channel cannot be greater than max channel.\n");
537 s->min_channel = min_channel;
538 s->max_channel = max_channel;
539 s->max_matrix_channel = max_matrix_channel;
540 s->noise_type = noise_type;
545 "Extracting %d-channel downmix (0x%"PRIx64
") from substream %d. "
546 "Further substreams will be skipped.\n",
547 s->max_channel + 1,
s->mask, substr);
559 &&
s->lossless_check_data != 0xffffffff) {
561 if (
tmp != lossless_check)
563 "Lossless check failed - expected %02x, calculated %02x.\n",
564 lossless_check,
tmp);
569 memset(
s->ch_assign, 0,
sizeof(
s->ch_assign));
571 for (
ch = 0;
ch <=
s->max_matrix_channel;
ch++) {
579 if (ch_assign < 0 || ch_assign >
s->max_matrix_channel) {
581 "Assignment of matrix channel %d to invalid output channel %d",
585 s->ch_assign[ch_assign] =
ch;
594 s->param_presence_flags = 0xff;
595 s->num_primitive_matrices = 0;
597 s->lossless_check_data = 0;
599 memset(
s->output_shift , 0,
sizeof(
s->output_shift ));
600 memset(
s->quant_step_size, 0,
sizeof(
s->quant_step_size));
602 for (
ch =
s->min_channel; ch <= s->max_channel;
ch++) {
621 s->max_matrix_channel,
627 int i =
s->ch_assign[4];
628 s->ch_assign[4] =
s->ch_assign[3];
629 s->ch_assign[3] =
s->ch_assign[2];
632 FFSWAP(
int,
s->ch_assign[2],
s->ch_assign[4]);
633 FFSWAP(
int,
s->ch_assign[3],
s->ch_assign[5]);
645 unsigned int substr,
unsigned int channel,
651 const char fchar =
filter ?
'I' :
'F';
663 if (order > max_order) {
665 "%cIR filter order %d is greater than maximum %d.\n",
666 fchar, order, max_order);
673 int coeff_bits, coeff_shift;
679 if (coeff_bits < 1 || coeff_bits > 16) {
681 "%cIR filter coeff_bits must be between 1 and 16.\n",
685 if (coeff_bits + coeff_shift > 16) {
687 "Sum of coeff_bits and coeff_shift for %cIR filter must be 16 or less.\n",
692 for (
i = 0;
i < order;
i++)
693 fcoeff[
i] =
get_sbits(gbp, coeff_bits) * (1 << coeff_shift);
696 int state_bits, state_shift;
700 "FIR filter has state data specified.\n");
709 for (
i = 0;
i < order;
i++)
710 fp->state[
i] = state_bits ?
get_sbits(gbp, state_bits) * (1 << state_shift) : 0;
722 unsigned int mat,
ch;
732 s->num_primitive_matrices =
get_bits(gbp, 4);
734 if (
s->num_primitive_matrices > max_primitive_matrices) {
736 "Number of primitive matrices cannot be greater than %d.\n",
737 max_primitive_matrices);
741 for (mat = 0; mat <
s->num_primitive_matrices; mat++) {
742 int frac_bits, max_chan;
743 s->matrix_out_ch[mat] =
get_bits(gbp, 4);
747 if (
s->matrix_out_ch[mat] >
s->max_matrix_channel) {
749 "Invalid channel %d specified as output from matrix.\n",
750 s->matrix_out_ch[mat]);
753 if (frac_bits > 14) {
755 "Too many fractional bits specified.\n");
759 max_chan =
s->max_matrix_channel;
763 for (
ch = 0;
ch <= max_chan;
ch++) {
766 coeff_val =
get_sbits(gbp, frac_bits + 2);
768 s->matrix_coeff[mat][
ch] = coeff_val * (1 << (14 - frac_bits));
772 s->matrix_noise_shift[mat] =
get_bits(gbp, 4);
774 s->matrix_noise_shift[mat] = 0;
779 s->num_primitive_matrices = 0;
780 memset(
s->matrix_out_ch, 0,
sizeof(
s->matrix_out_ch));
814 "FIR and IIR filters must use the same precision.\n");
850 unsigned recompute_sho = 0;
854 s->param_presence_flags =
get_bits(gbp, 8);
873 for (
ch = 0;
ch <=
s->max_matrix_channel;
ch++) {
875 if (
s->output_shift[
ch] < 0) {
877 s->output_shift[
ch] = 0;
883 s->max_matrix_channel,
889 for (
ch = 0;
ch <=
s->max_channel;
ch++) {
892 recompute_sho |= 1<<
ch;
895 for (
ch =
s->min_channel; ch <= s->max_channel;
ch++)
897 recompute_sho |= 1<<
ch;
904 for (
ch = 0;
ch <=
s->max_channel;
ch++) {
905 if (recompute_sho & (1<<
ch)) {
913 s->quant_step_size[
ch] = 0;
922 #define MSB_MASK(bits) (-1u << (bits))
937 unsigned int filter_shift = fir->
shift;
945 filter_shift,
mask,
s->blocksize,
958 unsigned int i,
ch, expected_stream_pos = 0;
961 if (
s->data_check_present) {
963 expected_stream_pos +=
get_bits(gbp, 16);
965 "Substreams with VLC block size check info");
976 for (
i = 0;
i <
s->blocksize;
i++)
980 for (
ch =
s->min_channel; ch <= s->max_channel;
ch++)
983 s->blockpos +=
s->blocksize;
985 if (
s->data_check_present) {
997 30, 51, 22, 54, 3, 7, -4, 38, 14, 55, 46, 81, 22, 58, -3, 2,
998 52, 31, -7, 51, 15, 44, 74, 30, 85, -17, 10, 33, 18, 80, 28, 62,
999 10, 32, 23, 69, 72, 26, 35, 17, 73, 60, 8, 56, 2, 6, -2, -5,
1000 51, 4, 11, 50, 66, 76, 21, 44, 33, 47, 1, 26, 64, 48, 57, 40,
1001 38, 16, -10, -28, 92, 22, -18, 29, -10, 5, -13, 49, 19, 24, 70, 34,
1002 61, 48, 30, 14, -6, 25, 58, 33, 42, 60, 67, 17, 54, 17, 22, 30,
1003 67, 44, -9, 50, -11, 43, 40, 32, 59, 82, 13, 49, -14, 55, 60, 36,
1004 48, 49, 31, 47, 15, 12, 4, 65, 1, 23, 29, 39, 45, -2, 84, 69,
1005 0, 72, 37, 57, 27, 41, -15, -16, 35, 31, 14, 61, 24, 0, 27, 24,
1006 16, 41, 55, 34, 53, 9, 56, 12, 25, 29, 53, 5, 20, -20, -8, 20,
1007 13, 28, -3, 78, 38, 16, 11, 62, 46, 29, 21, 24, 46, 65, 43, -23,
1008 89, 18, 74, 21, 38, -12, 19, 12, -19, 8, 15, 33, 4, 57, 9, -8,
1009 36, 35, 26, 28, 7, 83, 63, 79, 75, 11, 3, 87, 37, 47, 34, 40,
1010 39, 19, 20, 42, 27, 34, 39, 77, 13, 42, 59, 64, 45, -1, 32, 37,
1011 45, -5, 53, -6, 7, 36, 50, 23, 6, 32, 9, -21, 18, 71, 27, 52,
1012 -25, 31, 35, 42, -1, 68, 63, 52, 26, 43, 66, 37, 41, 25, 40, 70,
1029 uint32_t
seed =
s->noisegen_seed;
1030 unsigned int maxchan =
s->max_matrix_channel;
1032 for (
i = 0;
i <
s->blockpos;
i++) {
1033 uint16_t seed_shr7 =
seed >> 7;
1035 m->
sample_buffer[
i][maxchan+2] = ((int8_t) seed_shr7) * (1 <<
s->noise_shift);
1037 seed = (
seed << 16) ^ seed_shr7 ^ (seed_shr7 << 5);
1040 s->noisegen_seed =
seed;
1049 uint32_t
seed =
s->noisegen_seed;
1054 seed = (
seed << 8) ^ seed_shr15 ^ (seed_shr15 << 5);
1057 s->noisegen_seed =
seed;
1068 unsigned int maxchan;
1082 maxchan =
s->max_matrix_channel;
1083 if (!
s->noise_type) {
1092 for (mat = 0; mat <
s->num_primitive_matrices; mat++) {
1093 unsigned int dest_ch =
s->matrix_out_ch[mat];
1095 s->matrix_coeff[mat],
1098 s->num_primitive_matrices - mat,
1102 s->matrix_noise_shift[mat],
1108 frame->nb_samples =
s->blockpos;
1117 s->max_matrix_channel,
1134 int *got_frame_ptr,
AVPacket *avpkt)
1137 int buf_size = avpkt->
size;
1140 unsigned int length, substr;
1141 unsigned int substream_start;
1142 unsigned int header_size = 4;
1143 unsigned int substr_header_size = 0;
1154 if (length < 4 || length > buf_size)
1169 "Stream parameters not seen; skipping frame.\n");
1174 substream_start = 0;
1177 int extraword_present, checkdata_present,
end, nonrestart_substr;
1186 substr_header_size += 2;
1188 if (extraword_present) {
1194 substr_header_size += 2;
1197 if (
length < header_size + substr_header_size) {
1207 if (
end + header_size + substr_header_size >
length) {
1209 "Indicated length of substream %d data goes off end of "
1210 "packet.\n", substr);
1211 end =
length - header_size - substr_header_size;
1214 if (
end < substream_start) {
1216 "Indicated end offset of substream %d data "
1217 "is smaller than calculated start offset.\n",
1225 substream_parity_present[substr] = checkdata_present;
1226 substream_data_len[substr] =
end - substream_start;
1227 substream_start =
end;
1233 if ((((parity_bits >> 4) ^ parity_bits) & 0xF) != 0xF) {
1238 buf += header_size + substr_header_size;
1254 s->restart_seen = 1;
1257 if (!
s->restart_seen)
1263 if (!
s->restart_seen)
1270 goto substream_length_mismatch;
1276 if (substream_data_len[substr] * 8 -
get_bits_count(&gb) >= 32) {
1284 s->blockpos -=
FFMIN(shorten_by & 0x1FFF,
s->blockpos);
1292 if (substream_parity_present[substr]) {
1296 goto substream_length_mismatch;
1308 goto substream_length_mismatch;
1311 if (!
s->restart_seen)
1313 "No restart header present in substream %d.\n", substr);
1315 buf += substream_data_len[substr];
1323 substream_length_mismatch:
1332 #if CONFIG_MLP_DECODER
1344 #if CONFIG_TRUEHD_DECODER
uint8_t params_valid
Set if a valid major sync block has been read. Otherwise no decoding is possible.
int frame_size
Number of samples per channel in an audio frame.
#define AV_LOG_WARNING
Something somehow does not look correct.
static const int8_t noise_table[256]
Data table used for TrueHD noise generation function.
#define AV_CH_LAYOUT_5POINT0_BACK
static av_cold int init(AVCodecContext *avctx)
static unsigned int show_bits_long(GetBitContext *s, int n)
Show 0-32 bits.
uint8_t codebook
Which VLC codebook to use to read residuals.
static uint8_t xor_32_to_8(uint32_t value)
XOR four bytes into one.
int32_t matrix_coeff[MAX_MATRICES][MAX_CHANNELS]
Matrix coefficients, stored as 2.14 fixed point.
uint64_t channel_layout
Audio channel layout.
#define AV_CH_TOP_FRONT_CENTER
int sample_rate
samples per second
#define FFSWAP(type, a, b)
#define AV_CH_LOW_FREQUENCY_2
static const uint64_t thd_channel_order[]
#define INIT_VLC_STATIC(vlc, bits, a, b, c, d, e, f, g, static_size)
#define AV_CH_LAYOUT_MONO
int8_t output_shift[MAX_CHANNELS]
Left shift to apply to decoded PCM values to get final 24-bit output.
uint8_t pi<< 24) CONV_FUNC(AV_SAMPLE_FMT_S64, int64_t, AV_SAMPLE_FMT_U8,(uint64_t)((*(const uint8_t *) pi - 0x80U))<< 56) CONV_FUNC(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8,(*(const uint8_t *) pi - 0x80) *(1.0f/(1<< 7))) CONV_FUNC(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8,(*(const uint8_t *) pi - 0x80) *(1.0/(1<< 7))) CONV_FUNC(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16,(*(const int16_t *) pi >>8)+0x80) CONV_FUNC(AV_SAMPLE_FMT_S64, int64_t, AV_SAMPLE_FMT_S16,(uint64_t)(*(const int16_t *) pi)<< 48) CONV_FUNC(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, *(const int16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, *(const int16_t *) pi *(1.0/(1<< 15))) CONV_FUNC(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32,(*(const int32_t *) pi >>24)+0x80) CONV_FUNC(AV_SAMPLE_FMT_S64, int64_t, AV_SAMPLE_FMT_S32,(uint64_t)(*(const int32_t *) pi)<< 32) CONV_FUNC(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, *(const int32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, *(const int32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S64,(*(const int64_t *) pi >>56)+0x80) CONV_FUNC(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S64, *(const int64_t *) pi *(1.0f/(INT64_C(1)<< 63))) CONV_FUNC(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S64, *(const int64_t *) pi *(1.0/(INT64_C(1)<< 63))) CONV_FUNC(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, av_clip_uint8(lrintf(*(const float *) pi *(1<< 7))+0x80)) CONV_FUNC(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, av_clip_int16(lrintf(*(const float *) pi *(1<< 15)))) CONV_FUNC(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, av_clipl_int32(llrintf(*(const float *) pi *(1U<< 31)))) CONV_FUNC(AV_SAMPLE_FMT_S64, int64_t, AV_SAMPLE_FMT_FLT, llrintf(*(const float *) pi *(INT64_C(1)<< 63))) CONV_FUNC(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, av_clip_uint8(lrint(*(const double *) pi *(1<< 7))+0x80)) CONV_FUNC(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, av_clip_int16(lrint(*(const double *) pi *(1<< 15)))) CONV_FUNC(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, av_clipl_int32(llrint(*(const double *) pi *(1U<< 31)))) CONV_FUNC(AV_SAMPLE_FMT_S64, int64_t, AV_SAMPLE_FMT_DBL, llrint(*(const double *) pi *(INT64_C(1)<< 63))) #define FMT_PAIR_FUNC(out, in) static conv_func_type *const fmt_pair_to_conv_functions[AV_SAMPLE_FMT_NB *AV_SAMPLE_FMT_NB]={ FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_U8), FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_S16), FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_S32), FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_FLT), FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_DBL), FMT_PAIR_FUNC(AV_SAMPLE_FMT_U8, AV_SAMPLE_FMT_S64), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_S64), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S32, AV_SAMPLE_FMT_S64), FMT_PAIR_FUNC(AV_SAMPLE_FMT_FLT, AV_SAMPLE_FMT_S64), FMT_PAIR_FUNC(AV_SAMPLE_FMT_DBL, AV_SAMPLE_FMT_S64), FMT_PAIR_FUNC(AV_SAMPLE_FMT_S64, AV_SAMPLE_FMT_S64), };static void cpy1(uint8_t **dst, const uint8_t **src, int len){ memcpy(*dst, *src, len);} static void cpy2(uint8_t **dst, const uint8_t **src, int len){ memcpy(*dst, *src, 2 *len);} static void cpy4(uint8_t **dst, const uint8_t **src, int len){ memcpy(*dst, *src, 4 *len);} static void cpy8(uint8_t **dst, const uint8_t **src, int len){ memcpy(*dst, *src, 8 *len);} AudioConvert *swri_audio_convert_alloc(enum AVSampleFormat out_fmt, enum AVSampleFormat in_fmt, int channels, const int *ch_map, int flags) { AudioConvert *ctx;conv_func_type *f=fmt_pair_to_conv_functions[av_get_packed_sample_fmt(out_fmt)+AV_SAMPLE_FMT_NB *av_get_packed_sample_fmt(in_fmt)];if(!f) return NULL;ctx=av_mallocz(sizeof(*ctx));if(!ctx) return NULL;if(channels==1){ in_fmt=av_get_planar_sample_fmt(in_fmt);out_fmt=av_get_planar_sample_fmt(out_fmt);} ctx->channels=channels;ctx->conv_f=f;ctx->ch_map=ch_map;if(in_fmt==AV_SAMPLE_FMT_U8||in_fmt==AV_SAMPLE_FMT_U8P) memset(ctx->silence, 0x80, sizeof(ctx->silence));if(out_fmt==in_fmt &&!ch_map) { switch(av_get_bytes_per_sample(in_fmt)){ case 1:ctx->simd_f=cpy1;break;case 2:ctx->simd_f=cpy2;break;case 4:ctx->simd_f=cpy4;break;case 8:ctx->simd_f=cpy8;break;} } if(HAVE_X86ASM &&1) swri_audio_convert_init_x86(ctx, out_fmt, in_fmt, channels);if(ARCH_ARM) swri_audio_convert_init_arm(ctx, out_fmt, in_fmt, channels);if(ARCH_AARCH64) swri_audio_convert_init_aarch64(ctx, out_fmt, in_fmt, channels);return ctx;} void swri_audio_convert_free(AudioConvert **ctx) { av_freep(ctx);} int swri_audio_convert(AudioConvert *ctx, AudioData *out, AudioData *in, int len) { int ch;int off=0;const int os=(out->planar ? 1 :out->ch_count) *out->bps;unsigned misaligned=0;av_assert0(ctx->channels==out->ch_count);if(ctx->in_simd_align_mask) { int planes=in->planar ? in->ch_count :1;unsigned m=0;for(ch=0;ch< planes;ch++) m|=(intptr_t) in->ch[ch];misaligned|=m &ctx->in_simd_align_mask;} if(ctx->out_simd_align_mask) { int planes=out->planar ? out->ch_count :1;unsigned m=0;for(ch=0;ch< planes;ch++) m|=(intptr_t) out->ch[ch];misaligned|=m &ctx->out_simd_align_mask;} if(ctx->simd_f &&!ctx->ch_map &&!misaligned){ off=len &~15;av_assert1(off >=0);av_assert1(off<=len);av_assert2(ctx->channels==SWR_CH_MAX||!in->ch[ctx->channels]);if(off >0){ if(out->planar==in->planar){ int planes=out->planar ? out->ch_count :1;for(ch=0;ch< planes;ch++){ ctx->simd_f(out-> ch ch
@ THD_CH_MODIFIER_SURROUNDEX
static int get_bits_count(const GetBitContext *s)
static int read_decoding_params(MLPDecodeContext *m, GetBitContext *gbp, unsigned int substr)
Read decoding parameters that change more often than those in the restart header.
#define MAX_SAMPLERATE
maximum sample frequency seen in files
#define AV_CH_TOP_FRONT_RIGHT
static av_cold void init_static(void)
Initialize static data, constant between all invocations of the codec.
static av_cold int end(AVCodecContext *avctx)
This structure describes decoded (raw) audio or video data.
uint8_t ff_mlp_calculate_parity(const uint8_t *buf, unsigned int buf_size)
XOR together all the bytes of a buffer.
static const uint16_t table[]
static void filter_channel(MLPDecodeContext *m, unsigned int substr, unsigned int channel)
Generate PCM samples using the prediction filters and residual values read from the data stream,...
AVCodec ff_truehd_decoder
uint8_t restart_seen
Set if a valid restart header has been read. Otherwise the substream cannot be decoded.
static av_always_inline int get_vlc2(GetBitContext *s, VLC_TYPE(*table)[2], int bits, int max_depth)
Parse a vlc code.
static int output_data(MLPDecodeContext *m, unsigned int substr, AVFrame *frame, int *got_frame_ptr)
Write the audio data into the output buffer.
uint64_t mask
The channel layout for this substream.
uint8_t min_channel
The index of the first channel coded in this substream.
#define AV_CH_TOP_FRONT_LEFT
int major_sync_header_size
Size of the major sync unit, in bytes.
filter_frame For filters that do not use the this method is called when a frame is pushed to the filter s input It can be called at any time except in a reentrant way If the input frame is enough to produce then the filter should push the output frames on the output link immediately As an exception to the previous rule if the input frame is enough to produce several output frames then the filter needs output only at least one per link The additional frames can be left buffered in the filter
uint64_t request_channel_layout
Request decoder to use this channel layout if it can (0 for default)
av_cold void ff_mlpdsp_init(MLPDSPContext *c)
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
uint8_t max_channel
The index of the last channel coded in this substream.
uint8_t ch_assign[MAX_CHANNELS]
For each channel output by the matrix, the output channel to map it to.
#define AV_CH_SURROUND_DIRECT_RIGHT
int32_t(* mlp_pack_output)(int32_t lossless_check_data, uint16_t blockpos, int32_t(*sample_buffer)[MAX_CHANNELS], void *data, uint8_t *ch_assign, int8_t *output_shift, uint8_t max_matrix_channel, int is32)
static void skip_bits(GetBitContext *s, int n)
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
FilterParams filter_params[NUM_FILTERS]
uint8_t ff_mlp_checksum8(const uint8_t *buf, unsigned int buf_size)
MLP uses checksums that seem to be based on the standard CRC algorithm, but are not (in implementatio...
uint8_t huff_lsbs
Size of residual suffix not encoded using VLC.
static int32_t calculate_sign_huff(MLPDecodeContext *m, unsigned int substr, unsigned int ch)
#define AV_CH_LAYOUT_STEREO
#define AV_CH_LAYOUT_QUAD
#define MAX_MATRICES_MLP
Maximum number of matrices used in decoding; most streams have one matrix per output channel,...
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
uint8_t needs_reordering
Stream needs channel reordering to comply with FFmpeg's channel order.
@ AV_MATRIX_ENCODING_DOLBY
ChannelParams channel_params[MAX_CHANNELS]
Channel coding parameters for channels in the substream.
#define AV_CH_LOW_FREQUENCY
static const uint16_t mask[17]
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, FILE *outfile)
void(* mlp_filter_channel)(int32_t *state, const int32_t *coeff, int firorder, int iirorder, unsigned int filter_shift, int32_t mask, int blocksize, int32_t *sample_buffer)
#define av_assert0(cond)
assert() equivalent, that is always enabled.
int bits_per_raw_sample
Bits per sample/pixel of internal libavcodec pixel/sample format.
static int get_sbits(GetBitContext *s, int n)
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
int32_t(*(* mlp_select_pack_output)(uint8_t *ch_assign, int8_t *output_shift, uint8_t max_matrix_channel, int is32))(int32_t
@ AV_MATRIX_ENCODING_DOLBYHEADPHONE
and forward the result(frame or status change) to the corresponding input. If nothing is possible
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
static uint64_t thd_channel_layout_extract_channel(uint64_t channel_layout, int index)
int32_t lossless_check_data
Running XOR of all output samples.
int8_t bypassed_lsbs[MAX_BLOCKSIZE][MAX_CHANNELS]
uint8_t quant_step_size[MAX_CHANNELS]
Left shift to apply to Huffman-decoded residuals.
static unsigned int get_bits1(GetBitContext *s)
int filter_changed[MAX_CHANNELS][NUM_FILTERS]
#define AV_CH_FRONT_CENTER
#define AV_CH_FRONT_LEFT_OF_CENTER
int access_unit_size
number of PCM samples contained in each frame
int av_get_channel_layout_nb_channels(uint64_t channel_layout)
Return the number of channels in the channel layout.
uint8_t max_matrix_channel
The number of channels input into the rematrix stage.
static void error(const char *err)
@ THD_CH_MODIFIER_LBINRBIN
int32_t sample_buffer[MAX_BLOCKSIZE][MAX_CHANNELS]
uint8_t ff_mlp_restart_checksum(const uint8_t *buf, unsigned int bit_size)
Calculate an 8-bit checksum over a restart header – a non-multiple-of-8 number of bits,...
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame.
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
#define MAX_MATRIX_CHANNEL_MLP
Last possible matrix channel for each codec.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
uint16_t noise_type
restart header data
uint8_t num_substreams
Number of substreams contained within this stream.
SubStream substream[MAX_SUBSTREAMS]
@ AV_MATRIX_ENCODING_NONE
enum AVSampleFormat sample_fmt
audio sample format
#define MAX_SUBSTREAMS
Maximum number of substreams that can be decoded.
int is_major_sync_unit
Current access unit being read has a major sync.
#define MAX_MATRIX_CHANNEL_TRUEHD
static av_cold int mlp_decode_init(AVCodecContext *avctx)
#define MAX_MATRICES_TRUEHD
#define NUM_FILTERS
number of allowed filters
uint8_t order
number of taps in filter
int ff_mlp_read_major_sync(void *log, MLPHeaderInfo *mh, GetBitContext *gb)
Read a major sync info header - contains high level information about the stream - sample rate,...
#define AV_CH_LAYOUT_5POINT1_BACK
int16_t huff_offset
Offset to apply to residual values.
static void skip_bits1(GetBitContext *s)
#define AV_CH_FRONT_RIGHT_OF_CENTER
uint32_t noisegen_seed
The current seed value for the pseudorandom noise generator(s).
uint8_t max_decoded_substream
Index of the last substream to decode - further substreams are skipped.
uint8_t lsb_bypass[MAX_MATRICES]
Whether the LSBs of the matrix output are encoded in the bitstream.
uint8_t matrix_out_ch[MAX_MATRICES]
matrix output channel
#define MAX_FIR_ORDER
The maximum number of taps in IIR and FIR filters.
void(* mlp_rematrix_channel)(int32_t *samples, const int32_t *coeffs, const uint8_t *bypassed_lsbs, const int8_t *noise_buffer, int index, unsigned int dest_ch, uint16_t blockpos, unsigned int maxchan, int matrix_noise_shift, int access_unit_size_pow2, int32_t mask)
#define AV_LOG_INFO
Standard information.
static int mlp_channel_layout_subset(uint64_t channel_layout, uint64_t mask)
int channels
number of audio channels
#define DECLARE_ALIGNED(n, t, v)
static int read_restart_header(MLPDecodeContext *m, GetBitContext *gbp, const uint8_t *buf, unsigned int substr)
Read a restart header from a block in a substream.
#define i(width, name, range_min, range_max)
uint16_t blockpos
Number of PCM samples decoded so far in this frame.
uint8_t noise_shift
The left shift applied to random noise in 0x31ea substreams.
uint16_t blocksize
number of PCM samples in current audio block
int av_get_channel_layout_channel_index(uint64_t channel_layout, uint64_t channel)
Get the index of a channel in channel_layout.
#define AV_CH_BACK_CENTER
@ AV_SAMPLE_FMT_S16
signed 16 bits
static int read_channel_params(MLPDecodeContext *m, unsigned int substr, GetBitContext *gbp, unsigned int ch)
Read channel parameters.
const char * name
Name of the codec implementation.
sample data coding information
static void fill_noise_buffer(MLPDecodeContext *m, unsigned int substr)
Generate a block of noise, used when restart sync word == 0x31eb.
av_cold void ff_mlp_init_crc(void)
int32_t sign_huff_offset
sign/rounding-corrected version of huff_offset
int access_unit_size_pow2
next power of two above the number of samples in each frame
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
uint8_t num_primitive_matrices
matrix data
static volatile int checksum
int32_t state[MAX_FIR_ORDER]
#define FF_ARRAY_ELEMS(a)
uint8_t data_check_present
Set if the substream contains extra info to check the size of VLC blocks.
uint8_t matrix_noise_shift[MAX_MATRICES]
Left shift to apply to noise values in 0x31eb substreams.
main external API structure.
#define VLC_BITS
number of bits used for VLC lookup - longest Huffman code is 9
static int read_access_unit(AVCodecContext *avctx, void *data, int *got_frame_ptr, AVPacket *avpkt)
Read an access unit from the stream.
@ AV_MATRIX_ENCODING_DOLBYEX
#define AV_CH_SURROUND_DIRECT_LEFT
#define AV_CH_FRONT_RIGHT
int ff_side_data_update_matrix_encoding(AVFrame *frame, enum AVMatrixEncoding matrix_encoding)
Add or update AV_FRAME_DATA_MATRIXENCODING side data.
static int read_filter_params(MLPDecodeContext *m, GetBitContext *gbp, unsigned int substr, unsigned int channel, unsigned int filter)
Read parameters for one of the prediction filters.
static int read_huff_channels(MLPDecodeContext *m, GetBitContext *gbp, unsigned int substr, unsigned int pos)
Read a sample, consisting of either, both or neither of entropy-coded MSBs and plain LSBs.
#define avpriv_request_sample(...)
static int read_major_sync(MLPDecodeContext *m, GetBitContext *gb)
Read a major sync info header - contains high level information about the stream - sample rate,...
const uint8_t ff_mlp_huffman_tables[3][18][2]
Tables defining the Huffman codes.
uint8_t param_presence_flags
Bitmask of which parameter sets are conveyed in a decoding parameter block.
This structure stores compressed data.
static int read_matrix_params(MLPDecodeContext *m, unsigned int substr, GetBitContext *gbp)
Read parameters for primitive matrices.
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
uint8_t shift
Right shift to apply to output of filter.
@ AV_SAMPLE_FMT_S32
signed 32 bits
static void generate_2_noise_channels(MLPDecodeContext *m, unsigned int substr)
Noise generation functions.
enum AVMatrixEncoding matrix_encoding
The matrix encoding mode for this substream.
#define MAX_BLOCKSIZE_POW2
next power of two greater than MAX_BLOCKSIZE
int8_t noise_buffer[MAX_BLOCKSIZE_POW2]
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_WB24 unsigned int_TMPL AV_RB16
static int read_block_data(MLPDecodeContext *m, GetBitContext *gbp, unsigned int substr)
Read a block of PCM residual data (or actual if no filtering active).