[FFmpeg-devel] [PATCH]Read aspect ratio from tiff files
Carl Eugen Hoyos
cehoyos at ag.or.at
Mon Apr 7 02:59:16 CEST 2014
On Monday 07 April 2014 01:32:50 am Michael Niedermayer wrote:
> > +static void set_sar(TiffContext *s, unsigned tag, unsigned num, unsigned
> > den) +{
> > + int offset = tag == TIFF_YRES ? 2 : 0;
> > + s->res[offset++] = num;
> > + s->res[offset] = den;
> > + if (s->res[0] && s->res[1] && s->res[2] && s->res[3])
> > + av_reduce(&s->avctx->sample_aspect_ratio.num,
> > &s->avctx->sample_aspect_ratio.den, + s->res[2] *
> > s->res[1], s->res[0] * s->res[3], INT32_MAX);
>
> these need to be cast tp 64bit to avid overflows unless
> something ensures they are not more than 16bit
New patch attached.
Thank you, Carl Eugen
-------------- next part --------------
diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c
index cbc526a..e0629db 100644
--- a/libavcodec/tiff.c
+++ b/libavcodec/tiff.c
@@ -58,6 +58,7 @@ typedef struct TiffContext {
int fax_opts;
int predictor;
int fill_order;
+ uint32_t res[4];
int strips, rps, sstype;
int sot;
@@ -566,9 +567,19 @@ static int init_image(TiffContext *s, ThreadFrame *frame)
return 0;
}
+static void set_sar(TiffContext *s, unsigned tag, unsigned num, unsigned den)
+{
+ int offset = tag == TIFF_YRES ? 2 : 0;
+ s->res[offset++] = num;
+ s->res[offset] = den;
+ if (s->res[0] && s->res[1] && s->res[2] && s->res[3])
+ av_reduce(&s->avctx->sample_aspect_ratio.num, &s->avctx->sample_aspect_ratio.den,
+ s->res[2] * (uint64_t)s->res[1], s->res[0] * (uint64_t)s->res[3], INT32_MAX);
+}
+
static int tiff_decode_tag(TiffContext *s, AVFrame *frame)
{
- unsigned tag, type, count, off, value = 0;
+ unsigned tag, type, count, off, value = 0, value2 = 0;
int i, j, k, pos, start;
int ret;
uint32_t *pal;
@@ -587,6 +598,10 @@ static int tiff_decode_tag(TiffContext *s, AVFrame *frame)
case TIFF_LONG:
value = ff_tget(&s->gb, type, s->le);
break;
+ case TIFF_RATIONAL:
+ value = ff_tget(&s->gb, TIFF_LONG, s->le);
+ value2 = ff_tget(&s->gb, TIFF_LONG, s->le);
+ break;
case TIFF_STRING:
if (count <= 4) {
break;
@@ -717,6 +732,10 @@ static int tiff_decode_tag(TiffContext *s, AVFrame *frame)
return AVERROR_INVALIDDATA;
}
break;
+ case TIFF_XRES:
+ case TIFF_YRES:
+ set_sar(s, tag, value, value2);
+ break;
case TIFF_TILE_BYTE_COUNTS:
case TIFF_TILE_LENGTH:
case TIFF_TILE_OFFSETS:
More information about the ffmpeg-devel
mailing list