aboutsummaryrefslogtreecommitdiffstats
path: root/graphics/tiff/files
diff options
context:
space:
mode:
authordinoex <dinoex@FreeBSD.org>2004-10-17 17:26:18 +0800
committerdinoex <dinoex@FreeBSD.org>2004-10-17 17:26:18 +0800
commit5bed70ea2a7d5fa5c537d55d2e02f0677f21ffc8 (patch)
treee3836616539b435b82325e2cd46ba2340d0377a5 /graphics/tiff/files
parentd1bc9823095e122ad20c4de834fe2602d92c08be (diff)
downloadfreebsd-ports-gnome-5bed70ea2a7d5fa5c537d55d2e02f0677f21ffc8.tar.gz
freebsd-ports-gnome-5bed70ea2a7d5fa5c537d55d2e02f0677f21ffc8.tar.zst
freebsd-ports-gnome-5bed70ea2a7d5fa5c537d55d2e02f0677f21ffc8.zip
- update to 3.7.0
- honor options WITH_X11,WITHOUT_X11 - uses LIBTOOL and GNU_CONFIGURE - LZW compression enabled shared lib version not bumped, tested a few applications running it without recompilation.
Diffstat (limited to 'graphics/tiff/files')
-rw-r--r--graphics/tiff/files/patch-aa59
-rw-r--r--graphics/tiff/files/patch-ab43
-rw-r--r--graphics/tiff/files/patch-ac12
-rw-r--r--graphics/tiff/files/patch-ad26
-rw-r--r--graphics/tiff/files/patch-ae20
-rw-r--r--graphics/tiff/files/patch-ag74
-rw-r--r--graphics/tiff/files/patch-ah1158
-rw-r--r--graphics/tiff/files/patch-libtiff-tif_fax3.c21
-rw-r--r--graphics/tiff/files/patch-tools-tiffcp.c176
9 files changed, 0 insertions, 1589 deletions
diff --git a/graphics/tiff/files/patch-aa b/graphics/tiff/files/patch-aa
deleted file mode 100644
index 32a006c433c0..000000000000
--- a/graphics/tiff/files/patch-aa
+++ /dev/null
@@ -1,59 +0,0 @@
---- libtiff/Makefile.in.orig Wed Aug 20 19:42:17 2003
-+++ libtiff/Makefile.in Wed Oct 8 00:16:03 2003
-@@ -223,8 +223,8 @@
- @LN@ @LN_S@ libtiff.@DSOSUF_VERSION@ libtiff.@DSOSUF@; \
- fi
- touch $@
--# NetBSD 1.1 or FreeBSD (old style)
--NETBSDdso FREEBSDdso oldOPENBSDdso: ${OBJS}
-+# NetBSD 1.1 (old style)
-+NETBSDdso oldOPENBSDdso: ${OBJS}
- @rm -f libtiff_pic.a
- @${AR} cq libtiff_pic.a `lorder ${OBJS} | tsort -q`
- ${RANLIB} libtiff_pic.a
-@@ -242,6 +242,14 @@
- # OSF/1 3.2 shared lib rule
- OSFdso: ${OBJS}
- ${LD} -o libtiff.@DSOSUF@ -shared -error_unresolved ${OBJS} @LIBJPEG@ @LIBGZ@ -lc -lm
-+# FreeBSD shared lib rule
-+FREEBSDdso: ${OBJS}
-+ ${CC} -shared -Wl,-soname,libtiff.@DSOSUF_VERSION@ \
-+ -o libtiff.@DSOSUF_VERSION@ ${OBJS} \
-+ @LIBJPEG@ @LIBGZ@ @MACHDEPLIBS@
-+ rm -f libtiff.@DSOSUF@
-+ @LN@ @LN_S@ libtiff.@DSOSUF_VERSION@ libtiff.@DSOSUF@
-+ touch $@
-
- OPENBSDdso: ${OBJS}
- ${CC} -shared @LIBCOPTS@ -o libtiff.@DSOSUF_VERSION@ ${OBJS} @LIBJPEG@ @LIBGZ@ -lm
-@@ -374,18 +382,15 @@
- ${INSTALL} -idb tiff.sw.dev -m 755 -dir ${DESTDIR}@DIR_INC@
- for i in ${INCS_PRIVATE}; do \
- f=`basename $$i`; \
-- ${INSTALL} -idb tiff.sw.dev -m 444 -F ${DESTDIR}@DIR_INC@ \
-- -src $$i -O $$f; \
-+ ${BSD_INSTALL_DATA} $$i ${DESTDIR}@DIR_INC@/$$f; \
- done
-
- installDSO: @DSO@dso
- if [ @DSOSUF_VERSION@ != @DSOSUF@ ]; then \
-- ${INSTALL} -idb tiff.sw.tools.nostrip -m 555 \
-- -F ${DESTDIR}@DIR_LIB@ -O libtiff.@DSOSUF_VERSION@; \
-+ ${BSD_INSTALL_DATA} libtiff.@DSOSUF_VERSION@ \
-+ ${DESTDIR}@DIR_LIB@; \
- ${INSTALL} -idb tiff.sw.tools -F ${DESTDIR}@DIR_LIB@ \
- -lns libtiff.@DSOSUF_VERSION@ -O libtiff.@DSOSUF@; \
-- ${INSTALL} -idb tiff.sw.tools -F ${DESTDIR}@DIR_LIB@ \
-- -lns libtiff.@DSOSUF@ -O libtiff.so; \
- else \
- ${INSTALL} -idb tiff.sw.tools.nostrip -m 555 \
- -F ${DESTDIR}@DIR_LIB@ -O libtiff.@DSOSUF@; \
-@@ -393,7 +398,7 @@
-
- install: all installHdrs
- ${INSTALL} -idb tiff.sw.dev -m 755 -dir ${DESTDIR}@DIR_LIB@
-- ${INSTALL} -idb tiff.sw.dev -m 444 -F ${DESTDIR}@DIR_LIB@ -O libtiff.a
-+ ${BSD_INSTALL_DATA} libtiff.a ${DESTDIR}@DIR_LIB@
- if [ @DSO@dso != nodso ]; then \
- ${MAKE} -${MAKEFLAGS} installDSO; \
- else \
diff --git a/graphics/tiff/files/patch-ab b/graphics/tiff/files/patch-ab
deleted file mode 100644
index 13efb321509a..000000000000
--- a/graphics/tiff/files/patch-ab
+++ /dev/null
@@ -1,43 +0,0 @@
---- configure.orig Fri Nov 16 02:21:05 2001
-+++ configure Sat Dec 15 00:00:00 2001
-@@ -170,10 +170,10 @@
- esac
- done
-
--DIR_BIN=${EPREFIX}/bin # destination for applications
--DIR_LIB=${EPREFIX}/lib # destination for library
--DIR_INC=${PREFIX}/include # destination for include files
--DIR_HTML=${PREFIX}/doc/libtiff # destination for HTML files
-+#DIR_BIN=${EPREFIX}/bin # destination for applications
-+#DIR_LIB=${EPREFIX}/lib # destination for library
-+#DIR_INC=${PREFIX}/include # destination for include files
-+#DIR_HTML=${PREFIX}/doc/libtiff # destination for HTML files
-
- if [ -n "$ac_prev" ]; then
- bitch "configure: missing argument to --`echo $ac_prev | sed 's/_/-/g'`"
-@@ -1172,11 +1172,12 @@
- TIFFLIBREF='-L${DEPTH}/libtiff -ltiff'
- ;;
- *-freebsd*)
-- DSOSUF=so.${DIST_MAJOR}
-- DSOSUF_VERSION=${DSOSUF}.${DIST_MINOR}.${DIST_POINT}
-- LIBCOPTS='-fPIC'
-+ DSOSUF=so
-+ DSOSUF_VERSION=${DSOSUF}.4
-+ LIBCOPTS='-fPIC -DPIC'
- DSOOPTS='-shared'
-- DSO=GNULD
-+ DSO=FREEBSD
-+ TIFFLIBREF='-L${DEPTH}/libtiff -ltiff'
- ;;
- *-openbsd*)
- DSOSUF=so.${DIST_MAJOR}.${DIST_MINOR}
-@@ -1300,7 +1301,7 @@
- # Check if ln -s creates a symbolic link.
- #
- if [ -z "${LN_S-}" ]; then
-- $RM t.c; $LN -s foo t.c && LN_S=-s
-+ $RM t.c; $LN -sf foo t.c && LN_S=-sf
- fi
- if [ -n "$LN_S" ]; then
- Note "Looks like $LN supports the -s option to create a symbolic link."
diff --git a/graphics/tiff/files/patch-ac b/graphics/tiff/files/patch-ac
deleted file mode 100644
index dc917ad17a1d..000000000000
--- a/graphics/tiff/files/patch-ac
+++ /dev/null
@@ -1,12 +0,0 @@
---- tools/Makefile.in.orig Mon Aug 12 00:01:46 2002
-+++ tools/Makefile.in Wed Oct 8 00:19:39 2003
-@@ -115,8 +115,7 @@
- install: all
- ${INSTALL} -idb tiff.sw.tools -m 755 \
- -dir ${DESTDIR}@DIR_BIN@
-- ${INSTALL} -idb tiff.sw.tools -m 755 \
-- -F ${DESTDIR}@DIR_BIN@ -O ${TARGETS}
-+ ${BSD_INSTALL_PROGRAM} ${TARGETS} ${DESTDIR}@DIR_BIN@
- @if [ "@LIBIMAGE@" = yes ]; then \
- ${INSTALL} -idb tiff.sw.tools -m 755 \
- -F ${DESTDIR}@DIR_BIN@ -O sgi2tiff; \
diff --git a/graphics/tiff/files/patch-ad b/graphics/tiff/files/patch-ad
deleted file mode 100644
index a6008bf5a0db..000000000000
--- a/graphics/tiff/files/patch-ad
+++ /dev/null
@@ -1,26 +0,0 @@
---- man/Makefile.in.orig Sat Oct 4 20:43:16 2003
-+++ man/Makefile.in Wed Oct 8 00:22:56 2003
-@@ -354,9 +354,8 @@
- ${ECHO} 'install:'; \
- for i in *.1; do \
- f=${MANAPPNAME}; \
-- ${ECHO} ' cd ..; ${INSTALL} -m 444 \
-- -F $${DESTDIR}${MAN}/${MANAPPS} \
-- -idb tiff.man.tools -src' apps/"$$i" '-O' "$$f"; \
-+ ${ECHO} ' ${BSD_INSTALL_MAN}' \
-+ $$i $${DESTDIR}${MAN}/${MANAPPS}/$$f; \
- done \
- )>apps/Makefile
- lib/Makefile:
-@@ -367,9 +366,8 @@
- ${ECHO} 'install:'; \
- for i in *.3t; do \
- f=${MANLIBNAME}; \
-- ${ECHO} ' cd ..; ${INSTALL} -m 444 \
-- -F $${DESTDIR}${MAN}/${MANLIB} \
-- -idb tiff.man.dev -src' lib/"$$i" '-O' "$$f"; \
-+ ${ECHO} ' ${BSD_INSTALL_MAN}' \
-+ $$i $${DESTDIR}${MAN}/${MANLIB}/$$f; \
- done \
- )>lib/Makefile
-
diff --git a/graphics/tiff/files/patch-ae b/graphics/tiff/files/patch-ae
deleted file mode 100644
index 82a948e005c1..000000000000
--- a/graphics/tiff/files/patch-ae
+++ /dev/null
@@ -1,20 +0,0 @@
---- html/Makefile.in.orig Thu Oct 3 00:14:34 2002
-+++ html/Makefile.in Wed Oct 8 00:40:18 2003
-@@ -54,7 +54,6 @@
- HTML = @DIR_HTML@
-
- HTMLFILES=\
-- TIFFTechNote2.html \
- bugs.html \
- build.html \
- contrib.html \
-@@ -112,8 +111,7 @@
- install: all
- ${INSTALL} -m 755 -dir -idb tiff.man.html ${DESTDIR}${HTML} ${DESTDIR}${HTML}/images
- for i in ${HTMLFILES} ${IMAGES}; do \
-- ${INSTALL} -idb tiff.man.html -m 444 -F ${DESTDIR}${HTML} \
-- -src ${SRCDIR}/$$i -O $$i; \
-+ ${BSD_INSTALL_DATA} ${SRCDIR}/$$i ${DESTDIR}${HTML}/$$i; \
- done
-
- clean:;
diff --git a/graphics/tiff/files/patch-ag b/graphics/tiff/files/patch-ag
deleted file mode 100644
index b01dcec6f36d..000000000000
--- a/graphics/tiff/files/patch-ag
+++ /dev/null
@@ -1,74 +0,0 @@
-Index: libtiff/tif_luv.c
-===================================================================
-RCS file: /cvs/maptools/cvsroot/libtiff/libtiff/tif_luv.c,v
-retrieving revision 1.10
-retrieving revision 1.11
-diff -u -p -r1.10 -r1.11
---- libtiff/tif_luv.c 14 Sep 2004 06:02:56 -0000 1.10
-+++ libtiff/tif_luv.c 19 Sep 2004 10:08:38 -0000 1.11
-@@ -214,11 +214,11 @@ LogL16Decode(TIFF* tif, tidata_t op, tsi
- rc = *bp++ + (2-128);
- b = (int16)(*bp++ << shft);
- cc -= 2;
-- while (rc--)
-+ while (rc-- && i < npixels)
- tp[i++] |= b;
- } else { /* non-run */
- rc = *bp++; /* nul is noop */
-- while (--cc && rc--)
-+ while (--cc && rc-- && i < npixels)
- tp[i++] |= (int16)*bp++ << shft;
- }
- if (i != npixels) {
-@@ -314,11 +314,11 @@ LogLuvDecode32(TIFF* tif, tidata_t op, t
- rc = *bp++ + (2-128);
- b = (uint32)*bp++ << shft;
- cc -= 2;
-- while (rc--)
-+ while (rc-- && i < npixels)
- tp[i++] |= b;
- } else { /* non-run */
- rc = *bp++; /* nul is noop */
-- while (--cc && rc--)
-+ while (--cc && rc-- && i < npixels)
- tp[i++] |= (uint32)*bp++ << shft;
- }
- if (i != npixels) {
-Index: libtiff/tif_next.c
-===================================================================
-RCS file: /cvs/maptools/cvsroot/libtiff/libtiff/tif_next.c,v
-retrieving revision 1.3
-retrieving revision 1.4
-diff -u -p -r1.3 -r1.4
---- libtiff/tif_next.c 8 Jul 2003 16:40:46 -0000 1.3
-+++ libtiff/tif_next.c 19 Sep 2004 10:08:38 -0000 1.4
-@@ -87,7 +87,7 @@ NeXTDecode(TIFF* tif, tidata_t buf, tsiz
- */
- off = (bp[0] * 256) + bp[1];
- n = (bp[2] * 256) + bp[3];
-- if (cc < 4+n)
-+ if (cc < 4+n || off+n > scanline)
- goto bad;
- _TIFFmemcpy(row+off, bp+4, n);
- bp += 4+n;
-Index: libtiff/tif_thunder.c
-===================================================================
-RCS file: /cvs/maptools/cvsroot/libtiff/libtiff/tif_thunder.c,v
-retrieving revision 1.3
-retrieving revision 1.4
-diff -u -p -r1.3 -r1.4
---- libtiff/tif_thunder.c 14 Sep 2004 06:42:55 -0000 1.3
-+++ libtiff/tif_thunder.c 19 Sep 2004 10:08:38 -0000 1.4
-@@ -91,8 +91,10 @@ ThunderDecode(TIFF* tif, tidata_t op, ts
- } else
- lastpixel |= lastpixel << 4;
- npixels += n;
-- for (; n > 0; n -= 2)
-- *op++ = (tidataval_t) lastpixel;
-+ if (npixels < maxpixels) {
-+ for (; n > 0; n -= 2)
-+ *op++ = (tidataval_t) lastpixel;
-+ }
- if (n == -1)
- *--op &= 0xf0;
- lastpixel &= 0xf;
diff --git a/graphics/tiff/files/patch-ah b/graphics/tiff/files/patch-ah
deleted file mode 100644
index cb7da69e3ac4..000000000000
--- a/graphics/tiff/files/patch-ah
+++ /dev/null
@@ -1,1158 +0,0 @@
-diff -uprk.orig libtiff/tif_aux.c libtiff/tif_aux.c
---- libtiff/tif_aux.c 2003-12-07 14:58:36 +0300
-+++ libtiff/tif_aux.c 2004-10-03 00:20:41 +0400
-@@ -33,36 +33,59 @@
- #include "tif_predict.h"
- #include <math.h>
-
--static void
-+static int
- TIFFDefaultTransferFunction(TIFFDirectory* td)
- {
- uint16 **tf = td->td_transferfunction;
-- long i, n = 1<<td->td_bitspersample;
-+ tsize_t i, n, nbytes;
-
-- tf[0] = (uint16 *)_TIFFmalloc(n * sizeof (uint16));
-+ tf[0] = tf[1] = tf[2] = 0;
-+ if (td->td_bitspersample >= sizeof(tsize_t) * 8 - 2)
-+ return 0;
-+
-+ n = 1<<td->td_bitspersample;
-+ nbytes = n * sizeof (uint16);
-+ if (!(tf[0] = (uint16 *)_TIFFmalloc(nbytes)))
-+ return 0;
- tf[0][0] = 0;
- for (i = 1; i < n; i++) {
- double t = (double)i/((double) n-1.);
- tf[0][i] = (uint16)floor(65535.*pow(t, 2.2) + .5);
- }
-+
- if (td->td_samplesperpixel - td->td_extrasamples > 1) {
-- tf[1] = (uint16 *)_TIFFmalloc(n * sizeof (uint16));
-- _TIFFmemcpy(tf[1], tf[0], n * sizeof (uint16));
-- tf[2] = (uint16 *)_TIFFmalloc(n * sizeof (uint16));
-- _TIFFmemcpy(tf[2], tf[0], n * sizeof (uint16));
-+ if (!(tf[1] = (uint16 *)_TIFFmalloc(nbytes)))
-+ goto bad;
-+ _TIFFmemcpy(tf[1], tf[0], nbytes);
-+ if (!(tf[2] = (uint16 *)_TIFFmalloc(nbytes)))
-+ goto bad;
-+ _TIFFmemcpy(tf[2], tf[0], nbytes);
- }
-+ return 1;
-+
-+bad:
-+ if (tf[0])
-+ _TIFFfree(tf[0]);
-+ if (tf[1])
-+ _TIFFfree(tf[1]);
-+ if (tf[2])
-+ _TIFFfree(tf[2]);
-+ tf[0] = tf[1] = tf[2] = 0;
-+ return 0;
- }
-
--static void
-+static int
- TIFFDefaultRefBlackWhite(TIFFDirectory* td)
- {
- int i;
-
-- td->td_refblackwhite = (float *)_TIFFmalloc(6*sizeof (float));
-+ if (!(td->td_refblackwhite = (float *)_TIFFmalloc(6*sizeof (float))))
-+ return 0;
- for (i = 0; i < 3; i++) {
- td->td_refblackwhite[2*i+0] = 0;
- td->td_refblackwhite[2*i+1] = (float)((1L<<td->td_bitspersample)-1L);
- }
-+ return 1;
- }
-
- /*
-@@ -155,6 +178,8 @@ TIFFVGetFieldDefaulted(TIFF* tif, ttag_t
- if (!td->td_ycbcrcoeffs) {
- td->td_ycbcrcoeffs = (float *)
- _TIFFmalloc(3*sizeof (float));
-+ if (!td->td_ycbcrcoeffs)
-+ return (0);
- /* defaults are from CCIR Recommendation 601-1 */
- td->td_ycbcrcoeffs[0] = 0.299f;
- td->td_ycbcrcoeffs[1] = 0.587f;
-@@ -173,6 +198,8 @@ TIFFVGetFieldDefaulted(TIFF* tif, ttag_t
- if (!td->td_whitepoint) {
- td->td_whitepoint = (float *)
- _TIFFmalloc(2 * sizeof (float));
-+ if (!td->td_whitepoint)
-+ return (0);
- /* TIFF 6.0 specification says that it is no default
- value for the WhitePoint, but AdobePhotoshop TIFF
- Technical Note tells that it should be CIE D50. */
-@@ -184,8 +211,11 @@ TIFFVGetFieldDefaulted(TIFF* tif, ttag_t
- *va_arg(ap, float **) = td->td_whitepoint;
- return (1);
- case TIFFTAG_TRANSFERFUNCTION:
-- if (!td->td_transferfunction[0])
-- TIFFDefaultTransferFunction(td);
-+ if (!td->td_transferfunction[0] &&
-+ !TIFFDefaultTransferFunction(td)) {
-+ TIFFError(tif->tif_name, "No space for \"TransferFunction\" tag");
-+ return (0);
-+ }
- *va_arg(ap, uint16 **) = td->td_transferfunction[0];
- if (td->td_samplesperpixel - td->td_extrasamples > 1) {
- *va_arg(ap, uint16 **) = td->td_transferfunction[1];
-@@ -193,8 +223,8 @@ TIFFVGetFieldDefaulted(TIFF* tif, ttag_t
- }
- return (1);
- case TIFFTAG_REFERENCEBLACKWHITE:
-- if (!td->td_refblackwhite)
-- TIFFDefaultRefBlackWhite(td);
-+ if (!td->td_refblackwhite && !TIFFDefaultRefBlackWhite(td))
-+ return (0);
- *va_arg(ap, float **) = td->td_refblackwhite;
- return (1);
- }
-diff -uprk.orig libtiff/tif_compress.c libtiff/tif_compress.c
---- libtiff/tif_compress.c 2002-04-09 21:51:29 +0400
-+++ libtiff/tif_compress.c 2004-10-03 00:20:41 +0400
-@@ -210,9 +210,11 @@ TIFFRegisterCODEC(uint16 scheme, const c
- cd->info->init = init;
- cd->next = registeredCODECS;
- registeredCODECS = cd;
-- } else
-+ } else {
- TIFFError("TIFFRegisterCODEC",
- "No space to register compression scheme %s", name);
-+ return NULL;
-+ }
- return (cd->info);
- }
-
-diff -uprk.orig libtiff/tif_dir.c libtiff/tif_dir.c
---- libtiff/tif_dir.c 2003-12-26 14:56:25 +0300
-+++ libtiff/tif_dir.c 2004-10-03 00:20:41 +0400
-@@ -40,26 +40,33 @@
- #define DATATYPE_UINT 2 /* !unsigned integer data */
- #define DATATYPE_IEEEFP 3 /* !IEEE floating point data */
-
--void
--_TIFFsetByteArray(void** vpp, void* vp, long n)
-+static void
-+setByteArray(void** vpp, void* vp, size_t nmemb, size_t elem_size)
- {
- if (*vpp)
- _TIFFfree(*vpp), *vpp = 0;
-- if (vp && (*vpp = (void*) _TIFFmalloc(n)))
-- _TIFFmemcpy(*vpp, vp, n);
-+ if (vp) {
-+ tsize_t bytes = nmemb * elem_size;
-+ if (elem_size && bytes / elem_size == nmemb)
-+ *vpp = (void*) _TIFFmalloc(bytes);
-+ if (*vpp)
-+ _TIFFmemcpy(*vpp, vp, bytes);
-+ }
- }
-+void _TIFFsetByteArray(void** vpp, void* vp, long n)
-+ { setByteArray(vpp, vp, n, 1); }
- void _TIFFsetString(char** cpp, char* cp)
-- { _TIFFsetByteArray((void**) cpp, (void*) cp, (long) (strlen(cp)+1)); }
-+ { setByteArray((void**) cpp, (void*) cp, strlen(cp)+1, 1); }
- void _TIFFsetNString(char** cpp, char* cp, long n)
-- { _TIFFsetByteArray((void**) cpp, (void*) cp, n); }
-+ { setByteArray((void**) cpp, (void*) cp, n, 1); }
- void _TIFFsetShortArray(uint16** wpp, uint16* wp, long n)
-- { _TIFFsetByteArray((void**) wpp, (void*) wp, n*sizeof (uint16)); }
-+ { setByteArray((void**) wpp, (void*) wp, n, sizeof (uint16)); }
- void _TIFFsetLongArray(uint32** lpp, uint32* lp, long n)
-- { _TIFFsetByteArray((void**) lpp, (void*) lp, n*sizeof (uint32)); }
-+ { setByteArray((void**) lpp, (void*) lp, n, sizeof (uint32)); }
- void _TIFFsetFloatArray(float** fpp, float* fp, long n)
-- { _TIFFsetByteArray((void**) fpp, (void*) fp, n*sizeof (float)); }
-+ { setByteArray((void**) fpp, (void*) fp, n, sizeof (float)); }
- void _TIFFsetDoubleArray(double** dpp, double* dp, long n)
-- { _TIFFsetByteArray((void**) dpp, (void*) dp, n*sizeof (double)); }
-+ { setByteArray((void**) dpp, (void*) dp, n, sizeof (double)); }
-
- /*
- * Install extra samples information.
-@@ -521,14 +528,21 @@ _TIFFVSetField(TIFF* tif, ttag_t tag, va
- */
- if( tv == NULL )
- {
-- td->td_customValueCount++;
-- if( td->td_customValueCount > 1 )
-- td->td_customValues = (TIFFTagValue *)
-- _TIFFrealloc(td->td_customValues,
-- sizeof(TIFFTagValue) * td->td_customValueCount);
-- else
-- td->td_customValues = (TIFFTagValue *)
-- _TIFFmalloc(sizeof(TIFFTagValue));
-+ TIFFTagValue *new_customValues;
-+
-+ td->td_customValueCount++;
-+ new_customValues = (TIFFTagValue *)
-+ _TIFFrealloc(td->td_customValues,
-+ sizeof(TIFFTagValue) * td->td_customValueCount);
-+ if (!new_customValues) {
-+ TIFFError(module,
-+ "%s: Failed to allocate space for list of custom values",
-+ tif->tif_name);
-+ status = 0;
-+ goto end;
-+ }
-+
-+ td->td_customValues = new_customValues;
-
- tv = td->td_customValues + (td->td_customValueCount-1);
- tv->info = fip;
-@@ -584,6 +598,8 @@ _TIFFVSetField(TIFF* tif, ttag_t tag, va
- TIFFSetFieldBit(tif, _TIFFFieldWithTag(tif, tag)->field_bit);
- tif->tif_flags |= TIFF_DIRTYDIRECT;
- }
-+
-+end:
- va_end(ap);
- return (status);
- badvalue:
-diff -uprk.orig libtiff/tif_dirinfo.c libtiff/tif_dirinfo.c
---- libtiff/tif_dirinfo.c 2003-12-22 11:22:15 +0300
-+++ libtiff/tif_dirinfo.c 2004-10-03 00:20:41 +0400
-@@ -31,6 +31,8 @@
- */
- #include "tiffiop.h"
- #include <stdlib.h>
-+#include <assert.h>
-+#include <stdio.h>
-
- /*
- * NB: NB: THIS ARRAY IS ASSUMED TO BE SORTED BY TAG.
-@@ -309,6 +311,7 @@ _TIFFMergeFieldInfo(TIFF* tif, const TIF
- tif->tif_fieldinfo = (TIFFFieldInfo**)
- _TIFFmalloc(n * sizeof (TIFFFieldInfo*));
- }
-+ assert(tif->tif_fieldinfo != NULL);
- tp = &tif->tif_fieldinfo[tif->tif_nfields];
- for (i = 0; i < n; i++)
- tp[i] = (TIFFFieldInfo*) &info[i]; /* XXX */
-@@ -376,7 +379,7 @@ TIFFDataWidth(TIFFDataType type)
- TIFFDataType
- _TIFFSampleToTagType(TIFF* tif)
- {
-- int bps = (int) TIFFhowmany(tif->tif_dir.td_bitspersample, 8);
-+ uint32 bps = TIFFhowmany8(tif->tif_dir.td_bitspersample);
-
- switch (tif->tif_dir.td_sampleformat) {
- case SAMPLEFORMAT_IEEEFP:
-@@ -422,9 +425,6 @@ _TIFFFindFieldInfo(TIFF* tif, ttag_t tag
- return ((const TIFFFieldInfo *)0);
- }
-
--#include <assert.h>
--#include <stdio.h>
--
- const TIFFFieldInfo*
- _TIFFFieldWithTag(TIFF* tif, ttag_t tag)
- {
-@@ -460,6 +460,8 @@ _TIFFCreateAnonFieldInfo(TIFF *tif, ttag
- TIFFFieldInfo *fld;
-
- fld = (TIFFFieldInfo *) _TIFFmalloc(sizeof (TIFFFieldInfo));
-+ if (fld == NULL)
-+ return NULL;
- _TIFFmemset( fld, 0, sizeof(TIFFFieldInfo) );
-
- fld->field_tag = tag;
-@@ -470,6 +472,10 @@ _TIFFCreateAnonFieldInfo(TIFF *tif, ttag
- fld->field_oktochange = TRUE;
- fld->field_passcount = TRUE;
- fld->field_name = (char *) _TIFFmalloc(32);
-+ if (fld->field_name == NULL) {
-+ _TIFFfree(fld);
-+ return NULL;
-+ }
-
- /* note that this name is a special sign to TIFFClose() and
- * _TIFFSetupFieldInfo() to free the field
---- libtiff/tif_dirread.c Wed Oct 13 15:11:03 2004
-+++ libtiff/tif_dirread.c Wed Oct 13 15:11:32 2004
-@@ -62,11 +62,17 @@
- static void ChopUpSingleUncompressedStrip(TIFF*);
-
- static char *
--CheckMalloc(TIFF* tif, tsize_t n, const char* what)
-+CheckMalloc(TIFF* tif, size_t nmemb, size_t elem_size, const char* what)
- {
-- char *cp = (char*)_TIFFmalloc(n);
-+ char *cp = NULL;
-+ tsize_t bytes = nmemb * elem_size;
-+
-+ if (elem_size && bytes / elem_size == nmemb)
-+ cp = (char*)_TIFFmalloc(bytes);
-+
- if (cp == NULL)
- TIFFError(tif->tif_name, "No space %s", what);
-+
- return (cp);
- }
-
-@@ -93,6 +99,7 @@
- toff_t nextdiroff;
- char* cp;
- int diroutoforderwarning = 0;
-+ toff_t* new_dirlist;
-
- tif->tif_diroff = tif->tif_nextdiroff;
- if (tif->tif_diroff == 0) /* no more directories */
-@@ -108,14 +115,15 @@
- return (0);
- }
- tif->tif_dirnumber++;
-- tif->tif_dirlist = _TIFFrealloc(tif->tif_dirlist,
-- tif->tif_dirnumber * sizeof(toff_t));
-- if (!tif->tif_dirlist) {
-+ new_dirlist = _TIFFrealloc(tif->tif_dirlist,
-+ tif->tif_dirnumber * sizeof(toff_t));
-+ if (!new_dirlist) {
- TIFFError(module,
- "%.1000s: Failed to allocate space for IFD list",
- tif->tif_name);
- return (0);
- }
-+ tif->tif_dirlist = new_dirlist;
- tif->tif_dirlist[tif->tif_dirnumber - 1] = tif->tif_diroff;
-
- /*
-@@ -140,7 +148,7 @@
- if (tif->tif_flags & TIFF_SWAB)
- TIFFSwabShort(&dircount);
- dir = (TIFFDirEntry *)CheckMalloc(tif,
-- dircount * sizeof (TIFFDirEntry), "to read TIFF directory");
-+ dircount, sizeof (TIFFDirEntry), "to read TIFF directory");
- if (dir == NULL)
- return (0);
- if (!ReadOK(tif, dir, dircount*sizeof (TIFFDirEntry))) {
-@@ -167,7 +175,7 @@
- if (tif->tif_flags & TIFF_SWAB)
- TIFFSwabShort(&dircount);
- dir = (TIFFDirEntry *)CheckMalloc(tif,
-- dircount * sizeof (TIFFDirEntry), "to read TIFF directory");
-+ dircount, sizeof (TIFFDirEntry), "to read TIFF directory");
- if (dir == NULL)
- return (0);
- if (off + dircount*sizeof (TIFFDirEntry) > tif->tif_size) {
-@@ -175,9 +183,10 @@
- "%.1000s: Can not read TIFF directory",
- tif->tif_name);
- goto bad;
-- } else
-+ } else {
- _TIFFmemcpy(dir, tif->tif_base + off,
-- dircount*sizeof (TIFFDirEntry));
-+ dircount*sizeof (TIFFDirEntry));
-+ }
- off += dircount* sizeof (TIFFDirEntry);
- if (off + sizeof (uint32) <= tif->tif_size)
- _TIFFmemcpy(&nextdiroff, tif->tif_base+off, sizeof (uint32));
-@@ -390,6 +399,11 @@
- td->td_nstrips = TIFFNumberOfTiles(tif);
- tif->tif_flags |= TIFF_ISTILED;
- }
-+ if (!td->td_nstrips) {
-+ TIFFError(module, "%s: cannot handle zero number of %s",
-+ tif->tif_name, isTiled(tif) ? "tiles" : "strips");
-+ goto bad;
-+ }
- td->td_stripsperimage = td->td_nstrips;
- if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
- td->td_stripsperimage /= td->td_samplesperpixel;
-@@ -466,7 +480,7 @@
- break;
- }
- v *= sizeof (uint16);
-- cp = CheckMalloc(tif, dp->tdir_count * sizeof (uint16),
-+ cp = CheckMalloc(tif, dp->tdir_count, sizeof (uint16),
- "to read \"TransferFunction\" tag");
- if (cp != NULL) {
- if (TIFFFetchData(tif, dp, cp)) {
-@@ -573,8 +587,10 @@
- if(EstimateStripByteCounts(tif, dir, dircount) < 0)
- goto bad;
- }
-- if (dir)
-+ if (dir) {
- _TIFFfree((char *)dir);
-+ dir = NULL;
-+ }
- if (!TIFFFieldSet(tif, FIELD_MAXSAMPLEVALUE))
- td->td_maxsamplevalue = (uint16)((1L<<td->td_bitspersample)-1);
- /*
-@@ -601,8 +617,29 @@
- tif->tif_curstrip = (tstrip_t) -1;
- tif->tif_col = (uint32) -1;
- tif->tif_curtile = (ttile_t) -1;
-- tif->tif_tilesize = TIFFTileSize(tif);
-+ tif->tif_tilesize = (tsize_t) -1;
-+
- tif->tif_scanlinesize = TIFFScanlineSize(tif);
-+ if (!tif->tif_scanlinesize) {
-+ TIFFError(module, "%s: cannot handle zero scanline size",
-+ tif->tif_name);
-+ return (0);
-+ }
-+
-+ if (isTiled(tif)) {
-+ tif->tif_tilesize = TIFFTileSize(tif);
-+ if (!tif->tif_tilesize) {
-+ TIFFError(module, "%s: cannot handle zero tile size",
-+ tif->tif_name);
-+ return (0);
-+ }
-+ } else {
-+ if (!TIFFStripSize(tif)) {
-+ TIFFError(module, "%s: cannot handle zero strip size",
-+ tif->tif_name);
-+ return (0);
-+ }
-+ }
- return (1);
- bad:
- if (dir)
-@@ -622,7 +659,7 @@
- if (td->td_stripbytecount)
- _TIFFfree(td->td_stripbytecount);
- td->td_stripbytecount = (uint32*)
-- CheckMalloc(tif, td->td_nstrips * sizeof (uint32),
-+ CheckMalloc(tif, td->td_nstrips, sizeof (uint32),
- "for \"StripByteCounts\" array");
- if (td->td_compression != COMPRESSION_NONE) {
- uint32 space = (uint32)(sizeof (TIFFHeader)
-@@ -931,7 +968,7 @@
- uint32* l;
-
- l = (uint32*)CheckMalloc(tif,
-- dir->tdir_count*TIFFDataWidth((TIFFDataType) dir->tdir_type),
-+ dir->tdir_count, TIFFDataWidth((TIFFDataType) dir->tdir_type),
- "to fetch array of rationals");
- if (l) {
- if (TIFFFetchData(tif, dir, (char *)l)) {
-@@ -1087,35 +1124,35 @@
- case TIFF_SBYTE:
- /* NB: always expand BYTE values to shorts */
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (uint16), mesg);
-+ dp->tdir_count, sizeof (uint16), mesg);
- ok = cp && TIFFFetchByteArray(tif, dp, (uint16*) cp);
- break;
- case TIFF_SHORT:
- case TIFF_SSHORT:
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (uint16), mesg);
-+ dp->tdir_count, sizeof (uint16), mesg);
- ok = cp && TIFFFetchShortArray(tif, dp, (uint16*) cp);
- break;
- case TIFF_LONG:
- case TIFF_SLONG:
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (uint32), mesg);
-+ dp->tdir_count, sizeof (uint32), mesg);
- ok = cp && TIFFFetchLongArray(tif, dp, (uint32*) cp);
- break;
- case TIFF_RATIONAL:
- case TIFF_SRATIONAL:
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (float), mesg);
-+ dp->tdir_count, sizeof (float), mesg);
- ok = cp && TIFFFetchRationalArray(tif, dp, (float*) cp);
- break;
- case TIFF_FLOAT:
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (float), mesg);
-+ dp->tdir_count, sizeof (float), mesg);
- ok = cp && TIFFFetchFloatArray(tif, dp, (float*) cp);
- break;
- case TIFF_DOUBLE:
- cp = CheckMalloc(tif,
-- dp->tdir_count * sizeof (double), mesg);
-+ dp->tdir_count, sizeof (double), mesg);
- ok = cp && TIFFFetchDoubleArray(tif, dp, (double*) cp);
- break;
- case TIFF_ASCII:
-@@ -1124,7 +1161,7 @@
- * Some vendors write strings w/o the trailing
- * NULL byte, so always append one just in case.
- */
-- cp = CheckMalloc(tif, dp->tdir_count+1, mesg);
-+ cp = CheckMalloc(tif, dp->tdir_count+1, 1, mesg);
- if( (ok = (cp && TIFFFetchString(tif, dp, cp))) != 0 )
- cp[dp->tdir_count] = '\0'; /* XXX */
- break;
-@@ -1226,8 +1263,9 @@
- uint16* v = buf;
-
- if (samples > NITEMS(buf))
-- v = (uint16*) _TIFFmalloc(samples * sizeof (uint16));
-- if (TIFFFetchShortArray(tif, dir, v)) {
-+ v = (uint16*) CheckMalloc(tif, samples, sizeof (uint16),
-+ "to fetch per-sample values");
-+ if (v && TIFFFetchShortArray(tif, dir, v)) {
- int i;
- for (i = 1; i < samples; i++)
- if (v[i] != v[0]) {
-@@ -1240,7 +1278,7 @@
- status = 1;
- }
- bad:
-- if (v != buf)
-+ if (v && v != buf)
- _TIFFfree((char*) v);
- }
- return (status);
-@@ -1262,8 +1300,9 @@
- double* v = buf;
-
- if (samples > NITEMS(buf))
-- v = (double*) _TIFFmalloc(samples * sizeof (double));
-- if (TIFFFetchAnyArray(tif, dir, v)) {
-+ v = (double*) CheckMalloc(tif, samples, sizeof (double),
-+ "to fetch per-sample values");
-+ if (v && TIFFFetchAnyArray(tif, dir, v)) {
- int i;
- for (i = 1; i < samples; i++)
- if (v[i] != v[0]) {
-@@ -1276,7 +1315,7 @@
- status = 1;
- }
- bad:
-- if (v != buf)
-+ if (v && v != buf)
- _TIFFfree(v);
- }
- return (status);
-@@ -1301,7 +1340,7 @@
- */
- if (*lpp == NULL &&
- (*lpp = (uint32 *)CheckMalloc(tif,
-- nstrips * sizeof (uint32), "for strip array")) == NULL)
-+ nstrips, sizeof (uint32), "for strip array")) == NULL)
- return (0);
- lp = *lpp;
- memset( lp, 0, sizeof(uint32) * nstrips );
-@@ -1311,7 +1350,7 @@
- * Handle uint16->uint32 expansion.
- */
- uint16* dp = (uint16*) CheckMalloc(tif,
-- dir->tdir_count* sizeof (uint16), "to fetch strip tag");
-+ dir->tdir_count, sizeof (uint16), "to fetch strip tag");
- if (dp == NULL)
- return (0);
- if( (status = TIFFFetchShortArray(tif, dir, dp)) != 0 ) {
-@@ -1328,7 +1367,7 @@
- /* Special case to correct length */
-
- uint32* dp = (uint32*) CheckMalloc(tif,
-- dir->tdir_count* sizeof (uint32), "to fetch strip tag");
-+ dir->tdir_count, sizeof (uint32), "to fetch strip tag");
- if (dp == NULL)
- return (0);
-
-@@ -1360,8 +1399,12 @@
- uint16* v = buf;
- int status;
-
-- if (dir->tdir_count > NITEMS(buf))
-- v = (uint16*) _TIFFmalloc(dir->tdir_count * sizeof (uint16));
-+ if (dir->tdir_count > NITEMS(buf)) {
-+ v = (uint16*) CheckMalloc(tif, dir->tdir_count, sizeof (uint16),
-+ "to fetch extra samples");
-+ if (!v)
-+ return (0);
-+ }
- if (dir->tdir_type == TIFF_BYTE)
- status = TIFFFetchByteArray(tif, dir, v);
- else
-@@ -1390,10 +1433,10 @@
- /*
- * Handle LONG's for backward compatibility.
- */
-- cp = CheckMalloc(tif, dir->tdir_count * sizeof (uint32), mesg);
-+ cp = CheckMalloc(tif, dir->tdir_count, sizeof (uint32), mesg);
- if( (ok = (cp && TIFFFetchLongArray(tif, dir, (uint32*) cp))) != 0) {
- float* fp = (float*)
-- CheckMalloc(tif, dir->tdir_count * sizeof (float), mesg);
-+ CheckMalloc(tif, dir->tdir_count, sizeof (float), mesg);
- if( (ok = (fp != NULL)) != 0 ) {
- uint32 i;
- for (i = 0; i < dir->tdir_count; i++)
-@@ -1444,9 +1487,9 @@
- if (rowsperstrip >= td->td_rowsperstrip)
- return;
- nstrips = (tstrip_t) TIFFhowmany(bytecount, stripbytes);
-- newcounts = (uint32*) CheckMalloc(tif, nstrips * sizeof (uint32),
-+ newcounts = (uint32*) CheckMalloc(tif, nstrips, sizeof (uint32),
- "for chopped \"StripByteCounts\" array");
-- newoffsets = (uint32*) CheckMalloc(tif, nstrips * sizeof (uint32),
-+ newoffsets = (uint32*) CheckMalloc(tif, nstrips, sizeof (uint32),
- "for chopped \"StripOffsets\" array");
- if (newcounts == NULL || newoffsets == NULL) {
- /*
-diff -uprk.orig libtiff/tif_dirwrite.c libtiff/tif_dirwrite.c
---- libtiff/tif_dirwrite.c 2003-12-22 11:22:15 +0300
-+++ libtiff/tif_dirwrite.c 2004-10-03 00:20:41 +0400
-@@ -692,8 +692,14 @@ TIFFWritePerSampleShorts(TIFF* tif, ttag
- uint16* w = buf;
- int i, status, samples = tif->tif_dir.td_samplesperpixel;
-
-- if (samples > NITEMS(buf))
-+ if (samples > NITEMS(buf)) {
- w = (uint16*) _TIFFmalloc(samples * sizeof (uint16));
-+ if (w == NULL) {
-+ TIFFError(tif->tif_name,
-+ "No space to write per-sample shorts");
-+ return (0);
-+ }
-+ }
- TIFFGetField(tif, tag, &v);
- for (i = 0; i < samples; i++)
- w[i] = v;
-@@ -717,8 +723,14 @@ TIFFWritePerSampleAnys(TIFF* tif,
- int i, status;
- int samples = (int) tif->tif_dir.td_samplesperpixel;
-
-- if (samples > NITEMS(buf))
-+ if (samples > NITEMS(buf)) {
- w = (double*) _TIFFmalloc(samples * sizeof (double));
-+ if (w == NULL) {
-+ TIFFError(tif->tif_name,
-+ "No space to write per-sample values");
-+ return (0);
-+ }
-+ }
- TIFFGetField(tif, tag, &v);
- for (i = 0; i < samples; i++)
- w[i] = v;
-@@ -840,6 +852,11 @@ TIFFWriteRationalArray(TIFF* tif,
- dir->tdir_type = (short) type;
- dir->tdir_count = n;
- t = (uint32*) _TIFFmalloc(2*n * sizeof (uint32));
-+ if (t == NULL) {
-+ TIFFError(tif->tif_name,
-+ "No space to write RATIONAL array");
-+ return (0);
-+ }
- for (i = 0; i < n; i++) {
- float fv = v[i];
- int sign = 1;
-@@ -910,8 +927,14 @@ TIFFWriteAnyArray(TIFF* tif,
- char* w = buf;
- int i, status = 0;
-
-- if (n * TIFFDataWidth(type) > sizeof buf)
-+ if (n * TIFFDataWidth(type) > sizeof buf) {
- w = (char*) _TIFFmalloc(n * TIFFDataWidth(type));
-+ if (w == NULL) {
-+ TIFFError(tif->tif_name,
-+ "No space to write array");
-+ return (0);
-+ }
-+ }
- switch (type) {
- case TIFF_BYTE:
- { uint8* bp = (uint8*) w;
-diff -uprk.orig libtiff/tif_extension.c libtiff/tif_extension.c
---- libtiff/tif_extension.c 2003-12-22 11:22:15 +0300
-+++ libtiff/tif_extension.c 2004-10-03 00:20:41 +0400
-@@ -32,6 +32,7 @@
- */
-
- #include "tiffiop.h"
-+#include <assert.h>
-
- int TIFFGetTagListCount( TIFF *tif )
-
-@@ -100,8 +101,10 @@ void TIFFSetClientInfo( TIFF *tif, void
- */
-
- link = (TIFFClientInfoLink *) _TIFFmalloc(sizeof(TIFFClientInfoLink));
-+ assert (link != NULL);
- link->next = tif->tif_clientinfo;
- link->name = (char *) _TIFFmalloc(strlen(name)+1);
-+ assert (link->name != NULL);
- strcpy(link->name, name);
- link->data = data;
-
-diff -uprk.orig libtiff/tif_fax3.c libtiff/tif_fax3.c
---- libtiff/tif_fax3.c 2003-11-06 11:22:13 +0300
-+++ libtiff/tif_fax3.c 2004-10-03 00:20:41 +0400
-@@ -437,6 +437,21 @@ _TIFFFax3fillruns(u_char* buf, uint32* r
- #undef ZERO
- #undef FILL
-
-+static char *
-+CheckMalloc(TIFF* tif, size_t nmemb, size_t elem_size, const char* what)
-+{
-+ char *cp = NULL;
-+ tsize_t bytes = nmemb * elem_size;
-+
-+ if (elem_size && bytes / elem_size == nmemb)
-+ cp = (char*) _TIFFmalloc(bytes);
-+
-+ if (cp == NULL)
-+ TIFFError(tif->tif_name, "No space %s", what);
-+
-+ return (cp);
-+}
-+
- /*
- * Setup G3/G4-related compression/decompression state
- * before data is processed. This routine is called once
-@@ -481,13 +496,10 @@ Fax3SetupState(TIFF* tif)
-
- nruns = needsRefLine ? 2*TIFFroundup(rowpixels,32) : rowpixels;
-
-- dsp->runs = (uint32*) _TIFFmalloc((2*nruns+3)*sizeof (uint32));
-- if (dsp->runs == NULL) {
-- TIFFError("Fax3SetupState",
-- "%s: No space for Group 3/4 run arrays",
-- tif->tif_name);
-+ dsp->runs = (uint32*) CheckMalloc(tif, 2*nruns+3, sizeof (uint32),
-+ "for Group 3/4 run arrays");
-+ if (dsp->runs == NULL)
- return (0);
-- }
- dsp->curruns = dsp->runs;
- if (needsRefLine)
- dsp->refruns = dsp->runs + (nruns>>1);
-diff -uprk.orig libtiff/tiffiop.h libtiff/tiffiop.h
---- libtiff/tiffiop.h 2003-12-26 14:56:25 +0300
-+++ libtiff/tiffiop.h 2004-10-03 00:20:41 +0400
-@@ -198,8 +198,9 @@ struct tiff {
- #endif
-
- /* NB: the uint32 casts are to silence certain ANSI-C compilers */
--#define TIFFhowmany(x, y) ((((uint32)(x))+(((uint32)(y))-1))/((uint32)(y)))
--#define TIFFroundup(x, y) (TIFFhowmany(x,y)*((uint32)(y)))
-+#define TIFFhowmany(x, y) ((((uint32)(x))+(((uint32)(y))-1))/((uint32)(y)))
-+#define TIFFhowmany8(x) (((x)&0x07)?((uint32)(x)>>3)+1:(uint32)(x)>>3)
-+#define TIFFroundup(x, y) (TIFFhowmany(x,y)*(y))
-
- #define TIFFmax(A,B) ((A)>(B)?(A):(B))
- #define TIFFmin(A,B) ((A)<(B)?(A):(B))
-diff -uprk.orig libtiff/tif_getimage.c libtiff/tif_getimage.c
---- libtiff/tif_getimage.c 2003-12-22 11:22:15 +0300
-+++ libtiff/tif_getimage.c 2004-10-03 00:20:41 +0400
-@@ -565,6 +565,7 @@ gtTileContig(TIFFRGBAImage* img, uint32*
- TIFFError(TIFFFileName(tif), "No space for tile buffer");
- return (0);
- }
-+ _TIFFmemset(buf, 0, TIFFTileSize(tif));
- TIFFGetField(tif, TIFFTAG_TILEWIDTH, &tw);
- TIFFGetField(tif, TIFFTAG_TILELENGTH, &th);
-
-@@ -664,6 +665,7 @@ gtTileSeparate(TIFFRGBAImage* img, uint3
- TIFFError(TIFFFileName(tif), "No space for tile buffer");
- return (0);
- }
-+ _TIFFmemset(buf, 0, 4*tilesize);
- r = buf;
- g = r + tilesize;
- b = g + tilesize;
-@@ -727,9 +729,7 @@ gtTileSeparate(TIFFRGBAImage* img, uint3
- (*put)(img, raster+y*w+col, col, y,
- npix, nrow, fromskew, toskew + fromskew,
- r + pos, g + pos, b + pos, a + pos);
-- }
-- else
-- {
-+ } else {
- (*put)(img, raster+y*w+col, col, y,
- tw, nrow, 0, toskew, r + pos, g + pos, b + pos, a + pos);
- }
-@@ -783,13 +783,13 @@ gtStripContig(TIFFRGBAImage* img, uint32
- TIFFError(TIFFFileName(tif), "No space for strip buffer");
- return (0);
- }
-+ _TIFFmemset(buf, 0, TIFFStripSize(tif));
-
- flip = setorientation(img);
- if (flip & FLIP_VERTICALLY) {
- y = h - 1;
- toskew = -(int32)(w + w);
-- }
-- else {
-+ } else {
- y = 0;
- toskew = -(int32)(w - w);
- }
-@@ -865,6 +865,7 @@ gtStripSeparate(TIFFRGBAImage* img, uint
- TIFFError(TIFFFileName(tif), "No space for tile buffer");
- return (0);
- }
-+ _TIFFmemset(buf, 0, 4*stripsize);
- g = r + stripsize;
- b = g + stripsize;
- a = b + stripsize;
-diff -uprk.orig libtiff/tif_luv.c libtiff/tif_luv.c
---- libtiff/tif_luv.c 2003-11-27 18:08:10 +0300
-+++ libtiff/tif_luv.c 2004-10-03 00:20:41 +0400
-@@ -1161,6 +1161,17 @@ LogL16GuessDataFmt(TIFFDirectory *td)
- return (SGILOGDATAFMT_UNKNOWN);
- }
-
-+static uint32
-+multiply(size_t m1, size_t m2)
-+{
-+ uint32 bytes = m1 * m2;
-+
-+ if (m1 && bytes / m1 != m2)
-+ bytes = 0;
-+
-+ return bytes;
-+}
-+
- static int
- LogL16InitState(TIFF* tif)
- {
-@@ -1189,9 +1200,9 @@ LogL16InitState(TIFF* tif)
- "No support for converting user data format to LogL");
- return (0);
- }
-- sp->tbuflen = td->td_imagewidth * td->td_rowsperstrip;
-- sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (int16));
-- if (sp->tbuf == NULL) {
-+ sp->tbuflen = multiply(td->td_imagewidth, td->td_rowsperstrip);
-+ if (multiply(sp->tbuflen, sizeof (int16)) == 0 ||
-+ (sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (int16))) == NULL) {
- TIFFError(module, "%s: No space for SGILog translation buffer",
- tif->tif_name);
- return (0);
-@@ -1287,9 +1298,9 @@ LogLuvInitState(TIFF* tif)
- "No support for converting user data format to LogLuv");
- return (0);
- }
-- sp->tbuflen = td->td_imagewidth * td->td_rowsperstrip;
-- sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (uint32));
-- if (sp->tbuf == NULL) {
-+ sp->tbuflen = multiply(td->td_imagewidth, td->td_rowsperstrip);
-+ if (multiply(sp->tbuflen, sizeof (uint32)) == 0 ||
-+ (sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (uint32))) == NULL) {
- TIFFError(module, "%s: No space for SGILog translation buffer",
- tif->tif_name);
- return (0);
-diff -uprk.orig libtiff/tif_pixarlog.c libtiff/tif_pixarlog.c
---- libtiff/tif_pixarlog.c 2003-07-08 10:50:09 +0400
-+++ libtiff/tif_pixarlog.c 2004-10-03 00:20:41 +0400
-@@ -630,11 +630,23 @@ PixarLogGuessDataFmt(TIFFDirectory *td)
- return guess;
- }
-
-+static uint32
-+multiply(size_t m1, size_t m2)
-+{
-+ uint32 bytes = m1 * m2;
-+
-+ if (m1 && bytes / m1 != m2)
-+ bytes = 0;
-+
-+ return bytes;
-+}
-+
- static int
- PixarLogSetupDecode(TIFF* tif)
- {
- TIFFDirectory *td = &tif->tif_dir;
- PixarLogState* sp = DecoderState(tif);
-+ tsize_t tbuf_size;
- static const char module[] = "PixarLogSetupDecode";
-
- assert(sp != NULL);
-@@ -647,8 +659,13 @@ PixarLogSetupDecode(TIFF* tif)
-
- sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ?
- td->td_samplesperpixel : 1);
-- sp->tbuf = (uint16 *) _TIFFmalloc(sp->stride *
-- td->td_imagewidth * td->td_rowsperstrip * sizeof(uint16));
-+ tbuf_size = multiply(multiply(multiply(sp->stride, td->td_imagewidth),
-+ td->td_rowsperstrip), sizeof(uint16));
-+ if (tbuf_size == 0)
-+ return (0);
-+ sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size);
-+ if (sp->tbuf == NULL)
-+ return (0);
- if (sp->user_datafmt == PIXARLOGDATAFMT_UNKNOWN)
- sp->user_datafmt = PixarLogGuessDataFmt(td);
- if (sp->user_datafmt == PIXARLOGDATAFMT_UNKNOWN) {
-@@ -798,6 +815,7 @@ PixarLogSetupEncode(TIFF* tif)
- {
- TIFFDirectory *td = &tif->tif_dir;
- PixarLogState* sp = EncoderState(tif);
-+ tsize_t tbuf_size;
- static const char module[] = "PixarLogSetupEncode";
-
- assert(sp != NULL);
-@@ -806,8 +824,13 @@ PixarLogSetupEncode(TIFF* tif)
-
- sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ?
- td->td_samplesperpixel : 1);
-- sp->tbuf = (uint16 *) _TIFFmalloc(sp->stride *
-- td->td_imagewidth * td->td_rowsperstrip * sizeof(uint16));
-+ tbuf_size = multiply(multiply(multiply(sp->stride, td->td_imagewidth),
-+ td->td_rowsperstrip), sizeof(uint16));
-+ if (tbuf_size == 0)
-+ return (0);
-+ sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size);
-+ if (sp->tbuf == NULL)
-+ return (0);
- if (sp->user_datafmt == PIXARLOGDATAFMT_UNKNOWN)
- sp->user_datafmt = PixarLogGuessDataFmt(td);
- if (sp->user_datafmt == PIXARLOGDATAFMT_UNKNOWN) {
-diff -uprk.orig libtiff/tif_strip.c libtiff/tif_strip.c
---- libtiff/tif_strip.c 2003-11-11 18:43:10 +0300
-+++ libtiff/tif_strip.c 2004-10-03 00:20:41 +0400
-@@ -31,6 +31,32 @@
- */
- #include "tiffiop.h"
-
-+static uint32
-+summarize(TIFF* tif, size_t summand1, size_t summand2, const char* where)
-+{
-+ uint32 bytes = summand1 + summand2;
-+
-+ if (bytes - summand1 != summand2) {
-+ TIFFError(tif->tif_name, "Integer overflow in %s", where);
-+ bytes = 0;
-+ }
-+
-+ return (bytes);
-+}
-+
-+static uint32
-+multiply(TIFF* tif, size_t nmemb, size_t elem_size, const char* where)
-+{
-+ uint32 bytes = nmemb * elem_size;
-+
-+ if (elem_size && bytes / elem_size != nmemb) {
-+ TIFFError(tif->tif_name, "Integer overflow in %s", where);
-+ bytes = 0;
-+ }
-+
-+ return (bytes);
-+}
-+
- /*
- * Compute which strip a (row,sample) value is in.
- */
-@@ -66,7 +92,8 @@ TIFFNumberOfStrips(TIFF* tif)
- (td->td_imagelength != 0 ? 1 : 0) :
- TIFFhowmany(td->td_imagelength, td->td_rowsperstrip));
- if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
-- nstrips *= td->td_samplesperpixel;
-+ nstrips = multiply(tif, nstrips, td->td_samplesperpixel,
-+ "TIFFNumberOfStrips");
- return (nstrips);
- }
-
-@@ -100,15 +127,20 @@ TIFFVStripSize(TIFF* tif, uint32 nrows)
- ycbcrsubsampling + 1 );
-
- w = TIFFroundup(td->td_imagewidth, ycbcrsubsampling[0]);
-- scanline = TIFFhowmany(w*td->td_bitspersample, 8);
-+ scanline = TIFFhowmany8(multiply(tif, w, td->td_bitspersample,
-+ "TIFFVStripSize"));
- samplingarea = ycbcrsubsampling[0]*ycbcrsubsampling[1];
- nrows = TIFFroundup(nrows, ycbcrsubsampling[1]);
- /* NB: don't need TIFFhowmany here 'cuz everything is rounded */
-+ scanline = multiply(tif, nrows, scanline, "TIFFVStripSize");
- return ((tsize_t)
-- (nrows*scanline + 2*(nrows*scanline / samplingarea)));
-+ summarize(tif, scanline,
-+ multiply(tif, 2, scanline / samplingarea,
-+ "TIFFVStripSize"), "TIFFVStripSize"));
- } else
- #endif
-- return ((tsize_t)(nrows * TIFFScanlineSize(tif)));
-+ return ((tsize_t) multiply(tif, nrows, TIFFScanlineSize(tif),
-+ "TIFFVStripSize"));
- }
-
-
-@@ -189,10 +221,12 @@ TIFFScanlineSize(TIFF* tif)
- TIFFDirectory *td = &tif->tif_dir;
- tsize_t scanline;
-
-- scanline = td->td_bitspersample * td->td_imagewidth;
-+ scanline = multiply (tif, td->td_bitspersample, td->td_imagewidth,
-+ "TIFFScanlineSize");
- if (td->td_planarconfig == PLANARCONFIG_CONTIG)
-- scanline *= td->td_samplesperpixel;
-- return ((tsize_t) TIFFhowmany(scanline, 8));
-+ scanline = multiply (tif, scanline, td->td_samplesperpixel,
-+ "TIFFScanlineSize");
-+ return ((tsize_t) TIFFhowmany8(scanline));
- }
-
- /*
-@@ -207,11 +241,14 @@ TIFFRasterScanlineSize(TIFF* tif)
- TIFFDirectory *td = &tif->tif_dir;
- tsize_t scanline;
-
-- scanline = td->td_bitspersample * td->td_imagewidth;
-+ scanline = multiply (tif, td->td_bitspersample, td->td_imagewidth,
-+ "TIFFRasterScanlineSize");
- if (td->td_planarconfig == PLANARCONFIG_CONTIG) {
-- scanline *= td->td_samplesperpixel;
-- return ((tsize_t) TIFFhowmany(scanline, 8));
-+ scanline = multiply (tif, scanline, td->td_samplesperpixel,
-+ "TIFFRasterScanlineSize");
-+ return ((tsize_t) TIFFhowmany8(scanline));
- } else
-- return ((tsize_t)
-- TIFFhowmany(scanline, 8)*td->td_samplesperpixel);
-+ return ((tsize_t) multiply (tif, TIFFhowmany8(scanline),
-+ td->td_samplesperpixel,
-+ "TIFFRasterScanlineSize"));
- }
-diff -uprk.orig libtiff/tif_tile.c libtiff/tif_tile.c
---- libtiff/tif_tile.c 2003-11-11 18:43:10 +0300
-+++ libtiff/tif_tile.c 2004-10-03 00:20:41 +0400
-@@ -31,6 +31,32 @@
- */
- #include "tiffiop.h"
-
-+static uint32
-+summarize(TIFF* tif, size_t summand1, size_t summand2, const char* where)
-+{
-+ uint32 bytes = summand1 + summand2;
-+
-+ if (bytes - summand1 != summand2) {
-+ TIFFError(tif->tif_name, "Integer overflow in %s", where);
-+ bytes = 0;
-+ }
-+
-+ return (bytes);
-+}
-+
-+static uint32
-+multiply(TIFF* tif, size_t nmemb, size_t elem_size, const char* where)
-+{
-+ uint32 bytes = nmemb * elem_size;
-+
-+ if (elem_size && bytes / elem_size != nmemb) {
-+ TIFFError(tif->tif_name, "Integer overflow in %s", where);
-+ bytes = 0;
-+ }
-+
-+ return (bytes);
-+}
-+
- /*
- * Compute which tile an (x,y,z,s) value is in.
- */
-@@ -119,11 +145,13 @@ TIFFNumberOfTiles(TIFF* tif)
- if (dz == (uint32) -1)
- dz = td->td_imagedepth;
- ntiles = (dx == 0 || dy == 0 || dz == 0) ? 0 :
-- (TIFFhowmany(td->td_imagewidth, dx) *
-- TIFFhowmany(td->td_imagelength, dy) *
-- TIFFhowmany(td->td_imagedepth, dz));
-+ multiply(tif, multiply(tif, TIFFhowmany(td->td_imagewidth, dx),
-+ TIFFhowmany(td->td_imagelength, dy),
-+ "TIFFNumberOfTiles"),
-+ TIFFhowmany(td->td_imagedepth, dz), "TIFFNumberOfTiles");
- if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
-- ntiles *= td->td_samplesperpixel;
-+ ntiles = multiply(tif, ntiles, td->td_samplesperpixel,
-+ "TIFFNumberOfTiles");
- return (ntiles);
- }
-
-@@ -138,10 +166,12 @@ TIFFTileRowSize(TIFF* tif)
-
- if (td->td_tilelength == 0 || td->td_tilewidth == 0)
- return ((tsize_t) 0);
-- rowsize = td->td_bitspersample * td->td_tilewidth;
-+ rowsize = multiply(tif, td->td_bitspersample, td->td_tilewidth,
-+ "TIFFTileRowSize");
- if (td->td_planarconfig == PLANARCONFIG_CONTIG)
-- rowsize *= td->td_samplesperpixel;
-- return ((tsize_t) TIFFhowmany(rowsize, 8));
-+ rowsize = multiply(tif, rowsize, td->td_samplesperpixel,
-+ "TIFFTileRowSize");
-+ return ((tsize_t) TIFFhowmany8(rowsize));
- }
-
- /*
-@@ -170,16 +200,24 @@ TIFFVTileSize(TIFF* tif, uint32 nrows)
- */
- tsize_t w =
- TIFFroundup(td->td_tilewidth, td->td_ycbcrsubsampling[0]);
-- tsize_t rowsize = TIFFhowmany(w*td->td_bitspersample, 8);
-+ tsize_t rowsize =
-+ TIFFhowmany8(multiply(tif, w, td->td_bitspersample,
-+ "TIFFVTileSize"));
- tsize_t samplingarea =
- td->td_ycbcrsubsampling[0]*td->td_ycbcrsubsampling[1];
- nrows = TIFFroundup(nrows, td->td_ycbcrsubsampling[1]);
- /* NB: don't need TIFFhowmany here 'cuz everything is rounded */
-- tilesize = nrows*rowsize + 2*(nrows*rowsize / samplingarea);
-+ tilesize = multiply(tif, nrows, rowsize, "TIFFVTileSize");
-+ tilesize = summarize(tif, tilesize,
-+ multiply(tif, 2, tilesize / samplingarea,
-+ "TIFFVTileSize"),
-+ "TIFFVTileSize");
- } else
- #endif
-- tilesize = nrows * TIFFTileRowSize(tif);
-- return ((tsize_t)(tilesize * td->td_tiledepth));
-+ tilesize = multiply(tif, nrows, TIFFTileRowSize(tif),
-+ "TIFFVTileSize");
-+ return ((tsize_t)
-+ multiply(tif, tilesize, td->td_tiledepth, "TIFFVTileSize"));
- }
-
- /*
-diff -uprk.orig libtiff/tif_write.c libtiff/tif_write.c
---- libtiff/tif_write.c 2003-08-05 12:49:13 +0400
-+++ libtiff/tif_write.c 2004-10-03 00:20:41 +0400
-@@ -597,21 +597,30 @@ TIFFWriteBufferSetup(TIFF* tif, tdata_t
- static int
- TIFFGrowStrips(TIFF* tif, int delta, const char* module)
- {
-- TIFFDirectory *td = &tif->tif_dir;
-+ TIFFDirectory *td = &tif->tif_dir;
-+ uint32 *new_stripoffset, *new_stripbytecount;
-
- assert(td->td_planarconfig == PLANARCONFIG_CONTIG);
-- td->td_stripoffset = (uint32*)_TIFFrealloc(td->td_stripoffset,
-- (td->td_nstrips + delta) * sizeof (uint32));
-- td->td_stripbytecount = (uint32*)_TIFFrealloc(td->td_stripbytecount,
-- (td->td_nstrips + delta) * sizeof (uint32));
-- if (td->td_stripoffset == NULL || td->td_stripbytecount == NULL) {
-+ new_stripoffset = (uint32*)_TIFFrealloc(td->td_stripoffset,
-+ (td->td_nstrips + delta) * sizeof (uint32));
-+ new_stripbytecount = (uint32*)_TIFFrealloc(td->td_stripbytecount,
-+ (td->td_nstrips + delta) * sizeof (uint32));
-+ if (new_stripoffset == NULL || new_stripbytecount == NULL) {
-+ if (new_stripoffset)
-+ _TIFFfree(new_stripoffset);
-+ if (new_stripbytecount)
-+ _TIFFfree(new_stripbytecount);
- td->td_nstrips = 0;
- TIFFError(module, "%s: No space to expand strip arrays",
-- tif->tif_name);
-+ tif->tif_name);
- return (0);
- }
-- _TIFFmemset(td->td_stripoffset+td->td_nstrips, 0, delta*sizeof (uint32));
-- _TIFFmemset(td->td_stripbytecount+td->td_nstrips, 0, delta*sizeof (uint32));
-+ td->td_stripoffset = new_stripoffset;
-+ td->td_stripbytecount = new_stripbytecount;
-+ _TIFFmemset(td->td_stripoffset + td->td_nstrips,
-+ 0, delta*sizeof (uint32));
-+ _TIFFmemset(td->td_stripbytecount + td->td_nstrips,
-+ 0, delta*sizeof (uint32));
- td->td_nstrips += delta;
- return (1);
- }
-
---xHFwDpU9dbj6ez1V--
diff --git a/graphics/tiff/files/patch-libtiff-tif_fax3.c b/graphics/tiff/files/patch-libtiff-tif_fax3.c
deleted file mode 100644
index 5e44d4e1d7d8..000000000000
--- a/graphics/tiff/files/patch-libtiff-tif_fax3.c
+++ /dev/null
@@ -1,21 +0,0 @@
---- libtiff/tif_fax3.c.orig Thu Feb 5 09:02:26 2004
-+++ libtiff/tif_fax3.c Thu Feb 5 09:05:07 2004
-@@ -451,7 +451,7 @@
- Fax3BaseState* sp = Fax3State(tif);
- long rowbytes, rowpixels;
- int needsRefLine;
-- Fax3CodecState* dsp = DecoderState(tif);
-+ Fax3CodecState* dsp = (Fax3CodecState*) Fax3State(tif);
- uint32 nruns;
-
- if (td->td_bitspersample != 1) {
-@@ -1284,7 +1284,8 @@
- sp->recvparams = 0;
- sp->subaddress = NULL;
-
-- tif->tif_flags |= TIFF_NOBITREV; /* decoder does bit reversal */
-+ if (sp->rw_mode == O_RDONLY) /* FIXME: improve for in place update */
-+ tif->tif_flags |= TIFF_NOBITREV; /* decoder does bit reversal */
- DecoderState(tif)->runs = NULL;
- TIFFSetField(tif, TIFFTAG_FAXFILLFUNC, _TIFFFax3fillruns);
- EncoderState(tif)->refline = NULL;
diff --git a/graphics/tiff/files/patch-tools-tiffcp.c b/graphics/tiff/files/patch-tools-tiffcp.c
deleted file mode 100644
index 186ea4339b18..000000000000
--- a/graphics/tiff/files/patch-tools-tiffcp.c
+++ /dev/null
@@ -1,176 +0,0 @@
---- tools/tiffcp.c.orig Mon Dec 22 09:22:16 2003
-+++ tools/tiffcp.c Sat Feb 7 06:47:57 2004
-@@ -1,4 +1,4 @@
--/* $Header: /cvsroot/osrs/libtiff/tools/tiffcp.c,v 1.15 2003/12/20 13:46:57 dron Exp $ */
-+/* $Header: /cvsroot/osrs/libtiff/tools/tiffcp.c,v 1.18 2004/01/28 12:12:01 dron Exp $ */
-
- /*
- * Copyright (c) 1988-1997 Sam Leffler
-@@ -181,7 +181,7 @@
- fputs ("Bias image must be organized in strips\n", stderr);
- exit (-7);
- }
-- TIFFGetField(bias, TIFFTAG_SAMPLESPERPIXEL, &samples);
-+ TIFFGetField(bias, TIFFTAG_SAMPLESPERPIXEL, &samples);
- if (samples != 1) {
- fputs ("Bias image must be monochrome\n", stderr);
- exit (-7);
-@@ -358,7 +358,7 @@
- " -t write output in tiles",
- " -i ignore read errors",
- " -b file[,#] bias (dark) monochrome image to be subtracted from all others",
--" -,=% use % rather than , to separate image #'s (per Note below)",
-+" -,=% use % rather than , to separate image #'s (per Note below)",
- "",
- " -r # make each strip have no more than # rows",
- " -w # set output tile width (pixels)",
-@@ -500,8 +500,6 @@
- { TIFFTAG_PRIMARYCHROMATICITIES,(uint16) -1,TIFF_RATIONAL },
- { TIFFTAG_HALFTONEHINTS, 2, TIFF_SHORT },
- { TIFFTAG_INKSET, 1, TIFF_SHORT },
-- { TIFFTAG_INKNAMES, 1, TIFF_ASCII },
-- { TIFFTAG_NUMBEROFINKS, 1, TIFF_SHORT },
- { TIFFTAG_DOTRANGE, 2, TIFF_SHORT },
- { TIFFTAG_TARGETPRINTER, 1, TIFF_ASCII },
- { TIFFTAG_SAMPLEFORMAT, 1, TIFF_SHORT },
-@@ -526,7 +524,6 @@
- tiffcp(TIFF* in, TIFF* out)
- {
- uint16 bitspersample, samplesperpixel;
-- uint16 input_compression;
- copyFunc cf;
- uint32 width, length;
- struct cpTag* p;
-@@ -540,16 +537,22 @@
- else
- CopyField(TIFFTAG_COMPRESSION, compression);
- if (compression == COMPRESSION_JPEG) {
-+ uint16 input_compression, input_photometric;
-+
- if ( TIFFGetField( in, TIFFTAG_COMPRESSION, &input_compression )
- && input_compression == COMPRESSION_JPEG ) {
- TIFFSetField(in, TIFFTAG_JPEGCOLORMODE, JPEGCOLORMODE_RGB);
- }
-- if (jpegcolormode == JPEGCOLORMODE_RGB)
-- TIFFSetField(out, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_YCBCR);
-- else
-- TIFFSetField(out, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_RGB);
-+ if (TIFFGetField(in, TIFFTAG_PHOTOMETRIC, &input_photometric)
-+ && input_photometric == PHOTOMETRIC_RGB) {
-+ if (jpegcolormode == JPEGCOLORMODE_RGB)
-+ TIFFSetField(out, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_YCBCR);
-+ else
-+ TIFFSetField(out, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_RGB);
-+ }
- }
-- else if (compression == COMPRESSION_SGILOG || compression == COMPRESSION_SGILOG24)
-+ else if (compression == COMPRESSION_SGILOG
-+ || compression == COMPRESSION_SGILOG24)
- TIFFSetField(out, TIFFTAG_PHOTOMETRIC,
- samplesperpixel == 1 ?
- PHOTOMETRIC_LOGL : PHOTOMETRIC_LOGLUV);
-@@ -662,14 +665,75 @@
- if (TIFFGetField(in, TIFFTAG_ICCPROFILE, &len32, &data))
- TIFFSetField(out, TIFFTAG_ICCPROFILE, len32, data);
- }
-+ { uint16 ninks;
-+ const char* inknames;
-+ if (TIFFGetField(in, TIFFTAG_NUMBEROFINKS, &ninks)) {
-+ TIFFSetField(out, TIFFTAG_NUMBEROFINKS, ninks);
-+ if (TIFFGetField(in, TIFFTAG_INKNAMES, &inknames)) {
-+ int inknameslen = strlen(inknames) + 1;
-+ const char* cp = inknames;
-+ while (ninks > 1) {
-+ cp = strchr(cp, '\0');
-+ if (cp) {
-+ cp++;
-+ inknameslen += (strlen(cp) + 1);
-+ }
-+ ninks--;
-+ }
-+ TIFFSetField(out, TIFFTAG_INKNAMES, inknameslen, inknames);
-+ }
-+ }
-+ }
- {
- unsigned short pg0, pg1;
-- if (TIFFGetField(in, TIFFTAG_PAGENUMBER, &pg0, &pg1))
-- if (pageNum < 0) // only one input file
-+ if (TIFFGetField(in, TIFFTAG_PAGENUMBER, &pg0, &pg1)) {
-+ if (pageNum < 0) /* only one input file */
- TIFFSetField(out, TIFFTAG_PAGENUMBER, pg0, pg1);
- else
- TIFFSetField(out, TIFFTAG_PAGENUMBER, pageNum++, 0);
-+ }
- }
-+ {
-+ int i;
-+ short count;
-+ TIFFFieldInfo *xtiffFieldInfo;
-+
-+ count = (short) TIFFGetTagListCount(in);
-+ xtiffFieldInfo = _TIFFmalloc(count * sizeof(TIFFFieldInfo));
-+ for(i = 0; i < count; i++)
-+ {
-+ ttag_t tag = TIFFGetTagListEntry(in, i);
-+ const TIFFFieldInfo *fld = TIFFFieldWithTag(in, tag);
-+
-+ if(fld == NULL)
-+ continue;
-+
-+ _TIFFmemcpy(&xtiffFieldInfo[i], (void *)fld, sizeof(TIFFFieldInfo));
-+ }
-+ TIFFMergeFieldInfo( out, xtiffFieldInfo, count );
-+ for(i = 0; i < count; i++)
-+ {
-+ const TIFFFieldInfo *fld = &xtiffFieldInfo[i];
-+ if(fld->field_passcount)
-+ {
-+ short value_count;
-+ void *raw_data;
-+
-+ if(TIFFGetField(in, fld->field_tag, &value_count, &raw_data))
-+ TIFFSetField(out, fld->field_tag, value_count, raw_data);
-+ }
-+ else if(!fld->field_passcount
-+ && fld->field_type == TIFF_ASCII)
-+ {
-+ char *data;
-+
-+ if(TIFFGetField(in, fld->field_tag, &data))
-+ TIFFSetField(out, fld->field_tag, data);
-+ }
-+ }
-+
-+ _TIFFfree(xtiffFieldInfo);
-+ }
- for (p = tags; p < &tags[NTAGS]; p++)
- CopyTag(p->tag, p->count, p->type);
-
-@@ -767,7 +831,7 @@
- uint32 row;
- buf = _TIFFmalloc(bufSize);
- biasBuf = _TIFFmalloc(bufSize);
-- for (row = 0; row < imagelength; row++) {
-+ for (row = 0; row < imagelength; row++) {
- if (TIFFReadScanline(in, buf, row, 0) < 0 && !ignore)
- break;
- if (TIFFReadScanline(bias, biasBuf, row, 0) < 0 && !ignore)
-@@ -1000,7 +1064,7 @@
- DECLAREreadFunc(readContigStripsIntoBuffer)
- {
- tsize_t scanlinesize = TIFFScanlineSize(in);
-- uint8* bufp = buf;
-+ uint8* bufp = buf;
- uint32 row;
-
- (void) imagewidth; (void) spp;
-@@ -1454,7 +1518,7 @@
- uint32 irps = (uint32) -1L;
- TIFFGetField(in, TIFFTAG_ROWSPERSTRIP, &irps);
- /* if biased, force decoded copying to allow image subtraction */
-- bychunk = !bias && (rowsperstrip == irps);
-+ bychunk = !bias && (rowsperstrip == irps);
- }else{ /* either in or out is tiled */
- if (bias) {
- fprintf(stderr,