[FFmpeg-cvslog] avcodec/tiff: avoid seek back on reading tags
Michael Niedermayer
git at videolan.org
Fri Aug 9 14:59:24 CEST 2013
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Fri Aug 9 14:53:13 2013 +0200| [a9553e8f37926e9b71d87cb08b1f4a2e7bb60097] | committer: Michael Niedermayer
avcodec/tiff: avoid seek back on reading tags
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=a9553e8f37926e9b71d87cb08b1f4a2e7bb60097
---
libavcodec/tiff.c | 13 ++++++-------
1 file changed, 6 insertions(+), 7 deletions(-)
diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c
index fdfa8f2..483225d 100644
--- a/libavcodec/tiff.c
+++ b/libavcodec/tiff.c
@@ -705,8 +705,7 @@ static int tiff_decode_tag(TiffContext *s, AVFrame *frame)
tag = tget_short(&s->gb, s->le);
type = tget_short(&s->gb, s->le);
count = tget_long(&s->gb, s->le);
- off = tget_long(&s->gb, s->le);
- start = bytestream2_tell(&s->gb);
+ start = bytestream2_tell(&s->gb) + 4;
if (type == 0 || type >= FF_ARRAY_ELEMS(type_sizes)) {
av_log(s->avctx, AV_LOG_DEBUG, "Unknown tiff type (%u) encountered\n",
@@ -718,26 +717,26 @@ static int tiff_decode_tag(TiffContext *s, AVFrame *frame)
switch (type) {
case TIFF_BYTE:
case TIFF_SHORT:
- bytestream2_seek(&s->gb, -4, SEEK_CUR);
value = tget(&s->gb, type, s->le);
break;
case TIFF_LONG:
+ off = tget_long(&s->gb, s->le);
value = off;
break;
case TIFF_STRING:
if (count <= 4) {
- bytestream2_seek(&s->gb, -4, SEEK_CUR);
break;
}
default:
+ off = tget_long(&s->gb, s->le);
value = UINT_MAX;
bytestream2_seek(&s->gb, off, SEEK_SET);
}
} else {
- if (count <= 4 && type_sizes[type] * count <= 4)
- bytestream2_seek(&s->gb, -4, SEEK_CUR);
- else
+ if (count > 4 || type_sizes[type] * count > 4) {
+ off = tget_long(&s->gb, s->le);
bytestream2_seek(&s->gb, off, SEEK_SET);
+ }
}
switch (tag) {
More information about the ffmpeg-cvslog
mailing list