[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