libtiff-devel-4.0.9-45.5.1 >  A ap9|}% V#F iƾde?x8!KSc@wn(yhD E>{V҈~WՄI@t󧭷& ģ{n_oL:s9]Q16A-FzE ;Xۢg}e=|sG:N¤M!EO4&l2Z&X)YssB%kn= 915d16168451c5db856c9a36b3f86568f84e4d28e56c145e6bf26ad3dda7effcc2787aea6d175b7fea6026e7572de6ed2a26fb9bap9|/nM#L:j-D|O][-=(exXlV8vJ4Ww'P|T\o?,^hqèhKUov_NCS§g\o9jkH0.v ]׵0' "WcvSE}܃ɞGtU- Yx2:5Al[M$[{YW۟fZ05z uWslx#fNQs餶ΠÍ˫ &d=;pAZ_J. 'p`gsk>p>T?Dd  _-NS i44 4 `4 04 4 <4 4404<\(8$'9':X'FG4H4I4XY\4]4^SbcAdeflu4vw<4x 4yz@Clibtiff-devel4.0.945.5.1Development Tools for Programs which will use the libtiff LibraryThis package contains the header files and static libraries for developing programs which will manipulate TIFF format image files using the libtiff library.agibs-power9-14KSUSE Linux Enterprise 15SUSE LLC HPNDhttps://www.suse.com/Development/Libraries/C and C++http://www.simplesystems.org/libtiff/linuxppc64le eZ^s\*% d| c" R5 Ng ptF  gLa]a]a]a]a]a]a^a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_a_817fc7dacfc7499ca60575fbd6d9d52f661fa11e21bf9a16165673c0b1bf4e1abd5ce2bb7386939f98d6eee3745f4ff6ebda0806a48ac4e058ac0e06d4ea0a276d98b037201bbfb8a56a1947d08be85dfb1e4850eac2fc72ef850be0000dab7b1ac75ac6bd97627d92dbdd9d9b812b92598cfb1af75cac20257cd4ae08cb982e21195898e58f38860e4f0ca228047f29b2ea9056370c5268b1ec74f80c8353ece2131cd235badf68b48234170dda5be6791e1e7ab86be6969b49c7c1ec618eb1a23c93ee21d3c747b60d23f9f5b5a96b6ea3520b6b0f6eee118cc6a1c938157aa25e075deb1134c467adc8df79d4030eee8bb29c23d6bbeb623717fc199eae5e11adb6f2e0a5cd4857a5db6ddc8fe936fb97c80c159ec8504b4835982979502b79a216827d19e88166097daf8fc18839223874b2c9faa84fdd3dd1929194cc8034f64c5726e472f89ff6c32b51a0057602355c3343a63258c375a3205e3fc12fcfd187be23200b759a9c5834b37fb7e43deaefe6e0bd8b94e64b7e74e9f4132c7f1fcd7428a241e1ec2e32ee41e15fd824830390ee2d4d9da22e444dd2f25dbf85976b1e12a153bb64ab3542b98add76117bb1142fe691b30b4e74ab682128d4f3bec7f82e7d3b176a708f6b24ae73056a44e963c58b55e681ce8c3552172638a8fcf0ba5bc3224c041208560ae004828f23eeed54b6b296fe79d9683b698e42a6e31da094375befee7fafa37ccd03c7c218a7c1b27baed5411d928b82423338bbcbe306115b93feed25f4a0d40add52608d8e69962b3d54bf8fe449dbf51bda56b115bdf49cce358b1e3a22a7beca3b8921add702cf860590bc76928c0f8f1d0db7806d474073d3186bed9069ccfff5274869cecb19c1cc51a56100d2b474900ad44f9d3e4f4a15045815e2a7f0cb011414b3da74cde73caced7a4fbed59b14849b0c65bd87bc4873a13c2cd83af0a1d96ab91884c20371af19aa1ed8558d4bd38bcc60bc35152be1d96120fd203003584d9511a4774e03690e2a844f33500009e212fc98129b5b2fb3159038ab8376cb86f58c2aee781e8b91d9d1c6597277532d01bb62fec714831f6b10ee99fb0192cbb1316c3c3871b0be06bd875db9b73ea223f8600efb335d24663777e4d0d0a43215b888e24092a0849a52ebc4b1f8c20f771c4c04d3105c3457ed714cfdee86d6fcf7f0eb76f0a147fbf64d257583bd67c743ece7cfb09b19299dc453d1fa524e27628f639be1538f39d95f29e8a653ff2bbd1cd6d31d4c1e212cfd90700a87ab1cd8c2e571a41c82c94e65f2c36b5f509b81ddb1fabbadac252dbadc8525cbb3e7879ac321882506c95eadeddb75eca74519cd5ffeebc118111efb550c7e3476d9bf87ccceb3c41c3636eedaeb4511b56d4e162a3f8aa34df44d9c643ad6156e6113abc7c7dbe054ec5e8d072e917507cb5a79579283609eac8c9eac45982d49cc93eae24433cff3e8c51fd81e6d5fa350d2a1983aebe45e3935518a4bc597d1e9ebc5887098d00bf18db368832d787a8de7c0ba47c3b0f8145527e7c5a735c1ad298f2f274661274c719208128630084912b49ef975b48561f53185255ee52c6050a717c63b57822c293b3760f4c8b74a0bcc7484367aea0668c3c64798fc296554fc5ae0f39812a059a2ffd9c74323bbc04a7eaf272b4a0c101d46ff9b7c74600227054da4b65c1ad79474249e053d869d19f7850142b4c3990f1e756147c0ad977b2c0f6a88d66fa9ad4207697acfe52d65483e64dd4f82d680a1eb9b4b5f2a27befca8a4ba479d8db5e9a78cc0e38b8ab00a804cdbbf1c85fe717eb4eb89babf524024ba4ac90b359d61bc45b7d5038acf3de26bb44ffd9f8922d857d5489d9fcf8a4ebb07c597b9787052c76d8e3c20e8d96e009c91f8c39d5088c6bf72f207fa5c6caaa32f2bdf6da4024a2e00a81a88b60b0a6e15acda5ed2d36a9b4bbbc7229b838f3d17ed820a994b6bdbed095673f0396ff31929194259727f11e28b073dd2556c920f2b8e5f545fcc53de645017cf0ef1e8d9a5a97f0c3453f8b9260a7674e6cf84090a922a320084fc8e925e08dcab704731e65bc0211d4258e6b876e2b48bbae4e4f20e3b5f95c38811faf0e2c71ffbdb5f97582dff5615a19d3ba2406472adf481c064d39f8c338f294493039ed49a5a13b81e917dfb8ef0ae8fbab0c1f7399c831914a7fe09bac9365f37627e56e177c682a09993e83888bdc87a2d98d47c55f68cee82f8e38blibtiff.so.5.3.0libtiffxx.so.5.3.0rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootroottiff-4.0.9-45.5.1.src.rpmlibtiff-devellibtiff-devel(ppc-64)pkgconfig(libtiff-4)@    /usr/bin/pkg-configglibc-devellibstdc++-devellibtiff5rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)4.0.93.0.4-14.6.0-14.0-15.2-14.14.1aZ@]µ]µ\b@\X)@\Q[[k@[k@[$@[t[{@[)[)Z@ZZ ZZ;@Z@YI@XۡX@Xx@XWXWX=mWint32 conversion (when refBlackWhite[0] == 2147483648.f) Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1907 + libtiff/tif_dirinfo.c, tif_dirread.c: add _TIFFCheckFieldIsValidForCodec(), and use it in TIFFReadDirectory() so as to ignore fields whose tag is a codec-specified tag but this codec is not enabled. This avoids TIFFGetField() to behave differently depending on whether the codec is enabled or not, and thus can avoid stack based buffer overflows in a number of TIFF utilities such as tiffsplit, tiffcmp, thumbnail, etc. Patch derived from 0063-Handle-properly-CODEC-specific-tags.patch (http://bugzilla.maptools.org/show_bug.cgi?id=2580) by Raphaël Hertzog. Fixes: http://bugzilla.maptools.org/show_bug.cgi?id=2580 http://bugzilla.maptools.org/show_bug.cgi?id=2693 http://bugzilla.maptools.org/show_bug.cgi?id=2625 (CVE-2016-10095, bsc#1017690) http://bugzilla.maptools.org/show_bug.cgi?id=2564 (CVE-2015-7554, bsc#960341) http://bugzilla.maptools.org/show_bug.cgi?id=2561 (CVE-2016-5318, bsc#983436) http://bugzilla.maptools.org/show_bug.cgi?id=2499 (CVE-2014-8128, bsc#969783) http://bugzilla.maptools.org/show_bug.cgi?id=2441 http://bugzilla.maptools.org/show_bug.cgi?id=2433 + libtiff/tif_swab.c: if DISABLE_CHECK_TIFFSWABMACROS is defined, do not do the #ifdef TIFFSwabXXX checks. Make it easier for GDAL to rename the symbols of its internal libtiff copy. + libtiff/tif_dirread.c: fix regression of libtiff 4.0.8 in ChopUpSingleUncompressedStrip() regarding update of newly single-strip uncompressed files whose bytecount is 0. Before the change of 2016-12-03, the condition bytecount==0 used to trigger an early exit/disabling of strip chop. Re-introduce that in update mode. Otherwise this cause later incorrect setting for the value of StripByCounts/StripOffsets. (https://trac.osgeo.org/gdal/ticket/6924) + libtiff/tif_dirread.c: TIFFFetchStripThing(): limit the number of items read in StripOffsets/StripByteCounts tags to the number of strips to avoid excessive memory allocation. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2215 + libtiff/tif_getimage.c: avoid many (harmless) unsigned int overflows. + libtiff/tif_fax3.c: avoid unsigned int overflow in Fax3Encode2DRow(). Could potentially be a bug with huge rows. + libtiff/tif_jpeg.c: avoid (harmless) unsigned int overflow on tiled images. + libtiff/tif_dirread.c: avoid unsigned int overflow in EstimateStripByteCounts() and BYTECOUNTLOOKSBAD when file is too short. + libtiff/tif_predict.c: decorate legitimate functions where unsigned int overflow occur with TIFF_NOSANITIZE_UNSIGNED_INT_OVERFLOW + libtiff/tif_dirread.c: avoid unsigned int overflow in EstimateStripByteCounts() + libtiff/tiffiop.h: add TIFF_NOSANITIZE_UNSIGNED_INT_OVERFLOW macro to disable CLang warnings raised by - fsanitize=undefined,unsigned-integer-overflow + libtiff/tif_jpeg.c: add anti-denial of service measure to avoid excessive CPU consumption on progressive JPEGs with a huge number of scans. See http://www.libjpeg-turbo.org/pmwiki/uploads/About/TwoIssueswiththeJPEGStandard.pdf Note: only affects libtiff since 2014-12-29 where support of non-baseline JPEG was added. + libtiff/tif_jpeg.c: error out at decoding time if anticipated libjpeg memory allocation is above 100 MB. libjpeg in case of multiple scans, which is allowed even in baseline JPEG, if components are spread over several scans and not interleavedin a single one, needs to allocate memory (or backing store) for the whole strip/tile. See http://www.libjpeg-turbo.org/pmwiki/uploads/About/TwoIssueswiththeJPEGStandard.pdf This limitation may be overriden by setting the LIBTIFF_ALLOW_LARGE_LIBJPEG_MEM_ALLOC environment variable, or recompiling libtiff with a custom value of TIFF_LIBJPEG_LARGEST_MEM_ALLOC macro. + libtiff/tif_jbig.c: fix memory leak in error code path of JBIGDecode() Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2706 (CVE-2017-9936, bsc#1046073) + libtiff/tif_dirread.c: in TIFFReadDirEntryFloat(), check that a double value can fit in a float before casting. + libtiff/tiffiop.h, libtiff/tif_jpeg.c, libtiff/tif_jpeg_12.c, libtiff/tif_read.c: make TIFFReadScanline() works in CHUNKY_STRIP_READ_SUPPORT mode with JPEG stream with multiple scans. Also make configurable through a LIBTIFF_JPEG_MAX_ALLOWED_SCAN_NUMBER environment variable the maximum number of scans allowed. Defaults to 100. + libtiff/tif_read.c: TIFFFillTile(): add limitation to the number of bytes read in case td_stripbytecount[strip] is bigger than reasonable, so as to avoid excessive memory allocation (similarly to what was done for TIFFFileStrip() on 2017-05-10) + libtiff/tif_getimage.c: use _TIFFReadEncodedStripAndAllocBuffer(). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2708 and https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2433 + libtiff/tif_read.c, tiffiop.h: add a _TIFFReadEncodedStripAndAllocBuffer() function, variant of TIFFReadEncodedStrip() that allocates the decoded buffer only after a first successful TIFFFillStrip(). This avoids excessive memory allocation on corrupted files. + libtiff/tif_dirwrite.c: in TIFFWriteDirectoryTagCheckedXXXX() functions associated with LONG8/SLONG8 data type, replace assertion that the file is BigTIFF, by a non-fatal error. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2712 + libtiff/tif_read.c: TIFFStartTile(): set tif_rawcc to tif_rawdataloaded when it is set. Similarly to TIFFStartStrip(). This issue was revealed by the change of 2017-06-30 in TIFFFileTile(), limiting the number of bytes read. But it could probably have been hit too in CHUNKY_STRIP_READ_SUPPORT mode previously. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2454 + libtiff/tif_error.c, tif_warning.c: correctly use va_list when both an old-style and new-style warning/error handlers are installed. Patch by Paavo Helde (sent on the mailing list) + libtiff/tif_getimage.c: use _TIFFReadTileAndAllocBuffer(). Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2470 + libtiff/tif_read.c, tiffiop.h: add a _TIFFReadEncodedTileAndAllocBuffer() and _TIFFReadTileAndAllocBuffer() variants of TIFFReadEncodedTile() and TIFFReadTile() that allocates the decoded buffer only after a first successful TIFFFillTile(). This avoids excessive memory allocation on corrupted files. + libtiff/tif_pixarlog.c: avoid excessive memory allocation on decoding when RowsPerStrip tag is not defined (and thus td_rowsperstrip == UINT_MAX) Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2554 + libtiff/tif_lzw.c: fix 4.0.8 regression in the decoding of old-style LZW compressed files. + libtiff/tif_lzw.c: fix potential out-of-buffer read on 1-byte LZW strips. Crashing issue only on memory mapped files, where the strip offset is the last byte of the file, and the file size is a multiple of one page size on the CPU architecture (typically 4096) + libtiff/tif_dir.c: avoid potential null pointer dereference in _TIFFVGetField() on corrupted TIFFTAG_NUMBEROFINKS tag instance. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2713 + tools/tiff2pdf.c: prevent heap buffer overflow write in "Raw" mode on PlanarConfig=Contig input images. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2715 + libtiff/tif_read.c: TIFFFillStrip() / TIFFFillTile(). Complementary fix for http://bugzilla.maptools.org/show_bug.cgi?id=2708 in the isMapped() case, so as to avoid excessive memory allocation when we need a temporary buffer but the file is truncated. + libtiff/tif_read.c: in TIFFFetchStripThing(), only grow the arrays that hold StripOffsets/StripByteCounts, when they are smaller than the expected number of striles, up to 1 million striles, and error out beyond. Can be tweaked by setting the environment variable LIBTIFF_STRILE_ARRAY_MAX_RESIZE_COUNT. This partially goes against a change added on 2002-12-17 to accept those arrays of wrong sizes, but is needed to avoid denial of services. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2350 + libtiff/tif_read.c: add protection against excessive memory allocation attempts in TIFFReadDirEntryArray() on short files. Effective for mmap'ed case. And non-mmap'ed case, but restricted to 64bit builds. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2675 (CVE-2017-12944, bsc#1054594) + libtiff/tif_luv.c: LogLuvInitState(): avoid excessive memory allocation when RowsPerStrip tag is missing. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2683 + libtiff/tif_getimage.c: gtTileContig() and gtTileSeparate(): properly break from loops on error when stoponerr is set, instead of going on iterating on row based loop. + libtiff/tif_getimage.c: fix fromskew computation when to-be-skipped pixel number is not a multiple of the horizontal subsampling, and also in some other cases. Impact putcontig8bitYCbCr44tile, putcontig8bitYCbCr42tile, putcontig8bitYCbCr41tile, putcontig8bitYCbCr21tile and putcontig8bitYCbCr12tile Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2637 and https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2691 + libtiff/tif_luv.c: further reduce memory requirements for temporary buffer when RowsPerStrip >= image_length in LogLuvInitState() and LogL16InitState(). Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=2700 + libtiff/tif_dirwrite.c: replace assertion related to not finding the SubIFD tag by runtime check (in TIFFWriteDirectorySec()) Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2727 + libtiff/tif_dirwrite.c: replace assertion to tag value not fitting on uint32 when selecting the value of SubIFD tag by runtime check (in TIFFWriteDirectoryTagSubifd()). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2728 + libtiff/tif_jpeg.c: accept reading the last strip of a JPEG compressed file if the codestream height is larger than the truncated height of the strip. Emit a warning in this situation since this is non compliant. + libtiff/tiffiop.h, tif_aux.c: redirect SeekOK() macro to a _TIFFSeekoK() function that checks if the offset is not bigger than INT64_MAX, so as to avoid a -1 error return code of TIFFSeekFile() to match a required seek to UINT64_MAX/-1. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2726 + libtiff/tif_dirread.c: add NULL check to avoid likely false positive null-pointer dereference warning by CLang Static Analyzer. + libtiff/libtiff.def: add TIFFReadRGBAStripExt and TIFFReadRGBATileExt Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2735 + libtiff/tif_jpeg.c: add compatibility with libjpeg-turbo 1.5.2 that honours max_memory_to_use > 0. Cf https://github.com/libjpeg-turbo/libjpeg-turbo/issues/162 + libtiff/tif_getimage.c: avoid floating point division by zero in initCIELabConversion() Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=3733 * Changes in the tools: + tools/tiff2pdf.c: prevent heap buffer overflow write in "Raw" mode on PlanarConfig=Contig input images. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2715 + tools/tiffset.c: fix setting a single value for the ExtraSamples tag (and other tags with variable number of values). So 'tiffset -s ExtraSamples 1 X'. This only worked when setting 2 or more values, but not just one. + tools/fax2tiff.c (_FAX_Client_Data): Pass FAX_Client_Data as the client data. This client data is not used at all at the moment, but it makes the most sense. Issue that the value of client_data.fd was passed where a pointer is expected. + tools/tiff2pdf.c (t2p_sample_realize_palette): Fix possible arithmetic overflow in bounds checking code and eliminate comparison between signed and unsigned type. + tools/tiff2bw.c (main): Free memory allocated in the tiff2bw program. This is in response to the report associated with CVE-2017-16232, bsc#1069213 but does not solve the extremely high memory usage with the associated POC file.- Upgrade to upstream release 4.0.8 * libtiff/tif_getimage.c, libtiff/tif_open.c + add parenthesis to fix cppcheck clarifyCalculation warnings * libtiff/tif_predict.c, libtiff/tif_print.c + fix printf unsigned vs signed formatting (cppcheck invalidPrintfArgType_uint warnings) * libtiff/tif_read.c, libtiff/tiffiop.h + fix uint32 overflow in TIFFReadEncodedStrip() that caused an integer division by zero. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2596 * libtiff/tif_pixarlog.c, libtiff/tif_luv.c + fix heap-based buffer overflow on generation of PixarLog / LUV compressed files, with ColorMap, TransferFunction attached and nasty plays with bitspersample. The fix for LUV has not been tested, but suffers from the same kind of issue of PixarLog. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2604 * libtiff/tif_strip.c + revert the change in TIFFNumberOfStrips() done for http://bugzilla.maptools.org/show_bug.cgi?id=2587 / CVE-2016-9273 since the above change is a better fix that makes it unnecessary. * libtiff/tif_dirread.c + modify ChopUpSingleUncompressedStrip() to instanciate compute ntrips as TIFFhowmany_32(td->td_imagelength, rowsperstrip), instead of a logic based on the total size of data. Which is faulty is the total size of data is not sufficient to fill the whole image, and thus results in reading outside of the StripByCounts/StripOffsets arrays when using TIFFReadScanline(). Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2608. * libtiff/tif_ojpeg.c + make OJPEGDecode() early exit in case of failure in OJPEGPreDecode(). This will avoid a divide by zero, and potential other issues. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2611 * libtiff/tif_write.c + fix misleading indentation as warned by GCC. * libtiff/tif_fax3.h + revert change done on 2016-01-09 that made Param member of TIFFFaxTabEnt structure a uint16 to reduce size of the binary. It happens that the Hylafax software uses the tables that follow this typedef (TIFFFaxMainTable, TIFFFaxWhiteTable, TIFFFaxBlackTable), although they are not in a public libtiff header. Raised by Lee Howard. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2636 * libtiff/tiffio.h, libtiff/tif_getimage.c + add TIFFReadRGBAStripExt() and TIFFReadRGBATileExt() variants of the functions without ext, with an extra argument to control the stop_on_error behaviour. * libtiff/tif_getimage.c + fix potential memory leaks in error code path of TIFFRGBAImageBegin(). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2627 * libtiff/tif_jpeg.c + increase libjpeg max memory usable to 10 MB instead of libjpeg 1MB default. This helps when creating files with "big" tile, without using libjpeg temporary files. Related to https://trac.osgeo.org/gdal/ticket/6757 * libtiff/tif_jpeg.c + avoid integer division by zero in JPEGSetupEncode() when horizontal or vertical sampling is set to 0. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2653, bsc#1033127, CVE-2017-7595 * libtiff/tif_dirwrite.c + in TIFFWriteDirectoryTagCheckedRational, replace assertion by runtime check to error out if passed value is strictly negative. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2535, bsc#1038438, CVE-2016-10371 * libtiff/tif_dirread.c + avoid division by floating point 0 in TIFFReadDirEntryCheckedRational() and TIFFReadDirEntryCheckedSrational(), and return 0 in that case (instead of infinity as before presumably) Apparently some sanitizers do not like those divisions by zero. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2644, bsc#1033118, CVE-2017-7598 * libtiff/tif_dir.c, tif_dirread.c, tif_dirwrite.c + implement various clampings of double to other data types to avoid undefined behaviour if the output range isn't big enough to hold the input value. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2643 http://bugzilla.maptools.org/show_bug.cgi?id=2642 http://bugzilla.maptools.org/show_bug.cgi?id=2646 http://bugzilla.maptools.org/show_bug.cgi?id=2647, bsc#1033126, CVE-2017-7596, bsc#1033120, CVE-2017-7597, bsc#1033113, CVE-2017-7599, bsc#1033112, CVE-2017-7600, * libtiff/tif_jpeg.c + validate BitsPerSample in JPEGSetupEncode() to avoid undefined behaviour caused by invalid shift exponent. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2648, bsc#1033111, CVE-2017-7601 * libtiff/tif_read.c + avoid potential undefined behaviour on signed integer addition in TIFFReadRawStrip1() in isMapped() case. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2650, bsc#1033109, CVE-2017-7602 * libtiff/tif_getimage.c + add explicit uint32 cast in putagreytile to avoid UndefinedBehaviorSanitizer warning. Patch by Nicolas Pena. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2658, bsc#1033131, CVE-2017-7592 * libtiff/tif_read.c + TIFFReadBufferSetup(): use _TIFFcalloc() to zero initialize tif_rawdata. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2651, bsc#1033129, CVE-2017-7593 * libtiff/tiffio.h, tif_unix.c, tif_win32.c, tif_vms.c + add _TIFFcalloc() * libtiff/tif_luv.c, tif_lzw.c, tif_packbits.c + return 0 in Encode functions instead of -1 when TIFFFlushData1() fails. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2130 * libtiff/tif_ojpeg.c + fix leak in OJPEGReadHeaderInfoSecTablesQTable, OJPEGReadHeaderInfoSecTablesDcTable and OJPEGReadHeaderInfoSecTablesAcTable when read fails. Patch by Nicolas Pena. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2659, bsc#1033128, CVE-2017-7594 * libtiff/tif_jpeg.c + only run JPEGFixupTagsSubsampling() if the YCbCrSubsampling tag is not explicitly present. This helps a bit to reduce the I/O amount when the tag is present (especially on cloud hosted files). * libtiff/tif_lzw.c + in LZWPostEncode(), increase, if necessary, the code bit-width after flushing the remaining code and before emitting the EOI code. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=1982 * libtiff/tif_pixarlog.c + fix memory leak in error code path of PixarLogSetupDecode(). Patch by Nicolas Pena. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2665 * libtiff/tif_fax3.c, tif_predict.c, tif_getimage.c + fix GCC 7 -Wimplicit-fallthrough warnings. * libtiff/tif_dirread.c + fix memory leak in non DEFER_STRILE_LOAD mode (ie default) when there is both a StripOffsets and TileOffsets tag, or a StripByteCounts and TileByteCounts Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2689, bsc#1042805, CVE-2017-9403) * libtiff/tif_ojpeg.c + fix potential memory leak in OJPEGReadHeaderInfoSecTablesQTable, OJPEGReadHeaderInfoSecTablesDcTable and OJPEGReadHeaderInfoSecTablesAcTable Patch by Nicolas Pena. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2670 * libtiff/tif_fax3.c + avoid crash in Fax3Close() on empty file. Patch by Alan Coopersmith + complement by myself. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2673 * libtiff/tif_read.c + TIFFFillStrip(): add limitation to the number of bytes read in case td_stripbytecount[strip] is bigger than reasonable, so as to avoid excessive memory allocation. * libtiff/tif_zip.c, tif_pixarlog.c, tif_predict.c + fix memory leak when the underlying codec (ZIP, PixarLog) succeeds its setupdecode() method, but PredictorSetup fails. Credit to OSS-Fuzz (locally run, on GDAL) * libtiff/tif_read.c + TIFFFillStrip() and TIFFFillTile(): avoid excessive memory allocation in case of shorten files. Only effective on 64 bit builds and non-mapped cases. Credit to OSS-Fuzz (locally run, on GDAL) * libtiff/tif_read.c + TIFFFillStripPartial() / TIFFSeek(), avoid potential integer overflows with read_ahead in CHUNKY_STRIP_READ_SUPPORT mode. Should especially occur on 32 bit platforms. * libtiff/tif_read.c + TIFFFillStripPartial() + avoid excessive memory allocation in case of shorten files. Only effective on 64 bit builds. Credit to OSS-Fuzz (locally run, on GDAL) * libtiff/tif_read.c + update tif_rawcc in CHUNKY_STRIP_READ_SUPPORT mode with tif_rawdataloaded when calling TIFFStartStrip() or TIFFFillStripPartial(). This avoids reading beyond tif_rawdata when bytecount > tif_rawdatasize. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1545. Credit to OSS-Fuzz * libtiff/tif_color.c + avoid potential int32 overflow in TIFFYCbCrToRGBInit() Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1533 Credit to OSS-Fuzz * libtiff/tif_pixarlog.c, tif_luv.c + avoid potential int32 overflows in multiply_ms() and add_ms(). Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1558 Credit to OSS-Fuzz * libtiff/tif_packbits.c + fix out-of-buffer read in PackBitsDecode() Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1563 Credit to OSS-Fuzz * libtiff/tif_luv.c + LogL16InitState(): avoid excessive memory allocation when RowsPerStrip tag is missing. Credit to OSS-Fuzz (locally run, on GDAL) * libtiff/tif_lzw.c + update dec_bitsleft at beginning of LZWDecode(), and update tif_rawcc at end of LZWDecode(). This is needed to properly work with the latest chnges in tif_read.c in CHUNKY_STRIP_READ_SUPPORT mode. * libtiff/tif_pixarlog.c + PixarLogDecode(): resync tif_rawcp with next_in and tif_rawcc with avail_in at beginning and end of function, similarly to what is done in LZWDecode(). Likely needed so that it works properly with latest chnges in tif_read.c in CHUNKY_STRIP_READ_SUPPORT mode. But untested... * libtiff/tif_getimage.c + initYCbCrConversion(): add basic validation of luma and refBlackWhite coefficients (just check they are not NaN for now), to avoid potential float to int overflows. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1663 Credit to OSS Fuzz * libtiff/tif_read.c + _TIFFVSetField(): fix outside range cast of double to float. Credit to Google Autofuzz project * libtiff/tif_getimage.c + initYCbCrConversion(): check luma[1] is not zero to avoid division by zero. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1665 Credit to OSS Fuzz * libtiff/tif_read.c + _TIFFVSetField(): fix outside range cast of double to float. Credit to Google Autofuzz project * libtiff/tif_getimage.c + initYCbCrConversion(): check luma[1] is not zero to avoid division by zero. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1665 Credit to OSS Fuzz * libtiff/tif_getimage.c + initYCbCrConversion(): stricter validation for refBlackWhite coefficients values. To avoid invalid float->int32 conversion. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1718 Credit to OSS Fuzz * tools/fax2tiff.c (main) + Applied patch by Joerg Ahrens to fix passing client data for Win32 builds using tif_win32.c (USE_WIN32_FILEIO defined) for file I/O. Patch was provided via email on November 20, 2016. * tools/tiffcp.c + avoid uint32 underflow in cpDecodedStrips that can cause various issues, such as buffer overflows in the library. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2598 * tools/tiffcrop.c + fix readContigStripsIntoBuffer() in -i (ignore) mode so that the output buffer is correctly incremented to avoid write outside bounds. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2620 * tools/tiffcrop.c + add 3 extra bytes at end of strip buffer in readSeparateStripsIntoBuffer() to avoid read outside of heap allocated buffer. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2621 * tools/tiffcrop.c + fix integer division by zero when BitsPerSample is missing. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2619 * tools/tiffinfo.c + fix null pointer dereference in -r mode when the image has no StripByteCount tag. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2594 * tools/tiffcp.c + avoid potential division by zero is BitsPerSamples tag is missing. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2597 * tools/tif_dir.c + when TIFFGetField(, TIFFTAG_NUMBEROFINKS, ) is called, limit the return number of inks to SamplesPerPixel, so that code that parses ink names doesn't go past the end of the buffer. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2599 * tools/tiffcp.c + avoid potential division by zero is BitsPerSamples tag is missing. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2607 * tools/tiffcp.c + fix uint32 underflow/overflow that can cause heap-based buffer overflow. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2610 * tools/tiffcp.c + replace assert( (bps % 8) == 0 ) by a non assert check. Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2605 * tools/tiff2ps.c + fix 2 heap-based buffer overflows (in PSDataBW and PSDataColorContig). Reported by Agostino Sarubbo. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2633 and http://bugzilla.maptools.org/show_bug.cgi?id=2634. * tools/tiff2pdf.c + prevent heap-based buffer overflow in -j mode on a paletted image. Note: this fix errors out before the overflow happens. There could probably be a better fix. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2635 * tools/tiff2pdf.c + fix wrong usage of memcpy() that can trigger unspecified behaviour. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2638 * tools/tiff2pdf.c + avoid potential invalid memory read in t2p_writeproc. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2639 * tools/tiff2pdf.c + avoid potential heap-based overflow in t2p_readwrite_pdf_image_tile(). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2640 * tools/tiffcrop.c + remove extraneous TIFFClose() in error code path, that caused double free. Related to http://bugzilla.maptools.org/show_bug.cgi?id=2535 * tools/tiffcp.c + error out cleanly in cpContig2SeparateByRow and cpSeparate2ContigByRow if BitsPerSample != 8 to avoid heap based overflow. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2656 and http://bugzilla.maptools.org/show_bug.cgi?id=2657 * tools/raw2tiff.c + avoid integer division by zero. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2631 * tools/tiff2ps.c + call TIFFClose() in error code paths. * tools/fax2tiff.c + emit appropriate message if the input file is empty. Patch by Alan Coopersmith. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2672 * tools/tiff2bw.c + close TIFF handle in error code path. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2677 * Other issues fixed: + bsc#1042804, CVE-2017-9404 * CVE-2016-10092, CVE-2016-10093, CVE-2016-10094 [bsc#1017693] - Removed patches: * tiff-4.0.7-CVE-2015-7554.patch * tiff-4.0.7-CVE-2017-5225.patch * tiff-4.0.7-TIFFTAG_FAXRECVPARAMS.patch * tiff-CVE-2016-10266.patch * tiff-CVE-2016-10267.patch * tiff-CVE-2016-10268.patch * tiff-CVE-2016-10269.patch * tiff-CVE-2016-10270.patch * tiff-CVE-2016-10271.patch * tiff-CVE-2016-10272.patch + Fixed upstream- Added patches: * tiff-CVE-2016-10266.patch + Upstream fix for CVE-2016-10266, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (divide-by-zero error and application crash) via a crafted TIFF image (bsc#1031263) * tiff-CVE-2016-10267.patch + Upstream fix for CVE-2016-10267, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (divide-by-zero error and application crash) via a crafted TIFF image (bsc#1031262) * tiff-CVE-2016-10268.patch + Upstream fix for CVE-2016-10268, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (divide-by-zero error and application crash) via a crafted TIFF image (bsc#1031255) * tiff-CVE-2016-10269.patch + Upstream fix for CVE-2016-10269, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (heap-based buffer over-read) or possibly have unspecified other impact via a crafted TIFF image (bsc#1031254) * tiff-CVE-2016-10270.patch + Upstream fix for CVE-2016-10270, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (heap-based buffer over-read) or possibly have unspecified other impact via a crafted TIFF image (bsc#1031250) * tiff-CVE-2016-10271.patch + Upstream fix for CVE-2016-10271, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (heap-based buffer over-read and buffer overflow) or possibly have unspecified other impact via a crafted TIFF image (bsc#1031249) * tiff-CVE-2016-10272.patch + Upstream fix for CVE-2016-10272, LibTIFF 4.0.7 allows remote attackers to cause a denial of service (heap-based buffer overflow) or possibly have unspecified other impact via a crafted TIFF image (bsc#1031247)- Added patch: * tiff-4.0.7-TIFFTAG_FAXRECVPARAMS.patch - Fix a regression introduced in 4.0.7 (bsc#1022103) - http://bugzilla.maptools.org/show_bug.cgi?id=2636- Added patch: * tiff-4.0.7-CVE-2017-5225.patch - Upstream fix for CVE-2017-5225, bsc#1019611: heap buffer overflow in tools/tiffcp via a crafted BitsPerSample value- Drop --with-pic, this is only for static libs (which are not built) - Update descriptions- Update homepage- Upgrade to upstream release 4.0.7 * libtiff/tif_aux.c + Fix crash in TIFFVGetFieldDefaulted() when requesting Predictor tag and that the zip/lzw codec is not configured. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2591 * libtiff/tif_compress.c + Make TIFFNoDecode() return 0 to indicate an error and make upper level read routines treat it accordingly. (linked to the test case of http://bugzilla.maptools.org/show_bug.cgi?id=2517) * libtiff/tif_dir.c + Discard values of SMinSampleValue and SMaxSampleValue when they have been read and the value of SamplesPerPixel is changed afterwards (like when reading a OJPEG compressed image with a missing SamplesPerPixel tag, and whose photometric is RGB or YCbCr, forcing SamplesPerPixel being 3). Otherwise when rewriting the directory (for example with tiffset, we will expect 3 values whereas the array had been allocated with just one), thus causing a out of bound read access. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2500 (CVE-2014-8127, bsc#914890, duplicate: CVE-2016-3658, bsc#974840) * libtiff/tif_dirread.c + In TIFFFetchNormalTag(), do not dereference NULL pointer when values of tags with TIFF_SETGET_C16_ASCII/TIFF_SETGET_C32_ASCII access are 0-byte arrays. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2593 (regression introduced by previous fix done on 2016-11-11 for CVE-2016-9297, bsc#1010161). Assigned as CVE-2016-9448, bsc#1011103 + In TIFFFetchNormalTag(), make sure that values of tags with TIFF_SETGET_C16_ASCII/TIFF_SETGET_C32_ASCII access are null terminated, to avoid potential read outside buffer in _TIFFPrintField(). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2590 (CVE-2016-9297, bsc#1010161) + Initialize doubledata at line 3693 to NULL to please MSVC 2013 + Prevent reading ColorMap or TransferFunction if BitsPerPixel > 24, so as to avoid huge memory allocation and file read attempts + Reject images with OJPEG compression that have no TileOffsets/StripOffsets tag, when OJPEG compression is disabled. Prevent null pointer dereference in TIFFReadRawStrip1() and other functions that expect td_stripbytecount to be non NULL. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2585 + When compiled with DEFER_STRILE_LOAD, fix regression, when reading a one-strip file without a StripByteCounts tag. + Workaround false positive warning of Clang Static Analyzer about null pointer dereference in TIFFCheckDirOffset(). * libtiff/tif_dirwrite.c + Avoid null pointer dereference on td_stripoffset when writing directory, if FIELD_STRIPOFFSETS was artificially set for a hack case in OJPEG case. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2500 (CVE-2014-8127, bsc#914890, duplicate: CVE-2016-3658, bsc#974840) + Fix truncation to 32 bit of file offsets in TIFFLinkDirectory() and TIFFWriteDirectorySec() when aligning directory offsets on an even offset (affects BigTIFF). * libtiff/tif_dumpmode.c + DumpModeEncode() should return 0 in case of failure so that the above mentionned functions detect the error. * libtiff/tif_fax3.c + remove dead assignment in Fax3PutEOLgdal(). * libtiff/tif_fax3.h + make Param member of TIFFFaxTabEnt structure a uint16 to reduce size of the binary. * libtiff/tif_getimage.c + Fix out-of-bound reads in TIFFRGBAImage interface in case of unsupported values of SamplesPerPixel/ExtraSamples for LogLUV/CIELab. Add explicit call to TIFFRGBAImageOK() in TIFFRGBAImageBegin(). Fix CVE-2015-8665 and CVE-2015-8683. + Fix some benign warnings which appear in 64-bit compilation under Microsoft Visual Studio of the form "Arithmetic overflow: 32-bit value is shifted, then cast to 64-bit value. Results might not be an expected value." + TIFFRGBAImageOK: Reject attempts to read floating point images. * libtiff/tif_luv.c + Fix potential out-of-bound writes in decode functions in non debug builds by replacing assert()s by regular if checks (http://bugzilla.maptools.org/show_bug.cgi?id=2522). Fix potential out-of-bound reads in case of short input data. + Validate that for COMPRESSION_SGILOG and PHOTOMETRIC_LOGL, there is only one sample per pixel. Avoid potential invalid memory write on corrupted/unexpected images when using the TIFFRGBAImageBegin() interface * libtiff/tif_next.c + Fix potential out-of-bound write in NeXTDecode() (http://bugzilla.maptools.org/show_bug.cgi?id=2508) * libtiff/tif_pixarlog.c + Avoid zlib error messages to pass a NULL string to %s formatter, which is undefined behaviour in sprintf(). + Fix out-of-bounds write vulnerabilities in heap allocated buffers. Reported as MSVR 35094. + Fix potential buffer write overrun in PixarLogDecode() on corrupted/unexpected images (CVE-2016-5875, bsc#987351) + Fix write buffer overflow in PixarLogEncode if more input samples are provided than expected by PixarLogSetupEncode. Idea based on libtiff-CVE-2016-3990.patch from libtiff-4.0.3-25.el7_2.src.rpm, but with different and simpler check. (http://bugzilla.maptools.org/show_bug.cgi?id=2544, bsc#975069) * libtiff/tif_predict.c + PredictorSetup: Enforce bits-per-sample requirements of floating point predictor (3). Fixes CVE-2016-3622 "Divide By Zero in the tiff2rgba tool." (bsc#974449) * libtiff/tif_predict.h, libtiff/tif_predict.c + Replace assertions by runtime checks to avoid assertions in debug mode, or buffer overflows in release mode. Can happen when dealing with unusual tile size like YCbCr with subsampling. Reported as MSVR 35105. * libtiff/tif_read.c + Fix out-of-bounds read on memory-mapped files in TIFFReadRawStrip1() and TIFFReadRawTile1() when stripoffset is beyond tmsize_t max value (bsc#990460, CVE-2016-6223) + Make TIFFReadEncodedStrip() and TIFFReadEncodedTile() directly use user provided buffer when no compression (and other conditions) to save a memcpy(). * libtiff/tif_strip.c + Make TIFFNumberOfStrips() return the td->td_nstrips value when it is non-zero, instead of recomputing it. This is needed in TIFF_STRIPCHOP mode where td_nstrips is modified. Fixes a read outsize of array in tiffsplit (or other utilities using TIFFNumberOfStrips()). Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2587 (CVE-2016-9273, bsc#1010163) * libtiff/tif_write.c + Fix issue in error code path of TIFFFlushData1() that didn't reset the tif_rawcc and tif_rawcp members. I'm not completely sure if that could happen in practice outside of the odd behaviour of t2p_seekproc() of tiff2pdf). The report points that a better fix could be to check the return value of TIFFFlushData1() in places where it isn't done currently, but it seems this patch is enough. Reported as MSVR 35095. + Make TIFFWriteEncodedStrip() and TIFFWriteEncodedTile() directly use user provided buffer when no compression to save a memcpy(). + TIFFWriteEncodedStrip() and TIFFWriteEncodedTile() should return -1 in case of failure of tif_encodestrip() as documented * tools/fax2tiff.D c + Fix segfault when specifying -r without argument. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2572 * tools/Makefile.am + The libtiff tools bmp2tiff, gif2tiff, ras2tiff, sgi2tiff, sgisv, and ycbcr are completely removed from the distribution. The libtiff tools rgb2ycbcr and thumbnail are only built in the build tree for testing. Old files are put in new 'archive' subdirectory of the source repository, but not in distribution archives. These changes are made in order to lessen the maintenance burden. * tools/rgb2ycbcr.c + Validate values of -v and -h parameters to avoid potential divide by zero. Fixes CVE-2016-3623, bsc#974618 (http://bugzilla.maptools.org/show_bug.cgi?id=2569) * tools/tiff2bw.c + Fix weight computation that could result of color value overflow (no security implication). Fix http://bugzilla.maptools.org/show_bug.cgi?id=2550. * tools/tiff2pdf.c + Avoid undefined behaviour related to overlapping of source and destination buffer in memcpy() call in t2p_sample_rgbaa_to_rgb() Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2577 + Fix out-of-bounds write vulnerabilities in heap allocate buffer in t2p_process_jpeg_strip(). Reported as MSVR 35098. + Fix potential integer overflows on 32 bit builds in t2p_read_tiff_size() Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2576 + Fix read -largely- outsize of buffer in t2p_readwrite_pdf_image_tile(), causing crash, when reading a JPEG compressed image with TIFFTAG_JPEGTABLES length being one. Reported as MSVR 35101. CVE-2016-9453, bsc#1011107 + Fix write buffer overflow of 2 bytes on JPEG compressed images. Reported as TALOS-CAN-0187, CVE-2016-5652, bsc#1007280. Also prevents writing 2 extra uninitialized bytes to the file stream. * tools/tiff2rgba.c + Fix integer overflow in size of allocated buffer, when -b mode is enabled, that could result in out-of-bounds write. Based initially on patch tiff-CVE-2016-3945.patch from libtiff-4.0.3-25.el7_2.src.rpm, with correction for invalid tests that rejected valid files. (http://bugzilla.maptools.org/show_bug.cgi?id=2545, bsc#974614) * tools/tiffcp.c + Fix out-of-bounds write on tiled images with odd tile width vs image width. Reported as MSVR 35103. (bsc#1011841, CVE-2016-9538) + Fix read of undefined variable in case of missing required tags. Found on test case of MSVR 35100. * tools/tiffcrop.c + Avoid access outside of stack allocated array on a tiled separate TIFF with more than 8 samples per pixel. (CVE-2016-5321, CVE-2016-5323, http://bugzilla.maptools.org/show_bug.cgi?id=2558, http://bugzilla.maptools.org/show_bug.cgi?id=2559, bsc#984813, bsc#984815) + Fix memory leak in (recent) error code path. Fixes Coverity 1394415. + Fix multiple uint32 overflows in writeBufferToSeparateStrips(), writeBufferToContigTiles() and writeBufferToSeparateTiles() that could cause heap buffer overflows. Fixes http://bugzilla.maptools.org/show_bug.cgi?id=2592 + Fix out-of-bound read of up to 3 bytes in readContigTilesIntoBuffer(). Reported as MSVR 35092. + Fix out-of-bounds write in loadImage(). From patch libtiff-CVE-2016-3991.patch from libtiff-4.0.3-25.el7_2.src.rpm (http://bugzilla.maptools.org/show_bug.cgi?id=2543, bsc#975070) + Fix read of undefined buffer in readContigStripsIntoBuffer() due to uint16 overflow. Reported as MSVR 35100. (bsc#1011841, CVE-2016-9538) + Fix various out-of-bounds write vulnerabilities in heap or stack allocated buffers. Reported as MSVR 35093, MSVR 35096 and MSVR 35097. + readContigTilesIntoBuffer: Fix signed/unsigned comparison warning. * tools/tiffdump.c + Fix a few misaligned 64-bit reads warned by -fsanitize + ReadDirectory: Remove uint32 cast to_TIFFmalloc() argument which resulted in Coverity report. Added more mutiplication overflow checks * tools/tiffinfo.c + Fix out-of-bound read on some tiled images. (http://bugzilla.maptools.org/show_bug.cgi?id=2517) + TIFFReadContigTileData: Fix signed/unsigned comparison warning. + TIFFReadSeparateTileData: Fix signed/unsigned comparison warning. - Removed patches: * tiff-4.0.4-uninitialized_mem_NeXTDecode.patch * tiff-4.0.6-CVE-2015-8782.patch * tiff-4.0.6-CVE-2016-3186.patch * tiff-4.0.6-CVE-2016-3623.patch * tiff-4.0.6-CVE-2016-3945.patch * tiff-4.0.6-CVE-2016-3990.patch * tiff-4.0.6-CVE-2016-3991.patch * tiff-4.0.6-libtiff-tif_getimage.c-TIFFRGBAImageOK-Reject-attemp.patch * tiff-4.0.6-libtiff-tif_luv.c-validate-that-for-COMPRESSION_SGIL.patch * tiff-4.0.6-libtiff-tif_pixarlog.c-fix-potential-buffer-write-ov.patch * tiff-4.0.6-libtiff-tif_read.c-make-TIFFReadEncodedStrip-and.patch * tiff-4.0.6-tools-tiffcrop.c-fix-various-out-of-bounds-write-vul.patch - Fixed in the upsteam release - Changed patch: * tiff-4.0.6-CVE-2015-7554.patch -> tiff-4.0.7-CVE-2015-7554.patch - Rediffed to the changed context- Added patches: * tiff-4.0.6-tools-tiffcrop.c-fix-various-out-of-bounds-write-vul.patch - Upstream fixes for MSVR 35093, MSVR 35094, MSVR 35095, MSVR 35096, MSVR 35097, MSVR 35098. * tiff-4.0.6-libtiff-tif_getimage.c-TIFFRGBAImageOK-Reject-attemp.patch - Enforce bits-per-sample requirements of floating point predictor. Fixes CVE-2016-3622 [bsc#974449]- Added patches: * tiff-4.0.6-CVE-2016-3623.patch * tiff-4.0.6-CVE-2016-3945.patch * tiff-4.0.6-CVE-2016-3990.patch * tiff-4.0.6-CVE-2016-3991.patch - Upstream commits to fix CVE-2016-3623 [bsc#974618], CVE-2016-3945 [bsc#974614], CVE-2016-3990 [bsc#975069], CVE-2016-3991 [bsc#975070]- Added patches: * tiff-4.0.6-libtiff-tif_luv.c-validate-that-for-COMPRESSION_SGIL.patch * tiff-4.0.6-libtiff-tif_pixarlog.c-fix-potential-buffer-write-ov.patch * tiff-4.0.6-libtiff-tif_read.c-make-TIFFReadEncodedStrip-and.patch - Upstream commits to fix CVE-2016-5314 [bsc#984831], CVE-2016-5316 [bsc#984837], CVE-2016-5317 [bsc#984842], CVE-2016-5320 [bsc#984808] and CVE-2016-5875 [bsc#987351]- Added patch: * tiff-4.0.6-CVE-2016-3186.patch - fix CVE-2016-3186: buffer overflow in gif2tiff [bsc#973340]- Added patch: * tiff-4.0.6-CVE-2015-8782.patch - fix CVE-2015-8781, CVE-2015-8782, CVE-2015-8783: Out-of-bounds writes for invalid images (upstream bug #2522) [bsc#964225]- Added patch: * tiff-4.0.6-CVE-2015-7554.patch - fix CVE-2015-7554: Out-of-bounds Write in the thumbnail and tiffcmp tools (upsteam bug #2499) [bsc#960341]- Added patch: * tiff-4.0.4-uninitialized_mem_NeXTDecode.patch - fix uninitialized memory in NeXTDecode (upstream bug #2508) [bsc#942690]- Update to version 4.0.6 * Supports CMake 2.8.9 and later. * Add missing file which wasn't being distributed, causing unit tests to fail. * Make shared/static library building configurable. * CMake reads all version information directly from configure.ac to avoid duplication of values. * CMake builds are now included in 'distcheck' target. * Autotools 'make distcheck' now tests the CMake-based build if CMake is available. * Fixes to avoid undefined behaviour of signed types (C standard compliance). * Fixes to avoid possible isses when casting to unsigned char. * Fixes to avoid undefined behaviour with shifts. * Fix generation of output with 16 bit or 32 bit integer, when byte swapping is needed, in horizontal predictor (#2521). * Fix decoding when there is a single pixel to decode (unlikely case...) and byte swapping is involved. * Add add explicit masking with 0xff before casting to uchar in floating-point horizontal differencing and accumulation routines. * Eliminate requirement for and use of 64-bit constant values. * tiffgt : Silence glut API deprecation warnings on MacOS X. * fax2ps : Detect failure to write to temporary file. - Changes from version 4.0.5 * Support for configure/build using CMake. * Support for large (> 2GB) files under Microsoft Windows. * Configuration and building using CMake is now supported under Microsoft Windows and on Unix-type systems. * Test for and use fseeko() if it is available. This allows supporting large files on Unix-type systems with a 32-bit 'long' type and a 64-bit 'off_t' type. * tiffiop.h: Macros added to use 64-bit equivalents for all standard I/O and POSIX APIs used by libtiff and its tools which are limited to 2GB in Windows builds. Note that these 64-bit equivalents were introduced by the CRT provided with Visual Studio 2005 and if the necessary CRT is not installed on the target computer, the program will not run. The wrapper macros will not be activated unless the definition _MSC_VER is at least 1400 or __MSVCRT_VERSION__ is at least 0x800. * tif_unix.c: Updated to support large files under Microsoft Windows. This makes tif_unix.c a completely viable candidate for use under Windows (in spite of its name) if the CRT is modern enough. Please note that tif_win32.c already supported large files, but only 'tiffinfo' and 'tiffdump' made any provision to support large files under Windows. * _tiffReadProc() and _tiffWriteProc() are modified to chunk I/O to a maximum size of 2GB for extremely large I/O requests. This surmounts limitations in the Microsoft Windows read() and write() APIs (which are limited to the range of a 32-bit 'int'), and may avoid poor behavior with extremely large I/O requests on other systems. * Updated to use I/O wrapper macros from tiffiop.h in order to support large files under Microsoft Windows.- use spec-cleaner- update to 4.0.4 D tiff-4.0.3-double-free.patch D tiff-handle-TIFFTAG_CONSECUTIVEBADFAXLINES.patch D tiff-4.0.3-CVE-2013-1961.patch D erouault.2862.patch D bfriesen.2805.patch D tiff-4.0.3-CVE-2013-4232.patch D tiff-4.0.3-CVE-2013-4244.patch D erouault.2861.patch D erouault.2857.patch D erouault.2856.patch D erouault.2859.patch D tiff-4.0.3-CVE-2012-4564.patch D tiff-4.0.3-tiff2pdf-colors.patch D erouault.2876.patch D erouault.2860.patch D tiff-dither-malloc-check.patch D tiff-4.0.3-CVE-2013-1960.patch D erouault.2858.patch D tiff-handle-TIFFTAG_PREDICTOR.patch D tiff-4.0.3-CVE-2013-4231.patch D tiff-4.0.3-CVE-2013-4243.patch D erouault.2863.patch D tiff-4.0.3-test-jpeg-turbo.patch- security update: CVE-2014-9655, CVE-2014-8127, CVE-2014-8128, CVE-2014-8129, CVE-2014-8130, CVE-2015-1547 bnc#914890, bnc#916925, bnc#916927 + erouault.2856.patch + erouault.2857.patch + erouault.2858.patch + erouault.2859.patch + erouault.2860.patch + erouault.2861.patch + erouault.2862.patch + erouault.2863.patch + erouault.2876.patch + bfriesen.2805.patch + tiff-handle-TIFFTAG_CONSECUTIVEBADFAXLINES.patch + tiff-handle-TIFFTAG_PREDICTOR.patch + tiff-dither-malloc-check.patch- build with PIEibs-power9-14 1643619175  !"#$%&'()*+,-./012344.0.9-45.5.14.0.9-45.5.14.0.9tiff.htiffconf.htiffio.htiffio.hxxtiffvers.hlibtiff.solibtiffxx.solibtiff-4.pcTIFFClose.3tiff.gzTIFFDataWidth.3tiff.gzTIFFError.3tiff.gzTIFFFieldDataType.3tiff.gzTIFFFieldName.3tiff.gzTIFFFieldPassCount.3tiff.gzTIFFFieldReadCount.3tiff.gzTIFFFieldTag.3tiff.gzTIFFFieldWriteCount.3tiff.gzTIFFFlush.3tiff.gzTIFFGetField.3tiff.gzTIFFOpen.3tiff.gzTIFFPrintDirectory.3tiff.gzTIFFRGBAImage.3tiff.gzTIFFReadDirectory.3tiff.gzTIFFReadEncodedStrip.3tiff.gzTIFFReadEncodedTile.3tiff.gzTIFFReadRGBAImage.3tiff.gzTIFFReadRGBAStrip.3tiff.gzTIFFReadRGBATile.3tiff.gzTIFFReadRawStrip.3tiff.gzTIFFReadRawTile.3tiff.gzTIFFReadScanline.3tiff.gzTIFFReadTile.3tiff.gzTIFFSetDirectory.3tiff.gzTIFFSetField.3tiff.gzTIFFWarning.3tiff.gzTIFFWriteDirectory.3tiff.gzTIFFWriteEncodedStrip.3tiff.gzTIFFWriteEncodedTile.3tiff.gzTIFFWriteRawStrip.3tiff.gzTIFFWriteRawTile.3tiff.gzTIFFWriteScanline.3tiff.gzTIFFWriteTile.3tiff.gzTIFFbuffer.3tiff.gzTIFFcodec.3tiff.gzTIFFcolor.3tiff.gzTIFFmemory.3tiff.gzTIFFquery.3tiff.gzTIFFsize.3tiff.gzTIFFstrip.3tiff.gzTIFFswab.3tiff.gzTIFFtile.3tiff.gzlibtiff.3tiff.gz/usr/include//usr/lib64//usr/lib64/pkgconfig//usr/share/man/man3/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:22626/SUSE_SLE-15_Update/53e11be057f469e0553bd4e929bf80c0-tiff.SUSE_SLE-15_Updatecpioxz5ppc64le-suse-linuxC source, ASCII textASCII textpkgconfig filetroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)Algol 68 source, ASCII text (gzip compressed data, max compression, from Unix)troff or preprocessor input, ASCII text, with very long lines (gzip compressed data, max compression, from Unix)C source, ASCII text (gzip compressed data, max compression, from Unix)PR;L\ښto{utf-8f8531bfd3b8757e7ff4cfdf44c2cee0f12ce8ddf1089f7625d07c5cfaeb707a6? 7zXZ !t/Ữ] crv(vX0ufakUi!܃\Gn5fÞb+I &pzxʐ½;|n ,=!c]B#'912?*3~8VCrcDla%JXs::&E67Kn:p܍CDs 童Dvk{ՕR:~|.YAiȹ3Enr@K.ݿ rXP&Dn6\q\;.iYȣYv`)WCя{ojQ~#M|#rw4M5Fv*eZa[PgI}x:ިbd^րaޣwm ^ ahҕIӅA1*D@a&v>'/JX_nK3][ D=2 .gQo ?bHGurm{\s0 +iAڝ{<H"p/ ;ͯ >nViayD)Ga_CzRf/ێF}  o]ҝ8Bm̓o sW #L~B)vu6:Dt̊:׍8-u>SF|9.R׻&Tˈ,-rEۢSrZͺęJ7&DtĐ=e Xc?8aS $#K59J=rlW>dcǩvo2_a}ZAq,= ~f%BS]q7 ExZ9߄ZVuv2*:$P IRN>@aޝc@f͈]/d~wSb6E*;C9cJ^zฮ &/;4z*!͉\mFt$ʍ z2o)[繉xDrS%?'=,YtPEGCۻ4J?z{tg @O#D0F{g'-)& |cH>#%Uh;_z(A yq(x}gyT#m H-]l`9fRIz J20"CypLtً:if}{i:Yq< -!8<>+mynBir<;u}h$?st99#1Ԝa jGBIf s,%H{tyǔwiiQ8w+ T&E?J7@cCS}rp[ 5)\k*G(*&z3⣘ừy 4F#j̎*a Eb.ICh7'f8#YW*2ִӐ² х1:aNPV 60qN`O'sI$Z{:WaL\ᔹ3<;&N8l?X{nag-EwYL7y7'n';Nk1FN} 7=BAK%[GapDur7>ْ%*q67Y!'$+o!"}olA-SQ'ZZE"UL"i*RR VѱKP8wg\I IDښ&j}'?Ls *ЂN-tJ7j|vamNũ9*16:JyiIZ0mI"#$MBiok Ѻ\㖒Ѫxl)+Cv QTכbE{0%:">a]%CYDz;aBP0{6xiRz=M'tE7G6';k(`G+|fuW5pjaWh8?83fٴkB􊯰w@̪Gm(XGH~ w;%GT #dΉaN#"}ь. V-] :UEDr9 Ԟ?BE11H1`gd%ҟM]%!b74\2O(f2=daj!#0ۻ$ȟ]ELlzT0uujCy{juQ#+SB{Oq^7mAz ;QH $ȣ.V?a>3;krfGV S{L'O̹Ñ)=|l~tD">|PjP @ٽh#()^KEHgG*󧖿$26]Yt깜BBz)JZyU2{1 xْ$TC!)JLgMϴ:_>Ԧ-&IX/񛓓sr .?k6A]g U;8y Xg,[6S݊e;0w[uI. xrSk%%*]u$8֎DѧS.VfxB|,^#U gOqkFAnWW)Vo b-M[ɿ@dKѡ3R6vloW4] M@@v_~(k?5UIV1nC׉+)2cU>:@\SY Ž=hVI{r npMFRJdk Բ h̪oy8 `ۑICAƞITTw ? MbF 5 Qgvx:a,9?BwL29B9|A+ќ SMWG}?vO *8l><3-Nj $TV-SIK~[Xw2LǾa- jFXgvqo>9E(*Yka B^F6@7Ѭ`ߟxB 5PwO M!ë&&{) A\x7Dj\Y*3S91Gnhuӗ5#`X #Fx%ұ؋TPXT 52_d (['[=R3gOVGTй[Q/N])Y`#a%^I* Q/ELRѸf(exy}e"6U/R 5Vze.#GW m(Z0?8V ]_{_gq"̌D.ϖ,]^"M>sX^3d䨆^PX.v6= (dZvIKhByKݹ޳HYԥCI@U^ؐh-Ij b6,ʫ7 kK:ڐg~3¶ ?7zd2KM"?D:z+\uTdcʓ?/Am^q'{AQvEqsvѻaSS%>oaJhsJmvҏhX'+R0ynҨhmڨeJi]b E}+.WVyP8U4ii5-{O6#Ε?d@/k Xdܤ2lRKL//o`6d#!rB:Nj͒,_^4N.@)GI m4;SϠp { E1lv=J5H%n}f&B) I[,xW4۪mOEMACfmѓ# :;nde5(9pK/KQ~݊(dFm%9٥S%`} +GQ8͂+[ E]e 35ajzr(+/k tl _ESLc7D,JhvѾ% Up; @*(;}ntF)dvYل 튀R5&[E/w6|Rny %Ni:h%Kny5ƒnz _zTiSЍcpSgl4Gh$%XJڼ_8Vfخ8'l"StA攦b6t˩&@7scYAet?#ۅ7 3 9Wu+Fie$;;k`1_\]S>G8)(sЖ cA#L4z k/ 0-\l8G̩荴)_a{!Zy3)yZq:N(Ia4='/Pu.CK>=* -;{_)[Pd o RSpٺ4g4OQeLe)z} zpM kfk2(i qa,o@JƤGĐD6beZ"[$p禱E%. 'n3zb#\! "\ҠPV@қh 뽷 6!¤.tYt|V Rimʛ.udK%Kw+1哦e@hL Sf}@]ho(X`D⨀⨔X  UP\ByTuPFXITX~g4 Uu C1#7%stNLm_dpvM鞇J( EhĊve{#<`_Pޙ?&n<:eo7d,0je":HP] a -.ZZYkpp}Hn@:X+Hs/J8ŶЕHӓ]HF]dbBH̜mVqϛH%CBa?ryr-8*Wxaܼ4ap}HPd|~+ԍ[X>ؽ"g [;ݺ+ypԝAx ~օzh_oؼt.;E[qm)DC<"/Rߣe8*݀ QDjyI/ Tq4՝, $< ;σ1DxcC*:A$XMP\ʱs9tb*K;~UқvBՄ#<)B@WĘ 3OE˸a7G#(~͓ yR>&Nٳ8@xI} tP;$g [H:UJy=}=XGbCJP! L>D^+PU.?ք\joR_4p.~$T],\b㞈dtt +qݫ$;EY?,qY8*"_a60OS+8HUJfaajA~^[ș ѼOAԸ+o!7G W8;4 ~Gu$_Cܼɰ1X,77hv8~]') ,$bz}c!WqIg=L^`t( 聊/u>J!%H7O<ܙٖNpA?F AQ(A⢲`λxjuPY*:I(DKtlo46! %Tu~sr-@Q RA5+N}N֍&+#qt)qgRc5瞇A#kZٰ9Y*{.Qrҿ q?T,A'ǦVLOp7Yzi3 2K{!T7EJRfBMB!Wcg:o FUX6_,B] u uM}uoڞBE}HJ-zuZslTNb`bG6{+Ɓ[qR_Gԁr8G`&ԛۜʒbc F± jD UQJ,op v~bG)'a2/ԒjFWxv\wqEJf1Z,is %H_5GZ5^ߺצ$ȷÝ1=`lzT'+״t c].%kEg;K!nπ' V.P~8ç11X@ݪCI;cm%WYLjn=( T*pc o.;.x0+ˢaD&?ʲAIVzO`[$6^-Y8L/@hz ("[+7wLZO\"P8X+Xg/%(Kf@!s!0{GEѪqcOb)OH.Bf@ ~? r ;Y#~lbPt׸xT8;"3J)(Sx Q+Az8{W1֤V[+>kS<҇W=;+!Q8v-og{+ޛb5XHόO }Y,-`I 3$y0ENo\_иNc-c a:uܮr䋯|N>]ݠeΩbWBJ:lA.'ME¤ ӷτȧ΁R| 9.*N"b r=[Og^Wq uD)˲!7y9Khs<OH+Fkc Dͷ/aƀ71VYFB E}7?F6RY#W;7,Up+œF5C!T8-*#sF8Bu봫X~tS#V{ʡ|uov۫B~ɶsDzX}`\W?N@DiIoWuXZL$=%^BQL򎏌5=N5NO0Vȶ=䃀W~V@"Ѳ߼ ̟ 3^ `jQq)N~ oٮ+Z}34CwMD> oW~҇TݑPɯ ͪxWI*F,0jlGK;!zN-1&Aȅ-jȬfGÜMDA$EQۅS{Nӹ -XLvͿ@ oĖ%nq8yYo Zr&`4mP` ٯ" i`v19۝M3kԸ!5S Շϡ hnLula좉?RQT YP@zNRzD*E6=m~tb`)U!E=P9֎w1w0{Fl!UbJ/?Ndm®)K!^bV_0$k\3{49e|DXM0c J&;nTcT(2ؽa=>>EFMsNcS^ߎ} 7p`3;_g f+ؤ9$Fb?ŧot5'A%u sѳdJ|hBl.q_D6^$EHeNs5uDlzT-y'3+aS0Uq.dhvCU@b5x}~#^DX>v!d\HX g*aĸ&c_u_N"(/.Pƹٿ,ǺN{p;Q H$wB*50fYE8\Q_QoKYz/< >d;s\ogmq9rQpSmz49S|)wVphDi?-7 czm$!]PKr{QIiᭅt0H.W E9/V( V;> D%X uX}a 6޴3,UL"AZk?$,;XoDqIHnGiqJ8 })DJaPXnmBV "g&3dq]^ػ\RDB3tZ)G4Uڳ y\(}\ޥP\WR{{(U@4auB!xy^ MÈǕ񚮢` Q5.qC.ٳyj]g)%I)M1齓%yʜU"Pε~Kª+M*rwcf_t%P;o fВrA15]i84D˸ "8M~_ KΉBèG\LNvLEwqcx3rb%y0@ 6 ΔluyL pvR+VeTȅ#cZt0QGqB$j *:+VS0ߢ*X5} A,K={ֳ&F=4V9\<߹W5rQft3?y?SMJQn^w<4lG\! ?Oh;i166&+[Sp@񁶻zujxG3Lp+.ȫq:_b&qVq=T} LE"io wkЈX"Kx#pXB,|Z[!8-7\ЮMk&*;N\=Q>O1^—>J1C= z>%;ڨޭ k6Ǔ'fMbG0\EjKu kw}.+``*̍z˯^q-#f9x2w.+ca;4gS0PhP!zDESa'_18յG?v;8@ͶXsB]<y7#a}iUt +iM;`A$@G3Ӳ{%~FBr_թ,_ -R (VmZ3v%$8ilp8iR`c 0>ڽq?'u/oZn=)xj"b}+5 yz2jlrik3օS^ƸK-&& Yh+76I*9ilۯ۰:4OŪٕe8k`4C!w™K7KuZ_nTΖ/8w4P"ѝNw͏T !>Ej!7lѦGl񂢬J,SM}x~Uˁ55ߖycve uܱ9`|ي:lm߲q?)ny;ܻO#|LOIg uR, BRMMg_1J p*m^|؞0-"^y-V5+dDUTJ.CCI`{/P:A~_YrW3/ٱ#χBC*,@47@j]]nlƋIb]DsȭN*tOo^;̞FMm}p#E4>+HoOE\jqyr~\>T2VM >,xMI׉/e Y_ s X`HZ~DfB/JYcHpJ~ٽq'b/@<3 (NUb =DȪ ii|QyDڃmEE88m'̙8T%Kߟ΁Hh+>L0ׯ gPa[ikMW-m"ƻg V7Z$R:2VqTXq oa&ѥ[Ch4>( tbH(]'WzõdE 6%O,q"m((S"U2Y /@2F:5&V|\Zp`OR6yp!tNVP̵|Cѡy횸։^ ɭD78wE% 5в{hءG6vF3h3hJux2{o9[dm/IF+R "(:| sCj>~C@7#U fŲ~7qBSv0CsL``qP:SSwP ЍU e}YnusV'e+$gnBI=⏄=֊-0K0&#[w?:-L"y2h=7S%cTwPfy?4ĀW¶YiJz6.KvrGyk:6R2p9 +ݹaf釐ҺDj5|@y%(kJ$.V0ϏtXД ]8~C]M32I1˲l'FJ6Gh6( /wIП  Lk H&-OW4ýC7絸y%Q;[3@ە{%^DZ=!E]X,1C )5x15bD`&FZmMQ 2cހ4?5A 2]5=E3 1K bo֗*MO[$7ǕKFkM 6&ma.0Lr6WDZLe׼U3uuo]-z*Hb#1}FJag7 lsNK3an%K /MW{1[kI4L@ Bu q$C>fg~ݫ%Sx/d#{wҎhrw(֝§ RIX-%b"nI鵶"d޵,Ao`&h^9'+X c DdǦQC)1tArk3 X)zlm짼rxw2ul)5LOo`+ W9FdGC屵&^;x񆷩ԱO[0[P8637$yc6 1ԛaڇfܤ2ǹhƇpl4ӆq`z<5IЋ5_NsKȓh1h`kzz~ڟzqs[i3,{,17llpn)N`^x t/N8uI}ƂȣF q yO*✗PMMHVrb^&!J__%t P.^-|v=r:[ 2 *I8d28Sev{jamI&$!>,>:n6`ge+SK<˷PХ)ia&%|ZPຼs:ٝo|!PW=Gav2FR„xkxiCYeXPմiMU Z7cC-^Üs4g~5Mշ>tEM =ln4 Q8~o}0Cᴡq0B"g wmH䗴J$3 `7.|Q+e*ghtل{csqOT_Z\t'u_?'xgı&y^r[Ӝ_3C $lWuV‹R@#N"g0Puf⑦fQH-)gfqFEZV(9ż523,Oc 9PfaV7H\pH¯f`7`ᇊ섄/0TL͆ \)( 0ΠY x()`//1I&ך*Kж~;-pq^&;&3)Z*Ȉ9#Ұz T!I2-S|QMNL>Y#iCX;V-hW]܃.M(cm.Ni֠. O"D粦i<,2K(r5iy<ѨrcsoJ]]q鷬׈VJ /+gfA7p:ҽƻo>9j[(|"ӵ&K;[S=$ O[x۲e#~7Ŋٛ?L&5ؕil8ܿ@򳉚,X-RNHưKx."i Q bHLt~. HW:bm>|N?[" Tθ0!z4_7 T?dDQKmϱh#%h;g! K"oWHWNHfuU14@E8wl*ooPh$돺XR픁Q> / 3ތrlGNS ^B\uUbzOO?04?AO3 +))!rNym M-b+֗,˄s Ĝ֢[JH~^t\MX bQ"uжSDܘ!5I!RsN;IzBPtN^b40! Jq=Slb&0VngjpRCA]% "}?[sW_lXy-p4la{:+͡A7Kz۶8SLZC"" VK'CU[J6_(Nttz_!9è,yT,sN[<_ p @6P;Pj KcogtQPf'a:9+}cT1 #Oqh0#f[0c,x R$Dۏ^<y0NkU„Oa0G1U܂@7Y.b0r1v}دYxgϾPzS+{nVXHN( RZO^w\zDv̼{Vugɲ~0\)*}~~qړθo496'஠pu,K t]Aq-AyG*X XXHDjcP={a&D1c|VP@joY](믴~0dѕKE4C~>UT,ؚVPrţ*Rū_ >6 `X`'&Gf%VPyLPׂܒQ@iD`b:+ ,>7.6bb9zQiA{‹fy%ͤBëodphn.}iJ3a!מ(LW3a`&!xqa*ۆ8 }duBxnPI|3){n*gH7(C2۝9b' /`^N Z%41|ԜXa\}`w*@L z;K~h"DCi)tܿ6ItS2&l喕zjL:;u`C|:`[* 9PN r8/RFNm%w*}@'fé?:I"I?.6t%UDȤ&^81V"ԫ t(w?~oZ9oX5ZLKʄn!yͫ"V Uʥ8:TNڒ<ǬLg)^RՈK̺ªגG;JzFTe3|DO˥ }Ђo#:Pz2`6K/3_5V%.gڱ,yv3NiF^J -Kv&g6sv^~UcY 4m1So:_[|xڨ++ p"z&O[X ΉThc’7"cs/l8  }uU&@l /3Q"~@Tm,</,ncuN6H7љa ԝ@ @&ч=gkre4i2i I1X9$)ѷۧ;) VCԄNVq^tS2n%w@+=ʼ6,zI}Rpi{⭦L=_tP=`铇ꉇ9軤/jcx=Ò%7W1eUYpv#yVMmMx?WUq۴'hc?KO~N$s|̓dɶp4Sɦ Mxnfj¯O_n)wӓ%q0h?qIvȂh0ĺ7H$O"?v~|Zr= aSi N:6vSO%ti=C,}8.VYԩp4̒gP*hᓃ_>cV= 5YXeS6KrKݚA2[Ұ*"%5fp-HnM~PRzf>gwwvm?&OQ#1&u|i\psk=fmpLRkq. u0NpKbrd>YC*>$Y_3jX}דTMm:5M4c#g%o[Lq%K^,|xb9=hTVV,~4ٱ!/nbkGڗiOq9c% 96(|͋ GgDWW"9u ᭹5f@@ ށ^~%;I$AաW>)6KVT=I ~ p}{='B a$Qa?ߪ"Zy]kנݤJT@tR K@ח)1òJ֐eǵF$Y駹:lF%bJ $4)p*Q-åF7]T:] 8U6 0Jު>U=ND8&t;[My&f^6ӂ-1Gk sdLF`#t.1QҔ=>O٪Ws'%/"pyvsè^R K1h"dPɜ了[IHl^Ry-z)ejA\M֑9t w6v2vJ{AlD!@kSm35Lux@xRDbw%&mo}Ou$ `S feǯ߻y~U֊Y~w+5OdEʷfDͩCkl6;Pvh\;BcRˬK̏7UpW ZJ&w/Jg)?h:55c1t~_ ʋ6&r5^U!3Nݳ;DG*+VW\׿m5JVԬ;87ڨi5#,w%@UUhb39G̎b4Q Nº^_f՟S7{|\˖%RDfzjҮcm( \9:' QY :"k&kk3sGW?*:uŸz((ͻRZ}#9ͮ61>sݒs C,Qwbe:`04`{ 3+BT'Bw1B`FS ?j p?,8) xܖ9ԺTjp,*$TI 9Ydɰ~\/vPul*)s:&2PqMƶ3bu|VS6=%,ťȴ@:9>XSTN|p\$Jv*ъa.JP'uC\\#n|01WJɓVuhYvR6SkөZB[<3+a| _!͑J0wgƃ.h8vZ-k1'WGCȆ1ӫ4tyvΊZ&0@cFԋN:#\E"ƶ8=V5&jHhip`Ա}5~q ,J]j4s}Lυwy*]&8S֧ 0No=b=UH~=]mn]IQ?1msٽMS ӯR;6|E _481u햰aFKjS&w7*K~McDWj!|"\f(!Jn 3;RۤhkE4T@39oyds =m4M)`{EцisuhR φ)ʇ:sH+Eطp2𴦄qB iah,, @ ERR]LLE Nv1]}lorkLa6+OS  ~FM\O0OeP F5,&B~D7v)G=)XJ5u_+_j}(2XJ5A׼9ɮ ŮL@O*5ҡTwDlV3쌀6e0Wp@\ֲZ}s [رЩן =cJyA[k<NQMFӗ'v{!chAz+2k1^vˮ(Lmlg0𻹭|S]d47fSHOPԻhKÂtk]V7P _3YˡgĤh[3Kh-M#wݹX+tNaOx_ [<7r(ޢd(0=]jXfw97=ND*;y«BvtȺCjs=/&WӵJ@rJ+V/ROy@Э j qI`j\F p}(?w8b,N5+ZLs'1m0E-hUwBB<5#P3"NtJ $7Q5VsЀż׵a#ȓX5/\S 1d;#؝W>vzFR⎲u: 4/N))U;ȚgtVP9NQޥ,[Ŧdxt٫@00\ ]YmA'؄ig\wC##Y.Y8{`EuOUΊO? '%>an[ F&$]?peb9.ԖΜL \;;{{Q$OlDmP%yPëMy lz[֪`>9B̠@?]A Y`뗳]P3 {ʢ12񱸁3[ގmVCn RՓvjsdxsD{A'xQѳ)[οK[ }WLU|L~pp%8\b@ N=ד=EK˦iX2fGwx 2:[Zw-ڌۍ\tAnF'Ii}y7s~K/H^ha 3ދ]:YIkqW77MuMt52-&"W y,S8U/ Z͆ޓ(1$MT _7:V i%I:%hK 2T5b8Il2m0b˺ף$O!So*,NsM3CkPvYQ툐ƪ|cwҭa ҽf|jw!~UA0ջ^;wQ Fm*ܐ L35 bo|HM5݆ 2ֲ=F?;~@P:?+t7MfMsJ-nC'dd xX8[*q1IceC)}L-LŘ)[WgSpG>D.I~3H6cdTUV+>ԧ۱!k {^w!ts A^҆ؔ .t|5 ;" R(~$X\P>x4.T <уe5m%.5hS0}mܔ2ZA}xߝw6]|⁢}<%%.KҬ5Ttu SsPw"Ŀm^]XvP 7j$B\}QD y6AʥE6 t7-&Iu Vhx%ծNDf)I1vʿ8̤ ZU3p>')/v)H+A6#1խ;9:4S_Ii5d Os~?Pmq'\kU ;R m1V0iŚH3x%D4p؜,;šҨ-M?n#$BxAP-9nZgCc`Kn, t ߕ-&!T:J/~)S{b |9|pڨ,:ҚX VLT.Xq=NQOCka0:1\yfM'=k`QQr'E#m!B*W1)Ί_ni'Qc#hpCRE@vj/z~ gPF: '`ak8쀋à 15YqQu~9PbTj$l#Hli ЇXb}EJ uBI^-@"qr@"TV0N畦gpEW"Bѫ+bnOm9ITTz>II)J=܋{C@ɪh puam6H3/H71HmL c ՄTU6F7eIǞΞZ \mxu R\VwAoʛc _l=g䰡9oD5cZz$?yBI%~n#e!ؑ I"^ht9s%z40H~{n ѩ`5bV,e_I>O k;>c,P54F0ԃ:Lh@W0ݥ<iXw{> [PԱt^R&X3JQHgv9 D|8[~28lh"EWed;պX(|7p@[߯ݱl+ia9cԋpc%m$%qNKɡ?Q֝'d$a vN>|m oL|,ZRҟ"$\zj[PT<]ǮOǤ/DI{VU`&$vw1B6ҶeltW^wbJ;<;4 )3>Y_UǂJ] +Nb}',VސZOD N L9]y:#돠JS.&Ja]+BzC|` dhXA3}:'?L+Op[4dCZrL~ՅZjdRA4}f !TY vd@e*u+g^TW@T0yRa ̛#$k~X J0SCfu)Rw^h74BC ,!ͦƬ5. x!sl8Dj wZDrrA2WE@ltȬ%}(ߧՌ@s*؝ .x)zis_^%̻[9PhXjg@PK111My'eOK-!ӦS&pkQ\ZMIB5-ǗɄL (Jb$BR~u#(JԀs0nA1ӥ9$p(:HȟV9}VKjSq Z0$"4uZl gp߯Iߚ*b: `$d:fwM/Lr2T]Xc,Iw: :c l`cU K49zy9z cDYVaϐ{)ПH 60Z J3NȠO|/ /j:l.H܄ڥRa7/"Pd<.\_{qcmCJEk.K bVϵRp$5ӭ8[svso/%ᘹA^#o/6ζ>KFr{ݮpA481K4ʤc(a="ĈJ1^)agrǗT&u\dZ NȢypzEnz]Bvvk `3 _;LȊ&0n [hʡ/5xIa3ϲ$֖ =m8 3z:jUz[?rC-S<ŭbvDmg{=/GE&:=_>e}x+SA#^iup2k &6vW_Cl<"3ӽO;IxT6`wo5 gs@M!wȨʬ̞L>bɕ/R Zbު 8w$`eE9=#gG1;wѤ'56 ؆Vs0+9׭v07qt7;CU hݳ^`k: h$tin359\7D.}MXU;ڛh SBUUq` "oٱe9g8<=a61[h~93aۗ" PEK hSzZG؂ɸ2<0"+wcFPaf8CV;d}G}pYt.$_I[ :r?fiH=[ 5ںrcqXm0)SLAc׵T*?Bϸk Tk4PY[,y"$ e, $1ˎ :#܄e"_Z_Ʒ94vO2p`%՘8]໱C5/,G]6퉱1M@znqROFY!GG*u({4pr]ۦyU{>vNXjRkk8^<)@lH\CkT$iQ5JƒQ#LwGHHRlv43|ܻMSzq #$߃6(3oN=?-: axkUP3>kb1"*\_GEF~^ӌfv+4AHy [ $XOoPTCVDžfREI8%(2`<ZUqV.Zl8j(i,}tF1n tV>|IVU>yU/Ӊ>`OU.LAQxgaj&7Z*@v/LF K*3;و˚ּ q5mfbR0 >BCL3Nd(y~q{e7FY:N8lf-  7M#jܘKfEF& ~)dDRfr*9_["g+ hI3wĻ56pw3p٢l1]Uq,b6k9zUխ VJh"F +2ZC@\BN4E #|%*KI0ḡCO d>5"3!1s:gIRC{DWΞW&U/F#HQmV@m5V ; xߠ7C3^b+TUn@N&ZEp@ypѾ _d|:pu+ eS-'nW7R!\"HpBNTչD˵UH}rD™BĆ_*A&L pksEN.9CK8XWts[$.iKN)?mGH cR4ixN\"[AgJ^x[Hǫ3K f 2lO޿l %DsF6F_&^k;෨kDZ,;QhRĪ' \C^$I`p>oݚw~ m{]!;g$C5e_n7?] ?G]Ȭc$7Ϯ#;մ'*06-CsT^%. >A!( BgRL5jZ7L_*9 +ʁZa*Y$$UlB/K66_ .c Gр6bh y[R^A-hƪe#IY3>$.h9Ay9f');s}.*viq.{L* o#;5 IPG"s!| gE/PxRx*K|[YZA0j?NUqCўj |S(`\oҢrEPT hϝM[ ap\~jpk暆d6TogAHV?oaܚ>XRo|U 4l7VBIbR:`I^~R\;HvK~9*;=_B㭰;;")5)%5t&߸l?!I04K0*4J\#;'XGaR)vҡ~<aN]yvk3JAۉ_J&'Yi:wp9AZ;Vk\It{_\/5]ls%3]-_iߙWS@׍P+kx iJ8eÓ|,I3f+ KuO|L$7&| R~Gń.Zw8OS4>+cpv$Q")^xU=+ً:?>u|"#ђ:Ca'͚9.ǃFbp 'hkl)oFe!ށvBls10:k0~gptMiϔB) d4ѭ6s<+QҸVwj?ﻗ2*xP: D[<K8f01JF)iBg}c.k|mm1 TG_0~ @Rj8ENjI`7xfJ*xVv%"1_zL ڒOAf = ,Tew%k[Txc62 j ]EhVsE>Fg,'Ó>XriL5Ā!7v >!,C{"|_Dm2hcYu{l8z(ĞCߠ *lys'Rw4ŕoĜZ 6diDw]a,NɊl1l u]VH;Q|]|ƣLqN\%Jj: gzJ7%:;=aiV(,//}񹐊$Q0`ӁLO ވy#WT%$^NH4c"efL3Ui@zz ѕ} Ĩ՚ފHZ` Ju)8]k1}kPc.7l`F,/'D+$;{`.<5X(uǬBNx0V܉Uam^ B}NmtH*@r5SoF~m^HP: |zfJE,TFKuC K?C*'A]ҘFU/R.,nB GY,\ݦؾ荸 ɗ0]w(gJBO"qaδmAnW^Zy~1wϱbuN/)V3|_>\[{j!9Gڨ2pK?[Cޡ{?wS10 4LgA-F)tDJb͌WMprpUA3m1v3DK,6n^SCE[tQ^' '!. KX-c#ǟm 8CdX38}lrFJǬ)T*U"_8՜%ZXU ɘ'Jt mfW9p>drsMȹI*nuuKmv["cO.tP~AT2]ylBW#5\= {Ӿop%ߟJ,}QI>Q7vtZ+0o?N*;ur1% PlLx=Nd<$Bq-R=#w 2nC %-_mQ'E.e 2snͪK\+ y`QMЀvu$%l{t)]XR螴@M{$tO!396<<I/[gAO# ʺd#EjB Xawkic Ӏɿ‘*~qO^{ df(ۉsy9~vuq&̶W>o.|ܽW©VP8!ҹ7n .χ4`]wIEXY|G+w`XҸQӮuFWw Z$^C\KcHf#:)sN}_^lKE5Cۋݶ8s^z-Y?+ "o}d*F.lu+m$f ш'n|B/VbkefR'Gο%5^k$VM.֮sD_)4qDro샪PEM,cdGn!l8|{ kO1JY"zN$vHs]}ԑUenWdN,6XZ' L̲i`aLh~`fs\X, ʂA`?7(|c{Z6.֧A V E'K~tIM* nȺrQ}uYJj[`7S]ơGFfJ>̽‘h;_gӊp^d ? 1Q7^ء"qN:(ܜTYPg?0 x^ǩmx Z2mLU r#~<뺋ZVjlgEfTcgtmAb߀T̃:7DgPrq !> \ácNa4^.Mj!Ϩ(Z8H~[S|يh|28^5?9]BW Z8y35RQ-$כZ&fpq "izth'6:ozZE@05 !I9Qs{&\ɗC L`@/{~;ap4䲍Fr4Q 48J >khYʙG}ۃjmZsP`$j!yTSDyzP}PY~8 >߼B<,R|gzZkS$EG Z lv֞X()p ѡ.GC0  ~[ya,B,BΓfv\ IM+:6'&ٙo jE{Ao_rhebs( Q\8 Ԫ+* ͣ2" 3njQQgi731MMZkx%`$:ॖ}JV׌6Z'ag+~#f-}z3a g.DYE*Xd_L =7ߔK~PBU.e]ÿ)(w-|"mD?]ZtJ->LXd ᖢ>=E'4GtyfzTU*9].GUm2o)]ƀ|$ָ#\ s3LkŜ!Zv&e(?CilpG"p`h9Fi;rZ- /-S)\A)l6È׬vįb<pbMYSۨgzo57ܶ6*PN~ i[c|0La,wC.6m"'HQHQ.'EsY FhrEL@ne+?" 5ŭh5!$ҴAx-.v ێfb1uhՓͫV0Iq,e`ɐ;Nzo[M6f>ZDzcIѥȓAVS1#ƚ|u>NY"զUqu Vl(\GjMk2_eGe(%Dz`RLNƋjDKF 5]ve-ۅIyN'8Uhͽ5r94J28h3g4: ; ,gy5n^% i{(6ܢ(EqJO刱Y|!T\kM|hW+d2!u 1C}ɉ9iҜ{IݜymDѢ@{ u4*s8n SM:SQOLF @Jg}-5zrNSi$@?6PG(9.K H dҶM|[6]ڕ@*=(ni'o}BZ;Q X⤣KGr$$~r^zm )jg |Bs,[vutT^, KT8w61k2e[T~˒<9Y*~ `Z.?v 1]Hz$|/w>eNP*b^o!rW)*1>UgFMlixO܈H+ZlW5UW$#+مRM3 I[CVr8|%ӁB%בl?Yg.*ZOc{cUc_̊+{^ж4M"G@CTce 5T/ 5%z^1h8m)eQ`5U(l@E [ǜ6,uv?pH`ᩙ}FI6 Ü`+'N]_YúkD|Duzʉ~CH?pslu@ȇM C&q'th o *s~3 9H!s"(@=T)^z6_])%oHXͼ#KKтa[lg KcM~Y{"{*A!p_Ee{ > :[MFͿ?{Z4HGY.Aud4|c7ݍZ+-NjVyQl?B:Vrtp|x"aSzYO4, 3Iw[~>pI'r @#Y)+BL!1m1f;"]coŭt^\ iϏFa[= QXʝ;?AN r-G valkdlLWc XsQf;=ؿ):_ȁ{&QM/+T/<ǩޱٞ:%{)!| ț\LIŧ< B2YͽTة:b{QۺrvSV FD\%kC$ty}7Q(` Qx38wH+yN͗J;ݪ{_M.YV K&0ˣ4 8蹠]a$>fh/W/% Aj>>HK2f ЫdeÊe`KNTdEV&29WNf5ZU."x׳3^ 5^IIZ-@017wAc5SÔ#%!`A76V6M߶ d:oo'vI)P`@ nH#kѣ !* `RC1bKl湯KvJx)." xic `dݹaoSa(dj;/Z6B%8+x ,g D6 o>Siu;Q3VSp $a'B/ˢ T(9&Q@TOaZf=kt܊ros+_t__Q,`#\I(b/s'$ʏZGZy]8_*5'K8o+BHX9/DtZ]LQ&$ fU]QBsljLWFB$R;WҶ|16ZdDKD `Y0~G~[Wfb9`FTHVXEO3[F* mh?$m\^'Cc+ag 3hEلcM"6Gݍluvs)}y.y3Io\ڎ(^A528}$יӡQ gq/G󛼃 }J=:/jGg M+U miRVj{>if;IDMں 8kF67?er6|ܡ@F^ AgO)Y,a Y5b5.C鰠]I xQ nDOϫ-Ρ weiTG~c2w㬁2"62ª3߀"I\d}hϜ)V5ITj}l-4w IGEwhڙЗyhOH*P? kͮA\*eS er{g/$ #RNTl;d(wZ`-f:*$fwYt'L;rh.Q+M.f/s6|Ԓ?!f/BOz^!Kr2:AhbxfZ|TD#AQb:^TP9GU_F9%72CSm+Z7GB9˛qC &>P5|w)YSyp(FcXrBOxY뒈n0:ڝ0-A S-l$啕~:mRwxJ#cg(d"Ը 8CV#>.~xzSּ 8PKp(^(_ο0Q*C$4Lj\LTnI)y#}3m%-XKG -S6K]'f)AXTU˩Z;*wٱ>U?HP;Máӊ #|\̖ҰNjF:9Ov]sDI59NzxW'LO5$`K@<6aAF ԧ7so n]Sydz{m+!ƃCw^ вE;>',)Y3s.F}%~Wk{eQ pW6INA%HTt[)ktrX]b~AUFv<4;nq„ Z`aR{nKY#wO\֏P@kD3Sb !y+'Ny^lO>1ذbyz RoO[e=&_ĘU[m~~b2 Ю}A(6WG\RѨ׫RE;H=9J|a sE^=k?aQ,lMOXɷۇi^0D8Ű^} m2T3'z8- @IqroqZIȶ#!ƍ wM!QS#-84SM6!E(grʯ}juӒT<Xv#sn_h)?˃IS}Ej$c\au,X*´_⫅8 "+ g]=B#,U^!%.Sh{rQHR*%_JcJ "&Q^e"cjb^2t IYH́U(+Ha7pH^`+Y4! wY&\1܌/ז$tK2$W0*D4-Oq8K=P2:^cL?Rr>C௑I;*6B}Ϛ_ϻG@ly u+[0hEtQK]3?T˘kʏy/;/^ϼDP0^Gq_!C迺%1>RȕsV(_*xYї'Qt|{V6vFV:YGpޫCy:D1EK4l}n2uzKj[QFO5L%wox|TjXS_ rG"vJ]Buƒݮ K)+*֪YE<A}{}S\a:.),C D+Sl(Q >UuQ_%2M/8-v-g@6ٮיoDĽ._su: sbNZszWϪE jzq(}xN=Ԓ.6.(Ri̊f^X/-q6t3zMpJr_n^>zo%w9vsՠD~{%/Ѷ*exiw뇹)]C&?8 ΃S'y*{,@]^0J]5dW26)0kCDkс I/,!Q!$dqЙa32 ;!*wo ,_ʍe֔m(8` F#d:1q;Uv]%n(<>nr>: I4V6ow*jאlƻbJm)jj66$d|X0cdx6s喛s.^z<_؇)M7G@ 488Nm?8`YVU zm*G{~xjLa?+:>P(0nNJ7s@)M = r KT)#sJ/ƃp./-5C :\֍J!;ر D8Wh^jKϽL \(׹ g`kN7ֻ.r;Jpq]uk_?&;m0"i(y,ts6xr/fq1aZf+m'7K:+\^`3TˑBW}KpI)H`n0|W bp[ 2{wl) zԸN+n w$r_k^;3a 6ڴ7Z@~]OIɟy,ܨ>8/Qbt$H֤bF_-'h- $ҏҰ3##9:؀Bpbd VT(YNSmrbFm2!e 6R"Sٷ'6qrYwE֧%O!’mB?'Y9s}^y@enX4)#ظ8HKR†$ tsJH'6MɃDv=е  * Q}BoS ~gJev㼘 EړЗa ۫g&ژBv$u E|h7tXD㆜Eq`l̏tH߻ׯ!t-mo ֕tB~\xd鋒-A8@\&]~abآDABH'ZI^ig@vu,ul ZW6Q ֧ŌpWCY'(2S\mseݎnN3 _3G:sZOF_!=tNc\6ٚI1mv},7O}܊"ڰy`kNy yTRޖ?#b}Zk5OءoHYKYǣtYOI'=oOeŌGԾrp5HQ&ze$OTŠ|"!V<3f9*L|K6Moqi˂eq<6Cv˞z2vNgb^ 4&wOvp+}sA4>38lOAYZJ:KYw;켋E~a4"1+&d~5xo\s{,̤j0q3Fl4 "eG>Bhn*'V@XRtx>pq-36Ɖ&)Tl3<3 XߛmCQ1Lh󬂙꟱OlXC }-cok}=<~.v'[2\J*]5B$Zͪ^;(G--etHCkS"5b3dpkfy`hvhi~S"SKꮠw2C!ZKv{ѵO]i!=(v^&[CNPEYjc#un h=h.1d}1 <)Z}kENO[36{i؜XrPߎXYI{3IiOt3EqȸH#S "Og#VAdoJȉi t$وH뻞= -&C}7~< Y8ƺJym#& ־K\FUv&<)hB/iGC  pX dH$&ykuAg&g`da.xG4$|o+?"-ya~y4ʆѓZ+/D&w8h#JLi{! ~jV&!"{KZܪok[ʡȼy4VQhǸw$ I"Kt@L( ǂ mG Wڲqqa6їS ̻y"tF6xB(a oJwSv5BI[O*5Zy&!ՅJTKp3X$>CVКþ^HiE͟bjC=ӉMS,("B(;]+;i!B۶9 5-QO7x\p +$ tO/͒!#9/wV-H3⦡]6M]J8]ݨWn)ű^FV\òJj7жXAD*7KV}C$`pӛdX0wӻjʥ+ ]8I Nbu E:؇T{Հxcd,u\Δ[zޏ_B7qkwxn\5HJ}jHH# fеCuko"Bnql"ri*\wpiY3Ff4FV^y绺w $tjTHmuZBc -υ3]t|D_ŝ1 |?#QLT| a=q'72zA7uҮL~JIv|4Hv 2WaR~]u1^ePqw 9;ʰORNH} b,?2ULͳ4α$Ԉo} xeaGDz!a{v>oh|l1ȏ'A8ޱ.raӡӂ}*C !ݸ>í Qe^a;\>؟ɡ s Fa웁 fff Du8*2Csd`1r#ϵ ժwEaiFI7Owo,>7ˁ2b&g%p$卋 K:Zy('DD0 qE!:#5*9fBc氅*Nԃ R9\gǾg [;Ղj,+΂·g7~V,(RXQ!UEZ(o4 :'ve)P5?ne1A/F؈~)ހMVŶ&ʟÄ !)rn_[d+S:gT륶՜r0[`u2|q`5+Gϫ^JEt h#eQ]^^ҵX9 ^C:[a[IpړM u(v{~ nڙ6S<5le, zŞqNᏗEPe%CN=JO'ξ&G ᜔IkŁ<(~2#q-a{p:Zaqǂw XgUҟVf9o2K,gDi2Sg+hʯ9w/.Gi46>% f}arTz@dFtO6vYPO+W:Ф%2i"ohmlA6~_Q4Ĭ6թLz= K@.:!fD!ќtKQh;oW՛ ^ fXB+0n2+Ž7_>FWwS-Wpp?}3y"=mǟg%'i^9]iU4AeQwPәv3zTUr&K9mwwJ V>@n:|\u[`zVקӽr(#D<@}@yW424O&a4׭rotBq‡`yyMQ)"؍3t~;T %Pÿ ш~tvsb.Tbqy3n`j)$dG -/̲kf7k X1snh (FKȒ(ߩ4sL6nE)7}\ueeMB/Iۊi6"1mxEqp F(H(Ğp7F-eI5A9Q zA W +@+[aڛKnM|䡧L= :Q,utt _Qlk(Q$-!ȥ@mIj62I/f MQS`7U>^)L`4rOa }}scZOXv$V? mkD ]h#}kd+yQA/0;70X硈D #\SEjRxSMRNS<|h$)aYD,+ yy?P] ^in?:pV2@9@vt $hdsANV7p4zdV]^Ͻ bʟhVO9nĎjP6B0VDȞ5D$R1qNH%-9'MZ;N1TaYJDX4܎u;s!iX&Ol=8N8S/ }Z|mPfXswBk1 a q~~$A9!&^0V>iG ORiِ&7mqH*l{FLa_,[lntpc._nw d ÑkoaHjW^ $,u)#|#rhd|gF@C+ZTǫm!Єʎw; GABK, gA2:.0%iXQh_>_,.Xb;+Cs,V)s;ސWC/. oB$?-s@z%h+!UX 9ڹB9m~6/جfxeb^li-/L?xU|.Y7,p |ý[%Ջ`C; ɡs;}䞬I-Ƈv6 e2L$,k(ŲCAɬˑ \C\[@ܱ+zB;+ֵ+1$aR*.8~Ѫa+dSU*z58zHhXS'a ,F~(#7de<\5s`]1:r(/{mD:],$a,s'bQDPR2Rw{ͧP^8 y^XrD$ j7*5n0snGb+S,}rT*/f\܂jq<1b]/ǶMa} ,`APxK zT4CeNA( W8ם?Hjl|?eK9}'JMN {F^gEJ ܪ*9`W/3˸ɡnܹ^Bl0y6NFb홠pl|8̒cZ煋۶'t`EЦ<, # UnY$:KWÆԜZ3?z7QDŽȔƎ9].})|FNAeRVvO!/]@qO-]u 3b:U.TN3!*mtA"!$nN٨+*RA :Sl/})3}8.X,/<0t`t@:" b$/vU ~lm^L5 7hFOѺ7Ǖ+(2̀Nje-AѻR~5?I3=8jhQ8 FT:n+7`(t|D ro2*w ?CrN{.Fo2 wLn6 O,FY&!oG拏>7ԇH?rII+J-Ge]URBcΨ^pW]a9H6U2_xIv$& +c P}iEe<2BȂkol\t{Jud~r%FQϿw|rc/H]^R5O9Z#K恛\"^g"}bjLC $}vZAb˷]/: Ā7uiO m99-BZ$QD:t@B#_0*x0ڀ79D4j}7 rhWۺP^tf^eb`n~5v馻fBpYbB6; A4$,8.۵0(O#9H45 Ԙߖko|!{T#i}U%Z`mK44W*"YpZVO©guY=?0jB 5q9\_EƁ(c!}wJmT3^j!l:58}0}6si-"ןsmLPԾZd[50a,OzkaJ5&#CG[ype0|eUuK\~f^N_J][)\چbՂ"tE\a15k @" ~XX(X|[]yw"<BaŴ'c f#Ӆx8fN /fcܶ C9< ^6%X\xTl9!tёn bPN;v?xb4FOKG3~_GO ^t/!|)՞=ρ ]x~Nar`/Kum34_M/jN@-cjJ <)eMhxJW 'Ly QBu_9)MT!; wK%8gm0YJI!SQ.͗Ug! -_+ȧ3 Nd' |=^ڃᬕzzd2QivdZ55y7Qmp|hr4crFqb,] ?nAq]sz3;;` #mb7o- tԚ~P%Q:Dy4aCV7 4Lj#G`WBe5H.$c^LLyw"xǛP;ױϋFqr> =oAgiuVr7-'A_X(5Jӓ6P+Zc\D6x7bޕ&VG ³sfid<4FSC*) t@ m'DAɛ7Oj{́˞Pb<9vRhϒ+<7/h<.'專)qB{^1ؚ |h\| \1T}%45&986]lQsUj'zx8)>uJ'YdQ鉉1NW[ACyݏ/Sd<,N\.vC{B-0@YuL>XAAR`}?x d^0Uc;~jG osqV+VҐ_@P]zXe4N6(I%}BX%5PZmȆ3d^1>ۢvW Ћf1"2~+tU_s_凹B!{;Qw ?ߎ^ǥOUӹ =R-AC)jiYӒԐ#bv*3cSˉΗۅaցvxHX0!0Eo׃MY/U|O T-qEݿcZq_@w Eb;%}sMYM52 06pjjgƕ;U3Ib)X{||(*`B"'bd>xiG磼Uܻ}MQUНܯF*lڣۉvxǍ:::u0a{3PAv͈-;eԓ?*z/MՏwA')I[TĹEYĴn;dX%[ricůl56"Mw,wݮʶ͏+fKW8 ^V*C-_[}4$Ȧn_Q @]o ?*T1^?n s]#8)52nLЉOaAܛy*\$x,L#+'UB+ cQgN5bFM\"b<8.5SVaʤV 0'@/F;'4=2֑"zҼF|Ł ve0ຫR]])'SXG:\ EyG]Z"(W V( ITY؄%eJkW;gGb[ˢ1 V[&GSþv~3׈nr,ai? k}\K 9v68L9<>-E!?b| +khA01ݼ#fDQ 5 m:J;Dq$[, djBy'8 X(V66= jbQ_ąwNL(JFL+".%Y[ 92R iTͿA,<;,('X257M~R+!}cLώdW2Ji[lW`w-/&tɵhڑ-Ò!Z㝼:T> {a;B rM' xg3BވQRT=2kE/﹛˿Lx6-.<ۑN̠;_PVU8~G_@~>![- Ȅ^M_2@i/}gR,)ngA.8|$\_H8rdmlK!Hi]R7&>k6J.,PeJ" 5 (~NSfm,nO b?B"qAUI-rhPĘ1&) WNӣ'l!vu wUFi5!a)"pVQc:'Ҝd( idKXeա=Fwk0bE6u7$v^vb$( +غ#p^A꽁+H#,/qng~,{7ր@xjs!%,V~kc Pk;Kf`B3γv2kP'h 6s??u#2-vtXY퀒1&lh; "W>U;^?F^5YLJYZyF*;$RO)*qQPL>}DA~eDoJِ֦Nk}|qkgb'͹?C ;\P0pL`X+J K7-O:<0Eʳ)Ugm9h=Q=6VѮ֐&8yN}߬6Uy ~2 tJJ* y z%Jb (N`48o׆F֦f&\A2yЪ%N.|A/%\]ޅlX])TN"A?X9E f :0֜lQaсrɲZu}%XҀ+;GLcQ[`=PrЀd[vEBr*01_2R _z㍗8Z1 zSB#}em2/XY~h8IĶ(YmOQdaX {o8uvF%}EV!eDv8%itqx =y0hk0n8XN9֯- s,$2dk;0lO<3#px <ų%OOHمŹΣg[$ךS(fհc|̂#mȸ`8#R+ffm|} Q" ػ. L&[` @4=7ڀh&L~fۃDL9L*3˜Vi)p/ҫo̱CeEdȃG7|ɣG<4= zdN, !-sKrkHe){* Raդ4/gdaw*ב%:Hi}ć\AWhOi3R[t#1Q*Og\LnZ4v'9+QG2=AisuLF U9 ;748b5h GJQi"b@B}}߄+|QpZ \w5YąA֨豱։w?k/o$}&Z\ =y".}ƞJiAY A6vz *%:}r,n}n.NC`ɳM43ҭLKFT&i-Ҥ'8L28YMF v N TG@|5xu͹ѨhGj_YD}IN;C~QXlLĤCv %ъcfߡ쩁YtS {zE,0ٸ&AI9Ī(> E +$Ƀaaax],!ʑvFot5C@o?JUw݋apƤѽs!TpjJ(JU8 ^?/0~JFWayh5,ֻch>acwV\j`QT$aXIwϞ-v*R4hdt6_˩qiZKMv4S=E eHM\_Q0ʰ3ٴmn ޴;T+zఞFGX%_) a@0A_G"H3-#l 6q+gQ}O힟tDZxCqSSo' n."߽rV`9;KM(L;g2F&S_A?=U87r-馅{|+{R[H% aqat͕0J. v{"^K*D%h5"|FAbPUsf_" 4b zn۽k_) nTb$29J"ÚuJ]oiLd?h=U+ػlыStMst#-ݿMy*,\`HׅC(0=HkmixZx0&Kq*= hA(Μm<?|un[UZ6jz(,G;/r:N~ c.Mĩ2#b'mP?N'ܟwcLlmsю~De!Aa/ӺےJ+ )S|H!v|3mKyFߤmHEsg3v @vq@OKa%=L|AHZRJ6n46$0FyTCIe}{AX,Qfd C(侐 %_HⰨ'G,ex~b\#x ".*j|.yU,=[`jwЁaO68ݗ G-piȧ_l),k \ |+mfotSxL1SgYs$:Ķkp5[^w՟aˏ$=9fr(ͳ?$‹ݚ_MK*Թ Y~Ia_6s/ZۚHplJб1NGumk1xwqf :O@,5:v'>D~76燳⸏, Fy`徰[22B}5WM$^OB-4 W+pMGXwo 9w~ 7Y3ծ/Doݱt+|C)eM~v'ۏ<>FB{(z8VS,- ~^5<uv;z&+}7$ W\<& }Jϭ[X]^>3}tQ[{fYn-]J >ƻ$=âAigX/ i0mDON~3*f̏V}Dox{嶻.T5C6ڛI:Is\R$|q,@a\IBb|@@{BlО~8U2 sIl瘳3E?"nWAżt_ݖB9瘲vӢPmjqsYĤ)87HuB0q|!BW [qGT*<EGuY he0$ PZd@7_%%&t#˙S0dƺ?@c'JퟓdZ}d(K%ďg\'F6P8 ZpyipmSKs2Q/ oI4ii<|OcV2$ebHa_vݤN/ŧJElbbiQ!L-`UPQ_/%PG6Qn/fnh9(+!DwʊZ$(UYɊUmd ,`{r5lj:Tz>:1>9Pj0eey9n(p^5u-c=WC6({7Ѻ/E]HLw.=DEZtTn?)z?g 53k9YJ|LI1Pc5LrYX3Ms->OnӲdz_%~[i0:VC&k 7㯸S`/4ZWkbBDq$UPO{7 YgZa6YťHCPL"1"[N02ۍld7H=䩩S;NEn$]{!-]SPȡ.Y6l!]_amDwӄfQ` n[ʙ]-f;:xC+zy4a#2gmgW>{;C$0zeن}>í,>Y=FzMxAJ4OnW~13+fE1Ca 1]KiGun&m8EيkXL& C9+֘6`TZ+0= ($ݹeoG61'*E{9% pLƁ. s< m=33h Tre[KA%H9ҡlg@<=ӻ3wlWl,\Bct SSq9tֈw%ڱ$aZi@^M |ԑ*Jo\-?Y>QU,KXvĈح YfnС2A8ԗNHf^OoV>}.C\W*W;9͉>7k}q uyP88O[y/ŘOl^љAM$8AD^)# H=I- &YoCJ:o嫽U3ak:ShlS^ 1F }l8XGf qt> DL0V4 ^ٍZ>b߆_~ȇі1Inv?]Ë3:5GF@ b'-dLd4F:g*V ʵ8{=98Ne$s^(^jN>rB~c̙Ǐ}Uu$}W^TWƪ3C`ꈪ`t%Бpa78:wFLMNWܣ@H6$}dPvS:غ_& az T3Ij wlP>'|ǒb0ڂџ|a\nk!j)s .ɐ2Y|\fzpT<" )r:PZ~ض)lAПԙk!Pt닀v]Lf𪫛TW#^sdڙcv{;%1򣂂tR<3f==yBmцOjXKxuS3ݨszJ9sVehAA" v?yө|Azΐ.MM`,9YoBH .PN B&ݒos 5f!8vs!qΥ 2Se8*fnєXwkFɦv$;T_Wgyd(wKL̬Tov[.쮀 q f_tj!|hdTK|Չ)17cuɟ T1(%/\cr9Q`6t a½nZ=ƖSADΈ8$/uh,)Rs8 C\S϶JN'#4ߺ-[~6{Jx;ounr r| )  EN|AVv7>Sm߫S'N 7W?SZ%E@"6B}ϱSYu㧹O̗`A۬,W[f~n~UϨ"S_ZId &&Y U0x곐WެZZ jpyt},iU5b KZ]GM)w 9s"UJjݝ9V%#tZ5ȭicwlRk-$ycB :/T!=$7EPZo 99U i´N=NLW+'UFu;vnP~1Ӡ9}~N~A=FkUg#8`%rrM38u =~(PSLs;Upyzyy,$}ͱ맯'\I$rgg}Hbl1 V>S㧱TGv8CJyuݓ5Vr[%@&6Lg+RPW~݆NXy4\)^~4_0a== #H/~ EÙ5ouc9w$NSUܥ!5Ffu [ECzf!~[39#h[sT?zzgI@=}, <Ϯτ877D}W)8Ǿ"kP2l8E~ῧt"gh¶&pVbaA3&Tbh v*0QbT{?rWu>\o]eX@j row`%Ncyk`.C6tܐfmr|$GsEPMԜ;e*&e5󬲌 rȳZ͊ !x {r uR*iM?Xr\8(r%3ꑏ īr8ϖZ?. !K>߱%+4zXyrD#@n'f=U4o6"qjC5eԡ!,\^Þ"iڈ%HT%2Y]!Jk+c5zzW%/ˤB8]!9/pTOs.&z5fXt m v"&$}7ɬo uxCfdxs DV:̈́ B{3+64JŬ8n$+$q7A8TtbzJCN|.e K"R zji[p(j^n&a52MQ'vdۋ "b/(g*=Y޿0^4@;ry:i$/ z'H`:'i8q5WЈ50Wч؟{ȩT}xT$ q 0T,EC{fxP>*Ec&:5 |qFEAض;aszJh>23QIpDUWPc &K[z{Sh@W| )W#&șcedFrڠK%PucL}skǡZb"&P")[[ͼ%! 5|alG[VL˱ux_fo5UW"}p3+a&^4|S=L r@0~|.,HZMOUP(ζoWгR!sԁLDGD!'oo+?ƶn ‘5&<6zZz9k )0dx\zs*a`a(w.lJkhsl0 w_t"M١{=M?NVDO BӐ|A0<0]z9O>acC#jj9V$l˶nQ;qBB\b*[dlR/gwٯF h$E\}lWI&L|G6yW@$+њrW-x[)?Fۼ tFbk[ѷë&UjѶ^Ryb*&F*aM /c K2_EP]`#_ȧ_n=g\=9MIn}xȝ]|ƌ|Ɨ8 iy M ^;;e/8@){729W=*NhG# '_ÓwJAzn"H`.baʻ,^5Kϐlzл$'lEV%'Fכ% :}[ۍKG_f:iRT?u]lSqLjdWrk1$kNU(: r =6"*2͸M 7݇#-*kG[IU'.5N[jWЛ6jB6ǫuHL_uȕ^x]z馪 hpOSX x KD-?yi Z:.8)[= /%qϿQ=w XE[տqA%`txeK#} ~C. N @m6[+ 3v7i2/e_O3vQ҅(q>%kTPW/6>݀AU<)ߞIN>{^B i?nZY"菅{oxrbhaSst͹fٳ,.Z`3Zvlf3)n4#* Kn‐eVH2uPv"pXw? PX[1',y>Ǿ̃ɥPS$k-o,HҚ#E΋f[`|b7yPٺa& hwq-o4iӨa`X٫+-.Ҟ˚}z}7T2H\bv e{>4+FHYoʋvfa$Ưn5@N kº_ľn\te1xBo~P!(M@ 9_04,e{Nt=}c>5GzɃ 2Cr7D6Gy²6tH XF;J:Sm~^-m-@?N"̄X뿅r{[o #6D>GaP7TlanpYWj5VK k=*F~lPc;AN ]6 ~$1c̗ /-Z&4{ZC^1o>YשK<L̸F CPp%T7'gR-MW 5``Y۲ÖDmؓw66DPBqV(5/Û[:0C|؉&^$}Pk8 ;*:\Vʮ\Q7T-ÕvV i;o=w!7mg1

