diff options
author | Paul B Mahol <onemda@gmail.com> | 2020-09-18 12:08:42 +0200 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2020-10-03 21:49:39 +0200 |
commit | e0d0565425b418d8ac6f383c5377e690feaf181f (patch) | |
tree | 12afc628ac8a3ec3b9fde832366308653a5297cb | |
parent | 45070eec4c089b06947f07e25cdb1bc8b2102553 (diff) | |
download | ffmpeg-e0d0565425b418d8ac6f383c5377e690feaf181f.tar.gz |
avformat/adxdec: demux multiple blocks at once
Improves decoding speed by 24x
-rw-r--r-- | libavformat/adxdec.c | 26 |
1 files changed, 17 insertions, 9 deletions
diff --git a/libavformat/adxdec.c b/libavformat/adxdec.c index ccd5049acd..a265c87dea 100644 --- a/libavformat/adxdec.c +++ b/libavformat/adxdec.c @@ -53,6 +53,9 @@ static int adx_read_packet(AVFormatContext *s, AVPacket *pkt) AVCodecParameters *par = s->streams[0]->codecpar; int ret, size; + if (avio_feof(s->pb)) + return AVERROR_EOF; + if (par->channels <= 0) { av_log(s, AV_LOG_ERROR, "invalid number of channels %d\n", par->channels); return AVERROR_INVALIDDATA; @@ -63,16 +66,21 @@ static int adx_read_packet(AVFormatContext *s, AVPacket *pkt) pkt->pos = avio_tell(s->pb); pkt->stream_index = 0; - ret = av_get_packet(s->pb, pkt, size); - if (ret != size) { - return ret < 0 ? ret : AVERROR(EIO); - } - if (AV_RB16(pkt->data) & 0x8000) { - return AVERROR_EOF; + ret = av_get_packet(s->pb, pkt, size * 128); + if (ret < 0) + return ret; + if ((ret % size) && ret >= size) { + size = ret - (ret % size); + av_shrink_packet(pkt, size); + pkt->flags &= ~AV_PKT_FLAG_CORRUPT; + } else if (ret < size) { + return AVERROR(EIO); + } else { + size = ret; } - pkt->size = size; - pkt->duration = 1; - pkt->pts = (pkt->pos - c->header_size) / size; + + pkt->duration = size / (BLOCK_SIZE * par->channels); + pkt->pts = (pkt->pos - c->header_size) / (BLOCK_SIZE * par->channels); return 0; } |