aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2020-09-18 12:08:42 +0200
committerPaul B Mahol <onemda@gmail.com>2020-10-03 21:49:39 +0200
commite0d0565425b418d8ac6f383c5377e690feaf181f (patch)
tree12afc628ac8a3ec3b9fde832366308653a5297cb
parent45070eec4c089b06947f07e25cdb1bc8b2102553 (diff)
downloadffmpeg-e0d0565425b418d8ac6f383c5377e690feaf181f.tar.gz
avformat/adxdec: demux multiple blocks at once
Improves decoding speed by 24x
-rw-r--r--libavformat/adxdec.c26
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;
}