|
|
@ -81,114 +81,68 @@ static void get_array(GetBitContext *s, int32_t *array, int size, int n) |
|
|
|
// 5.3.1 - Bit stream header
|
|
|
|
// 5.3.1 - Bit stream header
|
|
|
|
static int parse_frame_header(DCACoreDecoder *s) |
|
|
|
static int parse_frame_header(DCACoreDecoder *s) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int normal_frame, pcmr_index; |
|
|
|
DCACoreFrameHeader h = { 0 }; |
|
|
|
|
|
|
|
int err = avpriv_dca_parse_core_frame_header(&s->gb, &h); |
|
|
|
|
|
|
|
|
|
|
|
// Frame type
|
|
|
|
if (err < 0) { |
|
|
|
normal_frame = get_bits1(&s->gb); |
|
|
|
switch (err) { |
|
|
|
|
|
|
|
case DCA_PARSE_ERROR_DEFICIT_SAMPLES: |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Deficit samples are not supported\n"); |
|
|
|
|
|
|
|
return h.normal_frame ? AVERROR_INVALIDDATA : AVERROR_PATCHWELCOME; |
|
|
|
|
|
|
|
|
|
|
|
// Deficit sample count
|
|
|
|
case DCA_PARSE_ERROR_PCM_BLOCKS: |
|
|
|
if (get_bits(&s->gb, 5) != DCA_PCMBLOCK_SAMPLES - 1) { |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Unsupported number of PCM sample blocks (%d)\n", h.npcmblocks); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Deficit samples are not supported\n"); |
|
|
|
return (h.npcmblocks < 6 || h.normal_frame) ? AVERROR_INVALIDDATA : AVERROR_PATCHWELCOME; |
|
|
|
return normal_frame ? AVERROR_INVALIDDATA : AVERROR_PATCHWELCOME; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// CRC present flag
|
|
|
|
|
|
|
|
s->crc_present = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Number of PCM sample blocks
|
|
|
|
|
|
|
|
s->npcmblocks = get_bits(&s->gb, 7) + 1; |
|
|
|
|
|
|
|
if (s->npcmblocks & (DCA_SUBBAND_SAMPLES - 1)) { |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Unsupported number of PCM sample blocks (%d)\n", s->npcmblocks); |
|
|
|
|
|
|
|
return (s->npcmblocks < 6 || normal_frame) ? AVERROR_INVALIDDATA : AVERROR_PATCHWELCOME; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Primary frame byte size
|
|
|
|
|
|
|
|
s->frame_size = get_bits(&s->gb, 14) + 1; |
|
|
|
|
|
|
|
if (s->frame_size < 96) { |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid core frame size (%d bytes)\n", s->frame_size); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Audio channel arrangement
|
|
|
|
|
|
|
|
s->audio_mode = get_bits(&s->gb, 6); |
|
|
|
|
|
|
|
if (s->audio_mode >= DCA_AMODE_COUNT) { |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Unsupported audio channel arrangement (%d)\n", s->audio_mode); |
|
|
|
|
|
|
|
return AVERROR_PATCHWELCOME; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Core audio sampling frequency
|
|
|
|
|
|
|
|
s->sample_rate = avpriv_dca_sample_rates[get_bits(&s->gb, 4)]; |
|
|
|
|
|
|
|
if (!s->sample_rate) { |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid core audio sampling frequency\n"); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Transmission bit rate
|
|
|
|
|
|
|
|
s->bit_rate = ff_dca_bit_rates[get_bits(&s->gb, 5)]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Reserved field
|
|
|
|
|
|
|
|
skip_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Embedded dynamic range flag
|
|
|
|
|
|
|
|
s->drc_present = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Embedded time stamp flag
|
|
|
|
|
|
|
|
s->ts_present = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Auxiliary data flag
|
|
|
|
|
|
|
|
s->aux_present = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// HDCD mastering flag
|
|
|
|
|
|
|
|
skip_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Extension audio descriptor flag
|
|
|
|
case DCA_PARSE_ERROR_FRAME_SIZE: |
|
|
|
s->ext_audio_type = get_bits(&s->gb, 3); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid core frame size (%d bytes)\n", h.frame_size); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
// Extended coding flag
|
|
|
|
|
|
|
|
s->ext_audio_present = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Audio sync word insertion flag
|
|
|
|
|
|
|
|
s->sync_ssf = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Low frequency effects flag
|
|
|
|
|
|
|
|
s->lfe_present = get_bits(&s->gb, 2); |
|
|
|
|
|
|
|
if (s->lfe_present == DCA_LFE_FLAG_INVALID) { |
|
|
|
|
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid low frequency effects flag\n"); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Predictor history flag switch
|
|
|
|
case DCA_PARSE_ERROR_AMODE: |
|
|
|
s->predictor_history = get_bits1(&s->gb); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Unsupported audio channel arrangement (%d)\n", h.audio_mode); |
|
|
|
|
|
|
|
return AVERROR_PATCHWELCOME; |
|
|
|
|
|
|
|
|
|
|
|
// Header CRC check bytes
|
|
|
|
case DCA_PARSE_ERROR_SAMPLE_RATE: |
|
|
|
if (s->crc_present) |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid core audio sampling frequency\n"); |
|
|
|
skip_bits(&s->gb, 16); |
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
|
|
|
|
// Multirate interpolator switch
|
|
|
|
case DCA_PARSE_ERROR_RESERVED_BIT: |
|
|
|
s->filter_perfect = get_bits1(&s->gb); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Reserved bit set\n"); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
|
|
|
|
// Encoder software revision
|
|
|
|
case DCA_PARSE_ERROR_LFE_FLAG: |
|
|
|
skip_bits(&s->gb, 4); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid low frequency effects flag\n"); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
|
|
|
|
// Copy history
|
|
|
|
case DCA_PARSE_ERROR_PCM_RES: |
|
|
|
skip_bits(&s->gb, 2); |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid source PCM resolution\n"); |
|
|
|
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
|
|
|
|
// Source PCM resolution
|
|
|
|
default: |
|
|
|
s->source_pcm_res = ff_dca_bits_per_sample[pcmr_index = get_bits(&s->gb, 3)]; |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Unknown core frame header error\n"); |
|
|
|
if (!s->source_pcm_res) { |
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
av_log(s->avctx, AV_LOG_ERROR, "Invalid source PCM resolution\n"); |
|
|
|
} |
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
s->es_format = pcmr_index & 1; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Front sum/difference flag
|
|
|
|
|
|
|
|
s->sumdiff_front = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Surround sum/difference flag
|
|
|
|
|
|
|
|
s->sumdiff_surround = get_bits1(&s->gb); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Dialog normalization / unspecified
|
|
|
|
s->crc_present = h.crc_present; |
|
|
|
skip_bits(&s->gb, 4); |
|
|
|
s->npcmblocks = h.npcmblocks; |
|
|
|
|
|
|
|
s->frame_size = h.frame_size; |
|
|
|
|
|
|
|
s->audio_mode = h.audio_mode; |
|
|
|
|
|
|
|
s->sample_rate = avpriv_dca_sample_rates[h.sr_code]; |
|
|
|
|
|
|
|
s->bit_rate = ff_dca_bit_rates[h.br_code]; |
|
|
|
|
|
|
|
s->drc_present = h.drc_present; |
|
|
|
|
|
|
|
s->ts_present = h.ts_present; |
|
|
|
|
|
|
|
s->aux_present = h.aux_present; |
|
|
|
|
|
|
|
s->ext_audio_type = h.ext_audio_type; |
|
|
|
|
|
|
|
s->ext_audio_present = h.ext_audio_present; |
|
|
|
|
|
|
|
s->sync_ssf = h.sync_ssf; |
|
|
|
|
|
|
|
s->lfe_present = h.lfe_present; |
|
|
|
|
|
|
|
s->predictor_history = h.predictor_history; |
|
|
|
|
|
|
|
s->filter_perfect = h.filter_perfect; |
|
|
|
|
|
|
|
s->source_pcm_res = ff_dca_bits_per_sample[h.pcmr_code]; |
|
|
|
|
|
|
|
s->es_format = h.pcmr_code & 1; |
|
|
|
|
|
|
|
s->sumdiff_front = h.sumdiff_front; |
|
|
|
|
|
|
|
s->sumdiff_surround = h.sumdiff_surround; |
|
|
|
|
|
|
|
|
|
|
|
return 0; |
|
|
|
return 0; |
|
|
|
} |
|
|
|
} |
|
|
@ -1850,7 +1804,6 @@ int ff_dca_core_parse(DCACoreDecoder *s, uint8_t *data, int size) |
|
|
|
if ((ret = init_get_bits8(&s->gb, data, size)) < 0) |
|
|
|
if ((ret = init_get_bits8(&s->gb, data, size)) < 0) |
|
|
|
return ret; |
|
|
|
return ret; |
|
|
|
|
|
|
|
|
|
|
|
skip_bits_long(&s->gb, 32); |
|
|
|
|
|
|
|
if ((ret = parse_frame_header(s)) < 0) |
|
|
|
if ((ret = parse_frame_header(s)) < 0) |
|
|
|
return ret; |
|
|
|
return ret; |
|
|
|
if ((ret = alloc_sample_buffer(s)) < 0) |
|
|
|
if ((ret = alloc_sample_buffer(s)) < 0) |
|
|
|