|
|
|
@@ -203,7 +203,6 @@ static int mpc7_decode_frame(AVCodecContext * avctx, void *data, |
|
|
|
int buf_size = avpkt->size; |
|
|
|
MPCContext *c = avctx->priv_data; |
|
|
|
GetBitContext gb; |
|
|
|
uint8_t *bits; |
|
|
|
int i, ch; |
|
|
|
int mb = -1; |
|
|
|
Band *bands = c->bands; |
|
|
|
@@ -223,9 +222,11 @@ static int mpc7_decode_frame(AVCodecContext * avctx, void *data, |
|
|
|
return ret; |
|
|
|
} |
|
|
|
|
|
|
|
bits = av_malloc(((buf_size - 1) & ~3) + FF_INPUT_BUFFER_PADDING_SIZE); |
|
|
|
c->dsp.bswap_buf((uint32_t*)bits, (const uint32_t*)(buf + 4), (buf_size - 4) >> 2); |
|
|
|
init_get_bits(&gb, bits, (buf_size - 4)* 8); |
|
|
|
av_fast_padded_malloc(&c->buffer, &c->buffer_size, FFALIGN(buf_size - 1, 4)); |
|
|
|
if (!c->buffer) |
|
|
|
return AVERROR(ENOMEM); |
|
|
|
c->dsp.bswap_buf((uint32_t*)c->buffer, (const uint32_t*)(buf + 4), (buf_size - 4) >> 2); |
|
|
|
init_get_bits(&gb, c->buffer, (buf_size - 4)* 8); |
|
|
|
skip_bits_long(&gb, buf[0]); |
|
|
|
|
|
|
|
/* read subband indexes */ |
|
|
|
@@ -282,8 +283,6 @@ static int mpc7_decode_frame(AVCodecContext * avctx, void *data, |
|
|
|
|
|
|
|
ff_mpc_dequantize_and_synth(c, mb, c->frame.data[0], 2); |
|
|
|
|
|
|
|
av_free(bits); |
|
|
|
|
|
|
|
bits_used = get_bits_count(&gb); |
|
|
|
bits_avail = (buf_size - 4) * 8; |
|
|
|
if(!buf[1] && ((bits_avail < bits_used) || (bits_used + 32 <= bits_avail))){ |
|
|
|
@@ -310,12 +309,21 @@ static void mpc7_decode_flush(AVCodecContext *avctx) |
|
|
|
c->frames_to_skip = 32; |
|
|
|
} |
|
|
|
|
|
|
|
static av_cold int mpc7_decode_close(AVCodecContext *avctx) |
|
|
|
{ |
|
|
|
MPCContext *c = avctx->priv_data; |
|
|
|
av_freep(&c->buffer); |
|
|
|
c->buffer_size = 0; |
|
|
|
return 0; |
|
|
|
} |
|
|
|
|
|
|
|
AVCodec ff_mpc7_decoder = { |
|
|
|
.name = "mpc7", |
|
|
|
.type = AVMEDIA_TYPE_AUDIO, |
|
|
|
.id = CODEC_ID_MUSEPACK7, |
|
|
|
.priv_data_size = sizeof(MPCContext), |
|
|
|
.init = mpc7_decode_init, |
|
|
|
.close = mpc7_decode_close, |
|
|
|
.decode = mpc7_decode_frame, |
|
|
|
.flush = mpc7_decode_flush, |
|
|
|
.capabilities = CODEC_CAP_DR1, |
|
|
|
|