|
|
# --- SDE-COPYRIGHT-NOTE-BEGIN --- # This copyright note is auto-generated by ./scripts/Create-CopyPatch. # # Filename: package/.../libtiff/thumbnail-fixup.patch # Copyright (C) 2010 The OpenSDE Project # Copyright (C) 2004 - 2006 The T2 SDE Project # # More information can be found in the files COPYING and README. # # This patch file is dual-licensed. It is available under the license the # patched project is licensed under, as long as it is an OpenSource license # as defined at http://www.opensource.org/ (e.g. BSD, X11) or under the terms # of the GNU General Public License as published by the Free Software # Foundation; either version 2 of the License, or (at your option) any later # version. # --- SDE-COPYRIGHT-NOTE-END ---
The box filter bit masking is broken in several ways - I wonder it ever worked for anyone ...
Marked clamp inline, just in case.
- Rene Rebe <rene@exactcode.de> for Archivista GmbH Z�rich
diff -ruN tiff-3.9.4-orig/tools/thumbnail.c tiff-3.9.4/tools/thumbnail.c
--- tiff-3.9.4-orig/tools/thumbnail.c 2010-06-08 20:50:44.000000000 +0200
+++ tiff-3.9.4/tools/thumbnail.c 2010-08-13 12:08:46.272260086 +0200
@@ -369,7 +369,7 @@
} } -static int clamp(float v, int low, int high)
+static int inline clamp(float v, int low, int high)
{ return (v < low ? low : v > high ? high : (int)v); } #ifndef M_E @@ -453,13 +453,15 @@
} rowoff[x] = sx0 >> 3; fw = sx - sx0; /* width */ + if (fw == 0) fw = 1;
+
+ src1[x] = fw;
b = (fw < 8) ? 0xff<<(8-fw) : 0xff; src0[x] = b >> (sx0&7); fw -= 8 - (sx0&7); if (fw < 0) fw = 0; - src1[x] = fw >> 3;
- fw -= (fw>>3)<<3;
+ fw %= 8;
src2[x] = 0xff << (8-fw); } stepSrcWidth = sw; @@ -471,20 +473,20 @@
setrow(uint8* row, uint32 nrows, const uint8* rows[]) { uint32 x; - uint32 area = nrows * filterWidth;
for (x = 0; x < tnw; x++) { uint32 mask0 = src0[x]; uint32 fw = src1[x]; - uint32 mask1 = src1[x];
+ uint32 mask1 = src2[x];
uint32 off = rowoff[x]; uint32 acc = 0; uint32 y, i; for (y = 0; y < nrows; y++) { const uint8* src = rows[y] + off; + uint32 _fw = fw - bits[mask0] - bits[mask1];
acc += bits[*src++ & mask0]; - switch (fw) {
+ switch (_fw) {
default: - for (i = fw; i > 8; i--)
+ for (i = _fw; i > 8; i--)
acc += bits[*src++]; /* fall thru... */ case 8: acc += bits[*src++]; @@ -499,6 +501,7 @@
} acc += bits[*src & mask1]; } + uint32 area = nrows * fw;
*row++ = cmap[(255*acc)/area]; } }
|