QC80LJ.[A#Hg18}ᛍ9lMiCC%㽸Rx"q-\!g+as {9tVL3j]<sƦ0*VN.i|y $R(F5Kdh9I.Jߒs/L]?Z՜80T9d{ޤ{+t%z.+q)Nm$2y!?jl8|э{X*;r _ 1w peg Mhh˥y}L u`XS0pEh7I_ [rdx.>[Ʉq}Py {Jc6޸UZl 5QԖIB5o7V <\Kj2"p3*)WEGJ-%)nqk?"i$ϗ"𜥓@Lȩ?Hќ~w}5rs\Rlǘv ,K0CLk3\3Fn_)l/Bm̖M4~&!sxS{-%1͆VAo^vR+3r!~6<,iq>ӫbCvfj] ^:`˶6yCok}Tm1z.#oB}Ianڻ՚9O@azcrw,h~y!: i BHY=՚\.RN@%/0C'NT"vn .C`M޾@:mB+*$#bދ) zǺC~$U ㄚ{ :< zҴE"㘿Jo=R;LXF3WQ ^Q C )N2H%|?SގD'I9+M*^JՉ3^ds5:'Eb6o(go,c O< - 0Tw!'JjYb5u0&d牓q ! l>LᆾPh}\U> %JP{[uh,c:UMi2)w1';H~fP0cV"opqۃLd-XXYwjNk}g/Lz ˤ"@.ousSgkƌ>d՗2'^PU0^pUd8аGj;be-bcjWg%_'=cqՎRۨpM5(L yUii`f8MeJSǻ#ZC ~obEov,U4:DNغCW=tD$VR ؆B%oO9njT׮;a^d``B7(1V_jp#(EC* )o Ars{a]úY"ʩaGY_@ tnz*F,gݚY?9Ue"H}e QQjI,:zW3.L>ҁ0GnptjBMǺPu:x\[7{~I#a&`)F%V/Z \M>jݔƻE jSw} . i >-tbx/Z G@{6MxSfeB CۭTTǮˠ@N)61!~ !Ap!0 .[9n͆ :KM#M :;ph B$ihRYWg<vdwRّ6Eڐ7օNa%cOmD,_,L2m;Xy;$r@`yf5 `\ UI!՚Ct1f4~T+&1 ˜P0 ^#d{>b(Y)p.3[d= H6`4W1Hvr6ﳏTʋ\O۞?sP5vvY]UE}|+mMZ-c(7P̺yII1 dD_-^rڣ;וή^3*OESNp K)_rE*euqzc(U ^3’kM]  R}Г>*smZ+7zV?k8rxiR_}׫SbO7TVYYjkU\UP IӪl3XdVɬF㥅; e@,.hF3wXko뀢^.|{Yk҅ k/9d{)Lv$xڊPXLzTC |>ЎH cih7X:a{O4b)b+o1x~E|†ٳNfoHم0H;cyXHyvmЗl,}IA  M{^pb8# M3_JO])BL{4f`y&,0ɿ % xEE\IwZky&@V:YyD;XlNqQe(gֆ?Fj<.!gXjU :{͝sfq^yׂQNC`o΄ #5|bh5Ֆ9^Yz4j|dR"eG4ԮvNZ%Z=n ENtr~RbwQ-sA}Ĭ9fe0RrDKC$1"*J>]0BOzC^HomFW-AžF@~ʩ~550LΏ!A՘HjhW3 o^E= mq5GAk sblӡs<p̶_>be,mLte`!wFT˱Xvp bh2VL A߅Ak˱(yslWQn-&jɌ$͒֐hŦ[ITtC.3%h=vsokթ;,v_Q!Wis* #9dbMџjJ *VP`2iadfbm |[n't)lUaS2:^4ɕ4XhȍṫpDQHVOI:Q*9/8ȭLvr?v`m.>DtN ֮D~ h`Qww *iZڱYNW5U/d GވBô2EQ9_;R^o3̑a~˴8DY54d,)*:=@"ߤ/@洫(+.y Rk\fXUIL;m%T-hC EkߑmfijǸIlk %#m:4vb"+_8 D>6T9 8'_1M$6K÷iQ [ҝ;&Diy+O欺;Jmմ9oy#nNAce"YoY Ӳ}BSvIO`H<ijZq&lC'z] v1AG`:Qi(uηOtpfE_QgP#<$ dyz|L*qUka_K!&'Hs17U̖/ɔ&*CuFIЛϨ$?QEKQXnلd,fN͹^_U@rxB%S[Wj RY3Ib~?{cOYHX>u#bݖ`0o_LYV(#S0ĞfdwbMvEn]Db̮&):fΘi0AIyH9WI W (qxU Ht]R7[kXZ6] y&28A͇oo/F5vzCLϟh*zOAuayMuse|~5\IG(7t,_fs_1!XYyʀvXKݞhm18c[ZZۆ-jy ɱL_0LWff|ok,PC,2E.!܌54U#ɥ ;*&TC^K {C Aod@^ ׹:Oazoi  s EjGYeUEPII(-$0S*:hQW8ޱ$$ӂ9;j]YH~\Vܻ(x+/ZoEU#Pfer_)f9/׸Pe%qi&XtPxr]o$O;Aiv}]fu@脞eb p5󽒏>Y=;ڎPϗ!#}JIv0&~1;l~Y-"ɛ)I.5M_.BF/"9=.eHUϪ;:bv >\b2Vńg?DM#K˨!O]?'VrhkgA5|]L"p}kVwNdLH8b ;Yyr2|8EG} n !SVы v2G61OBuj|N}HH!F]&}A-PW9oCF]3ca<|Ry zbBM%qj-&xX'ikV{SN$u2SDwGv^mf WC.h:]=M&?G@hpWw^@r8ztGkwn ؿNԀiMpҹ>7grpnWozkKij9{ǷۤfAfꋬ1?NH>K\p $x4qs/]BkR-T5:˨o]Z Y~)ڱ&W}aeI'NDT'Zʺcn-LEX;DNzOeTl,\3>! kF˧J ЅmfM IH DqqX8<%KNĢv0MaVZ w'pqeF˅l h 5 !Mw! #UG.1(n"w пH^փɬ{ܲ6P #5%6aMJW5/bD{?7@tpR^R:ieE^X<:^0dkۀ> 6ͅ~u#]PMZ!wQ<:2Ȼ+3Csr ~n.LWMC& _~FY\ 1s`gs^d^|ZD#1$5IL0U<2oE" P;&Kkjg^f B[lN*OS'haR%NQ > 0/Ք # i_iC4cbӷB; W)\ 8y5223,Rf077ef=;V?9S%+=//4 <ʞjczd#(G~2;h 1=JV-xܹ C;IWFr{}ƴyi5xiOQ~V{|l[_T`uvmڟ{S+P?Bt76+&,_tB8Iֻ!8e')IdpޓT4O,s+| e*,Hl3V8A6rNd'b% }3Yq^UYǾշ]~y<XMVBw|A?NkINNU#бNU%S줧 ='~`E,CĩyLQw6*gPbsh?GNs[U֥^{ٵ)rEI',ĸY͇\ׄb"--<c=@sF/O,75= eI):;lCeN!_·5溙"IAAhU)"WǞ۽=;EYVD<Ͷ2ɻ;AVV<3`D \ բz؋JknAj([߼b0.C}SRabC[B%xz: ؜<B/O'R5 X9[_JQ>ӫgrXY!PN/~m7Ka&K| l5㹜̂r{}FcCT,W0)FQ=[%u6kLad|4GU-M-lN!ѵ5فroCtz_ AKR4G}kI jEe}$F_ Lj a\48ϻ~şpiR~nCHpqWr-DAlc풇d.PxL}u5fōvG^.in&b1,\25Mbd*gB4e?wv=R.:͞\ q/-\f7Nxv3mFCA3ĥ#9˄arKq|V)O@X-eg+whpDc4`}x4ˎf#SS.HʯNW7tȨ=;w*ZNqeC ʵS`|s9}0..!oւٿWA1fTڙz rdh+>  ż4yM}n诬tu$!x xo߂$#nzTw(x  u^1?&.'-ͺ1*$w`, TƲY"Zu&=ؠ۟Z!{T6c^巻 Le- Z0H]`#3"/ڪ5~Y9:-- tuhi#|ڿyۙ6`wD*`ȓ(!x2SW7 C43UdRLA% W (őm%19*V O LWbĔSMQjO[JH܀7꒠g"p]_Ф :caafwʨNlP%.E2'Ƃ9S=E?Yw|rN5s6 [eQ*dc=ȝt&ܞhs|e m>E7")ǪY¬͈KHv0?]{;p`%[sh֘'>׸=kG",0ߞYMD'^ֻ>3$tw~f3&B>>&fK|,>e`yFCFq*YV'a'O\WOg$ &^V=tCi&ͭ%cV9hC9:dmccmc;(A\9GN%XY:9"$%z(f<ށb{y3|. xh{קiZt aWG> D6~9Ko=0v[r 6H[fZw}ɐ1s`\3HV(Q&isW+o X ,K\-"vZaSko,(-c<)v&'gGehSPRv9H]^"$DT~va#* {n_mh?rpGP㡎s jz$I44:75p;fZHC0vk;VK:(܊ $jy.vS=&Jz0}OVl[@if D)P篋-$&ؔ Bbkĝz˜!Hbւc[TrA^<'StWtv+i2G___ uԃt"0<UHaGw[4dJhS bDG\Fo ,xt}rG߰vh\ENZWee>0q" ". FE߄Ϛ6 Ro3{uA0jX.~&ƳK(kˁԓs[qYp\}&42Lq=SoXu5لU:"02 2_!e m dKӗbsX9vדqziZy-P>I-?8ϸS(\ָ5Λ4(4;I`H>wtRgحl!nիuٱ1!?؟Tn 4n'2*ͪ~X2@+ %Aέ—PoMgDv?|vXvFɛ0'Z˳8і5}(crg=PbycĥYeĉBp#}oId&V~eXVc4Ĺay%{wㇺމ:SUmY Ѿ+PTncG-2&U9{OAk_C[S d^_Yx:!pdfћ8xʓ`ĢI+^-_$&8*]S4FOygx+R 4!Il\_iN}-ZV3`[Vp>(?nЋÊsWXHq! xreG@e޼gOc_}t Ν:^-v>v[+)gE\9ExT nH{ <Ʌ)$g >TyJWa9EL0( \aYм"\!8_X{za.g ,:&O=ٱcs*Kf gJT'r+?fޕQ2, ~>4Ś恉8_TS,=_C.ɦ8z& 8B]ẘ\J#Cݦ|+\ H\p"Μ/֠MVe,b!k\ ʥ1C,T.{7Qe?UzeNunSL.Vgl)R?:R?^VHv74{J gGξ @LqkdH/J&QsW,)Y*ة˘ 4C9s%mG7{;ˆ| VwɌR9jN! `&q62c@ Fc58K7<HjeI(52,pOUP -VڅKw!Af+t7Jh="[AAU琙#h3ΑqY!o~IRoN|0%'kRs X/u/ Oc9x ˎ^j(ėM6\ú^a)j8CNVLٽ,`LE,E=ƪDYu Bb<|xْQ >ޝJf*Y.CpB\p-i f(!gN;}u~2Gd ,S]J$AIR_ GeAڂ5mdj7|6PYP38XG=NԓNif={e¤[<Ƙazq4ܣs\p-%z_--j}r)p 3g!c 2nx!pwb;?׍W9٨BM*!tEݖ:X ^7 Bc9Otdk>XPM݁ǿabzklQ㋠AZEKX?Wyp!$ʪ8iG%RKHfM0W3l)8ó FԊ}{O3wPlT[cFHDKjQh؆>ӊLj%:amq]4Kkє?:/t- FwcyϸZC \_TxE )PŨ[tsLK~PL}+eD² ,-ϧ~ R7Moݯ|a7,9Gm)50zR}r!6+5H15`<;h -rQblſ~*| ĸh(

Į[͍R2قfm'_2DT81<*Dڝb`-44TZ0X?@Ulg cZqɣq|8Maq6U^NzʙҎ9+w"Cca`Cdz8iX_ќ ѧnd;8gڊX\Z`gw}}ѸabVݸl<AR&tNhV%BSB5 K4Wp gd,>dXf[@wﶩ_ @7![8ӗ|ǢYY쥇;pWR̞&z>=vzF sNbGBқ6Κ?f*dخ\oZsfdKJ2jq!? cDJ@.݈ h|6)XG_ @bpٮOC0I\}.]WrVCl՞qL;4f5yV+Q$N(Ǖ1gA}͍P*xuzju<{FAWd2PpFroq6:ZDQn `֚5*IAHšœP_Vec0dUM*LgGKTi g@* ;hN\--K6un5 mAFQU?6&x]W74.&y (dPI!rʣ$}UG a\΅zꨐ7./~SJ "I':ymUy*[ Á=izrEV!P֚4g 2fVla@wg kkj vNHci:6"f𕘙)9^ԓ b'7٤_i"%ZVxH!_ kb7:#J)s[ Cjl˦4T͢Wua¯=7wCof1/ X@>L7K_6FOxhuA1 V XceU$/KH\G”Nf-Ay)#9X8^^>)" ҪʬC="y6|\.a^PK6CO3d ZxV*2uQ1>4xp[\On&tl|o"O ݩZeTu"aŸl-2˒h{C!*w=T!}) 1WTPݏZ6~_Ѣ;&XbLOv- =$FC®KP!уnULJY FNuc΅8k`D*l;J*G1ؔ \.yh !rX4>\<X3ziᇰk/fP& K&g!>Sz}JzzJMulf u&Z456Mg3TX6W:%(~bqkG #k%` =SNjUY+͜um{b ?ίexKt{VK.몗'N$[ChP8>ÁY5Tԥ6b^zd#w-f@QBV_p wwI7[RCiQ/ERSerLR:26*T'_={`{gKT$4츮1vз}YH[\\s3Z p3;=@> \isiE+r?8JeVdPb} r61˺^PLmtctX\Ԡ bɍySX2PN2;oFub@{%d^tch yHÕڪczI{3Plk @1odo`y@a1?;>왆\C$wI jC^ ϔmHoiOkV˯u,pB 8"i7eq#HA{pm:} 6VϽ{;֔iߢz; a{{fN"1f-6AL;؟W0[Lc K1?:@|u/>eOtk|UcT6]9&x,idܑI<&XS?NǝMJbNfIR$r2=\PvtڑiN"9>oo|З'~Qh_,,)fDT S4∹3cyix&Sn/c7h GB/ty q&݂ "POCBͬФۄ(>^ҢH[ +킌EC)>TES`&B:7m:|,cr=E ]@Skpbi f4pƁy7ŌnߟOVmnwGaϸ?s\^V)Rn_L Og]oS ) ဉx,\}Ŋ>R9w7kŬMy\CpyDptjp{`FPTwC}ns.F--tI}oUԱiߧjF[sN{srqcz̢*F^\@".GL,KK2 !au^vl\jROHmg78zẍu'`r V\!*6Mۏ ᱕g9YFz(RzU(qYrr|PcxK)I15N}VPN&tȼW*9ڌy|߷ ,EرU/8Aj6`jB'G'fOM+7?oxbp'w,ieZ`'*9!ğ|{Rk;ll:OMQ܍7+kySɮNl;ɸ‰> w ZEyrB64B3,lxe$,%-]AFƃ% ^Q`s>[/ZxBvr2x57xv)Ii4,*CI[%L3Sq!ćz3M3sƘɘvAeg F%܅{#M O~Yy3sS 1n5Hlhu9kFOU",_> %Hv[j-V;[PW|"H,uF&-]wn>{_sm 7F(ٯŎ"-gD|ܞrc~]Q~T&^OU^Mn4{e?i`ŧh:oDy.u,X&Sռ(dӝn0~FɐCT= Œ ңmo3$Xf8f[*^! 9,}P& *jZb8㛞H8S]@\[ڑ:qb}sPkΈzV`CzJy1*? <ߑͥigQ j)- R&*XHW mtůlIJ陾0>hܤX}€&7<` 4·Y,ySǖPZMg_eG|m@5½uYpzךJ]n,7ֻDMii7 yB+OˆDE>b:xDQp]ʁTMyܿ3@.Nh͍5m(>n;C##j=(\(UL#=6; QӴt4VH Ud1A-Ofq Þ+ةmw?iU2v-L3%706]^.MЩkk%:{c1_:Dz&3(R(UØp^9%*8F6.j `R4KyLgcdo5yo8[p7b+ a}hQap@"x')7R)?(m@2*_Zqw:F( GmiJ)ЎTřk/º6M$ȵmM\Ҽ8 1 !-e(4<'i%0EYom,'ܮ\t#m/w&1<9WeQzrjiDL>Lh%i{*2݃:wjtRI9NA6vlRYY+ס^xGL3"N XL >e/V :tnT;ϕ.p"Q0%aM=kXV<-KˆtfgyB $Xr>[ #?-W,V"5 + +U6AV}\w%ƨDY_saK*8G-iUWC|S;;`mϒ_Yj3"oӶ+5Č`"tWu%2[Lw\$[6a0dnľN@бjDy[Ce,ND[f*,K4aI_^y.1a-5Js)|eĿ375)[ckkL^F̉$mO+*I`QdVLXKޟAlܗulZۥ_:+^N=yͯ|oiUgia)Ϲ7!Yv.5Ѥ4'y4?TMH&(y+UOΔW`Ƌe;u?`L4ԉ3puC-Jx3_*Z\XfԙHkkq-%AK$rwy]OBbtS\}dx͹3Ǎ@+cg4CЄα~'c%2>IoqהD(a`jy$\>*PԿ&./2&Y[Y&G8:pjj>DpARs^(>D_FُI,*1?0aL.9*aą<'UpuH~mDZʯ A6Iqdj/ s<5uT"nG)ߢC-T-C. EWWBx3N5ċkfgvb4`ٷ/;Aq^1S\aDU^h4@}{kŮV>!6mÞ0 y5qy/#Nin&Q !baEf t^nZ(N_yP4j+e\e4y>`Eh+BFd#~A<ч /=Tˣ=\ u&9x;l {Xx)o}hwlakM٦t)=]z3#[5Ɠb&f}|xA^TVGf'~N:Uُx׬8H h_$ BkvF.#fX"C-߬N&Z'uZcb+g1{nT=Y%z/?tMF%/b4zɋif c.}yH nnVq0I"(Veg'fnG6 wF>Rܗ" bu oz eŦ'²N/"m,@'.'ƕ,-_ @UcCe9'r6fs:93Zu-S)<9x DNm9?-ـ^eQS2ΤE<+h63|h\h佔heh$BYXHe#ub7-L F<Ֆk܏ְ}XW*3Łr i" R^62!hX9f~ЃarMAU>F:No儅7:X} E}Jk逢4G05 .أ Gn}rznR˖]/[6Mxs'yʞV.JmUؖ'K\c2oH`tŚ/8⯧ cMJ R.z QuiKk\ W#m#"-5P"E UuN022GhDqK7LΌW]~lZn QM:DfYdɝfO+WQG"xQSMA9t]ᚚWEVv'{8U8dG"yqNPN#6`_fS _Ϳ qh H$D6u&t; *֙7Ge`JO# ԕvO]Yg܇֜U#(j)T8!:@{<)Z^@Y4Hi #; >46L |/'/' clu6$[%ڑ1 uUekm,6-t6cWw3g׊Čn^@?bz+whӽYS}F\c.{ӟAREGLCa'O02WRBͩ [pM(Sh;O4|G{n$ vS 4=s(tn]g#$FdD١qЬ NMUa)K]+]C@2lɂ"ՉW#͜P*sA3;xәam1I04Ÿ5Y(Uh"EƸ4"%>%@=,S.|0ԭqiϕ,Bk?䖆2&maݢ"{s_.Ã;*fmPro z\%MF+,><4ʩkX|e9WK\1cO S!*k}3(^-,mCtbOnt'73;ۛF,Eħ?Yq\mj^Hp]{ U2w- :^̉٬”'T ۏ7䂬k5Az0U(H!~uU*%5g#8NVMgq }y11MzwYܹ 1|oPnD~Ar@l>!n$n !M#z4P1\ eʓ8-.+ ߞF[ZeֺOM%m`.L1~9(-{LKͼ>c7.Z$YhE>o'ϬCۃ;.= )᏿D`f_MԢm7oq@:S!h⼳FEU]%zv; N4I>1wu\0Tt~`ۥOMpP?D` |cꈒCGW\۹K&|skxE 8H,jhV X/x6_̐$/A5&ljYZ׺]l>Q}aY׮?~8DG>Iem6wJd+0g۷Pܲ%q Dlt.[n?Pb4mAi$cyضZD92ј#Xzˮ&lUyǡs&G<3Atet hRTg6N⥖;&v^ C| Ġҝ1? AO{A}C(_8>ePa; g{K59vDlH9w,Ź^q3VgH++Tk_k^ǘIQqG;@4+sO8Rr=}u_]4bΔE6wC r$~CgLA>$t^).*Oݡqj| U}3inj/} WHNP+LᚙyB;@rVռn&nYcC@srz##W]ڊRc@ЧUi`>Y^áBal|pjj\pNJo~ 4ǐ^@ _:J%UDxnCSsv5?fUb-d맫FŻ "q\HDX4^bJ6S^5a<Ò6k| i+xMMT\j$Re3q4EErNf׸8D$-!i:i]msvAH9#=ҽmR@\|*wt {'䬉ɑMXRTG3i/AS*<%@| nltGSs%LQ ;j} J[cQ&g^Zfz=v"U|>Fü\~tQ+mϴP5mw8F!.f7&ò| N^ }Rm,[Pſ'r[ =n[_t4[fa2r=EA 19p.3Z^\&=psΐUc v2 a&QWQ8giT1E FIErwM vR.)1e21ܗ"F#rf"^4X "0K&DaUѿwqY$tgAa/VA;&4/:~UJbc5QOwڴJS҆웪OVkJtlK9ujH$A\D|V[!˚:w|*c FΜL *=IB VL[GŢ_x2K0dt^xJ({7tlLM'ڋK,Bp y n1g )/\xZ-﬉闡GAo#xUǃd`j '.=Jfi+i)q|:ņDx`@@~z3ʠݷfH?y٩[:p }̙swKFT+Eb?"c2‚[2yoG4 \]brZ{/#eCBڳI^!gQ/%*8(!2}|'(Zb ̅dQ/Q˔Oo8qE,2^^ŀc{@rZw L3, 0P2BN'A8ѝ"_^oB[h.Y*\Cb;o93nܩcǖbi9ZgvdX -AjV[*(i9 ͟Fְs] bFpaJ^ V6'?owd*TYT+(֒Dqҁ}#:b?o]+@"\Z%vo4l94*$3=CoM/;ȇ F~RkglV_Mǹ}#V&\[ndVtx2m|7XrDu _{+S]+і47 9NTk.sL5We곷yEhp b,S4C s r-(Y}ρ*H鉃 *k⢉F{o>S2([{8s;"n+КO3NFiGFVZ Bs9Ky!;):i7M3V$d]=sօgF;ž U p[oGN7N^bqYBV+!&4OIZEсmr.PCٯO [Q{!]&E@ƽAΔwFvUKH;y;p)$IO#ᪿK&ە;fՓ$j\D :`m 2-J4dJ )gS p!%h9$QIa)%ov6# ra(l8Sa#xKd=h`2Gw"J@,2u%=d61R>^мE@78LenA!@eShRڢ=/+4ws)nNÄg*.j⾚ ެIDxαLjs߫bܼF߿ʒ?e iId$蚳[#Yzp.:efC8bQ@WLrtehd{L)Q5 *0e{ŎRPY֊aAXyQ=9M_)WVud(MQ$]Ӑ0jp?A$R}޸:kq u&9a,)Iͬ< 2-#ŰځbF4ʦQy@ݻǏlV0ל1]u:T)<\: j=11z5Ty81*Z9j];f~CO />&{#0V"> ^|=ܑ'&[|އi dv,ϗH nHnA}G%+"<wϿxV{ P)7SN_=˫ӊ&uZ5>U˯swVa["F:Enn. 2J;ζQG^v Y#QdUN=D$QBRoEx=KA2(^Zt1<* DA6j+R6.oZ(bǘ1Yj9]"V&w?!%ADJ129dV4{\3mC!:P,ӏ !tl H+8g2wM o[*AֽMRӘ湓 16Dr޽" Rѭ(} &hKt7[,{l0KZG+F dTS%%ylu- t{/*[" i~_%ڵ&+a۟-o9aTĆ imn_%O*r]va{ E}IL+5\ѹ4nN c\iUV9vDlIm"h¶^4\5Qg6~r$ m4" rAڵ:&%@]rT LDxc_ekς 5ߞX4lg"> nLV)8%ENe"w)/V`˸.ɟE%ump艚)>+[$` w&L}K!;!0Q,G2Ќ"f& c=^BM7٪[% *-޶z:q*a/x^NKlj <<ʒv/*ozVnG|.n"n0{6nfAfw#1<|q.LsC@G:=Nz HT,[kt dq0dr85_| .cq˫ ].X-pU81t&اQ0`C֐T8Kg4.E嶺4Pl֚QyJ wq.<X~Oig\T-7tګ.Z>gyGwQD>X)HCTFc3:Su MS_{R|ϵyhjS*h槛%B/'6Ԏ\xvqR#^J"J/Ij!j<$;#Bi*JG\NgͬoY'u:1G,=Frj\Vl^Q &>̔*ǗH[(.-\঵BLS*q@ퟨ7|T=ͨcǃa<-_G(֋I/;~Ir*C& fsSJUպLL5a,Uݵr= 8D_B"l ܤS)^000kygOiJ,-끚ȔPS*hlY\'cg<sn-(oAFux}y\Iє96.ة`glhx3a{@_8`k 1 i Mc@ t$|rڮ0 _<{J EgZƑ)\ = D:F-0z, 10Ԭ;a:+(و~~ k Ok2VQ4]ŷΫ|PƑ:YJ0v8_J'@8 m6k0cF]=XIgߙO<'d^`Pdħ0)ph:8;ՑdE\MAaJ)(MeSVIQqi~kw\L5ɥ`9E?3>VF|adEt6M64W#E# 1o\9D<ZQ)ޣ1q`" n.n}4PK$"Swn98\i}0E<.޴]5IvZ(Qpc&d]dʪ~E1]R#3$?miIY= 0<7P7&\ʪ4\ȔDȴ+/9n.͹DpuCο"T:ܦ(1+ cE {}CC \2f ډ`!K}I`Ɠ)>x—Usڡ@BoY~1 ] e7BMW~}fְ.`c1111EѰt 2Ot_v%bzЋ9' qހƴ%iȐbL :"Wsm%(B}3`KP|ݖ|'7Ñ԰U^"8dy h\Vrvv:[P4v1d~D$cg2PCxq-JB62Nt}ȪհSSxc @D4YbHw+pyId'+7bH ퟅ-̾E=Q .!uG$oRލe ^Z|Ɍk,?'HŽk*IgA݅冻j }pD9i"%^鵯?]ġF,ahKr'2&y?V2[ 92V>MFŝ{>Px&?AچJ8 śE}mWLtW W$U'fwܹj>tݏe7ZV WDiq`A 'B[ ӝIGܠD:o~+aضBR@~#-Z]"C\Wz foͼzgu9O|tB廒8Nu  P낮0A8K@B+7^}V L|x#565?<@鷬{$}csf.FL٤@&G#/>!7ny- :Lf&$+薉; VZ LsaHKeXq\4 _^yG>Sa$f! r/gnгD"3`$b-`Q8BW\8i9O [O?>t\ 'cM9$2{ $ [gD=6zrX_)^)k*~S$/FRӋy mM0w0iH%s _C2*}B"5/֬`Sx 7[~88T(C/I1f@c,;DǺ1kd<14igvC 5jFYsn<Βb٭j?H6K ~ R!p|-}5Nɪ .) YZ