cryptsetup-2.0.6-lp152.4.3.1<>,qD_a-縋/=„n t0xih^{yVc?3 PuE>|.l>8/0N_&HU[9gZD<ru9 Z?0$(.CcR,p~Ͻ(C{禅!)~ R #Xgk͞@jT=q*e>?s)u?ޙ4VNt}.'D?d   M =CH$lGG G G G G dGGGFlG"0" "(!8!$9!`:">v@vFvGvGHwGIxGXyXYy`\yG]zG^Fbcd=eBfElGuXGvt wGxGyXzt)48>Ccryptsetup2.0.6lp152.4.3.1Set Up dm-crypt Based Encrypted Block Devicescryptsetup is used to conveniently set up dm-crypt based device-mapper targets. It allows to set up targets to read cryptoloop compatible volumes as well as LUKS formatted ones. The package additionally includes support for automatically setting up encrypted volumes at boot time via the config file /etc/crypttab._a-build70+openSUSE Leap 15.2openSUSESUSE-GPL-2.0-with-openssl-exception AND LGPL-2.0-or-laterhttp://bugs.opensuse.orgSystem/Basehttps://gitlab.com/cryptsetup/cryptsetup/linuxi586 mkdir -p /run/regenerate-initrd/ touch /run/regenerate-initrd/all [ -z "${TRANSACTIONAL_UPDATE}" -a -x /usr/bin/systemd-tmpfiles ] && /usr/bin/systemd-tmpfiles --create /usr/lib/tmpfiles.d/cryptsetup.conf || : mkdir -p /run/regenerate-initrd/ touch /run/regenerate-initrd/all# LfIrjodgN i:y^ 7!%9C E  [+AhG729#:EBlB8GH-G17XmGMJ @A큤_a-_a-_a-_a-_a-_a-_a-_a-S}O1d`PȈZt{[TV̋VZt{O1d`O1d`O1d`O1d`O1d`O1d`Zt{O1d`Zt{O1d`OSO&O [P}Pa)QNS$S$S$SS UCVN)WʈW,W,YYYZt{Zt{[T[T[U[A\_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-_a-d6bb4b689200c2348945700a6b0dad5df92bc2015860d15f36a25590814d77b0c16551123520e3ae30da7e3a862ec7e8f1bb88eb06ca42d9bc7da970e9e4a6b34969feaad2d0400ba5a18fe440da61f417e7235ed4e156cea434b71439739ae62194fd260fd3caf96ccc9993ac9b92e8315d053f0b427e4a932356bff9444d30d636dd6e2e836138d72bd10edfdd19470ab4dd105288fcfa3519460b9e29a518a7837aee5b822c01c64b81517b071218874aec603ad6624f3f559c2dd6a8ca1245670cce8b6a0ddd66c8016cd8ccef6cd71f35717cbacc7f1e895b3855207b338c33cc37871654ec7ed87e6fbb896c8cf33ef5ef05b1611a5aed857596ffafa5c0c35222dd8552610cb4f1d1559e6b09c8ea04b1888d25202787772f1332dfab88139e083bd0d541f2d25a13da34c797a57e3ab3dc8cdc29783f611dc5a7ec7f3fe9c1111453360d298c1a4afda5f84aebde925fa164cc30e14c8d31e4686ba7325800b1569fc977bde2337bffdd20077a5b5dd98f172c944e32b75a19556e3504505ff6feb42cb3fc27cd79c52b0a8dd446ebac636db57e47b466f2fb6f870e0b3b98db51402d5c6b54a76f049fe834f385bb0a81a195148c217776c29abb2885f985ae4dd6fa76e34b4abff697d973821ac6bb255e00ec8844fbf9fd7d936c0db4517a88ecd842a1ea48360c45563ef051ba71d51d6e5d40e240516536d8b7972e5fc2fc53522a41cf685cde1ed92ab42df50f608dad44b533a20d1468ba2ae01c5c98071c7c98d4d62b7af278c2c3c38a89a9f2aea7811e8078f34a6eaa99f921b65038a98a6281769a64e90528394c11e9f58978945cfbf058bd72d251bbd9f325cc7b69e35a3235b851f6e3d8db5d01d717afac72ba452ddca753be93df085ea8c727c1487e11b032c9357a5187ec8ef86d16f0bbb3d8f357ad4cf780c425b2628be5d85dad2656f925cee0b464f53c3a669223fb6a43dc581a27fbbbc5f6e280116a8aa26191a7f768e9dab9d82735c4b48a4aad0824763d081418a034a40f6b268b8cfbabdfe510845bf2de9d20af02dc914a3eebfc7bab6697989cc85e43b39da1f941f335b5137c8b33216f3665f2df5b74a2186760d518babfcddf758112ba6c3946c2b6fa183d6a3662b3b34c09ebb40140613400e779506f22b7e005ddf07eb9e34df8ddfb5a6b053e7f1a57b4e44ebebf4c14ad2725bc3c40790fdac009890d44f3383abd33132f3f6e5e2114b5cc22df9a8b90cff57b061562ae48b74ffa53d0870533233fd1052e3f707216cf5f4f5941b0a67a5fc4a061e9d198ff7ffb01319f58779842a605461416c316bdf058e6e9091be4a69251bfe3556c7156ea0bfcd002f24822c0ba3cdd2cebfa9dc6b2463fe259b455c858bd7ebe5988a8fa6a4715c6bd4115489dbbc697f5a5b34058fc475b7c0db7f5faa108eefef8259641d4e435288c77eaa861163c2ce048a82cac90d17ddaa9adefe6a0b0f5fd155f4a31e4b4c3b3a31833d66f425462368041359d6a3165839ba3d51ee8b791da4adbf42e9b8aecd710112cf0a60bc6f9dcfa2f9caf91dcd6559d630eff407694c22b8a7f3217e5987a59b232ca2c7ea4cd3014c1c5fd4c941b0b767fd8d3246cbf48031d37564c8e6b56394dfbce815f6977954291049b53e440d880b42705939d9a513836df7abf4ffa7155ff9a1d2b1cf4c132390aaaa81594537ebee834ef41dd79e3430310491ccd9afd39971af54a580151557aaa9b9b822912260109b314fec98a14b4e525681877a2205703f005ca6aa56ae54a692356508326d024e1af8779187808b94aac22d36fd2b16c1be1f9bd7062999e28638cf4bd50f9c18e06632bc8660889bf0f45d52f09d6491d5291fe8619b329f6495be879093e92fb88c7c771bc0ba7da4f99386c80e0da2637249fe7fd99a57966d1d1e20dfae75a4967bd4676a882e6c13c121806f093d7e9426ce22275f598942b4fb7509951305b214b8b8f847e4ba4b26a3d9654105680cc2e7fdadd4c5c2260b6e19016a7ba548ea78bb8c562a4a1c68753bcab7104110d3df6fa239d54bdd8edc6c165c348ead91ad0e6ceea6aaeea0f71128d8187b4583eef22f3f3eba95a642bb9587909ff0eca1c2951afba46b0197f4b7c5428eb5a85bf730e9f756aa2859346bfac37373701233a0d60fc6055f3d94da49c03a7882fd3d498632d70fbd6c0db57c57bc6bb35165258f3094e6227ebd11ab04a423070437690cd7a10bd4beb2dadd3e165c2ccd25cf91e8ce7e784371b2bde24e653d327836fb9ae76a570c4edb3a5f064177cde8ff10f6821c0ab1a898ef8ae884a02b0187ff705b250d4fa28d6b0210e7f4be1b259e383b56c44d6804f1221f61ed9afbefa1260671ee6e5493d8817804337c65cbb008a0583c1e56c4fdf52e00df2cb7141d9f14da19fdc7cfb80aed1ddd3710b56a6fa11e3d75c1fe793607d2e1d40c3447841d2a38070b848577f15beda8f85f109797aaa84ed5598f689b8f2c5655476ea40fcbe39543dac3c60327202ef6c8e1c0cd266ffe5f0d8dd8f659acfd959007dea7523e2ce949e969070e9328a07a1f6782a2372d61617293bc2b63d030508feef745d3bb439dfa257ec847dcd8843f8ed9610d6554b0eecc710f1cf25157cf1e2f519edcee21f668b783ba516abab22b0260ca4d967ca0485c93b1fed3018ab6c198e35d26734441749d39cc683b0dcacc7ba8ec731db802a527e44fe8eebe0071e84381a2f531298c3ce3d62bb94cf1d6a958de66ad89229aef7bcc80bf1fea19948cf76f617380006fe6fc0c934f96dfd6042ab8347838391dbfc41b755166bfac7b0d587c829da4ce51f1987586e43e06e627557c0cfed351c4ee114657e50063eda1d826a24f6a134a822bd0091b1c21e728006b98f564d00d1248ab1032d211023d85b05feda20fd3decee4c2332e01ce5cc25c553a23ab055b2e7fa8cc2e61ef772b4589415b4d58d00dff388770227c8fa8793ba38680516d9a67bd4dbd20b90335d5af10a92dd5123351dea5fb070ab6bbe0f6b613355eb8356b5cc5bf8316ce6/usr/sbin/cryptsetup@rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootcryptsetup-2.0.6-lp152.4.3.1.src.rpmcryptsetupcryptsetup(x86-32) @@@@@@@@@@@@@@@@@@@@@@@@@    /bin/sh/bin/sh/bin/shcoreutilscoreutilslibblkid.so.1libblkid.so.1(BLKID_2.15)libblkid.so.1(BLKID_2.17)libblkid.so.1(BLKID_2.21)libc.so.6libc.so.6(GLIBC_2.0)libc.so.6(GLIBC_2.1)libc.so.6(GLIBC_2.1.3)libc.so.6(GLIBC_2.15)libc.so.6(GLIBC_2.2)libc.so.6(GLIBC_2.25)libc.so.6(GLIBC_2.3)libc.so.6(GLIBC_2.3.3)libc.so.6(GLIBC_2.3.4)libc.so.6(GLIBC_2.4)libc.so.6(GLIBC_2.7)libc.so.6(GLIBC_2.8)libcryptsetup.so.12libcryptsetup.so.12(CRYPTSETUP_2.0)libpopt.so.0libpopt.so.0(LIBPOPT_0)libpwquality.so.1libpwquality.so.1(LIBPWQUALITY_1.0)libuuid.so.1libuuid.so.1(UUID_1.0)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.0.4-14.6.0-14.0-15.2-14.14.1]@[G[G[{Zp^@Zlnussel@suse.delnussel@suse.delnussel@suse.deastieger@suse.comarchie.cobbs@gmail.commpluskal@suse.commpluskal@suse.comalexander_naumov@opensuse.orgbenoit.monin@gmx.frtiwai@suse.deasterios.dramis@gmail.comcrrodriguez@opensuse.orgcrrodriguez@opensuse.orgmpluskal@suse.com- New version 2.0.6 (jsc#SLE-5911, bsc#1165580): Changes since version 2.0.5 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Fix support of larger metadata areas in LUKS2 header. This release properly supports all specified metadata areas, as documented in LUKS2 format description (see docs/on-disk-format-luks2.pdf in archive). Currently, only default metadata area size is used (in format or convert). Later cryptsetup versions will allow increasing this metadata area size. * If AEAD (authenticated encryption) is used, cryptsetup now tries to check if the requested AEAD algorithm with specified key size is available in kernel crypto API. This change avoids formatting a device that cannot be later activated. For this function, the kernel must be compiled with the CONFIG_CRYPTO_USER_API_AEAD option enabled. Note that kernel user crypto API options (CONFIG_CRYPTO_USER_API and CONFIG_CRYPTO_USER_API_SKCIPHER) are already mandatory for LUKS2. * Fix setting of integrity no-journal flag. Now you can store this flag to metadata using --persistent option. * Fix cryptsetup-reencrypt to not keep temporary reencryption headers if interrupted during initial password prompt. * Adds early check to plain and LUKS2 formats to disallow device format if device size is not aligned to requested sector size. Previously it was possible, and the device was rejected to activate by kernel later. * Fix checking of hash algorithms availability for PBKDF early. Previously LUKS2 format allowed non-existent hash algorithm with invalid keyslot preventing the device from activation. * Allow Adiantum cipher construction (a non-authenticated length-preserving fast encryption scheme), so it can be used both for data encryption and keyslot encryption in LUKS1/2 devices. For benchmark, use: [#] cryptsetup benchmark -c xchacha12,aes-adiantum [#] cryptsetup benchmark -c xchacha20,aes-adiantum For LUKS format: [#] cryptsetup luksFormat -c xchacha20,aes-adiantum-plain64 -s 256 The support for Adiantum will be merged in Linux kernel 4.21. For more info see the paper https://eprint.iacr.org/2018/720.- Suggest hmac package (boo#1090768) - remove old upgrade hack for upgrades from 12.1 - New version 2.0.5 Changes since version 2.0.4 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Wipe full header areas (including unused) during LUKS format. Since this version, the whole area up to the data offset is zeroed, and subsequently, all keyslots areas are wiped with random data. This ensures that no remaining old data remains in the LUKS header areas, but it could slow down format operation on some devices. Previously only first 4k (or 32k for LUKS2) and the used keyslot was overwritten in the format operation. * Several fixes to error messages that were unintentionally replaced in previous versions with a silent exit code. More descriptive error messages were added, including error messages if - a device is unusable (not a block device, no access, etc.), - a LUKS device is not detected, - LUKS header load code detects unsupported version, - a keyslot decryption fails (also happens in the cipher check), - converting an inactive keyslot. * Device activation fails if data area overlaps with LUKS header. * Code now uses explicit_bzero to wipe memory if available (instead of own implementation). * Additional VeraCrypt modes are now supported, including Camellia and Kuznyechik symmetric ciphers (and cipher chains) and Streebog hash function. These were introduced in a recent VeraCrypt upstream. Note that Kuznyechik requires out-of-tree kernel module and Streebog hash function is available only with the gcrypt cryptographic backend for now. * Fixes static build for integritysetup if the pwquality library is used. * Allows passphrase change for unbound keyslots. * Fixes removed keyslot number in verbose message for luksKillSlot, luksRemoveKey and erase command. * Adds blkid scan when attempting to open a plain device and warn the user about existing device signatures in a ciphertext device. * Remove LUKS header signature if luksFormat fails to add the first keyslot. * Remove O_SYNC from device open and use fsync() to speed up wipe operation considerably. * Create --master-key-file in luksDump and fail if the file already exists. * Fixes a bug when LUKS2 authenticated encryption with a detached header wiped the header device instead of dm-integrity data device area (causing unnecessary LUKS2 header auto recovery).- make parallell installable version for SLE12- New version 2.0.4 Changes since version 2.0.3 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Use the libblkid (blockid) library to detect foreign signatures on a device before LUKS format and LUKS2 auto-recovery. This change fixes an unexpected recovery using the secondary LUKS2 header after a device was already overwritten with another format (filesystem or LVM physical volume). LUKS2 will not recreate a primary header if it detects a valid foreign signature. In this situation, a user must always use cryptsetup repair command for the recovery. Note that libcryptsetup and utilities are now linked to libblkid as a new dependence. To compile code without blockid support (strongly discouraged), use --disable-blkid configure switch. * Add prompt for format and repair actions in cryptsetup and integritysetup if foreign signatures are detected on the device through the blockid library. After the confirmation, all known signatures are then wiped as part of the format or repair procedure. * Print consistent verbose message about keyslot and token numbers. For keyslot actions: Key slot unlocked/created/removed. For token actions: Token created/removed. * Print error, if a non-existent token is tried to be removed. * Add support for LUKS2 token definition export and import. The token command now can export/import customized token JSON file directly from command line. See the man page for more details. * Add support for new dm-integrity superblock version 2. * Add an error message when nothing was read from a key file. * Update cryptsetup man pages, including --type option usage. * Add a snapshot of LUKS2 format specification to documentation and accordingly fix supported secondary header offsets. * Add bundled optimized Argon2 SSE (X86_64 platform) code. If the bundled Argon2 code is used and the new configure switch - -enable-internal-sse-argon2 option is present, and compiler flags support required optimization, the code will try to use optimized and faster variant. Always use the shared library (--enable-libargon2) if possible. This option was added because an enterprise distribution rejected to support the shared Argon2 library and native support in generic cryptographic libraries is not ready yet. * Fix compilation with crypto backend for LibreSSL >= 2.7.0. LibreSSL introduced OpenSSL 1.1.x API functions, so compatibility wrapper must be commented out. * Fix on-disk header size calculation for LUKS2 format if a specific data alignment is requested. Until now, the code used default size that could be wrong for converted devices. Changes since version 2.0.2 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Expose interface to unbound LUKS2 keyslots. Unbound LUKS2 keyslot allows storing a key material that is independent of master volume key (it is not bound to encrypted data segment). * New API extensions for unbound keyslots (LUKS2 only) crypt_keyslot_get_key_size() and crypt_volume_key_get() These functions allow to get key and key size for unbound keyslots. * New enum value CRYPT_SLOT_UNBOUND for keyslot status (LUKS2 only). * Add --unbound keyslot option to the cryptsetup luksAddKey command. * Add crypt_get_active_integrity_failures() call to get integrity failure count for dm-integrity devices. * Add crypt_get_pbkdf_default() function to get per-type PBKDF default setting. * Add new flag to crypt_keyslot_add_by_key() to force update device volume key. This call is mainly intended for a wrapped key change. * Allow volume key store in a file with cryptsetup. The --dump-master-key together with --master-key-file allows cryptsetup to store the binary volume key to a file instead of standard output. * Add support detached header for cryptsetup-reencrypt command. * Fix VeraCrypt PIM handling - use proper iterations count formula for PBKDF2-SHA512 and PBKDF2-Whirlpool used in system volumes. * Fix cryptsetup tcryptDump for VeraCrypt PIM (support --veracrypt-pim). * Add --with-default-luks-format configure time option. (Option to override default LUKS format version.) * Fix LUKS version conversion for detached (and trimmed) LUKS headers. * Add luksConvertKey cryptsetup command that converts specific keyslot from one PBKDF to another. * Do not allow conversion to LUKS2 if LUKSMETA (external tool metadata) header is detected. * More cleanup and hardening of LUKS2 keyslot specific validation options. Add more checks for cipher validity before writing metadata on-disk. * Do not allow LUKS1 version downconversion if the header contains tokens. * Add "paes" family ciphers (AES wrapped key scheme for mainframes) to allowed ciphers. Specific wrapped ley configuration logic must be done by 3rd party tool, LUKS2 stores only keyslot material and allow activation of the device. * Add support for --check-at-most-once option (kernel 4.17) to veritysetup. This flag can be dangerous; if you can control underlying device (you can change its content after it was verified) it will no longer prevent reading tampered data and also it does not prevent silent data corruptions that appear after the block was once read. * Fix return code (EPERM instead of EINVAL) and retry count for bad passphrase on non-tty input. * Enable support for FEC decoding in veritysetup to check dm-verity devices with additional Reed-Solomon code in userspace (verify command). Changes since version 2.0.1 ~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Fix a regression in early detection of inactive keyslot for luksKillSlot. It tried to ask for passphrase even for already erased keyslot. * Fix a regression in loopaesOpen processing for keyfile on standard input. Use of "-" argument was not working properly. * Add LUKS2 specific options for cryptsetup-reencrypt. Tokens and persistent flags are now transferred during reencryption; change of PBKDF keyslot parameters is now supported and allows to set precalculated values (no benchmarks). * Do not allow LUKS2 --persistent and --test-passphrase cryptsetup flags combination. Persistent flags are now stored only if the device was successfully activated with the specified flags. * Fix integritysetup format after recent Linux kernel changes that requires to setup key for HMAC in all cases. Previously integritysetup allowed HMAC with zero key that behaves like a plain hash. * Fix VeraCrypt PIM handling that modified internal iteration counts even for subsequent activations. The PIM count is no longer printed in debug log as it is sensitive information. Also, the code now skips legacy TrueCrypt algorithms if a PIM is specified (they cannot be used with PIM anyway). * PBKDF values cannot be set (even with force parameters) below hardcoded minimums. For PBKDF2 is it 1000 iterations, for Argon2 it is 4 iterations and 32 KiB of memory cost. * Introduce new crypt_token_is_assigned() API function for reporting the binding between token and keyslots. * Allow crypt_token_json_set() API function to create internal token types. Do not allow unknown fields in internal token objects. * Print message in cryptsetup that about was aborted if a user did not answer YES in a query.- update to 2.0.1: * To store volume key into kernel keyring, kernel 4.15 with dm-crypt 1.18.1 is required * Increase maximum allowed PBKDF memory-cost limit to 4 GiB * Use /run/cryptsetup as default for cryptsetup locking dir * Introduce new 64-bit byte-offset *keyfile_device_offset functions. * New set of fucntions that allows 64-bit offsets even on 32bit systems are now availeble: - crypt_resume_by_keyfile_device_offset - crypt_keyslot_add_by_keyfile_device_offset - crypt_activate_by_keyfile_device_offset - crypt_keyfile_device_read The new functions have added the _device_ in name. Old functions are just internal wrappers around these. * Also cryptsetup --keyfile-offset and --new-keyfile-offset now allows 64-bit offsets as parameters. * Add error hint for wrongly formatted cipher strings in LUKS1 and properly fail in luksFormat if cipher format is missing required IV.- Update to version 2.0.0: * Add support for new on-disk LUKS2 format * Enable to use system libargon2 instead of bundled version * Install tmpfiles.d configuration for LUKS2 locking directory * New command integritysetup: support for the new dm-integrity kernel target * Support for larger sector sizes for crypt devices * Miscellaneous fixes and improvements- Update to version 1.7.5: * Fixes to luksFormat to properly support recent kernel running in FIPS mode (bsc#1031998). * Fixes accesses to unaligned hidden legacy TrueCrypt header. * Fixes to optional dracut ramdisk scripts for offline re-encryption on initial boot.- Update to version 1.7.4: * Allow to specify LUKS1 hash algorithm in Python luksFormat wrapper. * Use LUKS1 compiled-in defaults also in Python wrapper. * OpenSSL backend: Fix OpenSSL 1.1.0 support without backward compatible API. * OpenSSL backend: Fix LibreSSL compatibility. * Check for data device and hash device area overlap in veritysetup. * Fix a possible race while allocating a free loop device. * Fix possible file descriptor leaks if libcryptsetup is run from a forked process. * Fix missing same_cpu_crypt flag in status command. * Various updates to FAQ and man pages. - Changes for version 1.7.3: * Fix device access to hash offsets located beyond the 2GB device boundary in veritysetup. * Set configured (compile-time) default iteration time for devices created directly through libcryptsetup * Fix PBKDF2 benchmark to not double iteration count for specific corner case. * Verify passphrase in cryptsetup-reencrypt when encrypting a new drive. * OpenSSL backend: fix memory leak if hash context was repeatedly reused. * OpenSSL backend: add support for OpenSSL 1.1.0. * Fix several minor spelling errors. * Properly check maximal buffer size when parsing UUID from /dev/disk/.- Update to version 1.7.2: * Update LUKS documentation format. Clarify fixed sector size and keyslots alignment. * Support activation options for error handling modes in Linux kernel dm-verity module: - -ignore-corruption - dm-verity just logs detected corruption - -restart-on-corruption - dm-verity restarts the kernel if corruption is detected If the options above are not specified, default behavior for dm-verity remains. Default is that I/O operation fails with I/O error if corrupted block is detected. - -ignore-zero-blocks - Instructs dm-verity to not verify blocks that are expected to contain zeroes and always return zeroes directly instead. NOTE that these options could have security or functional impacts, do not use them without assessing the risks! * Fix help text for cipher benchmark specification (mention --cipher option). * Fix off-by-one error in maximum keyfile size. Allow keyfiles up to compiled-in default and not that value minus one. * Support resume of interrupted decryption in cryptsetup-reencrypt utility. To resume decryption, LUKS device UUID (--uuid option) option must be used. * Do not use direct-io for LUKS header with unaligned keyslots. Such headers were used only by the first cryptsetup-luks-1.0.0 release (2005). * Fix device block size detection to properly work on particular file-based containers over underlying devices with 4k sectors. - Update to version 1.7.1: * Code now uses kernel crypto API backend according to new changes introduced in mainline kernel While mainline kernel should contain backward compatible changes, some stable series kernels do not contain fully backported compatibility patches. Without these patches most of cryptsetup operations (like unlocking device) fail. This change in cryptsetup ensures that all operations using kernel crypto API works even on these kernels. * The cryptsetup-reencrypt utility now properly detects removal of underlying link to block device and does not remove ongoing re-encryption log. This allows proper recovery (resume) of reencrypt operation later. NOTE: Never use /dev/disk/by-uuid/ path for reencryption utility, this link disappears once the device metadata is temporarily removed from device. * Cryptsetup now allows special "-" (standard input) keyfile handling even for TCRYPT (TrueCrypt and VeraCrypt compatible) devices. * Cryptsetup now fails if there are more keyfiles specified for non-TCRYPT device. * The luksKillSlot command now does not suppress provided password in batch mode (if password is wrong slot is not destroyed). Note that not providing password in batch mode means that keyslot is destroyed unconditionally.- update to 1.7.0: * The cryptsetup 1.7 release changes defaults for LUKS, there are no API changes. * Default hash function is now SHA256 (used in key derivation function and anti-forensic splitter). * Default iteration time for PBKDF2 is now 2 seconds. * Fix PBKDF2 iteration benchmark for longer key sizes. * Remove experimental warning for reencrypt tool. * Add optional libpasswdqc support for new LUKS passwords. * Update FAQ document.- Fix missing dependency on coreutils for initrd macros (boo#958562) - Call missing initrd macro at postun (boo#958562)- Update to 1.6.8 * If the null cipher (no encryption) is used, allow only empty password for LUKS. (Previously cryptsetup accepted any password in this case.) The null cipher can be used only for testing and it is used temporarily during offline encrypting not yet encrypted device (cryptsetup-reencrypt tool). Accepting only empty password prevents situation when someone adds another LUKS device using the same UUID (UUID of existing LUKS device) with faked header containing null cipher. This could force user to use different LUKS device (with no encryption) without noticing. (IOW it prevents situation when attacker intentionally forces user to boot into different system just by LUKS header manipulation.) Properly configured systems should have an additional integrity protection in place here (LUKS here provides only confidentiality) but it is better to not allow this situation in the first place. (For more info see QubesOS Security Bulletin QSB-019-2015.) * Properly support stdin "-" handling for luksAddKey for both new and old keyfile parameters. * If encrypted device is file-backed (it uses underlying loop device), cryptsetup resize will try to resize underlying loop device as well. (It can be used to grow up file-backed device in one step.) * Cryptsetup now allows to use empty password through stdin pipe. (Intended only for testing in scripts.)- Enable verbose build log.- regenerate the initrd if cryptsetup tool changes (wanted by 90crypt dracut module)- Update to 1.6.7 * Cryptsetup TCRYPT mode now supports VeraCrypt devices (TrueCrypt extension) * Support keyfile-offset and keyfile-size options even for plain volumes. * Support keyfile option for luksAddKey if the master key is specified. * For historic reasons, hashing in the plain mode is not used if keyfile is specified (with exception of --key-file=-). Print a warning if these parameters are ignored. * Support permanent device decryption for cryptsetup-reencrypt. To remove LUKS encryption from a device, you can now use - -decrypt option. * Allow to use --header option in all LUKS commands. The - -header always takes precedence over positional device argument. * Allow luksSuspend without need to specify a detached header. * Detect if O_DIRECT is usable on a device allocation. There are some strange storage stack configurations which wrongly allows to open devices with direct-io but fails on all IO operations later. * Add low-level performance options tuning for dmcrypt (for Linux 4.0 and later). * Get rid of libfipscheck library. (Note that this option was used only for Red Hat and derived distributions.) With recent FIPS changes we do not need to link to this FIPS monster anymore. Also drop some no longer needed FIPS mode checks. * Many fixes and clarifications to man pages. * Prevent compiler to optimize-out zeroing of buffers for on-stack variables. * Fix a crash if non-GNU strerror_r is used./bin/sh/bin/shbuild70 1600204263  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGcsdadeesfifriditnlplptsrsvukvizh2.0.6-lp152.4.3.12.0.6-lp152.4.3.1 cryptsetupcryptsetupcryptsetup.confcryptsetupcryptsetup-reencryptintegritysetupveritysetupcryptsetupAUTHORSCOPYINGCOPYING.LGPLChangeLog.oldFAQREADMETODOv1.0.7-ReleaseNotesv1.1.0-ReleaseNotesv1.1.1-ReleaseNotesv1.1.2-ReleaseNotesv1.1.3-ReleaseNotesv1.2.0-ReleaseNotesv1.3.0-ReleaseNotesv1.3.1-ReleaseNotesv1.4.0-ReleaseNotesv1.4.1-ReleaseNotesv1.4.2-ReleaseNotesv1.4.3-ReleaseNotesv1.5.0-ReleaseNotesv1.5.1-ReleaseNotesv1.6.0-ReleaseNotesv1.6.1-ReleaseNotesv1.6.2-ReleaseNotesv1.6.3-ReleaseNotesv1.6.4-ReleaseNotesv1.6.5-ReleaseNotesv1.6.6-ReleaseNotesv1.6.7-ReleaseNotesv1.6.8-ReleaseNotesv1.7.0-ReleaseNotesv1.7.1-ReleaseNotesv1.7.2-ReleaseNotesv1.7.3-ReleaseNotesv1.7.4-ReleaseNotesv1.7.5-ReleaseNotesv2.0.0-ReleaseNotesv2.0.1-ReleaseNotesv2.0.2-ReleaseNotesv2.0.3-ReleaseNotesv2.0.4-ReleaseNotesv2.0.5-ReleaseNotesv2.0.6-ReleaseNotescryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup.mocryptsetup-reencrypt.8.gzcryptsetup.8.gzintegritysetup.8.gzveritysetup.8.gz/run//sbin//usr/lib/tmpfiles.d//usr/sbin//usr/share/doc/packages//usr/share/doc/packages/cryptsetup//usr/share/locale/cs/LC_MESSAGES//usr/share/locale/da/LC_MESSAGES//usr/share/locale/de/LC_MESSAGES//usr/share/locale/es/LC_MESSAGES//usr/share/locale/fi/LC_MESSAGES//usr/share/locale/fr/LC_MESSAGES//usr/share/locale/id/LC_MESSAGES//usr/share/locale/it/LC_MESSAGES//usr/share/locale/nl/LC_MESSAGES//usr/share/locale/pl/LC_MESSAGES//usr/share/locale/pt_BR/LC_MESSAGES//usr/share/locale/sr/LC_MESSAGES//usr/share/locale/sv/LC_MESSAGES//usr/share/locale/uk/LC_MESSAGES//usr/share/locale/vi/LC_MESSAGES//usr/share/locale/zh_CN/LC_MESSAGES//usr/share/man/man8/-fomit-frame-pointer -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.opensuse.org/openSUSE:Maintenance:14041/openSUSE_Leap_15.2_Update/e2e0104882693f52cbf2d9700907fb01-cryptsetup.openSUSE_Leap_15.2_Updatedrpmxz5i586-suse-linuxdirectoryASCII textELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib, BuildID[sha1]=705ad9d0b1bf09381bacceb201a6366ca9a86362, for GNU/Linux 3.2.0, strippedELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib, BuildID[sha1]=c462541888481cf23a063e8a1116c024eaa6df9b, for GNU/Linux 3.2.0, strippedELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib, BuildID[sha1]=68c066cea1618a84b4c1309e0b0ae355fe44fcd3, for GNU/Linux 3.2.0, strippedELF 32-bit LSB shared object, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib, BuildID[sha1]=5c24c80e6ee644eca2921e2fd7bae37d8ad3b06d, for GNU/Linux 3.2.0, strippedUTF-8 Unicode texttroff or preprocessor input, ASCII text (gzip compressed data, max compression, from Unix)1FRRRRRRRR R RRRRRRRRR R RRRRRR RRRRRRRR R RRRRRRRR R RRRRRR RRRRRRR RRRRRRRR R RRRRR RRRRRR RRRRRRR R RRRR X'A+렊 if test -x /usr/lib/module-init-tools/regenerate-initrd-posttrans; then /bin/bash -c 'set +e; /usr/lib/module-init-tools/regenerate-initrd-posttrans' fi #/bin/shutf-842cdb71e3482be07058391dfec124bd99b65c4c5df1b394c185bff2b09b86ea4?7zXZ !t/ ]"k%{Aٙz |25YǒUdq=HO`jUC>+mDA}SWf\B` ^77J/*ACo>&H e[fdvl!Mf=BsQF؈]%Qt1u x?j/kLnj3%Ca;%y}h0*Nr-X3[r azNfvYǢGY~<EHd+Xm#SgjG7*$J֗/w}_CTdɅDL[eZJzg,zYp3~Ue;EMj*5^kEBsuoxxQX,DCc^:iD.9hAVH`>!^bVjzrf+HЈCbtna=dq bw4Ci::}ZniCGlr#x^ p(w t}%g 8Gxr Ԅ!/iq' V&Pj8qn>ի&W]mDv"te*2/s`1F\0͆jT{^LOR !K^f6mw7fց?;YڇdA4ñƾyV{(sΟ@:Ti ےJU݆ c\,K5S{1I{D3#..ZF.vL2B 5"2"$}2+j? -O7I zzWYD+U1 Am 畧<%dsT5 FmDa ̦05o/`[G.^ ΧqO ` 񖃝G#6JW+񄴈3K'f_ @.fGk̟ U(*_v&Nr*[Y,3cZ"],7ȏ\\ s|5ԬzC'ZɅP7qZ˦q\ HwAUgz˸]o 6*wYl o_#jFfN@z)c)1B i( &;j o}p+#XDHlxB#*SZn\b $6qk Qv3\:y dLA>^T 2@Zxe^ e#\.RMIKX jH"|IpsY}*B5yï=u\$0 [/rؖb>2N!2)& K6)Uc vM~hp8:_:!?+C6IAGeBE{mg .{uײE-ӂ&9RoޅJayΛ3GX:@`ɥP-<@ ̵_~v1LSzgE?Xv٭jAvS4R¤ʖgc>WGb'`e>#]TLO^cFWsף)^l]fJㅹ}ꃄqSCMŕӽ80kV&Z'Z.z|-npBTys?) 7۳ǔ>I T~{_p5QSb9%bt.#-IC`/}$4bJYH3<lځ ~KLꌛM%3;3*C@Sp R3x|"zxHDx3xY/ãEB=Qzg '01+Wy Șḃ?z@?^nYT\,G:C-Կ`kW+(!'}āz9zh5V`DmPV8hl)mwkJѷJ06?,%0 P(mc 2.y`<[;Sol2BMg駇 W]}qekrg`ց]hfmrTѮm̳dpe]YD᫷v wRE {SVV[6-+h"7DI+ Choj+j`0ixStBBΪPK|dDngne}"Q@'FivM̂S,w v1fNb nkv3H$t "m'$=-!{<'=6`E-JOOO`n]qt&i}]?&@8E7wdZ^წT/P"B=pР{g~k利ㄴ,xoUQ,<лlqW&Q۫Q__xDLR3VSf?p~TBpQ_,q{f6 DF ]ْ~bP|7L͋B!ey %PxeE שlbXAH1BG*FW8(Ŧ|?BTtO5} g6O*=&,-C3&ADžsN*h#e?bʙj4[_mJ4ˎ>3U5f]4#4%G{_L,gPOH*6?dSjU4fSrS9@ E6e``wH^~۟K2 F 5Q4'2lDT7e!f $XRq/&yZEq+ V`D=:{u-\2~/ E$p;Y(ct"5f4a^CWߦ<:,Ic JQE)X󈎛jS}Ei5:=tErY)M.|=^ /0,H622NWH'_u-٬5Jʃ|tW2/1F)` O7&ERIxlJa#Um=[t-x{-ыvWΜ$544ƅW](;22XךʒcTI- %kXu^[dHU /ֳp+R)`[8݅ݻ \P WDC[ DJn;@,""ũ/܆y,n㦆8AcO~YFj]vN]71>uJZ>ڡFe@CfcS[ߥE Բ cy¿E5"f:8Q3꘍nt q' b.$3%׈Ĺm|lΧHlf󶰈k n];RZX +X L*z=(g`veLA& x x#U_x͑m2._8`^vt}O[@L_4%zׇ0?}ux)!G[7 6J,:-v%'m3vQW.8e9ϙ8$|UwԧS3[XRTx{A[AM7xѹvktMH1ZhUԅ8 t~1<_;%d٤ _5nߦb3CV8R_ЮVt,gFGaٓ{sьt & سMj&, m6aHzbDSy?Axm.bwM+-Fj4_}uƓ*  1IB;3y1_5Z}*²V~̓}G Ӫc|%"m  _x{g.}AoֳˤY GpԶ;Z2֙RQ+M*XMnmh E:Fp;( `+PΊiLxD@D0E5/e/z!E1?Љ1eJV @>YJ2hUiQn͙E)GhC H/7T(0M<PJNP0e{$F  ,$83=%1dsfcn´!Oᤛ#,ecF _šgT0`Z*GF0F|uxӪ6="9tJysS.3Z%3vh T_|7کn^b&STf[y7.e~(9^ƪfj\a 77ۜXl)_mEÙ+ 0;*ī_ AKϤ)ޙ c8mJ~tpRp~-'M|1 /F1!Ik#Ǘt_.Lh4 AI:?݊gOcNRGVfͺ>V1|y$a|'qeoj[T \Nj:=d^= >P⬁:Պ}A͘ &Qtt׉ ٓR +@=T_RNrSĴ /sJm×sV<[.M[ܟZ'K6J9<"|C6F9g2]CDCV` ~<&O4nfD Fh3xO) GjaC]+Nc[kaIY^)40w"Z~n{Ä$;,b{|O _xTcaO1_LE[KȤOI=Y'B}ÀaԾ{POok,+NRrɒ'ZO~dZmi2B"uqGjEnHH!6kȒ)kٮfU_9+~D)qQdEF=Ӯ b)Wyvv_}}wc}/x;Rxg.Xv#PRc ۟CPAUꘑ}0pL0U"2}]d&vSugARizԄ <\Y7 Z+VҚFd_ pkDSm8džmHY6p9s 6 *N^Ry83oў0lj$ϙt~vV{sABw`MiJuX sfJ@gjsP{gW߿~]uB#44>lR6-!E={HA.iRHK kXd۷ F:BƏ ;̼u딝I`nŽ؉,da|TEՇ7&w7{Zu[5Kg^ULKӭ ~[ulܲ$ĩ;X(F$yQ f3~ 硜j &ҧNBN-?tgtbi%TN??k6p{mqEOόZ.hxVv^1!HQSɷV_L&ej2|1(EМt,0Pxh}sJ1%1J?Ċp%OjI&>KT'`".y[7Q6YbvfURi lICչ{ ~mRr%DC.J̺pHzSm8DENp,6V7:1dMCEWh|yA0|~VnXLYz= mǡ'*!>7 DZ,#=>c z`"'eu4 횝<57`ƽjQ恟ALu$'#錸5NRdF 23pJ|B5~??Ohb"s<8%R@p ~0˶<$)7"GUZa(B*'db;@JtUjM4OiJ:Ue)}] SD0%e7%ҩu *\jE;I.ubyc)P& 5 jVm]QЫod((6E( bKmKe%MC\쉅FrX Dy2ìoD{RFEv$HXDnsUCpE4ó!~pC<P/ٮ4u/ģb]|ȭDdLf"C;n:st.y#,7Fz@&UrR@ٰQ$Rr4Q,&4lr[X\ 2JϒB jK.^Mp ڼǘPfQ!u0be ,½%pk)Wd[Kעx+|b5ii>͠!\Of>f1Fg^zpS14*dăd6˜T1@qw![?@!joC>.#2a4p/Sv|UZl. C>'~\~PA]!i>H@VH%fV׫H x x/4G]T]Dbf|Zg (e&^7`wN_U5mrW1tp9'{C&࿽0W ^aOK M:>, U9u}2Gɢ،irHǾ+Ҧ }ScO$/# <=[ 6Z4K ^]hfp .)A៲7L6a>{QtX$LH!6MOǣNLHGS-رx?&c]: ac}-P{ǒ j”3Gi_D`z*k D8$rz/Q2^$:_#*m5|γ#H$ Q~.ؾxȭez,~@;henB~U}"dٸ:~RK4_6?nD= ~b j\g}&ǁ+EW`E7֝+j-RHmY/$7v2pPT0!®^.5$ewOΪ;U̩.zoiTW x^YK 5^K5uxF^κ!"dm+}KϐUNۦY3JqCQpSM ʻ9Ot~ȫ5U.v_[U&-8#=UX\6B9'"B*<)9 dqN:X>tjkT$e^If&C '+G)RTCl["m+zO] %'%Q @1$U;eqLR+sۏ[QIDFDjkEˆBWg/ƎBttyYCN+@:bs,`CFF=tJۧ"BmX/썓o}]6:X%<ڇfU%Wsu.vB3g;VDy## zJRJ%X͗ A¹m! Rh׬3Gձhw[pgEWZ#PJ;@ɤo2ÑϜ7wJ5dӪ '&C]G:'k8(T~[3p8˞f)8(ɍҞ.l }5XӴ}yk1UqC W\aD((p ,-47 hFfiAG8z{!r`L,Ae.c;hWkZ_ h=%HǛ=v5_pݘ۴0ѻtǙN4mAP^uY\ PRuޫ1~z]ׄ$WwEJ DiQM>\3p oJ91k$Tu%?3:Ay ߿ }PX ICԪ[iNñT{̩m #H&='b IMAK Q \ŮѤue[33MB)( ݅nJ 4٩1b[uP ?q4zg> P[( :0!|zoB}ge(7V(ޛ(G }L I91_T]rLIN`Kx1=PVb0\FJJӻJ9Rb;F{g!/B77=Z%+Ō/x6VVZ*SU60pP,/2HW.)P;ՒpirTo䂨MP܎7(j2k7d,9˾>~3 (hp3NX L1ZG&]vݶ σz,~q] ; 7I.UyF )2a $X?ĒW41BLθw?](?U 9l'O@+XlG!LBalL J9{bfؾZيF+T<55IJ/]ꘞڬ.>V)Z%@}8zsfH ʗ>"W[WHM(]« K^&@pq93y<~o*x: P'& &o*2!GkiD`B^qt*!% ?+΅ǻ{(Ȁam}z|F?*/H$ ]ߖ9҇eZ1U+Ա?10_7Pu)N/g4ʑH)gyOi;6B  &(Ȑ;*-Z/^kt%8Fȍ5_r~ ,dqD@NYa:QJC捻n, PWlMns'^r Y{kgu1/W\ꯋa=r;/TxrQD8(RE]-]8H>qbVwN>۫R[&Ԯ׊^wf2bonVM "N'/`$OPbj*P1ޛY@R QT(oU5)[@)sv( ab&̙U{vaGrCQr=y?fJP

@wz,O\=`^w*5O P"Uò$dz>>/T$ nwj}\k!kW>ߥ9c=F}Z2"R2[n-`;rE{4}+>6@_Yk^k4@Fc(Ifu^l:NsLE.bQ &Sa~oWػ q֦vYRZHE/'SDU庪CGPDC2b5r5qVs@[z2 } AGSPڇ&yg.mϧ1v#̟DRfłEf\e\'{ږ_ޏ 9#5"~0SbܖΔ={)=t-' 0J_,AJ‰!$Ӗ\@Hb-qXh^eiM@mlO AvMκE0\O!:.S~@Xmf ֶ e[*].픷LϪ>|Љh3BE׀A]?X?`p^u~E5Өh3R?צ26_661xL2aU_m[g}}mL~J? ܉<ϴܘ qjh|=#+gPYP)rCxy5^uʑg[ FHIz;' 6ٽ<170x9UeQY%h'C-~ ~}m=?v3|Auy}/C 늘R.lіא%`i@qoӧ7yɠ(D -Vn3BMS'޷{͏slÐq]X0M0 ;WV5Ii煚Sa=k؛I5=7_$(i9-QZ ub(تC7>k\ MΏ)GZZ'9j0Z zA6v&ͦѣ1Of[b=,mȸd c$Ta 3QhG1kOgK{n}/B888lSKk$!fZ YiwG2va@]? rCɜ0^Qi5{@pv'x8@P+*pHFߋFXmsԇDL?Q6)r@|/;UD^ծ8FւB˽6@ OS) 6=rޫrPwzpu;LبnEMit#8D>H#pDl PGi:Y #5_Q+rPR_3/ )gfCDB2 +3p*ef<Ҁf\e$|E%Yv~ϛ|lФ`Ew ̜,,Oս+!hkKPǿ'z _:S|#LȍB ͐ %V z<M-'pFpdL*g6O xȀx >dl/ݒ:N+Ui蕄3NɪAtMx"M_Q95WY宨|AKE! xw10.JtڽȌmpv9FD@6WJ 4dGN.J-L)3̡q=ܩḟɗ RyϚluJd:-J>;VB$xw] zbntǧ-5,їr2J]ˏ+fSlwcr@}G;[DZQ-\ݗz(>r>#ɈrY[,@?iv.-)AOC+0ciS\,\A5)D󢟬䁾.RJU` j% 5tr&i%7y40;zm?NS(ÈGM" ŭKքM !dds^ORȁK0P7+z9f'ƳKSs^] w“R(g`ջ?q4gH+A=_tWzY"PXn5m(K6صWI1^Yimr2t&,̔ǗnH!{LF˘" 2\ٚ IY3l\J] Q2D-ݏv}4ɿ ڸ Ο/wO˴Lǽk. MIS+Ԫj9VK5( &*}Gc/xn[7#D+ev񋇏|]vD0w@_c_+wCiZW)t#&|=%˫O鸂BB]Z1|x̩S~Gf-f!: 4X*=&2\˰Mi՞Q-1u#]FX>l,d|K40~ l}MK&E8=i]5uP3c$O}QRlI3C0͆8wwO_hQ&$ Ԇb^f VS*K$5Av_L aB`,e#0:MbC4LJaq ,GF;ˇ4PA2AG@Z#b ~hrHQQEi[lsu4Nn ϰSaƨ?>l;򉘛HW޷̌!3z( v5Fڠ wS,k F[@ZG)e v=H>Uz0ozGmnMzαe2֫/ֹ^w3 $V6'![fu$m n U޳)8rY)TB E D{c^Dv3}@.oog 4Tysٍl>h -GC?#+ }(2*X-{!ͥL°'-RE {az>]Е}J\n|TLҲaZqv>+*;QeX6#{ʼ={e[v̟%Шwd]+ Ez3»_3 Zj (Q%A[4Y<@3pr^F#GW+1EWa%X]8pTOuD6vźGO\QyEClx?<܌4}F.drt/\)ޏ(} p/Z/ ym2JKwܩJ@~jU EcR]Q"4Xpbo"? `)'HQ`XT{*D/@31wNS^:_lq7E`B-UB@3f>Nbfۉ21h6U1V9 T>c,6hl#wO|sR u8 <)Ju:LfޟQ߮oo.Ҙ? Rkt>(rh_F?& H= 9aFYB KdMɱfkp4@p<‘W-qս?R|VXŐ#թH90lwf,"EP&n2|_U\K>'61U -A-&,lтgz7J1ߞ!@լ\kFmi7mtj,n Gj?QJ ) fTfvk5nDF^d ȭ- })igAJ Y񘋰ӌ=Rj-OPz#$ 3^'OdLti^[-)D@C+ItE2&N6,Du) 㴤^ ۖa5QOqirMY NdRiJS.T̜`5|RΉ3#)G%?v_m#"ps$€< !T1N%;DJd{&7 2ˌ0h8Yމ-D"8K"x0V.) ;Y5iLhV?Jِ qډYIAdNM&0IeS%[7`)|\cm~iWMi,` "HΫ3" "=V[F}رR<[! N:8?;nz3'%* V+W9L{}R=kJѻ |t80>Bgϥ;:L7 bV\еZVj.[ӼK:S_8_R$4V|:mZQ4GJgf_2v_iFY!15әwéQM&b(Fmi`(JTsSϊƛUŊVzjl~jRfG5J #&FʯeTQA1rzWEoVm]w̯EW%ra}~%q!L$(IDȢMbӎ-<{'"ApVĂ(u4A4&FfzME4USF-0?+i~ޠ~l&Sugb5Z>}}dșDwпKꃠ+ߗnvD"J3,@?ԫ7cRqcgt {JcǓZoET1:))ٯm MG~s80ާ*-5#l@#E5#o ly?7Gv[LbXYR %/#'9@eqXW7_ゎҕ>,[! Cs>[Jg{Aduۤ^ߜ4DMұN!ӟxV *k?.C3i6VV ΁UIߥ4/X{ eL}8~eLo-f)E<PwX6Ns'LKl6al~7rU\MbǿTU \#iO6xoWi*7:Hū;Ԩ#h8'tso0T$.H]]i-]-=r\)1|žtv[&S|dd$"b;Uub_f&Go&r.#$d N ȟC $lTθ,H%p d^=4Wue Mj Ri:Y$DZIeg0(Z`кM >.exZBiR$ k.1SQpe"/.u@ui 䘎!q4{=lI CTVy]=s&~cV&0^ rͭO3A[ӿgE`X4]˿ɳʉ{I^A_븪z9]}TMRg3s|1m\44 |ݶ-tv(н-2wx=v}I ݅LCcKP}OU^r0*w2YMp]$Hz^>ZcέnXP7M bx؊EMsO#FRcłfmE[ !E $Wu<?ؓ>@S QUP%ߛgt5Ù(8KG Y-EJ%!$eP`qMrwD2($],|uy>; a?6ꖻyXͣ$uuUsmLLa>&Qk6zpT$anh Q5RDXK8e@8mԟ*Ů~pWC\+|_?MKG`<2`-^Y_| 8XX8**'u#_ևT]vɔ rV 3JFzv,(oC V.J;D~%k|p A}_ȆUn^C_u{$@L {M|s6|OֽI,GKUa#ǟ2"GNeA0P<᳴mzcw-U*Ү1aPAXY6@7f/Gt&f@WȀvkhnt񆻻WdcÌk[ZIېK>-m@/U/'ݦ=I! uR4`cNYs1B)UiC*YnԱC6X̀D#Srb눰[k77 l;q Gzs*T1 TMLY [ې>nYLF 9Ͽ͹ormXj6&knz ^|~摗&yoVy|,|G9K@NqYo7A12Ͼ@~7>KHQnesFvUaz9 рr[L{Q# _ (^1ջLd\jwo̝7{|j|WTǬ{lX 0UNG;J+2xjBJL{ z̩cXTp4Gr垏i˧8d'ۭY@f{x,!Qj19>HbR {_'{ 1Ibe}by?,FU"\|T6693I']-J{:%SITRJ-e܍|*6od!m8x齤DFn3IKn f뫑o'7gnހ؊1Z7*4J”j+!}Ok+M k3fw;2{V|J1K#[EWt­R3Q)i;8?Ds/&C!q,rj`(Y0KZnSuBBZS CU8UZ{WE\ep!vJ CR-Nzf r7=>gom4Bذ/8Z \t2>-ipKlڡk[/M"t]r*iC)~`P;m q,\oz;X0o99Ǧt(SGbLWy[w{$!gL'-NG=N8}i?Pl].[˧ *΁]@Qɿ>a^@(Xl5^V6䥉Pv#Ygq#5ۇ. r5EisV:HNItl@k$@^_6ytd O]fQ4\V*7 (1TTn&K]! g,sjŽJ})#ԋ4qX> YߓM{5M; շ︗dhO;Tug2.9rlw#ɂm]͜r:HinOr#$51N8?Yr_AG>j_s2vBԱȽRWqTC{9V 7h_$K M8H/Z=34D'قg 쿯Lnןu{:fϾs$6V Kf7]:tJ%6._Ir\4}ڔВIu.n|- G~OL8Y1;<&&d|gf1 bv6Xٕ$MpY3Y2Y_f;l'UueAd䞺Mp(]KByȝDNO{hAԋB. Nv |b>E&lBiN~ ?{y;uJzlwR JZ$=)$"ԵNn,ŋ4ʔdaW3\Ԅ &ĭf@dy(;mE2  dh"lFl:- VK >s5fܸ3M?dBI^c2dH:gr}g7_2lu<H h%˸Ce%vˈz{7+kv:4X/DxUF>+CNH(q) c);oWgˬBGR(IM{"-PW{j)S*n衜 D ڀ,.;md1[DgT(o )J?Q<$6>T`)8ܕ,w{טF 7_U(zW,[B;E_v\s̠L SA @ 2#/\hkOk8RK:!h/]_m@)Sٻ)hqo[~h(]B[hQIʮ QTfEd" ^cEi-K$z%~okgӍjMNr=#錍yԃ׷X.'KQHӬB6fW&bAkrG TaN.n^N - N/T}!Æz%.z-_osc Yk kkDMwannJ$G fk]P׵Zl>]!8 '2TM(B" !nS(&Gg'=cKo\w|i %/ŘΧ9.H2Topf y2Ӄ d A1QB,K:3.:5dBϽ3oH$3"?9:qHM۹iZ,y-"&P;bBg^t~zf97tgx+ZҸ-C ˋ#qSoݏVgO?]f4ݿ3Hrw \6WeQshH-u -c΅=7΋qstHڎ.Tcb/?9dy0GN6Ě}9u{MԳ)U訦". c0)*<% ۑ rù]-g3zwujc=^͉)7 2ޏ"Mڄ m2yH^\_杯#WrTAO}mxPW?Yz͌D%CD FKbI]j^E) y4\>2[Vt$~05gт1摡2/c%QENJvh</l-5!&{l1Gz?hvnŵ--_ؙ~@G1h=)>#K-[ j͋JkHiVS{R A%Ш&3S]Iunγݣظ[2;S9mC~686zlmfF+srI,1a8_ش5ԙϬ.}X 2fO>I=RM,3v{o5#^ I> Dқs}:do2vQAWʚrW͛:Y;J^l `12dBoF5pfrVn%=02gygt9еE'ˠVpRŖg{eMfW#j yd>c]:^O[2)KI(ҵ7tO[1y*ʜkgIF$ҳ!ցfy mj'6Uil:n gLʽN/ omq(.JmUxK(lnـ[4M6ٙ:h,W^EBeN{{w" d`M'/ [evIOfQ|w HGb2D:[mp֒@]^oYt|(&} 9V<ėESDidn\b.YBѰ;~NkIKAᗏ:bbqҠDtq+ eƄ9qh# .m20cC!͍@FbvD9.] ?\[U 4~I#;%X9CO~ gpL: p]4';4 KL{E~"]B'}k,b<'!2Ivam7tfPTYT 1S|Dyק1 PN,yد&(},Ǥ(8L6kG}2^}i .;8';s^Qm(QY8Fn JGkJ?/DF2Eh_Ϟ[7D]-aU1i*g="m ֋ VI9Q o@{&j`,/&v1ā@ |kTS@s J=R>^4K "P4T71bgx X_Z|A(|T-OO%@zqd S*X#P^6>k҈%oCI&TMD`w}Zy2-?d!8 <[3{Run_ iwFI$ZTou+댪x(th vɻLb,a+exyE/fO9|Sxo"P7l{7.Kiz-GELEN뼑$ZPk⼮#^Tkh:DZ;W;ԖCih7FYg9D?H +D2BPӇF&§b#:<EلHi O eEP,2נ:cdrC%W7Ih+@I/e% ,ثRn ~5WxPύD0H& ⭩ a|r'"Bb FIFl@$Agd{otrH(jW]›Ʈ^>GvI.R{hy<6ơ: }֙c0aGw5.y4@,:OU$= ZQE؜x]TlVXsd2㴴RUl>6ʾ -ہWU2[.^z!Y<uT4bKv* sՋr[5:Z:?Gs;T-Mu2;DEz`=T ZLjP 0pG} 2&v&,29hp,k`d '$Z d/jӺB ) M*x)ڋCw8*[ 1J*LŪ@;;FY򓓬8G8&+Q2E\H^lAzAȬq5Rjֆ1hHhI(d 7歽шl$wYS b:4Ll.Yd_ bųx#܋w4g@nFHѺp> hlAV?yg^\e9Ht[bfxBP9(~l zL DptVHNe$[JtCa4 ~l8?ԳE(e iG@$\6eY ۄN_\Y9=l4zKZ ط-^BKjj ]dž5i ׶VIeJw1BrH'j=*H) ^Af=⩌yZ:ؕlwe$snp8+F #^kΞqjL`Xg574EvCbC_I7 >D./ޖ-(^PluD|Bdr4uL!xndŴgˉbS'ڥ'/5 DșC ['c-[2,vk zks|Qvj^)?>$FhGYd Q#!r՗,햔^i޿aJi-`M[ #=vH6HzRTUͥB@CDf[d3}[FZ-|,Ի-D{tKr'hvO"M g޹N~P<*_iK=6aFk(2ltJDOKh,9s4TYԒIbMFN0x}D"FPg饱ה :Avō@aR*8OO6'zwU Y>6:60gPBlEctFhdz/˚Xay4zo)[ۛJ9#a)b;t4omѿ!pڅnB~y4hp 8Qx wRIo0o+)-}w5@w1𨎣i)C82uSۤ }M| bk2f#WlDuuBҴ`$SGbu>$,Pֻ˱QA`Rn,/AK>ےʃ:]`xWfwt{i,&å̒c ڽeqى"dR@-<ƨUB<>7n?X+yg9H 'l쐣!X率|j#\^ʏFCOEJqnr”2CK-yI:o @9ykhN{gr[|VHbKb/7\:J ) LS;\y^}ɢ~Xz[gJá'_mnu ^M> u(촂܎a@ UA 1_zoWY8`pz@A\BªQGk{&@eۑ1-m@ٲ< `Ƽ~qQxN|\ c JOr:@ X͛ |z mȳyCK.G, LRP/mH!I.RQ-!;aJx&u%2N0[;S]$LV(1p>1TꝻ{+.8CEldƅn_rZ3AO^ J CK! E?qa$Ue@Y+IFx;Sf4.z2t [צ^M4Fsd%RcPc9P-Gc+0^=Rp^s+f;гY^>Z$oy?͕JI3yH)p *ex0_|jK9 gKkZpMa@Б:$8jnHs--|Cw'ʼnzܐ"W61)~85E:&ӣ}= hBI{F-13j*r5B9q p͏c3>kj' :onp̆Ȏ1^Ikd]^4Kp*v6 2.IT [*Rn $JĐ`y!ڬ𧲶I30(3꣌,>\KKXTmehކ1`3Bu:+_#,1zal)|jܚM"7`|'ͨ_,YPye4tYԭZ|(<EnG-Ŧj92Ls"x5ʫm{M|4TsU0sWԫ;^7G#_FLt[*{x8$0qW|O"]Yz0A4ԇ#ap9+e'zNo91qdou ]kg,Y'0cfΐ@J|^Ll5nnm_ ud~4d4S(8W\g|-O@QC4r0OOƜBY!kpPQH}^$rb/<7ΨR!nE{}3d%2r$( 6 ~y Gm VKʡX\! 8,U )7>0ʮB oI撽lC^ [%뤫5q+a h9J9&p*+/:7@Gd,>w$-IcCސ:?톬a[Pp{2sEMs=Qy;xZȮ9cBOsC8v%qkD·)eRPW6$GE: 01!I@f Υ`xgccI r$I61 `IA6{[7ΥaBm~lQ)dqRd0f=߀ʥ Q Hq_j$M"-h0 ++.@Xc Eb9j/2EiMInN 1rIG仹hP`z\XO-\}-؅d>/"SHHYAŕ-@T*} /?Nb}kWcˤוjNfY嗂݄ Y*|Woױ{);]'6Ss]C, TP lރV_Ѡ ݞ}4˖泠pN%YFQsE}G:X&Ͱ"cz 6-"t\%nLUG/xէt2JFLVo>.NGo39V,&٣:Şy4M271}o(aın4kTX'typ;DM6H 0,"n}ǖf%foV{3b@.cGm# vJY*.:x5?V۲ecR7`#lU{:NF>]} !&Q jd6brE]+pZBĴr:3lV ^>CR|cIhCy L<8V}ht~3s5I$`D]= 0 0qwluh\[6\JgBƫ%2aiupCD=ni/ZD0L9jh,S;)HX2w((X,ad0Eb+bUT.>@0' [p.,E\sMySr ~X?M3:Y[*j^%9}TM> 마 y Oۜk}KJ/rF%W(:JZIP||٭WJ1ű'꽃ҩ@1>yE/$C81|[s/ TxZ# =`. q%G4ֽK~\ 0yn-,76\Q0<Ƕj(|?Ed";x(X@Xk&sgc5);d-qr)=ZFl`^Ze[ p dbߜsʵvpa`Ti7͗/JZ_X@3U0֏ez[-ub2 G&E 4rbҿͮ$'a@_wGr@Bǹ ʅJ!gMS!)ӋLlOࡉcI`dݖLʠ':1un ,:c&oS۽1'>y\=SDgoG4 *rF {Q+19 X/!Hbd,Lha=viIFNGLd y}- &<=6JJIkgE&F0,H8w%9S\ D-&0ka]aPj!&+]~fS/ ) Cq?WwiWeWm{Kt?Rյim&<~njxrEM~Kۿo4ibkR=?:% {Zԩ:͏vǔ^I 8\qjFBHNn(kY:C4橏C@\XO~Qd=֡b5Ё ,yic?\boyk3AI`#"trnJSyin/bYrΒp ;畴GHs(Z JZQl,׌dvipt5.O`#yKYC=,^`:[`V!~%&ʵLHS=\աtpϳ>qU|!q|qkE<`^;-&KDҐV@ArB[][L? g!X#Ob(BT1iԹޱ.H@%J ܟy[F=@Fq$m5e fD'Wt& z.{qH%b(43,?]!Yn1(eYhܓO6 +2SD&ɓazIMʋ)`*\8^EJ2=5>^#%E%Fq1 -Kq5^Ϻ-' L-:O~ۘg0rٯDu aq^x)X !eIhrQ e kD͙{(W*%៬זϓS:*f黃~@'㭐sk-vj9y:O‡1P#<ϭ{3)O\@ %`7'A`mI//U,Lj/_.H{Lzk݄ wXA;P5,R/fWhKc~M5 +t4%*^YzdSh]¸R]L2-,f_uƸ[sqx-~783lErL ߴzPHӍojuKMehACcZ(`\w,5>7mMbΎm(ұ,>wA! asR%,ۢ7o‰ 3гZ>]lT)2⪔ALԾ8QQSR̠v"wxڵ+!mE<8G4u^wQsPoj/Tf-,7kqo.*R]rϾQr(}4JZ9ݓ«?bYkN V2sNq7|GW#DJ`'/ĝ^i愀oWG[yH:\JZdmȄJGג0'6<ӊ÷r*|KqI@:w3?*}f5kW4 yZGPA3z19 ^ۤ'QX=_MʁWo`֥d'DVђ!,w>2k}v{MWSi PFewBJә2]~T/m16"8ho"K!Zc ʖp^\+ot+PLl5"OMv {q/=^={q1JC }GW 7C3Q^ hc]5h,A'k 9r8B0'K1PZ%DU$~v}}uYU׿goG36V \~)5_*L2@g%B?rcN\nb0$\WL*!/髝NKTX2~'iB߮eXQAǁ@/K̇mQ8%u7R?^?!jÝ6G8%xE&K2GG߾͢>>Pr<xбl3H1 IpϴqAZӯůAA A/h{Uv[)w7H^F2O+yOTT.YxR# *0T^@'<xE?y]|kQ=׀@RVJad_6Kj)p>1TڨwCi#\_Q&ޭbե$Q#9r-;[A_nv۰kI T9gav3*Eqrad 'k3"kךʩ[բUyn7Un ;yqQ*CXԃ|,!Ie[@0So3Ra.,pXmL^Dkun) dMmOxNΣc*A"˩lej?_qt5SB&$Nq,p@0<(%$Vx<>/A Q:ڌ7DeUWZ=c a&@ ާkCRdBRah3bKyl@ C)~#ĩ&yC}"i:]m#@<14r4wcCYx!Q8u*gJxlk(d h=W:=襈}f~vޡ/ԟ!?C<&z@oiv8%M/|$熕>cu0H3!j`,xt},o+N_R$֢buKF<;KzTVRSŊՑ^ */dVQV8FQ4E@O-MyܙO>G["]>슨m2d4lh3%8q>vV5la .&iu`&Z^^&8Red:ы#e^iKg|&P].7P ʪL&ES] mm%攎@Z ?x:?n}9W{D@$H E>*Vpf 6 Z {;{,_!<64Q˵-{pzZ]Yp@EvMNVB+yoٛ3hc-+{'W/.` kqn1 d^?׺Z ϞP5|2v +[-҃Y:xkt`̩]PsZ\ndp.WMC sʘP@1LC iwIg`vƿ [mD T2`Y0i-Y40!vϮ`#wmk?@^jzf3ޅOp]A9^ YT$/{1\ XƜ,;Dc:@жu+%eF Ҽ-ݯ۹e՘NP4i[=?kz(mjx3Sθߙƽy0#]Άf sx$,n,*S$o]A82T y60:ϚF7ǃt˥ݎ/EwU՟TXWȈ)An=tWjO]/11c\y=3; 8U 7׌Tpgb\^ A߄kx@tDҝLAMcmZHWFM֕vgܚ;wqWڔIJ^8ǸdsbQS YM =i")**+3 5j\W(5X F(Nk遠;5 PЬt5Ӏ皻]o;Fww/^+PGmZנVBf$bV ˱b IBauy_&qRG{9Y.5vhﵼM%!ۜi* ]P A%Y+(;x{pU/zSZ e>IW?1T9VZ;Λ+4>3{gBvGhbNړVëoW0SL1MȨO̼9P[bT y h?cp;߁40hz6-WCHe"0"`KM xx]MH_g"𾇁c6oǐ,!/5Ĩ )~M-~oy6 =K2=:9: `: }Yla4 X5C-lP!|FF(U _C8iKϲZ =?'Jj3Do(>ml/zM>rΠE/ 7/\P SOΓzLC0>< ;t#SI~ӞdOq9*=Mvh$TU$A񠔼Tgr'du\Ip soj)fqjb<ڑUF{kUժ>22 &Ũ!5꽂%n$ڜf[;?[lx<D}{Զ}3y`F(;o9Epxsp8Kn ܣaކҎVMa2(_AGͼ|b\ Sy!"p  񅐺< zdb841Dc[Uv(>qaU3o4 2N`B}#sY$k}+TS}LfLvqf-qs;3:ǓXv&;8E%`t}mnRޭuhZ#ܠQyМ[܊U+w_ !RAU%-XÖe*g=*Q,ͅ8 آ>  l6MK &c-.,労RsA"%vuen b53#ΡT޾:9@>[ᤧ\<;ՋK90WA]V[a̹/f#$Gzַ8sGϹ*Y8KOO?-iR'H5"b?E)%Pҟ)ꒌ)ìP{ 6 V"I,- 7qszٌW,D9Vsd!&ܸ@Wv>9QyrEoZw{IJ9^߇xy? s5[O{>ACxYċtW|x`Nh!2!w~TwlߏДsPL ZfݍĂ,Ӿȱl"2lN̆[THbՔ>)摖l.ɥfwĉLa@߰V#?(%ڢ'(/׊S>g>:{q;dGVɠ\HۍfR~mF\>Ѡ#^"?{)@=!)-?Ya IkhhԜfNQv˻tA`+)`FgΠw= j'(neu !aP/ ڎeF E8xp,z_1>L/:*KZQXK$4wGZ$`@l+l _aHw(q?!@Z5GަB3Ƹ/ͦq\f=Kxc`Š5ZI GY b7&G$ b6 hit`Y3ǖpM&7`g/"f3.r, 0K8p.eW/yBTiy~s>ldNŠ[X{L2G=9IA# [xUٌ>H\oĩn!~Bme#/ڮࡎ\p{`^{$d9{fNJ(]wϤJO>PR匨܌-\]g{奥JDOk;1b83@{7ɷgfxDa$|d۸۰S`N%bi̵_Yf< A ]^qLmPQ38W[ʀ@x$sT7)j.>U=+""uXgST7Xn99]ԡeeUG"Pm=n5Ő0qmS/2AĪGWzr+i{:/h~|'KB62n5a&Zarp) B$z( Ai (ti6o=]O7HPLˈ<81H1җ> jD^[ ,R;skgYjz?D?ΙAUcND jVE4nNwk3(ޢ%eziASg}~[p_A&{M-F3wb!МHvD\_i4q*5#m록^w0s&>cYƵ#ABI,Dm/ɠCJ"ψ|;AlS5IIk!XDHGguc F'*1 %Sc_ǬEP\ S&%M9u/!_1?]Rm0 WN Tdv@`#2éFx%5}گdS4y̎I9UM:P#3PyDhD"B#7\Zd#RҒޢރ U焥a?e벱'r`Xm26ZJe@k:^ 'ZPe-;8q h&+ۥ\11Vka=>RN,!g>ȶLFt+rIaC&̝ط=!W4!T)EτttsʮP_p[y dև@~ꗽq}Bu5pruAzp^/Mݦ[ 2{_l\'t&g*Ki&(5_-sNy[m0 R@a d/֣fvк(=JǙ_=:!*a)-} Ci]b`%`&lRpnn(گUt!ක"&/K$-BcYeX,(A1I.}ۼjܐAl~8</0Rt|rg:R坫%@@-ce_և 9V@'H/ ^RHϿ>I\ԿRD=k ;bI\@]3Ȇ3xTIeFGQ2 h` m?H⡾(q< (eUс`7T{K@ݒRxMȒdߑ+ c-yީ)xu b4-YϋfR0/Nag L`O1ܕ!6R{`'X+rwr[A7Ggc֫uWK~07+JW%- 6չFVcC?&f3-xmGHsӐr,E=m)dJr!W$˟b[ fÜ_ԖZnRBڡWEoﻳ 4F灬ӲP&LR/iF&ဣ0<sx㥸诅'4@4yAj uYڧa G?j|P@O'^q@qES ꑂd1dʀ \b}4wևk:Bf7V@//4:-v#X+qe浽UrF|CHN5-@Xu60E2[\t[:;+¶D]YtX1n( &_0_ `;  7pmsR]r *^{xb6w.TМR edl cqv.K8(B+k#v_۫B٨db-cĶHWbeM[>m"A M\wŹq^AR_t8!6X7] >2;Q>6.LlÍ_LsLSJz D? dv{wfʮ-Cxgɤp}Mܼկ Wzd,IߡAX5a!7S3& xFG.S[BǏ< ޙoCTqABS&(q~\)O˦#4 zطEɵp}m4䰕|Yc81GP]@!z13įrT3D'>t{f-ҎN9D3\*=*f dT128di`-~4:.OIl e-g()vDjːqcMc6pHVˏ%FZQIix?}[C}X 9VSXzySi۳T~k0"]˫&SNĨ[q8y/&<-(!N~ơ?I0 S'[*ޖ DK3prOIRgRpd8嗵J^fg`k˱Z.3$Z! 7$ NUU˝]FQ.ڿOxkd>/Ѽ EۨL.Q{P8v#z"yB1Y$cxCHv{L_%rwp^~e6c,',]9PtuF1JbyN[>@%Um j|rXɠ&N4 ;jD&MЖfr:ʫpIsycH'@], hIq VMn+v-BkgXˠ883[L57*\о)vwO-Ɗg甅ǖG<ӊGJ:-ܳ+r`umb+qA$ 8G3 wAG -47ӫBGv ^1 vVp}4 T,k7Ss+qm7F.-ȷM=ʸWKq_v|[# IHtld(@Kbb_{OھcKmhjbz0&.1$8C4e$6K'5SТ^E( >ۆ{q78 ;;a8 f>7#QHtY jqTp _&мR;;!*a=8-],hI31oflT'AM";YeJ>?(2Εlx%p Afѳ02|)X l@̓%O#(0%פVI . eSS{7J/)ժKq"K O]>Zۡ`ce'~\3897i}̐)A2gbco WզV4>ڌ&I' 9rvoz[^yaPq +ռǁ}rC0VB}=w&X ׳}bk4µ+JfrXy=Ή;_C5 &٭М[" Xh0$!QXr[d WBQczZk9| <*,ٲJWudBo᭸QՋ¥9-RrlkkW|ÏJ[rGY@%>E6'bYٴI5=u_HQaR)c}zӝ6[/̼Ė)͟z)AQ}/ʽPq-~0gsP%W ְRՐ)W$Ѥu쵷p \~I~V`MMm9DՅ\ (kJDAt;\rFooBY9xjU{z&Z-iF[CabN\ZFX{ el*+ oo_m⁑\퉬" /{/cIԼPswE԰[Zetuq9մQ¡nGtpa*IKg0X.g-w_e HQ󃝔=r̊5^wkWuùv>9h9)>Q\k"PeVmP ޜ*Z'4:I+kX~#ioYa4W =xXC)vל0c. YػIaĸF ) bQX?jigX|}{_IdXؾzV1QkX^WN-8(nyF4ФRo/ >.utX`ʹDJ|>@+Ja/5.r6LbKH&m8WӒK+ISayT_ r"dd>㩘[B/= X9", v+JӖSA9 tkիx'K,YssGX^rTD5rpL}:5\!ʒNK9/e1]seB土| K;>#G7)qp-R.21ʼnOnGSSHjQJlylL6h!p}`!1JG3%MFObNRNa鑖/E *23aO:^Vq|a:yϟdy >$3=.EYf2vl(ڽ@GEI9Q͝0Á{k7qCb(j=\49˔ƿ+.vetxŃu7u:ēyqQS)_yuY娞Wf D[!w^wcy sEiQW9xBBb\/GG5!@(DXHWwͼ / S 퓪HFS ,C=h -um@2] /\xt=̠MSܯ4Tiqz44+UM+z p"iY8&dj|L_*$WGE xAԩh|]:+A<+աs.,yuj 3uV?Iz8/t\QٍǶ;vФ̚h-T&E!taޕDKVXoT$EGCJAfz)Hul) V3ZnyfmogC<,3$B:)`Aox$@hokGn!j\nhwʋe.رf;oǠƓ |ޜ*lR uT>ժVtMbߺ x U^ t 3'(ʹRE@t(@9 6p|#M0o7KcztΚ[UVJ;ږR1۴fJHwX[] /I_#@fgܤlASޣ̨C PߘkifT #4%AtV2Q 7Mee@ŕV}5eJ[q0z\ǧZrC2Smo+_'or?cZ,4-y@S޳Z2+vU 1 mȓ:`8e2KP&=˿An]6<ݨJta%/@xͭ{M?Ǒ 6xPuGT`4?T@\c&(['1e.Zd!~8JkxYKY&mINQ \-4P$cIlR4uk+[>UB;JI!$!PTTd& Z6z:]mu gВSW^E&P3 !_[6sRpK@4 E4CV!%NqBS![ATg2icvkr(ʦIVpE "$I)n?+ ™4պf:aBb)8ڰLyGf*ܭ%b (VX`}l)DAV k [ OmGl/ltIT<2: }ڇ˴q^ )S.l!gJaT%TmpԞtm^[aށߨ7n5avA8;`; xtĻcs,k랍kkLiY֓h^W[4txnB/qr%ſ^Z"-[ً;g25V5 gFGNF]E3߳d\)RD 6sO_D?-8GmH{E)D^ X3;4r"yݱ3il1K* GGX7 taTv77$@6cqat>mQO1MQ2YD3[%W ,x-L@8u'?f,kWѝ|zǞZjȩ\n fԧ28bASR]mJRF}'~ +Y˜~ADqIڊ#{ݺ? | ,~—vwQp¥0B3R9FOG卵񩔎0]N.8OX-9Eʔ6E.FqRC(ːʂtK|)a{][x[k]A$8;V\-@o^ ՀŘzޤzy+1cl= l(9¨5ȉzFnJ:<ГQGq7BAMlp[&aO;OXk\4+#PG#mL[5q0~H1(:GoURKu-+,NSj,cwY{Adl$*~5"4UTX1Hy+ӗ0g^}9?LJ'nNMFϢXIU)AF8 Eζ/\U8,0QQ]ڊXxzmsŤw!,Hxy",AZRNJлjxʛtPH0]}.ĻU z$۝oԲF"G_VCkҘU IpU7ʎ!dR܃mw .vyܻ`hR]jLU@>ro6ŅNpWLMtMk5 '=y ….>`B|%38ax-dߪOYL ;@tA4\ċoVWM*ڷN_d~~fԷpsS:D Xy,5wnF]{)j Vc{]}%.hJx7w(̒ayZه-nrxnj$XKw!gaP(+ʔqC[2*6y%A0jM >kz!(¼mP6C gYYk%e5I(=ղQE:%cBn  DgS xD[FP=f *ywPM85 Zr袭3xMNnY.UճJLG[W:oћ]1cĉIsg!S2Me *d<%u#ip7>I|Y!A ^HÒ P2[ 4<#yPI9j>#\w}gO#Q@ocrez~e%a"Bޏ7&EN:s`Hf_%A_3]Qߔ`S0o 'YuǗքknZS<x5,YՠuP)؊A<8RR,?%sh?x٠h5J+}&'%'US;$j8e&rމ#줋n jp9V~K^fȩ,Cj$"7ӵ1 =Q~Q4@ q%HrRa _[黱3S=+ V2_%~@w/^|# ~ӋRBpt؛IN|}SI0kY|gҋq 5yj!It|