aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2011-08-15 12:03:40 +0200
committerAnton Khirnov <anton@khirnov.net>2011-08-17 15:00:42 +0200
commit48ce8b8da714558c8738610d5512b6c3c95c901a (patch)
treee64cb0a2bed12def3eb1294f35ff6f4cdfbfcccf
parent7c1f6df4b5f80ead35b66e5373af6c8046bace56 (diff)
downloadffmpeg-48ce8b8da714558c8738610d5512b6c3c95c901a.tar.gz
Use parsers for RealVideo 3/4 to determine correct PTS
Signed-off-by: Anton Khirnov <anton@khirnov.net>
-rw-r--r--libavcodec/Makefile2
-rw-r--r--libavcodec/allcodecs.c2
-rw-r--r--libavcodec/rv34_parser.c97
-rw-r--r--libavformat/rmdec.c1
-rw-r--r--tests/ref/fate/real-rv40205
-rw-r--r--tests/ref/fate/rv3063
6 files changed, 235 insertions, 135 deletions
diff --git a/libavcodec/Makefile b/libavcodec/Makefile
index 36e07a9fc1..2264e86b7d 100644
--- a/libavcodec/Makefile
+++ b/libavcodec/Makefile
@@ -616,6 +616,8 @@ OBJS-$(CONFIG_MPEGVIDEO_PARSER) += mpegvideo_parser.o \
mpeg12.o mpeg12data.o \
mpegvideo.o error_resilience.o
OBJS-$(CONFIG_PNM_PARSER) += pnm_parser.o pnm.o
+OBJS-$(CONFIG_RV30_PARSER) += rv34_parser.o
+OBJS-$(CONFIG_RV40_PARSER) += rv34_parser.o
OBJS-$(CONFIG_VC1_PARSER) += vc1_parser.o vc1.o vc1data.o \
msmpeg4.o msmpeg4data.o mpeg4video.o \
h263.o mpegvideo.o error_resilience.o
diff --git a/libavcodec/allcodecs.c b/libavcodec/allcodecs.c
index dcef0d6d94..7ba945c3d4 100644
--- a/libavcodec/allcodecs.c
+++ b/libavcodec/allcodecs.c
@@ -396,6 +396,8 @@ void avcodec_register_all(void)
REGISTER_PARSER (MPEGAUDIO, mpegaudio);
REGISTER_PARSER (MPEGVIDEO, mpegvideo);
REGISTER_PARSER (PNM, pnm);
+ REGISTER_PARSER (RV30, rv30);
+ REGISTER_PARSER (RV40, rv40);
REGISTER_PARSER (VC1, vc1);
REGISTER_PARSER (VP3, vp3);
REGISTER_PARSER (VP8, vp8);
diff --git a/libavcodec/rv34_parser.c b/libavcodec/rv34_parser.c
new file mode 100644
index 0000000000..c2563a5fdc
--- /dev/null
+++ b/libavcodec/rv34_parser.c
@@ -0,0 +1,97 @@
+/*
+ * RV30/40 parser
+ * Copyright (c) 2011 Konstantin Shishkov
+ *
+ * This file is part of Libav.
+ *
+ * Libav is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * Libav is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with Libav; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+/**
+ * @file
+ * RV30/40 parser
+ */
+
+#include "parser.h"
+#include "libavutil/intreadwrite.h"
+
+typedef struct {
+ ParseContext pc;
+ int64_t key_dts;
+ int key_pts;
+} RV34ParseContext;
+
+static const int rv_to_av_frame_type[4] = {
+ AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B,
+};
+
+static int rv34_parse(AVCodecParserContext *s,
+ AVCodecContext *avctx,
+ const uint8_t **poutbuf, int *poutbuf_size,
+ const uint8_t *buf, int buf_size)
+{
+ RV34ParseContext *pc = s->priv_data;
+ int off;
+ int type, pts, hdr;
+
+ if (buf_size < 13 + *buf * 8) {
+ *poutbuf = buf;
+ *poutbuf_size = buf_size;
+ return buf_size;
+ }
+
+ off = AV_RL32(buf + 5);
+ hdr = AV_RB32(buf + 9 + *buf * 8);
+ if (avctx->codec_id == CODEC_ID_RV30) {
+ type = (hdr >> 27) & 3;
+ pts = (hdr >> 7) & 0x1FFF;
+ } else {
+ type = (hdr >> 29) & 3;
+ pts = (hdr >> 6) & 0x1FFF;
+ }
+
+ if (type != 3 && s->pts != AV_NOPTS_VALUE) {
+ pc->key_dts = s->pts;
+ pc->key_pts = pts;
+ } else {
+ if (type != 3)
+ s->pts = pc->key_dts + ((pts - pc->key_pts) & 0x1FFF);
+ else
+ s->pts = pc->key_dts - ((pc->key_pts - pts) & 0x1FFF);
+ }
+ s->pict_type = rv_to_av_frame_type[type];
+
+ *poutbuf = buf;
+ *poutbuf_size = buf_size;
+ return buf_size;
+}
+
+#ifdef CONFIG_RV30_PARSER
+AVCodecParser ff_rv30_parser = {
+ { CODEC_ID_RV30 },
+ sizeof(RV34ParseContext),
+ NULL,
+ rv34_parse,
+};
+#endif
+
+#ifdef CONFIG_RV40_PARSER
+AVCodecParser ff_rv40_parser = {
+ { CODEC_ID_RV40 },
+ sizeof(RV34ParseContext),
+ NULL,
+ rv34_parse,
+};
+#endif
diff --git a/libavformat/rmdec.c b/libavformat/rmdec.c
index 5ee75b53b9..cf5c46a095 100644
--- a/libavformat/rmdec.c
+++ b/libavformat/rmdec.c
@@ -298,6 +298,7 @@ ff_rm_read_mdpr_codecdata (AVFormatContext *s, AVIOContext *pb,
st->codec->time_base.num= 1;
fps= avio_rb16(pb);
st->codec->codec_type = AVMEDIA_TYPE_VIDEO;
+ st->need_parsing = AVSTREAM_PARSE_TIMESTAMPS;
avio_rb32(pb);
avio_skip(pb, 2);
avio_rb16(pb);
diff --git a/tests/ref/fate/real-rv40 b/tests/ref/fate/real-rv40
index 990a530436..22cc731c89 100644
--- a/tests/ref/fate/real-rv40
+++ b/tests/ref/fate/real-rv40
@@ -16,106 +16,105 @@
0, 112500, 276480, 0x5f7a0d4f
0, 120000, 276480, 0x5f7a0d4f
0, 127500, 276480, 0x5f7a0d4f
-0, 135000, 276480, 0x75641594
-0, 142500, 276480, 0x32ee3526
-0, 150000, 276480, 0x5ce39368
-0, 157500, 276480, 0x4ec1e418
-0, 165000, 276480, 0x85cbc3b5
-0, 172500, 276480, 0x377c7b46
-0, 180000, 276480, 0x756a4a2e
-0, 187500, 276480, 0xcb379547
-0, 195000, 276480, 0x99c085be
-0, 202500, 276480, 0xe479ffed
-0, 210000, 276480, 0x1e4fae19
-0, 217500, 276480, 0x776412ef
-0, 225000, 276480, 0x58ce0f38
-0, 232500, 276480, 0x5ab69b27
-0, 240000, 276480, 0xc3db9706
-0, 247500, 276480, 0xc9c57884
-0, 255000, 276480, 0x000b5269
-0, 262500, 276480, 0x27ff7a5d
-0, 270000, 276480, 0x70647530
-0, 277500, 276480, 0x97612c4b
-0, 285000, 276480, 0xdf4e04d7
-0, 292500, 276480, 0xbd98f57c
-0, 300000, 276480, 0x5163b29b
-0, 307500, 276480, 0x99170e64
-0, 315000, 276480, 0x8a4e991f
-0, 322500, 276480, 0x6a45425f
-0, 330000, 276480, 0x7bf6b1ef
-0, 337500, 276480, 0x6de1e34b
-0, 345000, 276480, 0xdcaaa99a
-0, 352500, 276480, 0xd1e98808
-0, 360000, 276480, 0x6e2d524e
-0, 367500, 276480, 0x22c50a3d
-0, 375000, 276480, 0x62b76407
-0, 382500, 276480, 0x51e9b3eb
-0, 390000, 276480, 0x441f7afd
-0, 397500, 276480, 0xfb01efc6
-0, 405000, 276480, 0x294bb441
-0, 412500, 276480, 0xe04ac45e
-0, 420000, 276480, 0x58f275ea
-0, 427500, 276480, 0xf0b3b71b
-0, 435000, 276480, 0x674e34e4
-0, 442500, 276480, 0x41dda2d9
-0, 450000, 276480, 0xf46ba7fb
-0, 457500, 276480, 0x28b54815
-0, 465000, 276480, 0xaf2b5d89
-0, 472500, 276480, 0x8facba58
-0, 480000, 276480, 0x28a63236
-0, 487500, 276480, 0x1ad43fd7
-0, 495000, 276480, 0x71507bd2
-0, 502500, 276480, 0x35626022
-0, 510000, 276480, 0x7c1139b3
-0, 517500, 276480, 0x7fd73a99
-0, 525000, 276480, 0xb52e1aa2
-0, 532500, 276480, 0xd6f82cae
-0, 540000, 276480, 0xf88f75d4
-0, 547500, 276480, 0x04a8e3ee
-0, 555000, 276480, 0xa29f5b01
-0, 562500, 276480, 0x754ceaf5
-0, 570000, 276480, 0x5a38b4af
-0, 577500, 276480, 0xfcebc261
-0, 585000, 276480, 0x3d3ca985
-0, 592500, 276480, 0x94a03c75
-0, 600000, 276480, 0x2f98911c
-0, 607500, 276480, 0x923b9937
-0, 615000, 276480, 0xefab7ffd
-0, 622500, 276480, 0x6b9fbc80
-0, 630000, 276480, 0xe4bdbd1e
-0, 637500, 276480, 0x225a56c0
-0, 645000, 276480, 0xf58b1b7c
-0, 652500, 276480, 0xbaffcdcc
-0, 660000, 276480, 0xeb6eb88f
-0, 667500, 276480, 0xdb753d35
-0, 675000, 276480, 0xea80a82e
-0, 682500, 276480, 0x2aae902a
-0, 690000, 276480, 0x9b9ee961
-0, 697500, 276480, 0xaa12b6fd
-0, 705000, 276480, 0x50c31e73
-0, 712500, 276480, 0xdd9fb89f
-0, 720000, 276480, 0xaf82399a
-0, 727500, 276480, 0x7ce5f23c
-0, 735000, 276480, 0x5aaa7519
-0, 742500, 276480, 0xe45a5599
-0, 750000, 276480, 0x704411fb
-0, 757500, 276480, 0x9d7430a1
-0, 765000, 276480, 0x2c230702
-0, 772500, 276480, 0x4a4f76cd
-0, 780000, 276480, 0x27f54854
-0, 787500, 276480, 0x694d76e3
-0, 795000, 276480, 0x525463e2
-0, 802500, 276480, 0x819898f9
-0, 810000, 276480, 0xeeed00fc
-0, 817500, 276480, 0xb6f99ee3
-0, 825000, 276480, 0xefc83107
-0, 832500, 276480, 0xbb22e024
-0, 840000, 276480, 0x300f922a
-0, 847500, 276480, 0x826fc3bd
-0, 855000, 276480, 0x679a53f8
-0, 862500, 276480, 0x976c9e93
-0, 870000, 276480, 0xb194656e
-0, 877500, 276480, 0xf002c5ca
-0, 885000, 276480, 0xb243dda5
-0, 892500, 276480, 0x1700efbb
-0, 900000, 276480, 0x8f316c66
+0, 135000, 276480, 0x32ee3526
+0, 142500, 276480, 0x7ca9658e
+0, 150000, 276480, 0x4ec1e418
+0, 157500, 276480, 0xa9f1506f
+0, 165000, 276480, 0x377c7b46
+0, 172500, 276480, 0xe1de7f0a
+0, 180000, 276480, 0xcb379547
+0, 187500, 276480, 0x8e12331c
+0, 195000, 276480, 0xe479ffed
+0, 202500, 276480, 0xac7672dd
+0, 210000, 276480, 0x776412ef
+0, 217500, 276480, 0x1cd1ab29
+0, 225000, 276480, 0x5ab69b27
+0, 232500, 276480, 0x9eca3f11
+0, 240000, 276480, 0xc9c57884
+0, 247500, 276480, 0xdc07f3c9
+0, 255000, 276480, 0x27ff7a5d
+0, 262500, 276480, 0x18d4b27d
+0, 270000, 276480, 0x97612c4b
+0, 277500, 276480, 0x4ec4d57f
+0, 285000, 276480, 0xbd98f57c
+0, 292500, 276480, 0xa5d670ec
+0, 300000, 276480, 0x99170e64
+0, 307500, 276480, 0x7a4f2561
+0, 315000, 276480, 0x6a45425f
+0, 322500, 276480, 0xd75482c6
+0, 330000, 276480, 0x6de1e34b
+0, 337500, 276480, 0xf964e18e
+0, 345000, 276480, 0xd1e98808
+0, 352500, 276480, 0x0cf65540
+0, 360000, 276480, 0x22c50a3d
+0, 367500, 276480, 0xf4b1c461
+0, 375000, 276480, 0x51e9b3eb
+0, 382500, 276480, 0x6dd14ca6
+0, 390000, 276480, 0xfb01efc6
+0, 397500, 276480, 0x5ac8e06f
+0, 405000, 276480, 0xe04ac45e
+0, 412500, 276480, 0xf688a3ed
+0, 420000, 276480, 0xf0b3b71b
+0, 427500, 276480, 0x01840548
+0, 435000, 276480, 0x41dda2d9
+0, 442500, 276480, 0x9b209f41
+0, 450000, 276480, 0x28b54815
+0, 457500, 276480, 0x34484aff
+0, 465000, 276480, 0x8facba58
+0, 472500, 276480, 0x02162c7c
+0, 480000, 276480, 0x1ad43fd7
+0, 487500, 276480, 0x2b8a89c5
+0, 495000, 276480, 0x35626022
+0, 502500, 276480, 0xce5af1ec
+0, 510000, 276480, 0x7fd73a99
+0, 517500, 276480, 0xcb60725a
+0, 525000, 276480, 0xd6f82cae
+0, 532500, 276480, 0xfa88a483
+0, 540000, 276480, 0x04a8e3ee
+0, 547500, 276480, 0x0b41f0d7
+0, 555000, 276480, 0x754ceaf5
+0, 562500, 276480, 0xde084059
+0, 570000, 276480, 0xfcebc261
+0, 577500, 276480, 0x046394ae
+0, 585000, 276480, 0x94a03c75
+0, 592500, 276480, 0x6a841f41
+0, 600000, 276480, 0x923b9937
+0, 607500, 276480, 0xee82d657
+0, 615000, 276480, 0x6b9fbc80
+0, 622500, 276480, 0x6d4b49d7
+0, 630000, 276480, 0x225a56c0
+0, 637500, 276480, 0xff4e1a8c
+0, 645000, 276480, 0xbaffcdcc
+0, 652500, 276480, 0x3d861ae6
+0, 660000, 276480, 0xdb753d35
+0, 667500, 276480, 0xb24c8016
+0, 675000, 276480, 0x2aae902a
+0, 682500, 276480, 0x5c6e97a9
+0, 690000, 276480, 0xaa12b6fd
+0, 697500, 276480, 0xbf09053c
+0, 705000, 276480, 0xdd9fb89f
+0, 712500, 276480, 0x0b752d28
+0, 720000, 276480, 0x7ce5f23c
+0, 727500, 276480, 0x55dadd30
+0, 735000, 276480, 0xe45a5599
+0, 742500, 276480, 0x2f447fd3
+0, 750000, 276480, 0x9d7430a1
+0, 757500, 276480, 0x51cb657c
+0, 765000, 276480, 0x4a4f76cd
+0, 772500, 276480, 0x87160f99
+0, 780000, 276480, 0x694d76e3
+0, 787500, 276480, 0x50742e1b
+0, 795000, 276480, 0x819898f9
+0, 802500, 276480, 0x35c46927
+0, 810000, 276480, 0xb6f99ee3
+0, 817500, 276480, 0xde97d9fd
+0, 825000, 276480, 0xbb22e024
+0, 832500, 276480, 0xbe1fbb19
+0, 840000, 276480, 0x826fc3bd
+0, 847500, 276480, 0x5497097b
+0, 855000, 276480, 0x976c9e93
+0, 862500, 276480, 0xdc2d7c6c
+0, 870000, 276480, 0xf002c5ca
+0, 877500, 276480, 0xf62d8581
+0, 885000, 276480, 0x1700efbb
+0, 892500, 276480, 0x8f316c66
diff --git a/tests/ref/fate/rv30 b/tests/ref/fate/rv30
index 867151bd66..8777367c8e 100644
--- a/tests/ref/fate/rv30
+++ b/tests/ref/fate/rv30
@@ -2,45 +2,44 @@
0, 7500, 126720, 0xa416ece5
0, 15000, 126720, 0xa416ece5
0, 22500, 126720, 0x259af497
-0, 30000, 126720, 0x5e6ff4d7
-0, 37500, 126720, 0xeb6fb8d7
+0, 30000, 126720, 0x763ab817
+0, 37500, 126720, 0xda71b917
0, 45000, 126720, 0xbb1abbb7
-0, 52500, 126720, 0x273fbc37
-0, 60000, 126720, 0x7fa3ae27
-0, 67500, 126720, 0x722e99f7
-0, 75000, 126720, 0x29d6a887
+0, 52500, 126720, 0x16eebbd7
+0, 60000, 126720, 0x722e99f7
+0, 67500, 126720, 0x07beba77
+0, 75000, 126720, 0x9ca7aac7
0, 82500, 126720, 0xd115a757
-0, 90000, 126720, 0x6ddaef32
-0, 97500, 126720, 0x04e7897c
+0, 90000, 126720, 0xac6c071b
+0, 97500, 126720, 0x5eee050f
0, 105000, 126720, 0x68cfda2b
-0, 112500, 126720, 0xe572dfc9
-0, 120000, 126720, 0xbc3cc34f
-0, 127500, 126720, 0xcf8cb0e2
-0, 135000, 126720, 0x75ae61b6
+0, 112500, 126720, 0x582fb176
+0, 120000, 126720, 0xcf8cb0e2
+0, 127500, 126720, 0xc6e10f9f
+0, 135000, 126720, 0x85597543
0, 142500, 126720, 0x554fe3e4
-0, 150000, 126720, 0x72ecea95
-0, 157500, 126720, 0x5d00b5fe
+0, 150000, 126720, 0x9bf6a605
+0, 157500, 126720, 0x93f7b040
0, 165000, 126720, 0xe39bba0d
-0, 172500, 126720, 0x9c21bad8
-0, 180000, 126720, 0x72f2a47d
-0, 187500, 126720, 0x4f639ebe
-0, 195000, 126720, 0x534a10cc
+0, 172500, 126720, 0xa567f25b
+0, 180000, 126720, 0x4f639ebe
+0, 187500, 126720, 0x6cf87d39
+0, 195000, 126720, 0xfdca11d3
0, 202500, 126720, 0x5fd753d8
-0, 210000, 126720, 0x0c735615
-0, 217500, 126720, 0x0eaf0c1b
+0, 210000, 126720, 0xeaf3dd0b
+0, 217500, 126720, 0xce5e6794
0, 225000, 126720, 0x14cf7974
-0, 232500, 126720, 0x1c2a513d
-0, 240000, 126720, 0xbc513f2a
-0, 247500, 126720, 0xbc303fae
-0, 255000, 126720, 0xd9f67585
+0, 232500, 126720, 0xa3f515ab
+0, 240000, 126720, 0xbc303fae
+0, 247500, 126720, 0x0a22cc69
+0, 255000, 126720, 0xf92b2a25
0, 262500, 126720, 0x3378251f
-0, 270000, 126720, 0xb3ed5911
-0, 277500, 126720, 0xc15a3577
+0, 270000, 126720, 0x8da30275
+0, 277500, 126720, 0xf2942f53
0, 285000, 126720, 0x0a24f256
-0, 292500, 126720, 0xfab9c45d
-0, 300000, 126720, 0x45464610
-0, 307500, 126720, 0xfe2e057d
-0, 315000, 126720, 0x23efdc35
+0, 292500, 126720, 0x10e939ce
+0, 300000, 126720, 0xfe2e057d
+0, 307500, 126720, 0x5284da7b
+0, 315000, 126720, 0xc9e92bf1
0, 322500, 126720, 0x4d888b2e
-0, 330000, 126720, 0xdd0d74df
-0, 337500, 126720, 0x08382b8e
+0, 330000, 126720, 0x08382b8e