slurm_22_05-plugins-22.05.11-150300.7.9.1<>,|Љe ]p9|3 *f[;HuIZqi謁nq[WBӽߋnJi/ I^CJPNCxF,$jD?d , T   BZ`h`` ` h` ` ` `x`!X`#8#d`$%p%()8)<)J()K8)T9+:3BY FZGZ`H\`I]`X]Y^ Z^\ [^ \^`]`d`^gbh&chdiUeiZfi]li_uit`vj^w`x|`ybzCslurm_22_05-plugins22.05.11150300.7.9.1SLURM plugins (loadable shared objects)This package contains the SLURM plugins (loadable shared objects)e ]mourvedreSUSE Linux Enterprise 15SUSE LLC SUSE-GPL-2.0-with-openssl-exceptionhttps://www.suse.com/Productivity/Clustering/Computinghttps://www.schedmd.comlinuxppc64le+ 8H    x X   hX 0      'X)  @  ( Xh8   p ` x  x ȁAAe 4e 4e 4e Ee De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De Ee De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De De D8229df484a3842a477b8b4acc414874daa6267f1577fc45c380c2f0f724fcfd49703a958670d36208d837402abcbd10775ad3eee0f2ce830f21fcd789b44aa38238c8e23181a1999af23f8cd6d49ca49db37db4280e2403eb23c4a16617d9a7c6a45b41677fdcfbf2a068fd183981ab30b8ef8b62c9060085ae93daf679de80a92c76257670564336155ce37cc6086d332578e62c54b3bc3e24693331544256100d74bdeaa2066b4e37943bdbd6e0e97e708049c08d012dbca3f926056e5999e174047904faaafbf480f7cdc7dd1e4cd6e3251d6d2b1253a4cf63db3b57f199b3506564fefb3c4fddaefad797b639e0feefaff5eec5e79f96a40e326b54caaedda6458f436aa5f8e7b9a7869a57b0c757d8fd5e846826cc6d9f4df8d244ac0d9e1fe74ed0a696ff34a8827fb34ef117d98cd7a55418e7bceee43baa03fb6bf8ba06e2871517d12676fb7ed18e7def66e537f8a3c92c564e06909ea0ae094505179e45c0c4fe79e44a64e0820e7dfb235f2684076edac8b2310303bf8b1e41f5cb861e2f6d44a47b581659211e3cb93eeff521e69a77698b6c63d240c88f04f02beb53ffb8355541cbb45165ab0b1ab5dd5c6026952ec683aa99cc95167468d85f2031fc66ae48aa191013d5ce284a74f2e0e5183fddba898eadb5a0c82caf8513bf396603fdfc35df33113981a86668dd3301b5dc30c78e72d919cf08988fe933c9cfaea4d97b617f78b713d2867edb9cf356673c13bb7ddab591cd2aaf4421ef8e1a5f5f14cee24ef1a8190d9b19e1ffd8395ecb321d67270efb8c34a1bd069d29beeea1350a9d0dec44c0b2747ecc479fb817948ba1078587faea2972b82c5f9da00967319ee90ce95599e33ff9bce0a2b4293e118083ba19d748b24a47bd0e461e2e57273282217e5fc9ddd11fccccea992eafaf15b5f8d79d488d1c01c5c96cb91aa3deddb15a18c4d4079c518e30b88cdaa9c8d0f5de27c7dabc9c14469c53bd05b3f172fedbd0c5a98701aa6fa306d0f9bfb69965e95088ebf68c3d7413c81f78c6051827bd0d6fc21eb6a30dbd85883c8f45030d29dfed36321c3f9da41e1aefad79b1520c7ac09dc1b4c12ae6a0bfc52c17cb037e3c838dfd9f5432d8bd47c271435a5eb7ca5413723746113e805f59666549e6d8f6f85239ae3d9b034c44310cea45e0be243f9aa7b657fdfd35b80ecc9a503733d304f1f06fca6adb6a09bea6f9166c5c5a8169adb0f029b62c4c32e9efa14ce205bf57320af08623d7096828998759693b9d6fe0fa70be06528be6d9fd769d343c33a7593bb3e53e9f7af7b6946246fe797b4b29f218c58f7e0b9a2a845de694b4cc82ce66435562447187533d5ed33a7df5c3f94c4a6b5c82a625130b0a01c92050f04ca44b9127ecad2e0331e16ba36c9cd477fe515144d9bd6c4f2ba58fa843e1bfcf49144f39d557238c44feef9f5b7444bac3d090978cc94b46972b244360a49cdcf4a131bee2b52c22b2549f530b3f1c3b618cd8cc9ccdd5b954d639690d08eff99710385abe08a3c52dbf4bfc708fcb9d45461b619f98ec2f61e86d122609af3ccceddc52f225b6c46d9587225dbea4434d9964da0f9fccb0aca46e334debde3d5132c43b65f394746e051529a112a320eb7ad5bc48c5d3768d8510944a6c7a1c6628d6a01539b446d02e5c1580c38723a49b310c3d67c1ce91e0eb7f55e2b58bbd7d07cf2d679e7701d1f1cd4760f8132a9b00b1a560494fcd647d93b4c80a9e762ef29461c165a691eb901484efe323e5e72b7ac0d8abce4f7f37c95f0cef40e7f7a6eaec734418d960b5ab30914bde2f15b14059012095d6464e54e89380a0d25c1db03e3a53f80fb6a23a4fa038d6c9004c9d6c0feb25d4f637b0ffe046958534a9807595820e4f0ecccf559a8c72a72bf95292a567031d3dd24d8831a5094117f19ac5d9d583dbd7a1a508b25fddd5f20ba24549c4da6b558feff2caa201440a7bc45fc3af5e8be41daac45859462c10ee39fd07c595dd75396cc3f53f6e6addf60c2dfcaf04af60f0d3b53454d425d5decf1f8261be441525ade2cc5e44ce2ed3f8d43f1d45e2f5d05db6e0bb92a8e2905515208033b078f81b5dd233ac760678be0e40f5ec62fb284e361f9dba3311c6f4d7d0e3a335c539259b851105444334c6eeee41cb946b11dafcf8f7629f55df4402ec6fe0a4d69e9cd9f41c1347fb47b1851dd815d7561a1453bbacc75d50347d5a1a2ab0890ea6a65ffcb9f2c29963d9bf88bd6acb24ca58bdde4f7a703b4db3705e616b44afa5c795db1602d0853340cb23bcb56f0890ff731391ac7a5962dfc960a923c25aeace0e3421334be8811f9f98a846855152436f93e491e27a3262e04608762d82f156225d234e82510d770026dd17a438d041a4cad1644fca59e7f0e0996e67aa896b149c3a78de48df6570e0599161e55917f29742562cb0e59fd688615adb49ccff34fa7095156d6a8024f7c0a69e8693eb816ea5583a484d6c076cd74f68d887d47a9b686d56f1b0572fa9dcf6508bfa90ccafe8d803a7e5a5d597cb7a3cdaee0422c22e2b2e7156b9bfe4a7568f503ba3176fabdb4a3985699df1e30ec54cbeab61e816f9c4affbbd1b2b3bfffebc13b520330a74ea671774574f81ffd1193d219895d13492f82a2607113a2462d650a4d1f62f08bb61f1baaded89539475411ab2ca73c1c13aaae094815f3d74a38eadcbd3712d5ee7984f95e5fdbf7c55901ea8483bb74711f25a64629b4bc35d230b9d6c5fe50dc4273c559e6f3c297f75f7d2f92d288b1549f0f65fb7c23edf94e94e229e5349f36b25331bbb931022787b2739e2c452538f04d1980f495fa99a98b641162f37d58b82bfa532d7859dc8585fa41d920d2ad469239b0f5a9201138acace674cce37546f3935bbdd34971b288c9a7fe2260b0008ecac178f80aeace174116863dc097d0464ccc0b3a541936b8314d25a09240121e0556fb1ac77c8c33104fcd15c9aaae409e67453086ef9d64b3ff549a52ea01794d6c5e341907da3ddcf41c6d1273b839a4286fad14ede689c0711c2d1c940c29bc139f2dd74c79940a2a5d31d6c29d4d756bb0e7914339980c0be53b2a9869de2863f9fad95b8b1f9aa686a5bd380455aa06d598894e4969a6a8d9dfc6714ab573f00541f7e244031dabae55d2eaac658a4d9a661ca0093ccc0f3b2effe69c8837c5714ef564a2a96b85d61f044336b2e583b7431391955bb60f9a95725e901543bd18e3a44ab40a22557d9926c7924fd9a5f8100c67d3d6f81295ae02cf56a8e761bebe8b3ba8215e803bd7308bb0d981693b98791bcf3b2796d5c4995f50e6ae9a969d9d96d5ecbc0ff5c3119e06793a1214d03acf5e3aaa5d8ebd9ef7c0570e2c2b8f53eb31697ab35d3c050d755b25af04c049516c403ba0bd704b0508c69593495110c93bf38d1f61198f305dddc2b5cb67cbcecb02948c52fa306ce2623780946e0692e4675aa7cc57fc6fd6717fa70c792a08e1317692dfc2597ba792498f903933ff12e05992102ca4e1554d3b01aefb0e7cb8815f1a3900d2ea3f29b79f94ba02d884a4a44f53e2f27d9097beaffa5902aafbe7b7043b64eaa8bfa2ce3a2770e487a7745ed22c7f53f10e95375fd6eb31e98b35e40ae9d657d0d6b829f0176f42785b376310e6b468cd95215f9c97e985393f2237550a1bc93bd39a0326ba366deffb1ffcd2a539294764ff68fabf458934c640f80db0d6373478ed51e7e43a491ce90124280b53beb45d27d227ebfcf91011a37f12aff4bb58b60d2370cc7cb860f40be864974db59d103ca6bee490f9d2e67e7695ff33213ce4fade78606e94cac54406b8cb68ac58d91c4be6b73b23b6dc2e9f789832e8ddb827b29262fe41a3a312e6c05db4039fdee1a31599f9b1518f2650c9dbf28e31550904c5287b9cb98f359ac1e6a6e2b89bfccf7b74c0da5b7421cfa8b50216791fd2ad1a451e14a4bf55c6e952ded5c4258f66420e0487eb3e2c7540480cd2230e9fc8bdac4eeff9e0c29278ecbaf763a8de26ac21fe4085a25ec6554945c9a54ea876805b2b507be9ac770d3f6b9ab3b03f72464766834c51010d91401798a7bf6fd59d5d04fbdb5cb1d24dd527c5214e95bc3026eee320ae19320488666c22e0769e716c5ee55518f98356fe11834373cb38b93b1d3478adbbde5ba79b57c400mpi_pmix_v3.sorootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootslurm_22_05-22.05.11-150300.7.9.1.src.rpmconfig(slurm_22_05-plugins)libslurm_pmi.so()(64bit)libslurmfull.so()(64bit)slurm-pluginsslurm_22_05-pluginsslurm_22_05-plugins(ppc-64)@@@@@@@@@@@@@@@@@@@@@@@    config(slurm_22_05-plugins)libc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)libc.so.6(GLIBC_2.27)(64bit)libcurl.so.4()(64bit)libdbus-1.so.3()(64bit)libdbus-1.so.3(LIBDBUS_1_3)(64bit)libdl.so.2()(64bit)libdl.so.2(GLIBC_2.17)(64bit)libhwloc.so.15()(64bit)libibmad.so.5()(64bit)libibmad.so.5(IBMAD_1.3)(64bit)libjson-c.so.3()(64bit)liblua5.3.so.5()(64bit)libm.so.6()(64bit)libm.so.6(GLIBC_2.17)(64bit)libm.so.6(GLIBC_2.29)(64bit)libmunge.so.2()(64bit)libpmix2libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.17)(64bit)libresolv.so.2()(64bit)libresolv.so.2(GLIBC_2.17)(64bit)librrd.so.8()(64bit)libyaml-0.so.2()(64bit)pmixrpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)slurm_22_05-config22.05.11-150300.7.9.13.0.4-14.6.0-14.0-15.2-122.05.11slurm-plugins4.14.3eL@ehy@ee@e[J@e'd c>@cRcIO@c.@c)@bb?b@ba@b@b@bzSbu boa@aa{@amaa]aSaD@a6a0``f@``Q@`4@`@_I@_I@_T___ _F@__c^א^Ǿ^^}^d@^_@^Y^W@^W@^V]^M#@^E:@^B@^:@^.^*@^*@^)^[^@^ @] @]@]]B]]](]@]x]W@]+@](v@]'$]#0@]#0@] @] @] @\v{\T4\R@\R@\I\U@\[@[@[@[@[[[.[r@[b@[`O@[`O@[\Z[E@[{@Z؄ZЛZJ@ZJ@ZZ@ZZZo Zo Z_:Z!D@ZY@Yp@Y˒Y@Ycl@Y-^Y]XDX@XBXXXk@XAb@X>@X43@Xx@X@X@V5UL@TVTVeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.combwiedemann@suse.comeich@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comaguerrero@suse.comeich@suse.comeich@suse.comaguerrero@suse.comaguerrero@suse.comeich@suse.comaguerrero@suse.comfbui@suse.comaguerrero@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comeich@suse.comkasimir_@outlook.decgoll@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comeich@suse.comdimstar@opensuse.orgcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comcgoll@suse.comjjolly@suse.comcgoll@suse.comcgoll@suse.comeich@suse.comeich@suse.comjengelh@inai.dejjolly@suse.comjjolly@suse.comjjolly@suse.comeich@suse.comeich@suse.comeich@suse.comjengelh@inai.deeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comeich@suse.comscorot@free.frscorot@free.frscorot@free.frscorot@free.fr- Update to 22.05.11 to fix (CVE-2023-49933 - bsc#1218046, CVE-2023-49936 - bsc#1218050, CVE-2023-49937 - bsc#1218051, CVE-2023-49938 - bsc#1218053) * Security Fixes: + Prevent message extension attacks that could bypass the message hash. CVE-2023-49933. + Prevent NULL pointer dereference on `size_valp` overflow. CVE-2023-49936. + Prevent double-xfree() on error in `_unpack_node_reg_resp()`. CVE-2023-49937. + Prevent modified `sbcast` RPCs from opening a file with the wrong group permissions. CVE-2023-49938.- Add missing service file for slurmrestd (boo#1217711).- Explicitly create an Obsoletes: entry for each package version that is obsoleted by the present version. These are all published versions of the last two major releases as well as all minor versions of the present release lower than the current one (bsc#1216869 2nd part). This prevents the current version to upgrade a old Slurm version for which no upgrade path exists.- On SLE-12 exclude build for s390x. Mon Nov 6 07:38:00 UTC 2023 - Egbert Eich - Add missing dependencies to slurm-config to plugins package. These should help to tie down the slurm version and help to avoid a package mix (bsc#1216869).- Update to 22.05.10 with fix for (CVE-2023-41914, bsc#1216207) Fix filesystem handling race conditions that could lead to an attacker taking control of an arbitrary file, or removing entire directories' contents. - Removed: Fix-test-32.8.patch Fix-test-38.11.patch Fix-test-3.13.patch - Other Fixes: * Changes in Slurm 22.05.9 + Allocate correct number of sockets when requesting gres and running with `CR_SOCKET*`. + Fix handling of `--prefer` for job arrays. + Fix regression in 22.05.5 that causes some jobs that request `--ntasks-per-node` to be incorrectly rejected. + Fix slurmctld crash when a step requests fewer tasks than nodes. + Fix incorrect task count in steps that request `--ntasks-per-node` and a node count with a range (e.g. -N1-2). + Fix some valid step requests hanging instead of running. + slurmrestd - avoid possible race condition which would cause slurmrestd to silently no longer accept new client connections. + Fix GPU setup on CRAY systems when using the `CRAY_CUDA_MPS` environment variable. GPUs are now correctly detected in such scenarios. + Fix the job prolog not running for jobs with the interactive step (salloc jobs with `LaunchParameters=use_interactive_step` set in `slurm.conf`) that were scheduled on powered down nodes. The prolog not running also broke `job_container/tmpfs`, `pam_slurm_adopt`, and `x11` forwarding. + `task/affinity` - fix slurmd segfault when request launch task requests of type `--cpu-bind=[map,mask]_cpu:` have no `` provided. + `sched/backfill` - fix segfault when removing a `PLANNED` node from system. + `sched/backfill` - fix deleted planned node staying in planned node bitmap. + Fix nodes remaining as PLANNED after slurmctld save state recovery. + Fix regression in 22.05.0rc1 that broke `Nodes=ALL` in a NodeSet. + Fix incorrect memory constraint when receiving a job from 20.11 that uses cpu count for memory calculation. + `openapi/v0.0.[36-38]` - avoid possible crash from jobs submitted with argv. + `openapi/v0.0.[36-38]` - avoid possible crash from rejected jobs submitted with batch_features. + `srun` - fix regression in 22.05.7 that prevented slurmctld from connecting to an srun running outside of a compute node. * Changes in Slurm 22.05.8 + Fix potential deadlock at `slurmctld` startup when job has invalid qos. + Avoid unnecessary call to `clusteracct_storage_g_cluster_tres()` when pinging dynamic nodes. This avoids significant slowdowns for `slurmctld` when `ping_nodes()` calls all nodes to re-register. + `openapi/dbv0.0.3[6-8]` - fix segfault that could arrise from Slurm database connnection failing. + Fix regression introduced in 22.05.0rc1 when updating a `NodeName=` with `NodeAddr` and/or `NodeHostname` if the specified nodelist wasn't sorted. + `openapi/v0.0.38` - change type of nice field for job submissions to integer from string. + `openapi/v0.0.38` - add oversubscribe option to job submission properties. + `openapi/v0.0.38` - fix incorrect data used to populate "time/start" field for jobs. + `openapi/dbv0.0.38` - avoid dumping failure if preempt qos with level 0 is provided by `slurmdbd` query. + Avoid an fd leak when lib dir for sbcast fails to be created. + `common/slurmdbd_pack` - fix env and script hash when unpacking a 21.08 `dbd_job_start_msg_t`. + Fix a race between `job_container/tmpfs`, `cncu`, `x11` setup and adoption of pids in cray with `pam_slurm_adopt`. * Changes in Slurm 22.05.7 + Fix slurmctlds in a federation not recovering a lost connection until a slurmctld restart or a federation update. + Fix incorrectly rejecting jobs that request GRES on multiple sockets and `--gres-flags=enforce-binding`. + Fix job core selection with `--gres-flags=enforce-binding`: this fixes cases where enforce-binding was not respected. + openapi/v0.0.38 - set assoc_id resolution failure as a debug log instead of an error log. + Fix issues when running in FrontEnd mode. + Fix srun and salloc I/O code to set `keepaliveinterval`/`keepalivetime` on connections. + Fix overwrite race of `cont_id` in `cgroup/v2` when using `task/cgroup` with `proctrack/cray_aries`. + Fix node remaining allocated after a reconfig with a completing job that has an `EpilogSlurmctld` instance still running. + `openapi/dbv0.0.38` - fix a cast to a wrong type + `openapi/dbv0.0.38` - correct issues where modifying association fields were ignored. + `openapi/dbv0.0.38` - correct issue where 16 bit integers were not able to be unset. + `openapi/dbv0.0.38` - correct issue where 16 & 32 bit integers were not able to be unset. + Fix `scontrol show hostlist` to read off a pipe correctly. + Fix `scontrol reconfigure` with configless enabled to send updated configs to 21.08 nodes correctly. (22.05 nodes are unaffected.) + Fix assertion and locks for dynamic node registrations with rpc queueing. + `rest_auth/local` - avoid logging root access as an error but instead as a normal info log. + `slurmrestd` - switch users earlier on startup to avoid sockets being made as root. + `slurmrestd` - disable umask during socket creation as the authentication is handled by Slurm instead of file ACLs. + Fix `sbcast`, `srun --bcast`, sstat not working with cloud/dynamic nodes. + `sacctmgr` - Allow removal of user's default account when `AllowNoDefAcct=yes`. + Fix segfault caused by race condition when a reconfiguration is requested while slurmd initializes. + `openapi/v0.0.38` - avoid divison by zero causing slurmrestd to crash during diag queries. + Update default values for text/blob columns in the database if upgrading to MariaDB >= 10.2.1 from a pre-10.2.1 version or from MySQL to avoid `sacctmgr` failures. + Fix several minor memory leaks in the cgroup/v2 plugin. + Fix possible issue when enabling controllers with long names in cgroup/v2. + Fix potential segfault in slurmd when using `acct_gather_energy/ipmi`. + Fix controller being able to contact non-addressable step hosts. + Allow setting `SuspendTime` to -1 when used on a partition. + `openapi/v0.0.38` - fix `maximum_memory_per_node` description typo. + `openapi/v0.0.38` - add `maximum_memory_per_cpu` to `GET /partitions`. + `openapi/v0.0.38` - add `default_memory_per_node` to `GET /partitions`. + Fix dynamic node losing dynamic node status when changing state to `FUTURE`. + Fix adoption into most recent job in `pam_slurm_adopt` and `cgroup/v2`. + `gres/shard` - Fix `plugin_name` definition to print correctly in debug lines. * Changes in Slurm 22.05.6 + Fix a partition's DisableRootJobs=no from preventing root jobs from working. + Fix the number of allocated cpus for an auto-adjustment case in which the job requests `--ntasks-per-node` and `--mem` (per-node) but the limit is `MaxMemPerCPU`. + Fix `POWER_DOWN_FORCE` request leaving node in completing state. + Do not count magnetic reservation queue records towards backfill limits. + Clarify error message when `--send-libs=yes` or BcastParameters=send_libs fails to identify shared library files, and avoid creating an empty `_libs` directory on the target filesystem. + Fix missing `CoreSpec` on dynamic nodes upon slurmctld restart. + Fix node state reporting when using specialized cores. + Fix number of CPUs allocated if `--cpus-per-gpu` used. + Add flag `ignore_prefer_validation` to not validate `--prefer` on a job. + Fix `salloc/sbatch` `SLURM_TASKS_PER_NODE` output environment variable when the number of tasks is not requested. + Permit using wildcard magic cookies with X11 forwarding. + `cgroup/v2` - Add check for swap when running OOM check after task termination. + Fix deadlock caused by race condition when disabling power save with a reconfigure. + Fix memory leak in the dbd when container is sent to the database. + `openapi/dbv0.0.38` - correct `dbv0.0.38_tres_info`. + Fix node `SuspendTime`, `SuspendTimeout`, `ResumeTimeout` being updated after altering partition node lists with scontrol. + `jobcomp/elasticsearch` - fix `data_t` memory leak after serialization. + Fix issue where `*` wasn't accepted in gpu/cpu bind. + Fix `SLURM_GPUS_ON_NODE` for shared GPU gres (MPS, shards). + Add `SLURM_SHARDS_ON_NODE` environment variable for shards. + Fix srun error with overcommit. + Fix bug in core selection for the default cyclic distribution of tasks across sockets, that resulted in random task launch failures. + Fix core selection for steps requesting multiple tasks per core when allocation contains more cores than required for step. + `gpu/nvml` - Fix MIG minor number generation when GPU minor number (`/dev/nvidia[minor_number]`) and index (as seen in `nvidia-smi`) do not match. + Fix accrue time underflow errors after slurmctld reconfig or restart. + Surpress errant errors from prolog_complete about being unable to locate `node:(null)`. + Fix issue where shards were selected from multiple gpus and failed to allocate. + Fix step cpu count calculation when using `--ntasks-per-gpu=`. + Fix overflow problems when validating array index parameters in `slurmctld` and prevent a potential condition causing `slurmctld` to crash. + Remove dependency on json-c in slurmctld when running with power saving. Only the new `SLURM_RESUME_FILE` support relies on this, and it will be disabled if json-c support is unavailable instead.- Create a macro for upgrade dependency to ensure uniform handling.- Add missing Provides:, Conflicts: and Obsoletes: to slurm-cray, slurm-hdf5 and slurm-testsuite to avoid package conflicts (bsc#1208810). - Unify Obsoletes:. - Add dependency for the general plugin package to the AcctGatherProfile HDF5 plugin.- Test Suite fixes: * Update README_Testsuite.md. * Clean up left over files when de-installing test suite. * Adjustment to test suite package: for SLE mark the openmpi4 devel package and slurm-hdf5 optional. * Add -ffat-lto-objects to the build flags when LTO is set to make sure the object files we ship with the test suite still work correctly. * Improve setup-testsuite.sh: copy ssh fingerprints from all nodes.- updated to 22.05.5 - NOTE: Slurm validates that libraries are of the same version. Unfortunately, due to an oversight, we failed to notice that the slurmstepd loads the hash_k12 library only after a job has completed. This means that if the hash_k12 library is upgraded before a job finishes, the slurmstepd will load the new library when the job finishes, and will fail due to a mismatch of versions. This results in nodes with slurmstepd processes stuck indefinitely. These processes require manual intervention to clean up. There is no clean way to resolve these hung slurmstepd processes. The only recommended way to upgrade between minor versions of 22.05 with RPM’s or upgrades that replace current binaries and libraries is to drain the nodes of running jobs first. - Fixes a number of moderate severity issues, noteable are: * Load hash plugin at slurmstepd launch time to prevent issues loading the plugin at step completion if the Slurm installation is upgraded. * Update nvml plugin to match the unique id format for MIG devices in new Nvidia drivers. * Fix multi-node step launch failure when nodes in the controller aren't in natural order. This can happen with inconsistent node naming (such as node15 and node052) or with dynamic nodes which can register in any order. * job_container/tmpfs - cleanup containers even when the .ns file isn't mounted anymore. * Wait up to PrologEpilogTimeout before shutting down slurmd to allow prolog and epilog scripts to complete or timeout. Previously, slurmd waited 120 seconds before timing out and killing prolog and epilog scripts.- Do not deduplicate files of testsuite Slurm configuration. This directory is supposed to be mounted over /etc/slurm therefore it must not contain softlinks to the files in this directory. - Improve .a and .o file collection for test suite: find these files even if there are multiple ones in a single line.- Fix build for older product version.- Fix a potential security vulnerability in the test package (bsc#1201674, CVE-2022-31251).- make slurmtest.tar reproducible- Improve check for mpicc in testsuite package: if binary isn't found, don't crash. - Patch NOFILE Limit in the slurmd.service copy for the testsuite.- update to 22.05.2 with following fixes: * Fix regression which allowed the oversubscription of licenses. * Fix a segfault in slurmctld when requesting gres in job arrays.- Package the Slurm testsuite for QA purposes. NOTE: This package is not meant to be used for testing by the user but rather for testing by the maintainers to ensure the package is working properly. DO NOT report test suite failures unless you are able to confirm that the failure is really a bug. * Fixes for test suite: Keep-logs-of-skipped-test-when-running-test-cases-sequentially.patch Fix-test-21.41.patch Fix-test-38.11.patch Fix-test-32.8.patch Fix-test-3.13.patch Fix-test7.2-to-find-libpmix-under-lib64-as-well.patch * Add documentation: README_Testsuite.md - Allow log in as user 'slurm'. This allows admins to run certain priviledged commands more easily without becoming root.- update to 22.05.0 with following changes: - Support for dynamic node addition and removal - Support for native Linux cgroup v2 operation - Newly added plugins to support HPE Slingshot 11 networks (switch/hpe_slingshot), and Intel Xe GPUs (gpu/oneapi) - Added new acct_gather_interconnect/sysfs plugin to collect statistics from arbitrary network interfaces. - Expanded and synced set of environment variables available in the Prolog/Epilog/PrologSlurmctld/EpilogSlurmctld scripts. - New "--prefer" option to job submissions to allow for a "soft constraint" request to influence node selection. - Optional support for license planning in the backfill scheduler with "bf_licenses" option in SchedulerParameters. - removed file slurm-2.4.4-init.patch as sysvinit is now realy deprecated - removed file load-pmix-major-version.patch as fixed upstream - set environment variable SUSE_ZNOW to 0 in %build to avoid module load failures due to unresolved symbols as module take advantage of lazy bindings (bsc#1200030).- Add a comment about the CommunicationParameters=block_null_hash option warning users who migrate - just in case.- Update to 21.08.8 which fixes CVE-2022-29500 (bsc#1199278), CVE-2022-29501 (bsc#1199279), and CVE-2022-29502 (bsc#1199281). - Added 'CommunicationParameters=block_null_hash' to slurm.conf, please add this parameter to existing configurations.- Update to 21.08.7 with following changes: * openapi/v0.0.37 - correct calculation for bf_queue_len_mean in /diag. * Avoid shrinking a reservation when overlapping with downed nodes. * Only check TRES limits against current usage for TRES requested by the job. * Do not allocate shared gres (MPS) in whole-node allocations * Constrain slurmstepd to job/step cgroup like in previous versions of Slurm. * Fix warnings on 32-bit compilers related to printf() formats. * Fix reconfigure issues after disabling/reenabling the GANG PreemptMode. * Fix race condition where a cgroup was being deleted while another step was creating it. * Set the slurmd port correctly if multi-slurmd * Fix FAIL mail not being sent if a job was cancelled due to preemption. * slurmrestd - move debug logs for HTTP handling to be gated by debugflag NETWORK to avoid unnecessary logging of communication contents. * Fix issue with bad memory access when shrinking running steps. * Fix various issues with internal job accounting with GRES when jobs are shrunk. * Fix ipmi polling on slurmd reconfig or restart. * Fix srun crash when reserved ports are being used and het step fails to launch. * openapi/dbv0.0.37 - fix DELETE execution path on /user/{user_name}. * slurmctld - Properly requeue all components of a het job if PrologSlurmctld fails. * rlimits - remove final calls to limit nofiles to 4096 but to instead use the max possible nofiles in slurmd and slurmdbd. * Allow the DBD agent to load large messages (up to MAX_BUF_SIZE) from state. * Fix potential deadlock during slurmctld restart when there is a completing job. * slurmstepd - reduce user requested soft rlimits when they are above max hard rlimits to avoid rlimit request being completely ignored and processes using default limits. * Fix Slurm user commands displaying available features as active features when no features were active. * Don't power down nodes that are rebooting. * Clear pending node reboot on power down request. * Ignore node registrations while node is powering down. * Don't reboot any node that is power down. * Don't allow a node to reboot if it's marked for power down. * Fix issuing reboot and downing when rebooting a powering up node. * Clear DRAIN on node after failing to resume before ResumeTimeout. * Prevent repeating power down if node fails to resume before ResumeTimeout. * Fix federated cloud node communication with srun and cloud_dns. * Fix jobs being scheduled on nodes marked to be powered_down when idle. * Fix problem where a privileged user could not view array tasks specified by _ when PrivateData had the jobs value set. - Changes in Slurm 21.08.6 * Fix plugin_name definitions in a number of plugins to improve logging. * Close sbcast file transfers when job is cancelled. * scrontab - fix handling of --gpus and --ntasks-per-gpu options. * sched/backfill - fix job_queue_rec_t memory leak. * Fix magnetic reservation logic in both main and backfill schedulers. * job_container/tmpfs - fix memory leak when using InitScript. * slurmrestd / openapi - fix memory leaks. * Fix slurmctld segfault due to job array resv_list double free. * Fix multi-reservation job testing logic. * Fix slurmctld segfault due to insufficient job reservation parse validation. * Fix main and backfill schedulers handling for already rejected job array. * sched/backfill - restore resv_ptr after yielding locks. * acct_gather_energy/xcc - appropriately close and destroy the IPMI context. * Protect slurmstepd from making multiple calls to the cleanup logic. * Prevent slurmstepd segfault at cleanup time in mpi_fini(). * Fix slurmctld sometimes hanging if shutdown while PrologSlurmctld or EpilogSlurmctld were running and PrologEpilogTimeout is set in slurm.conf. * Fix affinity of the batch step if batch host is different than the first node in the allocation. * slurmdbd - fix segfault after multiple failover/failback operations. * Fix jobcomp filetxt job selection condition. * Fix -f flag of sacct not being used. * Select cores for job steps according to the socket distribution. Previously, sockets were always filled before selecting cores from the next socket. * Keep node in Future state if epilog completes while in Future state. * Fix erroneous --constraint behavior by preventing multiple sets of brackets. * Make ResetAccrueTime update the job's accrue_time to now. * Fix sattach initialization with configless mode. * Revert packing limit checks affecting pmi2. * sacct - fixed assertion failure when using -c option and a federation display * Fix issue that allowed steps to overallocate the job's memory. * Fix the sanity check mode of AutoDetect so that it actually works. * Fix deallocated nodes that didn't actually launch a job from waiting for Epilogslurmctld to complete before clearing completing node's state. * Job should be in a completing state if EpilogSlurmctld when being requeued. * Fix job not being requeued properly if all node epilog's completed before EpilogSlurmctld finished. * Keep job completing until EpilogSlurmctld is completed even when "downing" a node. * Fix handling reboot with multiple job features. * Fix nodes getting powered down when creating new partitions. * Fix bad bit_realloc which potentially could lead to bad memory access. * slurmctld - remove limit on the number of open files. * Fix bug where job_state file of size above 2GB wasn't saved without any error message. * Fix various issues with no_consume gres. * Fix regression in 21.08.0rc1 where job steps failed to launch on systems that reserved a CPU in a cgroup outside of Slurm (for example, on systems with WekaIO). * Fix OverTimeLimit not being reset on scontrol reconfigure when it is removed from slurm.conf. * serializer/yaml - use dynamic buffer to allow creation of YAML outputs larger than 1MiB. * Fix minor memory leak affecting openapi users at process termination. * Fix batch jobs not resolving the username when nss_slurm is enabled. * slurmrestd - Avoid slurmrestd ignoring invalid HTTP method if the response serialized without error. * openapi/dbv0.0.37 - Correct conditional that caused the diag output to give an internal server error status on success. * Make --mem-bind=sort work with task_affinity * Fix sacctmgr to set MaxJobsAccruePer{User|Account} and MinPrioThres in sacctmgr add qos, modify already worked correctly. * job_container/tmpfs - avoid printing extraneous error messages in Prolog and Epilog, and when the job completes. * Fix step CPU memory allocation with --threads-per-core without --exact. * Remove implicit --exact when --threads-per-core or --hint=nomultithread is used. * Do not allow a step to request more threads per core than the allocation did. * Remove implicit --exact when --cpus-per-task is used.- update to 21.08.5 with following changes: * Fix issue where typeless GRES node updates were not immediately reflected. * Fix setting the default scrontab job working directory so that it's the home of the different user (*u ) and not that of root or SlurmUser editor. * Fix stepd not respecting SlurmdSyslogDebug. * Fix concurrency issue with squeue. * Fix job start time not being reset after launch when job is packed onto already booting node. * Fix updating SLURM_NODE_ALIASES for jobs packed onto powering up nodes. * Cray - Fix issues with starting hetjobs. * auth/jwks - Print fatal() message when jwks is configured but file could not be opened. * If sacctmgr has an association with an unknown qos as the default qos print 'UNKN*###' instead of leaving a blank name. * Correctly determine task count when giving --cpus-per-gpu, --gpus and * -ntasks-per-node without task count. * slurmctld - Fix places where the global last_job_update was not being set to the time of update when a job's reason and description were updated. * slurmctld - Fix case where a job submitted with more than one partition would not have its reason updated while waiting to start. * Fix memory leak in node feature rebooting. * Fix time limit permanetly set to 1 minute by backfill for job array tasks higher than the first with QOS NoReserve flag and PreemptMode configured. * Fix sacct -N to show jobs that started in the current second * Fix issue on running steps where both SLURM_NTASKS_PER_TRES and SLURM_NTASKS_PER_GPU are set. * Handle oversubscription request correctly when also requesting * -ntasks-per-tres. * Correctly detect when a step requests bad gres inside an allocation. * slurmstepd - Correct possible deadlock when UnkillableStepTimeout triggers. * srun - use maximum number of open files while handling job I/O. * Fix writing to Xauthority files on root_squash NFS exports, which was preventing X11 forwarding from completing setup. * Fix regression in 21.08.0rc1 that broke --gres=none. * Fix srun --cpus-per-task and --threads-per-core not implicitly setting * -exact. It was meant to work this way in 21.08. * Fix regression in 21.08.0 that broke dynamic future nodes. * Fix dynamic future nodes remembering active state on restart. * Fix powered down nodes getting stuck in COMPLETING+POWERED_DOWN when job is cancelled before nodes are powering up.- updated to 21.08.4 which fixes (CVE-2021-43337) which is only present in 21.08 tree. * CVE-2021-43337: For sites using the new AccountingStoreFlags=job_script and/or job_env options, an issue was reported with the access control rules in SlurmDBD that will permit users to request job scripts and environment files that they should not have access to. (Scripts/environments are meant to only be accessible by user accounts with administrator privileges, by account coordinators for jobs submitted under their account, and by the user themselves.) - changes from 21.08.3: * This includes a number of fixes since the last release a month ago, including one critical fix to prevent a communication issue between slurmctld and slurmdbd for sites that have started using the new AccountingStoreFlags=job_script functionality.- Utilize sysuser infrastructure to set user/group slurm. For munge authentication slurm should have a fixed UID across all nodes including the management server. Set it to 120 - Limit firewalld service definitions to SUSE versions >= 15.- added service definitions for firewalld (JSC#SLE-22741)- update to 21.08.2 - major change: * removed of support of the TaskAffinity=yes option in cgroup.conf. Please consider using "TaskPlugins=cgroup,affinity" in slurm.conf as an option. - minor changes and bugfixes: * slurmctld - fix how the max number of cores on a node in a partition are calculated when the partition contains multi*socket nodes. This in turn corrects certain jobs node count estimations displayed client*side. * job_submit/cray_aries - fix "craynetwork" GRES specification after changes introduced in 21.08.0rc1 that made TRES always have a type prefix. * Ignore nonsensical check in the slurmd for [Pro|Epi]logSlurmctld. * Fix writing to stderr/syslog when systemd runs slurmctld in the foreground. * Fix issue with updating job started with node range. * Fix issue with nodes not clearing state in the database when the slurmctld is started with clean*start. * Fix hetjob components > 1 timing out due to InactiveLimit. * Fix sprio printing -nan for normalized association priority if PriorityWeightAssoc was not defined. * Disallow FirstJobId=0. * Preserve job start info in the database for a requeued job that hadn't registered the first time in the database yet. * Only send one message on prolog failure from the slurmd. * Remove support for TaskAffinity=yes in cgroup.conf. * accounting_storage/mysql - fix issue where querying jobs via sacct * -whole-hetjob=yes or slurmrestd (which automatically includes this flag) could in some cases return more records than expected. * Fix issue for preemption of job array task that makes afterok dependency fail. Additionally, send emails when requeueing happens due to preemption. * Fix sending requeue mail type. * Properly resize a job's GRES bitmaps and counts when resizing the job. * Fix node being able to transition to CLOUD state from non-cloud state. * Fix regression introduced in 21.08.0rc1 which broke a step's ability to inherit GRES from the job when the step didn't request GRES but the job did. * Fix errors in logic when picking nodes based on bracketed anded constraints. This also enforces the requirement to have a count when using such constraints. * Handle job resize better in the database. * Exclude currently running, resized jobs from the runaway jobs list. * Make it possible to shrink a job more than once.- moved pam module from /lib64 to /usr/lib64 which fixes boo#1191095 via the macro %_pam_moduledir- updated to 21.08.1 with following bug fixes: * Fix potential memory leak if a problem happens while allocating GRES for a job. * If an overallocation of GRES happens terminate the creation of a job. * AutoDetect=nvml: Fatal if no devices found in MIG mode. * Print federation and cluster sacctmgr error messages to stderr. * Fix off by one error in --gpu-bind=mask_gpu. * Add --gpu-bind=none to disable gpu binding when using --gpus-per-task. * Handle the burst buffer state "alloc-revoke" which previously would not display in the job correctly. * Fix issue in the slurmstepd SPANK prolog/epilog handler where configuration values were used before being initialized. * Restore a step's ability to utilize all of an allocations memory if --mem=0. * Fix --cpu-bind=verbose garbage taskid. * Fix cgroup task affinity issues from garbage taskid info. * Make gres_job_state_validate() client logging behavior as before 44466a4641. * Fix steps with --hint overriding an allocation with --threads-per-core. * Require requesting a GPU if --mem-per-gpu is requested. * Return error early if a job is requesting --ntasks-per-gpu and no gpus or task count. * Properly clear out pending step if unavailable to run with available resources. * Kill all processes spawned by burst_buffer.lua including decendents. * openapi/v0.0.{35,36,37} - Avoid setting default values of min_cpus, job name, cwd, mail_type, and contiguous on job update. * openapi/v0.0.{35,36,37} - Clear user hold on job update if hold=false. * Prevent CRON_JOB flag from being cleared when loading job state. * sacctmgr - Fix deleting WCKeys when not specifying a cluster. * Fix getting memory for a step when the first node in the step isn't the first node in the allocation. * Make SelectTypeParameters=CR_Core_Memory default for cons_tres and cons_res. * Correctly handle mutex unlocks in the gres code if failures happen. * Give better error message if -m plane is given with no size. * Fix --distribution=arbitrary for salloc. * Fix jobcomp/script regression introduced in 21.08.0rc1 0c75b9ac9d. * Only send the batch node in the step_hostlist in the job credential. * When setting affinity for the batch step don't assume the batch host is node 0. * In task/affinity better checking for node existence when laying out affinity. * slurmrestd - fix job submission with auth/jwt. - removed Fix-statement-condition-in-netloc-autoconf-macro.patch issue was fixed upstream- Fix-statement-condition-in-netloc-autoconf-macro.patch: Fix netloc check, reestablish netloc disable code. - Make configure arg '--with-pmix' conditional. - Move openapi plugins to package slurm-restd.- updated to 21.08.0, major changes: * A new "AccountingStoreFlags=job_script" option to store the job scripts directly in SlurmDBD. * Added "sacct -o SubmitLine" format option to get the submit line of a job/step. * Changes to the node state management so that nodes are marked as PLANNED instead of IDLE if the scheduler is still accumulating resources while waiting to launch a job on them. * RS256 token support in auth/jwt. * Overhaul of the cgroup subsystems to simplify operation, mitigate a number of inherent race conditions, and prepare for future cgroup v2 support. * Further improvements to cloud node power state management. * A new child process of the Slurm controller called "slurmscriptd" responsible for executing PrologSlurmctld and EpilogSlurmctld scripts, which significantly reduces performance issues associated with enabling those options. * A new burst_buffer/lua plugin allowing for site-specific asynchronous job data management. * Fixes to the job_container/tmpfs plugin to allow the slurmd process to be restarted while the job is running without issue. * Added json/yaml output to sacct, squeue, and sinfo commands. * Added a new node_features/helpers plugin to provide a generic way to change settings on a compute node across a reboot. * Added support for automatically detecting and broadcasting shared libraries for an executable launched with "srun --bcast". * Added initial OCI container execution support with a new --container option to sbatch and srun. * Improved "configless" support by allowing multiple control servers to be specified through the slurmd --conf-server option, and send additional configuration files at startup including cli_filter.lua. - minor changes: * If an overallocation of GRES happens terminate the creation of a job. * AutoDetect=nvml: Fatal if no devices found in MIG mode. * Print federation and cluster sacctmgr error messages to stderr. * Add --gpu-bind=none to disable gpu binding when using --gpus-per-task. * Handle the burst buffer state "alloc-revoke" which previously would not display in the job correctly. * Fix issue in the slurmstepd SPANK prolog/epilog handler where configuration values were used before being initialized. * Restored --gpu-bind=single: to check core affinity like * -gpu-bind=closest does. This removal of this behavior only was in rc2. * slurmd - Fix assert failure on initialization due to bad node name. * Fix error codes in cgroup/v1. * Don't destroy the memory step outside fini, which leads to a double destroy causing an error message. * Add support for lua 5.4. * Force cgroup.clone_children to 0 in slurm cgroup directories. This caused issues in task cpuset plugin in systems with it enabled by default. * Clear GRES HAS_TYPE flag when removing type name. * Environment flags in gres.conf now override flags set by AutoDetect. * Environment flags in gres.conf now apply to subsequent gres.conf lines where Environment flags are not set. * Set missing job_uid and job_gid members when preparing a kill_job_msg_t in abort_job_on_node(), abort_job_on_nodes() and kill_job_on_node(). * Fix swappiness not being set in cgroups. * Fix coordinators for new subaccounts. * Fix coordinators when adding existing users with PrivateData=users. * slurmctld - do not attempt to relinquish control to self. * openapi/v0.0.37 - Honor kill_on_invalid_dependency as job parameter. * Check max_gres when doing step allocation, fix for regression in rc2. * SPANK plugins are now required to match the current Slurm version, and must be recompiled for each new Slurm release. * node_features/helpers - add ExecTime configuration option. * srun - Fix force termination with -X. * On slurmctld restart set node typed GRES counts correctly. * Fix places where a step wasn't allocated in the slurmctld but wasn't ever removed from the job. * Fix step allocation memory when using --threads-per-core. * Fix step allocations to consume all threads on a core when using threads-per-core. * Add check to validate cpu request on a step if --threads-per-core is given and it is less than what the core on the node has in the allocation. * Fix issue where a step could request more gres than the job had and the step would hang forever. This bug was only introduced in 21.08.0rc2. * Only print \r\n for logging messages on stderr when --pty has been explicitly requested. * Relax check on SPANK plugins to only require Slurm major + minor versions to match. * job_container/tmpfs - delegate handling of /dev/shm to the extern step so new step launches will be attached correctly even after the slurmd process has been restarted. * Limit the wait time in proctrack_g_wait() to UnkillableStepTimeout instead of a hardcoded value of 256 seconds, and limit the delay between tests to a maximum of 32 seconds. * fatal() on start if using job_container/tmpfs without PrologFlags=Contian. * Load bf_when_last_cycle from job state only if protocol version >= 21.08. * Docs - remove man3 section entirely. * Set step memory when using MemPerGPU or DefMemPerGPU. Previously a step's memory was not set even when it requested *-mem-per-gpu and at least one GPU. * Add cli_filter.lua support in configless mode. * Check that the step requests at least as many gres as nodes. * Make job's SLURM_JOB_GPUS print global GPU IDs instead of MIG unique_ids. * Fix miscounting of GPU envs in prolog/epilog if MultipleFiles was used. * Support MIGs in prolog/epilog's CUDA_VISIBLE_DEVICES & co. * Add SLURM_JOB_GPUS back into Prolog; add it to Epilog. * Fix issue where the original executable, not the bcast'd version, was executed with 'srun *-bcast'. * sacct - print '-' header correctly for fields over 53-characters wide. * openapi/dbv0.0.37 - replace "REST" with "Slurm OpenAPI" for plugin_name. * openapi/v0.0.37 - replace "REST" with "Slurm OpenAPI" for plugin_name. * configless - fix segfault on 'scontrol reconfigure'. * Use FREE_NULL_LIST instead of list_destroy. * If we made are running an interactive session we need to force track_steps. * Disable OPOST flag when using --pty to avoid issues with Emac. * Fix issue where extra bonus core was allocated in some situations. * Avoid putting gres with count of 0 on a TRES req/alloc. * Fix memory in requested TRES when --mem-per-gpu is used. * Changed ReqMem field in sacct to match memory from ReqTRES. * Changed --gpu-bind=single: to no longer check core affinity like * -gpu-bind=closest does. This consequently affects --ntasks-per-gpu. * slurmrestd - add v0.0.37 OpenAPI plugin. * slurmrestd/v0.0.37 - rename standard_in -> standard_input. * slurmrestd/v0.0.37 - rename standard_out -> standard_output. * Changed the --format handling for negative field widths (left justified) to apply to the column headers as well as the printed fields. * Add LimitFactor to the QOS. A float that is factored into an associations [Grp|Max]TRES limits. For example, if the LimitFactor is 2, then an association with a GrpTRES of 30 CPUs, would be allowed to allocate 60 CPUs when running under this QOS. * slurmrestd - Pass SLURM_NO_CHANGE_IN_DATA to client as 403 (Not Modified). * slurmrestd/v0.0.37 - Add update_time field to Jobs query to allow clients to only get jobs list based on change timestamp. * Reset job eligible time when job is manually held. * Add DEBUG_FLAG_JAG to improve logging related to job account gathering. * Convert logging in account_gather/common to DEBUG_FLAG_JAG. * Add more logging for jag_common_poll_data() when prec_extra() called. * slurmrestd/v0.0.37 - add API to fetch reservation(s) info. * Catch more errors in task/cgroup initalization and cleanup to avoid allowing jobs to start when cgroups failure to configure correctly. * Fix cgroup ns detection when using containers (e.g. LXC or Docker). * Reset job's next_step_id counter to 0 after being requeued. * Make scontrol exit with non-zero status after failing to delete a partition or reservation. * Make NtasksPerTRES optional in slurm_sprint_job_info(). * slurmrestd/v0.0.37 - Add update_time field to nodes query to allow clients to only get nodes list based on change timestamp. * common/parse_config - catch and propagate return codes when handling a match on a key-value pattern. This implies error codes detected in the handlers are now not ignored and users of _handle_keyvalue_match() can fatal(). * common/hostlist - fix hostlist_delete_nth() xassert() upper bound check. * API change: Removed slurm_kill_job_msg and modified the function signature for slurm_kill_job2. slurm_kill_job2 should be used instead of slurm_kill_job_msg. * Fix non-zero exit code for scontrol ping when all controllers are down. * Enforce a valid configuration for AccountingStorageEnforce in slurm.conf. If the configuration is invalid, then an error message will be printed and the command or daemon (including slurmctld) will not run. * slurmrestd/v0.0.37 - Add update_time field to partitions/reservations query to allow clients to only get the entities list when something changed. * slurmdbd.service - add "After" relationship to all common names for MariaDB to reduce startup delays. * slurmrestd/v0.0.37 - Correct displaying node states that are UNKNOWN. * slurmrestd/v0.0.37 - Add flags to node states. * Fix first job on fresh cluster not being assigned JobId=1 (or FirstJobId). * squeue - make it so --nodelist is sensitive to --clusters. * squeue - do --nodelist node validation in the same order as listing. * Removed AccountingStoreJobComment option. Please update your config to use AccountingStoreFlags=job_comment instead. * AccountingStoreFlags=job_script allows you to store the job's batch script. * AccountingStoreFlags=job_env allows you to store the job's env vars. * Add sacct -o SubmitLine to get the submit line of a job/step. * Removed DefaultStorage{Host,Loc,Pass,Port,Type,User} options. * Fix NtasksPerTRES delimiter from : to = in scontrol show job output. * Removed CacheGroups, CheckpointType, JobCheckpointDir, MemLimitEnforce, SchedulerPort, SchedulerRootFilter options. * Make job accounting queries use consistent timeframes with and w/o jobs. * --cpus-per-task and --threads-per-core now imply --exact. This fixes issues where steps would be allocated the wrong number of CPUs. * configure: the --with option handling has been made consistent across the various optional libraries. Specifying *-with-foo=/path/to/foo will only check that directory for the applicable library (rather than, in some cases, falling back to the default directories), and will always error the build if the library is not found (instead of a mix of error messages and non- fatal warning messages). * configure: replace --with-rmsi_dir option with proper handling for * -with-rsmi=dir. * Pass additional job environment variables to MailProg. * Add SLURM_JOB_WORK_DIR to Prolog, Epilog. * Removed sched/hold plugin. * Fix srun overwriting SLURM_SUBMIT_DIR and SLURM_SUBMIT_HOST when within an existing allocation. * step_ctx code has been removed from the api. * cli_filter/lua, jobcomp/lua, job_submit/lua now load their scripts from the same directory as the slurm.conf file (and thus now will respect changes to the SLURM_CONF environment variable). * SPANK - call slurm_spank_init if defined without slurm_spank_slurmd_exit in slurmd context. * job_container/tmpfs - Remove need for .active file to allow salloc without an interactive step to work. * slurmd - Delay background node registration on every failure up to 128s on startup. * slurmctld - Always notify slurmd that node registration was accepted to avoid slurmd needless attempting to re-register if there is configuration issue. * Put node into "INVAL" state upon registering with an invalid node configuration. Node must register with a valid configuration to continue. * Make --cpu-bind=threads default for --threads-per-core -- cli and env can override. * jobcomp/elasticsearch - Use data_t to serialize data. The plugin now has the JSON-C library as a prerequisite. * scrontab - create the temporary file under the TMPDIR environment variable (if set), otherwise continue to use TmpFS as configured in slurm.conf. * Add LastBusyTime to "scontrol show nodes" and slurmrestd nodes output, which represents the time the node last had jobs on it. * slurmd - allow multiple comma-separated controllers to be specified in configless mode with *-conf-server * sacctmgr - changed column headings to "ParentID" and "ParentName" instead of "Par ID" and "Par Name" respectively. * Perl API - make sure man pages are installed under the --prefix given to configure. * Manually powering down of nodes with scontrol now ignores SuspendExc. * SALLOC_THREADS_PER_CORE and SBATCH_THREADS_PER_CORE have been added as input environment variables for salloc and sbatch, respectively. They do the same thing as *-threads-per-core. * Distinguish queued reboot requests (REBOOT) from issued reboots (REBOOT^). * Set the maximum number of open files per process to 4096 to avoid performance issues when closing the entire range with closeall(). * auth/jwt - add support for RS256 tokens. * Relax reservation purge due to any invalid uid after creation time. * Reject srun that requests both --exclusive and --overlap. * service files - change dependency to network-online rather than just network to ensure DNS and other services are available. * RSMI: Fix incorrect PCI BDF bits. * plugins/cli_filter - Convert to using data_t to serialize JSON. * Fix testing array job after regaining locks in backfill. * Don't display node's comment with "scontrol show nodes" unless set. * Add "Extra" field to node to store extra information other than a comment. * scrontab - Use /tmp instead of TmpFS if TMPDIR is not set. * Add ResumeTimeout, SuspendTimeout and SuspendTime to Partitions. * sreport - change to sorting TopUsage by the --tres option. * slurmrestd - do not run allow operation as SlurmUser/root by default. * Allow map_cpu and mask_cpu for non-whole node allocation. * TaskPluginParam=verbose is now treated as a default. Previously it would be applied regardless of the job specifying a *-cpu-bind. * Add "node_reg_mem_percent" SlurmctldParameter to define percentage of memory nodes are allowed to register with. * Show correct number of SocketsPerBoard in slurmd -C with hwloc2. * Alter sreport's cluster utilization report column name from 'Reserved' to 'Planned' to match the nomenclature of the 'Planned' node. * Add StateComplete format option to sinfo to show base_state+flags. * "scontrol show node" now shows State as base_state+flags instead of shortened state with flags appended. eg. IDLE# *> IDLE+POWERING_UP. Also "POWER" state flag string is "POWERED_DOWN". * slurmd/req - add missing job_env_t's het_job_id initialization off the request in _rpc_{abort,terminate}_job(). This caused problems for Native Cray builds when joining a CNCU job_container plugin with Epilog configured. * Fix joining a CNCU job_container on a Native Cray build before executing the UnkillableStepProgram for a HetJob step. * slurmrestd/v0.0.35 - Plugin has been tagged as deprecated. * srun - Job steps requiring more cores than available to be rejected unless '--overlap' is specificed. * Add bf_node_space_size to SchedulerParameters. * Add scontrol update node state=POWER_DOWN_FORCE and POWER_DOWN_ASAP as new ways to power off and reset especially CLOUD nodes. * Define and separate node power state transitions. Previously a powering down node was in both states, POWERING_OFF and POWERED_OFF. These are now separated. * Create a new process called slurmscriptd which runs PrologSlurmctld and EpilogSlurmctld. This avoids fork() calls from slurmctld, and can avoid performance issues if the slurmctld has a large memory footprint. * Added new Script option to DebugFlags for debugging slurmscriptd. * scrontab - add ability to update crontab from a file or standard input. * scrontab - add ability to set and expand variables. * Pass JSON of job to node mappings to ResumeProgram. * If running steps in an allocation with CR_PACK_NODE or -mpack the srun will only attempt to allocate as much as needed from the allocation instead of always trying to allocate every node in the allocation. * Jobs that request the whole node now check to see if any gres are allocated. * Rename SbcastParameters to BcastParameters. * Make srun sensitive to BcastParameters. * RSMI: Add gres_links_create_empty() and preserve RSMI enumeration order. * GPUs: Use index instead of dev_num for CUDA_VISIBLE_DEVICES * Don't run epilog on nodes if job never launched. * QOS accrue limits only apply to the job QOS, not partition QOS. * Add --gpu-bind=per_task: option, --gpus-per-task will now set this option by default. * Treat any return code from SPANK plugin that is not SLURM_SUCCESS to be an error or rejection. * Print the statistics for extern step adopted processes in sstat. * Fix SLURM_NODE_ALIASES to work for ipv6 node addrs. * Add support for automatically detecting and broadcasting executable shared object dependencies for sbcast and srun *-bcast.- Updated to 20.11.8: * slurmctld - fix erroneous "StepId=CORRUPT" messages in error logs. * Correct the error given when auth plugin fails to pack a credential. * Fix unused-variable compiler warning on FreeBSD in fd_resolve_path(). * acct_gather_filesystem/lustre - only emit collection error once per step. * Add GRES environment variables (e.g., CUDA_VISIBLE_DEVICES) into the interactive step, the same as is done for the batch step. * Fix various potential deadlocks when altering objects in the database dealing with every cluster in the database. * slurmrestd: - handle slurmdbd connection failures without segfaulting. - fix segfault for searches in slurmdb/v0.0.36/jobs. - remove (non-functioning) users query parameter for slurmdb/v0.0.36/jobs from openapi.json - fix segfault in slurmrestd db/jobs with numeric queries - add argv handling for job/submit endpoint. - add description for slurmdb/job endpoint. * slurmrestd/dbv0.0.36: - Fix values dumped in job state/current and job step state. - Correct description for previous state property. * srun: - fix broken node step allocation in a heterogeneous allocation. - leave SLURM_DIST_UNKNOWN as default for --interactive. * Fail step creation if -n is not multiple of --ntasks-per-gpu. * job_container/tmpfs - Fix slowdown on teardown. * Fix problem with SlurmctldProlog where requeued jobs would never launch. * job_container/tmpfs - Fix issue when restarting slurmd where the namespace mount points could disappear. * sacct: - avoid truncating JobId at 34 characters. - fix segfault when printing StepId (or when using --long). * scancel - fix segfault when --wckey filtering option is used. * select/cons_tres - Fix memory leak. * Prevent file descriptor leak in job_container/tmpfs on slurmd restart. * perlapi/libslurmdb - expose tres_req_str to job hash. * scrontab - close and reopen temporary crontab file to deal with editors that do not change the original file, but instead write out then rename a new file. * sstat - fix linking so that it will work when --without-shared-libslurm was used to build Slurm. * Clear allocated cpus for running steps in a job before handling requested nodes on new step. * Don't reject a step if not enough nodes are available. Instead, defer the step until enough nodes are available to satisfy the request. * Don't reject a step if it requests at least one specific node that is already allocated to another step. Instead, defer the step until the requested node(s) become available. * Better handling of --mem=0. * Ignore DefCpuPerGpu when --cpus-per-task given.- Updated to 20.11.7 which fixes CVE-2021-31215 (bsc#1186024) - New features in 20.11.7: * slurmd - handle configless failures gracefully instead of hanging indefinitely. * select/cons_tres - fix Dragonfly topology not selecting nodes in the same leaf switch when it should as well as requests with *-switches option. * Fix issue where certain step requests wouldn't run if the first node in the job allocation was full and there were idle resources on other nodes in the job allocation. * Fix deadlock issue with Slurmctld. * torque/qstat - fix printf error message in output. * When adding associations or wckeys avoid checking multiple times a user or cluster name. * Fix wrong jobacctgather information on a step on multiple nodes due to timeouts sending its the information gathered on its node. * Fix missing xstrdup which could result in slurmctld segfault on array jobs. * Fix security issue in PrologSlurmctld and EpilogSlurmctld by always prepending SPANK_ to all user-set environment variables. CVE-2021-31215. - New features in 20.11.6: * Fix sacct assert with the --qos option. * Use pkg-config --atleast-version instead of --modversion for systemd. * common/fd - fix getsockopt() call in fd_get_socket_error(). * Properly handle the return from fd_get_socket_error() in _conn_readable(). * cons_res - Fix issue where running jobs were not taken into consideration when creating a reservation. * Avoid a deadlock between job_list for_each and assoc QOS_LOCK. * Fix TRESRunMins usage for partition qos on restart/reconfig. * Fix printing of number of tasks on a completed job that didn't request tasks. * Fix updating GrpTRESRunMins when decrementing job time is bigger than it. * Make it so we handle multithreaded allocations correctly when doing - -exclusive or --core-spec allocations. * Fix incorrect round-up division in _pick_step_cores * Use appropriate math to adjust cpu counts when --ntasks-per-core=1. * cons_tres - Fix consideration of power downed nodes. * cons_tres - Fix DefCpuPerGPU, increase cpus-per-task to match with gpus-per-task * cpus-per-gpu. * Fix under-cpu memory auto-adjustment when MaxMemPerCPU is set. * Make it possible to override CR_CORE_DEFAULT_DIST_BLOCK. * Perl API - fix retrieving/storing of slurm_step_id_t in job_step_info_t. * Recover state of burst buffers when slurmctld is restarted to avoid skipping burst buffer stages. * Fix race condition in burst buffer plugin which caused a burst buffer in stage-in to not get state saved if slurmctld stopped. * auth/jwt - print an error if jwt_file= has not been set in slurmdbd. * Fix RESV_DEL_HOLD not being a valid state when using squeue --states. * Add missing squeue selectable states in valid states error message. * Fix scheduling last array task multiple times on error, causing segfault. * Fix issue where a step could be allocated more memory than the job when dealing with --mem-per-cpu and --threads-per-core. * Fix removing qos from assoc with -= can lead to assoc with no qos * auth/jwt - fix segfault on invalid credential in slurmdbd due to missing validate_slurm_user() function in context. * Fix single Port= not being applied to range of nodes in slurm.conf * Fix Jobs not requesting a tres are not starting because of that tres limit. * acct_gather_energy/rapl - fix AveWatts calculation. * job_container/tmpfs - Fix issues with cleanup and slurmd restarting on running jobs.- Ship REST API version and auth plugins with slurmrestd. - Add YAML support for REST API to build (bsc#1185603).- Udpate to 20.11.5: - New features: * New job_container/tmpfs plugin developed by NERSC that can be used to create per-job filesystem namespaces. Documentaiion and configuration can be found in the respecting man page. - Bug fixes: * Fix main scheduler bug where bf_hetjob_prio truncates SchedulerParameters. * Fix sacct not displaying UserCPU, SystemCPU and TotalCPU for large times. * scrontab - fix to return the correct index for a bad #SCRON option. * scrontab - fix memory leak when invalid option found in #SCRON line. * Add errno for when a user requests multiple partitions and they are using partition based associations. * Fix issue where a job could run in a wrong partition when using EnforcePartLimits=any and partition based associations. * Remove possible deadlock when adding associations/wckeys in multiple threads. * When using PrologFlags=alloc make sure the correct Slurm version is set in the credential. * When sending a job a warning signal make sure we always send SIGCONT beforehand. * Fix issue where a batch job would continue running if a prolog failed on a node that wasn't the batch host and requeuing was disabled. * Fix issue where sometimes salloc/srun wouldn't get a message about a prolog failure in the job's stdout. * Requeue or kill job on a prolog failure when PrologFlags is not set. * Fix race condition causing node reboots to get requeued before ResumeTimeout expires. * Preserve node boot_req_time on reconfigure. * Preserve node power_save_req_time on reconfigure. * Fix node reboots being queued and issued multiple times and preventing the reboot to time out. * Fix run_command to exit correctly if track_script kills the calling thread. * Only requeue a job when the PrologSlurmctld returns nonzero. * When a job is signaled with SIGKILL make sure we flush all prologs/setup scripts. * Handle burst buffer scripts if the job is canceled while stage_in is happening. * When shutting down the slurmctld make note to ignore error message when we have to kill a prolog/setup script we are tracking. * scrontab - add support for the --open-mode option. * acct_gather_profile/influxdb - avoid segfault on plugin shutdown if setup has not completed successfully. * Reduce delay in starting salloc allocations when running with prologs. * Alter AllocNodes check to work if the allocating node's domain doesn't match the slurmctld's. This restores the pre*20.11 behavior. * Fix slurmctld segfault if jobs from a prior version had the now-removed INVALID_DEPEND state flag set and were allowed to run in 20.11. * Add job_container/tmpfs plugin to give a method to provide a private /tmp per job. * Set the correct core affinity when using AutoDetect. * slurmrestd - mark "environment" as required for job submissions in schema.- Udpate to 20.11.04 * Fix node selection for advanced reservations with features. * mpi/pmix: Handle pipe failure better when using ucx. * mpi/pmix: include PMIX_NODEID for each process entry. * Fix job getting rejected after being requeued on same node that died. * job_submit/lua - add "network" field. * Fix situations when a reoccuring reservation could erroneously skip a period. * Ensure that a reservations [pro|epi]log are ran on reoccuring reservations. * Fix threads-per-core memory allocation issue when using CR_CPU_MEMORY. * Fix scheduling issue with --gpus. * Fix gpu allocations that request --cpus-per-task. * mpi/pmix: fixed print messages for all PMIXP_* macros * Add mapping for XCPU to --signal option. * Fix regression in 20.11 that prevented a full pass of the main scheduler from ever executing. * Work around a glibc bug in which "0" is incorrectly printed as "nan" which will result in corrupted association state on restart. * Fix regression in 20.11 which made slurmd incorrectly attempt to find the parent slurmd address when not applicable and send incorrect reverse*tree info to the slurmstepd. * Fix cgroup ns detection when using containers (e.g. LXC or Docker). * scrontab - change temporary file handling to work with emacs. - Removed check-for-lipmix.so.MAJOR.patch - Added: load-pmix-major-version.patch- Update to 20.11.03 - This release includes a major functional change to how job step launch is handled compared to the previous 20.11 releases. This affects srun as well as MPI stacks - such as Open MPI - which may use srun internally as part of the process launch. One of the changes made in the Slurm 20.11 release was to the semantics for job steps launched through the 'srun' command. This also inadvertently impacts many MPI releases that use srun underneath their own mpiexec/mpirun command. For 20.11.{0,1,2} releases, the default behavior for srun was changed such that each step was allocated exactly what was requested by the options given to srun, and did not have access to all resources assigned to the job on the node by default. This change was equivalent to Slurm setting the --exclusive option by default on all job steps. Job steps desiring all resources on the node needed to explicitly request them through the new '--whole' option. In the 20.11.3 release, we have reverted to the 20.02 and older behavior of assigning all resources on a node to the job step by default. This reversion is a major behavioral change which we would not generally do on a maintenance release, but is being done in the interest of restoring compatibility with the large number of existing Open MPI (and other MPI flavors) and job scripts that exist in production, and to remove what has proven to be a significant hurdle in moving to the new release. Please note that one change to step launch remains - by default, in 20.11 steps are no longer permitted to overlap on the resources they have been assigned. If that behavior is desired, all steps must explicitly opt-in through the newly added '--overlap' option. Further details and a full explanation of the issue can be found at: https://bugs.schedmd.com/show_bug.cgi?id=10383#c63 - Other changes from 20.11.03 * Fix segfault when parsing bad "#SBATCH hetjob" directive. * Allow countless gpu:srun, sbatch->srun sequence. * Reject job credential if non-superuser sets the LAUNCH_NO_ALLOC flag. * Make it so srun --no-allocate works again. * jobacct_gather/linux - Don't count memory on tasks that have already finished. * Fix 19.05/20.02 batch steps talking with a 20.11 slurmctld. * jobacct_gather/common - Do not process jobacct's with same taskid when calling prec_extra. * Cleanup all tracked jobacct tasks when extern step child process finishes. * slurmrestd/dbv0.0.36 - Correct structure of dbv0.0.36_tres_list. * Fix regression causing task/affinity and task/cgroup to be out of sync when configured ThreadsPerCore is different than the physical threads per core. * Fix situation when --gpus is given but not max nodes (-N1-1) in a job allocation. * Interactive step - ignore cpu bind and mem bind options, and do not set the associated environment variables which lead to unexpected behavior from srun commands launched within the interactive step. * Handle exit code from pipe when using UCX with PMIx.- Fix fallout introduced by: "Replace '%service_del_postun -n' with '%service_del_postun_without_restart'" for older Leap/SLE versions.- Fix Provides:/Conflicts: for libnss_slurm (bsc#1180700).- Add support for configuration files from external plugins. While built-in plugins have their configuration added in slurm.conf, external SPANK plugins add their configuration to plugstack.conf To allow packaging easily spank plugins, their configuration files should be added independently at /etc/spack/plugstack.conf.d and plugstack.conf should be left with an oneliner including all the files under /etc/spack/plugstack.conf.d- Update to 20.11.02 * Fix older versions of sacct not working with 20.11. * Fix slurmctld crash when using a pre-20.11 srun in a job allocation. * Correct logic problem in _validate_user_access. * Fix libpmi to initialize Slurm configuration correctly. - Update to 20.11.01 * Fix spelling of "overcomited" to "overcomitted" in sreport's cluster utilization report. * Silence debug message about shutting down backup controllers if none are configured. * Don't create interactive srun until PrologSlurmctld is done. * Fix fd symlink path resolution. * Fix slurmctld segfault on subnode reservation restore after node configuration change. * Fix resource allocation response message environment allocation size. * Ensure that details->env_sup is NULL terminated. * select/cray_aries - Correctly remove jobs/steps from blades using NPC. * cons_tres - Avoid max_node_gres when entire node is allocated with - -ntasks-per-gpu. * Allow NULL arg to data_get_type(). * In sreport have usage for a reservation contain all jobs that ran in the reservation instead of just the ones that ran in the time specified. This matches the report for the reservation is not truncated for a time period. * Fix issue with sending wrong batch step id to a < 20.11 slurmd. * Add a job's alloc_node to lua for job modification and completion. * Fix regression getting a slurmdbd connection through the perl API. * Stop the extern step terminate monitor right after proctrack_g_wait(). * Fix removing the normalized priority of assocs. * slurmrestd/v0.0.36 - Use correct name for partition field: "min nodes per job" -"min_nodes_per_job". * slurmrestd/v0.0.36 - Add node comment field. * Fix regression marking cloud nodes as "unexpectedly rebooted" after multiple boots. * Fix slurmctld segfault in _slurm_rpc_job_step_create(). * slurmrestd/v0.0.36 - Filter node states against NODE_STATE_BASE to avoid the extended states all being reported as "invalid". * Fix race that can prevent the prolog for a requeued job from running. * cli_filter - add "type" to readily distinguish between the CLI command in use. * smail - reduce sleep before seff to 5 seconds. * Ensure SPANK prolog and epilog run without an explicit PlugStackConfig. * Disable MySQL automatic reconnection. * Fix allowing "b" after memory unit suffixes. * Fix slurmctld segfault with reservations without licenses. * Due to internal restructuring ahead of the 20.11 release, applications calling libslurm MUST call slurm_init(NULL) before any API calls. Otherwise the API call is likely to fail due to libslurm's internal configuration not being available. * slurm.spec - allow custom paths for PMIx and UCX install locations. * Use rpath if enabled when testing for Mellanox's UCX libraries. * slurmrestd/dbv0.0.36 - Change user query for associations to optional. * slurmrestd/dbv0.0.36 - Change account query for associations to optional. * mpi/pmix - change the error handler error message to be more useful. * Add missing connection in acct_storage_p_{clear_stats, reconfig, shutdown}. * Perl API - fix issue when running in configless mode. * nss_slurm - avoid deadlock when stray sockets are found. * Display correct value for ScronParameters in 'scontrol show config'- Update to version 20.11.0 Slurm 20.11 includes a number of new features including: * Overhaul of the job step management and launch code, alongside improved GPU task placement support. * A new "Interactive Step" mode of operation for salloc. * A new "scrontab" command that can be used to submit and manage periodically repeating jobs. * IPv6 support. * Changes to the reservation logic, with new options allowing users to delete reservations, allowing admins to skip the next occurance of a repeated reservation, and allowing for a job to be submitted and eligible to run within multiple reservations. * Dynamic Future Nodes - automatically associate a dynamically provisioned (or "cloud") node against a NodeName definition with matching hardware. * An experimental new RPC queuing mode for slurmctld to reduce thread contention on heavily loaded clusters. * SlurmDBD integration with the Slurm REST API. Also check https://github.com/SchedMD/slurm/blob/slurm-20-11-0-1/RELEASE_NOTES- Updated to 20.02.6, addresses two security fixes: * PMIx - fix potential buffer overflows from use of unpackmem(). CVE-2020-27745 (bsc#1178890) * X11 forwarding - fix potential leak of the magic cookie when sent as an argument to the xauth command. CVE-2020-27746 (bsc#1178891) - And many other bugfixes, full log and details available at: * https://lists.schedmd.com/pipermail/slurm-announce/2020/000045.html- Replace '%service_del_postun -n' with '%service_del_postun_without_restart' '-n' is deprecated and will be removed in the future.- Updated to 20.02.5, changes: * Fix leak of TRESRunMins when job time is changed with --time-min * pam_slurm - explicitly initialize slurm config to support configless mode. * scontrol - Fix exit code when creating/updating reservations with wrong Flags. * When a GRES has a no_consume flag, report 0 for allocated. * Fix cgroup cleanup by jobacct_gather/cgroup. * When creating reservations/jobs don't allow counts on a feature unless using an XOR. * Improve number of boards discovery * Fix updating a reservation NodeCnt on a zero-count reservation. * slurmrestd - provide an explicit error messages when PSK auth fails. * cons_tres - fix job requesting single gres per-node getting two or more nodes with less CPUs than requested per-task. * cons_tres - fix calculation of cores when using gres and cpus-per-task. * cons_tres - fix job not getting access to socket without GPU or with less than --gpus-per-socket when not enough cpus available on required socket and not using --gres-flags=enforce binding. * Fix HDF5 type version build error. * Fix creation of CoreCnt only reservations when the first node isn't available. * Fix wrong DBD Agent queue size in sdiag when using accounting_storage/none. * Improve job constraints XOR option logic. * Fix preemption of hetjobs when needed nodes not in leader component. * Fix wrong bit_or() messing potential preemptor jobs node bitmap, causing bad node deallocations and even allocation of nodes from other partitions. * Fix double-deallocation of preempted non-leader hetjob components. * slurmdbd - prevent truncation of the step nodelists over 4095. * Fix nodes remaining in drain state state after rebooting with ASAP option. - changes from 20.02.4: * srun - suppress job step creation warning message when waiting on PrologSlurmctld. * slurmrestd - fix incorrect return values in data_list_for_each() functions. * mpi/pmix - fix issue where HetJobs could fail to launch. * slurmrestd - set content-type header in responses. * Fix cons_res GRES overallocation for --gres-flags=disable-binding. * Fix cons_res incorrectly filtering cores with respect to GRES locality for - -gres-flags=disable-binding requests. * Fix regression where a dependency on multiple jobs in a single array using underscores would only add the first job. * slurmrestd - fix corrupted output due to incorrect use of memcpy(). * slurmrestd - address a number of minor Coverity warnings. * Handle retry failure when slurmstepd is communicating with srun correctly. * Fix jobacct_gather possibly duplicate stats when _is_a_lwp error shows up. * Fix tasks binding to GRES which are closest to the allocated CPUs. * Fix AMD GPU ROCM 3.5 support. * Fix handling of job arrays in sacct when querying specific steps. * slurmrestd - avoid fallback to local socket authentication if JWT authentication is ill-formed. * slurmrestd - restrict ability of requests to use different authentication plugins. * slurmrestd - unlink named unix sockets before closing. * slurmrestd - fix invalid formatting in openapi.json. * Fix batch jobs stuck in CF state on FrontEnd mode. * Add a separate explicit error message when rejecting changes to active node features. * cons_common/job_test - fix slurmctld SIGABRT due to double-free. * Fix updating reservations to set the duration correctly if updating the start time. * Fix update reservation to promiscuous mode. * Fix override of job tasks count to max when ntasks-per-node present. * Fix min CPUs per node not being at least CPUs per task requested. * Fix CPUs allocated to match CPUs requested when requesting GRES and threads per core equal to one. * Fix NodeName config parsing with Boards and without CPUs. * Ensure SLURM_JOB_USER and SLURM_JOB_UID are set in SrunProlog/Epilog. * Fix error messages for certain invalid salloc/sbatch/srun options. * pmi2 - clean up sockets at step termination. * Fix 'scontrol hold' to work with 'JobName'. * sbatch - handle --uid/--gid in #SBATCH directives properly. * Fix race condition in job termination on slurmd. * Print specific error messages if trying to run use certain priority/multifactor factors that cannot work without SlurmDBD. * Avoid partial GRES allocation when --gpus-per-job is not satisfied. * Cray - Avoid referencing a variable outside of it's correct scope when dealing with creating steps within a het job. * slurmrestd - correctly handle larger addresses from accept(). * Avoid freeing wrong pointer with SlurmctldParameters=max_dbd_msg_action with another option after that. * Restore MCS label when suspended job is resumed. * Fix insufficient lock levels. * slurmrestd - use errno from job submission. * Fix "user" filter for sacctmgr show transactions. * Fix preemption logic. * Fix no_consume GRES for exclusive (whole node) requests. * Fix regression in 20.02 that caused an infinite loop in slurmctld when requesting --distribution=plane for the job. * Fix parsing of the --distribution option. * Add CONF READ_LOCK to _handle_fed_send_job_sync. * prep/script - always call slurmctld PrEp callback in _run_script(). * Fix node estimation for jobs that use GPUs or --cpus-per-task. * Fix jobcomp, job_submit and cli_filter Lua implementation plugins causing slurmctld and/or job submission CLI tools segfaults due to bad return handling when the respective Lua script failed to load. * Fix propagation of gpu options through hetjob components. * Add SLURM_CLUSTERS environment variable to scancel. * Fix packing/unpacking of "unlinked" jobs. * Connect slurmstepd's stderr to srun for steps launched with --pty. * Handle MPS correctly when doing exclusive allocations. * slurmrestd - fix compiling against libhttpparser in a non-default path. * slurmrestd - avoid compilation issues with libhttpparser < 2.6. * Fix compile issues when compiling slurmrestd without --enable-debug. * Reset idle time on a reservation that is getting purged. * Fix reoccurring reservations that have Purge_comp= to keep correct duration if they are purged. * scontrol - changed the "PROMISCUOUS" flag to "MAGNETIC" * Early return from epilog_set_env in case of no_consume. * Fix cons_common/job_test start time discovery logic to prevent skewed results between "will run test" executions. * Ensure TRESRunMins limits are maintained during "scontrol reconfigure". * Improve error message when host lookup fails. - Refresh patch: pam_slurm-Initialize-arrays-and-pass-sizes.patch- Add support for openPMIx also for Leap/SLE 15.0/1 (bsc#1173805). - Do not run %check on SLE-12-SP2: Some incompatibility in tcl makes this fail. - Remove unneeded build dependency to postgresql-devel. - Disable build on s390 (requires 64bit).- Bring QA to the package build: add %%check stage. - Remove cruft that isn't needed any longer. - Add 'ghosted' run-file. - Add rpmlint filter to handle issues with library packages for Leap and enterprise upgrade versions.- Updated to 20.02.3 which fixes CVE-2020-12693 (bsc#1172004). - Other changes are: * Factor in ntasks-per-core=1 with cons_tres. * Fix formatting in error message in cons_tres. * Fix calling stat on a NULL variable. * Fix minor memory leak when using reservations with flags=first_cores. * Fix gpu bind issue when CPUs=Cores and ThreadsPerCore > 1 on a node. * Fix --mem-per-gpu for heterogenous --gres requests. * Fix slurmctld load order in load_all_part_state(). * Fix race condition not finding jobacct gather task cgroup entry. * Suppress error message when selecting nodes on disjoint topologies. * Improve performance of _pack_default_job_details() with large number of job * arguments. * Fix archive loading previous to 17.11 jobs per-node req_mem. * Fix regresion validating that --gpus-per-socket requires --sockets-per-node * for steps. Should only validate allocation requests. * error() instead of fatal() when parsing an invalid hostlist. * nss_slurm - fix potential deadlock in slurmstepd on overloaded systems. * cons_tres - fix --gres-flags=enforce-binding and related --cpus-per-gres. * cons_tres - Allocate lowest numbered cores when filtering cores with gres. * Fix getting system counts for named GRES/TRES. * MySQL - Fix for handing typed GRES for association rollups. * Fix step allocations when tasks_per_core > 1. * Fix allocating more GRES than requested when asking for multiple GRES types.- Treat libnss_slurm like any other package: add version string to upgrade package.- Updated to 20.02.1 with following changes" * Improve job state reason for jobs hitting partition_job_depth. * Speed up testing of singleton dependencies. * Fix negative loop bound in cons_tres. * srun - capture the MPI plugin return code from mpi_hook_client_fini() and use as final return code for step failure. * Fix segfault in cli_filter/lua. * Fix --gpu-bind=map_gpu reusability if tasks > elements. * Make sure config_flags on a gres are sent to the slurmctld on node registration. * Prolog/Epilog - Fix missing GPU information. * Fix segfault when using config parser for expanded lines. * Fix bit overlap test function. * Don't accrue time if job begin time is in the future. * Remove accrue time when updating a job start/eligible time to the future. * Fix regression in 20.02.0 that broke --depend=expand. * Reset begin time on job release if it's not in the future. * Fix for recovering burst buffers when using high-availability. * Fix invalid read due to freeing an incorrectly allocated env array. * Update slurmctld -i message to warn about losing data. * Fix scontrol cancel_reboot so it clears the DRAIN flag and node reason for a pending ASAP reboot.- Remove legacy_cray: with 20.02 the special treatment for cray-specific plugins on SLE version prior to 15SP2 is no longer required.- slurm-plugins will now also require pmix not only libpmix (bsc#1164326)- Removed autopatch as it doesn't work for the SLE-11-SP4 build.- Disable %arm builds as this is no longer supported.- pmix searches now also for libpmix.so.2 so that there is no dependency for devel package (bsc#1164386) * added patch file check-for-lipmix.so.MAJOR.patch * reworded patch file Remove-rpath-from-build.patch to use %autopatch- Update to version 20.02.0 (jsc#SLE-8491) * Fix minor memory leak in slurmd on reconfig. * Fix invalid ptr reference when rolling up data in the database. * Change shtml2html.py to require python3 for RHEL8 support, and match man2html.py. * slurm.spec - override "hardening" linker flags to ensure RHEL8 builds in a usable manner. * Fix type mismatches in the perl API. * Prevent use of uninitialized slurmctld_diag_stats. * Fixed various Coverity issues. * Only show warning about root-less topology in daemons. * Fix accounting of jobs in IGNORE_JOBS reservations. * Fix issue with batch steps state not loading correctly when upgrading from 19.05. * Deprecate max_depend_depth in SchedulerParameters and move it to DependencyParameters. * Silence erroneous error on slurmctld upgrade when loading federation state. * Break infinite loop in cons_tres dealing with incorrect tasks per tres request resulting in slurmctld hang. * Improve handling of --gpus-per-task to make sure appropriate number of GPUs is assigned to job. * Fix seg fault on cons_res when requesting --spread-job. - Move to python3 for everything but SLE-11-SP4 * For SLE-11-SP4 add a workaround to handle a python3 script (python2.7 compliant).- Add explicit version dependency to libpmix as well. 'slurm-devel' has a tight version dependency on libpmix - allowing multiple libpmix versions in one package repository is therefore essential.- Update to version 20.02.0-rc1 * sbatch - fix segfault when no newline at the end of a burst buffer file. * Change scancel to only check job's base state when matching -t options. * Save job dependency list in state files. * cons_tres - allow jobs to be run on systems with root-less topologies. * Restore pre-20.02pre1 PrologSlurmctld synchonization behavior to avoid various race conditions, and ensure proper batch job launch. * Add new slurmrestd command/daemon which implements the Slurm REST API.- Update to version 20.02.0-0pre1, highlights are Highlights: * Exclusive behavior of a node includes all GRES on a node as well as the cpus. * Use python3 instead of python for internal build/test scripts. The slurm.spec file has been updated to depend on python3 as well. * Added new NodeSet configuration option to help simplify partition configuration sections for heterogeneous / condo*style clusters. * Added slurm.conf option MaxDBDMsgs to control how many messages will be stored in the slurmctld before throwing them away when the slurmdbd is down. * The checkpoint plugin interface and all associated API calls have been removed. * slurm_init_job_desc_msg() initializes mail_type as uint16_t. This allows mail_type to be set to NONE with scontrol. * Add new slurm_spank_log() function to print messages back to the user from within a SPANK plugin without prepending "error: " from slurm_error(). * Enforce having partition name and nodelist=ALL when creating reservations with flags=PART_NODES. * SPANK - removed never-implemented slurm_spank_slurmd_init() interface. This hook has always been accessible through slurm_spank_init() in the S_CTX_SLURMD context instead. * sbcast - add new BcastAddr option to NodeName lines to allow sbcast traffic to flow over an alternate network path. * Added auth/jwt plugin, and 'scontrol token' subcommand. PMIx - improve * performance of proc map generation. Deprecate kill_invalid_depend in * SchedulerParameters and move it to a new option called DependencyParameters. * Enable job dependencies for any job on any cluster in the same federation. * Allow clusters to be added automatically to db at startup of ctld. Add * AccountingStorageExternalHost slurm.conf parameter. The * "ConditionPathExists" condition in slurmd.service has been disabled by default to permit simpler installation of a "configless" Slurm cluster. * In SchedulerParameters remove deprecated max_job_bf and replace with bf_max_job_test. * Disable sbatch, salloc, srun --reboot for non-admins. SPANK - added support * for S_JOB_GID in the job script context with spank_get_item(). * Prolog/Epilog - add SLURM_JOB_GID environment variable. configuration file changes: * The mpi/openmpi plugin has been removed as it does nothing. MpiDefault=openmpi will be translated to the functionally-equivalent MpiDefault=none. command changes (see man pages for details) * Display StepId=.batch instead of StepId=.4294967294 in output of "scontrol show step". (slurm_sprint_job_step_info()) * MPMD in srun will now defer PATH resolution for the commands to launch to slurmstepd. Previously it would handle resolution client*side, but with a non*standard approach that walked PATH in reverse. * squeue - added "--me" option, equivalent to --user=$USER. * The LicensesUsed line has been removed from 'scontrol show config'. Please see the 'scontrol show licenses' command as an alternative. * sbatch - adjusted backoff times for "--wait" option to reduce load on slurmctld. This results in a steady*state delay of 32s between queries, instead of the prior 10s delay. - Removed following deprecated patches: * removed patch slurmctld-rerun-agent_init-when-backup-controller-takes-over.patch * removed patch split-xdaemon-in-xdaemon_init-and-xdaemon_finish-for.patch * removed patch slurmctld-uses-xdaemon_-for-systemd.patch * removed patch slurmd-uses-xdaemon_-for-systemd.patch * removed patch slurmdbd-uses-xdaemon_-for-systemd.patch * removed patch slurmsmwd-uses-xdaemon_-for-systemd.patch * removed patch removed-deprecated-xdaemon.patch- standard slurm.conf uses now also SlurmctldHost on all build targets (bsc#1162377)- Fix a missed systemd_requires -> systemd_ordering conversion.- Remove special OHPC compatibility macro: these settings should be applied univerally. - Add a Recommends for mariadb to slurm-slurmdbd: it is recommened to run the database on the same machine as the daemon.- BuildRequire pkgconfig(systemd) instead of systemd: allow OBS to shortcut through the -mini flavors. - Use systemd_ordering instead of systemd_requires: systemd is never a strict requirement; but in case the system is scheduled for installation together with systemd, we want systemd to be installed prior to slurm.- start slurmdbd after mariadb (bsc#1161716)- Fix base_ver for SLE 15 SP2.- Update to version 19.05.5 (jsc#SLE-8491) * Check %docdir/NEWS for details. * Includes security fixes CVE-2019-19727, CVE-2019-19728, CVE-2019-12838. * Disable i586 builds as this is no longer supported. * Create libnss_slurm package to support user and group resolution thru slurmstepd. * slurm-2.4.4-rpath.patch -> Remove-rpath-from-build.patch Obsoleted: - pam_slurm_adopt-avoid-running-outside-of-the-sshd-PA.patch - pam_slurm_adopt-send_user_msg-don-t-copy-undefined-d.patch - pam_slurm_adopt-use-uid-to-determine-whether-root-is.patch- Deprecate "ControlMachine" only for SLURM version upgrades and products newer than 1501. This ensures that the original setting is retained for the SLURM version shipped origianlly with SLE-15-SP1 or Leap 15.1.- Update to v18.08.9 for fixing CVE-2019-19728 (bsc#1159692). * Wrap END_TIMER{,2,3} macro definition in "do {} while (0)" block. * Make sview work with glib2 v2.62. * Make Slurm compile on linux after sys/sysctl.h was deprecated. * Install slurmdbd.conf.example with 0600 permissions to encourage secure use. CVE-2019-19727. * srun - do not continue with job launch if --uid fails. CVE-2019-19728.- added pmix support jsc#SLE-10800- Use --with-shared-libslurm to build slurm binaries using libslurm. - Make libslurm depend on slurm-config.- Fix ownership of /var/spool/slurm on new installations and upgrade (boo#1158696).- Fix permissions of slurmdbd.conf (bsc#1155784, CVE-2019-19727). - Fix %posttrans macro _res_update to cope with added newline (bsc#1153259).- Add package slurm-webdoc which sets up a web server to provide the documentation for the version shipped.- Move srun from 'slurm' to 'slurm-node': srun is required on the nodes as well so sbatch will work. 'slurm-node' is a requirement when 'slurm' is installed (bsc#1153095).- Set %base_ver for SLE-15-SP2 to 18.08 (for now).- Edit sample configuration to deprecate "ControlMachine", "ControlAddr", "BackupController" and "BackupAddr" in favor "SlurmctldHost".- Fix logic of slurm-munge recommends: slurm-munge requires munge already, so if we have munge installed we recommend slurm-munge as the authentication when installing slurm or slurm-node.- Fix build for SLE-11-SP4 and older.- added cray depend libraries to seperate package, as they are now built, since json is enabled- Updated to 18.08.8 for fixing (CVE-2019-12838, bsc#1140709, jsc#SLE-7341, jsc#SLE-7342) * Update "xauth list" to use the same 10000ms timeout as the other xauth commands. * Fix issue in gres code to handle a gres cnt of 0. * Don't purge jobs if backfill is running. * Verify job is pending add/removing accrual time. * Don't abort when the job doesn't have an association that was removed before the job was able to make it to the database. * Set state_reason if select_nodes() fails job for QOS or Account. * Avoid seg_fault on referencing association without a valid_qos bitmap. * If Association/QOS is removed on a pending job set that job as ineligible. * When changing a jobs account/qos always make sure you remove the old limits. * Don't reset a FAIL_QOS or FAIL_ACCOUNT job reason until the qos or account changed. * Restore "sreport -T ALL" functionality. * Correctly typecast signals being sent through the api. * Properly initialize structures throughout Slurm. * Sync "numtask" squeue format option for jobs and steps to "numtasks". * Fix sacct -PD to avoid CA before start jobs. * Fix potential deadlock with backup slurmctld. * Fixed issue with jobs not appearing in sacct after dependency satisfied. * Fix showing non-eligible jobs when asking with -j and not -s. * Fix issue with backfill scheduler scheduling tasks of an array when not the head job. * accounting_storage/mysql - fix SIGABRT in the archive load logic. * accounting_storage/mysql - fix memory leak in the archive load logic. * Limit records per single SQL statement when loading archived data. * Fix unnecessary reloading of job submit plugins. * Allow job submit plugins to be turned on/off with a reconfigure. * Fix segfault when loading/unloading Lua job submit plugin multiple times. * Fix printing duplicate error messages of jobs rejected by job submit plugin. * Fix printing of job submit plugin messages of het jobs without pack id. * Fix memory leak in group_cache.c * Fix jobs stuck from FedJobLock when requeueing in a federation * Fix requeueing job in a federation of clusters with differing associations * sacctmgr - free memory before exiting in 'sacctmgr show runaway'. * Fix seff showing memory overflow when steps tres mem usage is 0. * Upon archive file name collision, create new archive file instead of overwriting the old one to prevent lost records. * Limit archive files to 50000 records per file so that archiving large databases will succeed. * Remove stray newlines in SPANK plugin error messages. * Fix archive loading events. * In select/cons_res: Only allocate 1 CPU per node with the --overcommit and - -nodelist options. * Fix main scheduler from potentially not running through whole queue. * cons_res/job_test - prevent a job from overallocating a node memory. * cons_res/job_test - fix to consider a node's current allocated memory when testing a job's memory request. * Fix issue where multi-node job steps on cloud nodes wouldn't finish cleaning up until the end of the job (rather than the end of the step). * Fix issue with a 17.11 sbcast call to a 18.08 daemon. * Add new job bit_flags of JOB_DEPENDENT. * Make it so dependent jobs reset the AccrueTime and do not count against any AccrueTime limits. * Fix sacctmgr --parsable2 output for reservations and tres. * Prevent slurmctld from potential segfault after job_start_data() called for completing job. * Fix jobs getting on nodes with "scontrol reboot asap". * Record node reboot events to database. * Fix node reboot failure message getting to event table. * Don't write "(null)" to event table when no event reason exists. * Fix minor memory leak when clearing runaway jobs. * Avoid flooding slurmctld and logging when prolog complete RPC errors occur. * Fix GCC 9 compiler warnings. * Fix seff human readable memory string for values below a megabyte. * Fix dump/load of rejected heterogeneous jobs. * For heterogeneous jobs, do not count the each component against the QOS or association job limit multiple times. * slurmdbd - avoid reservation flag column corruption with the use of newer flags, instead preserve the older flag fields that we can still fit in the smallint field, and discard the rest. * Fix security issue in accounting_storage/mysql plugin on archive file loads by always escaping strings within the slurmdbd. CVE-2019-12838.- Fix build dependency issue around libibmad-devel introduced in SLE-12-SP4.- Add BuildRequires to address warnings during build: * for libcurl-devel, libssh2-devel and rrdtool-devel * for libjson-c-devel and liblz4-devel where available, disable these with --without-json and --without-lz4 where not. * disable DataWarp (--without-datawarp).- Update SLURM to 18.08.7: * Set debug statement to debug2 to avoid benign error messages. * Add SchedulerParameters option of bf_hetjob_immediate to attempt to start a heterogeneous job as soon as all of its components are determined able to do so. * Fix underflow causing decay thread to exit. * Fix main scheduler not considering hetjobs when building the job queue. * Fix regression for sacct to display old jobs without a start time. * Fix setting correct number of gres topology bits. * Update hetjobs pending state reason when appropriate. * Fix accounting_storage/filetxt's understanding of TRES. * Set Accrue time when not enforcing limits. * Fix srun segfault when requesting a hetjob with test_exec or bcast options. * Hide multipart priorities log message behind Priority debug flag. * sched/backfill - Make hetjobs sensitive to bf_max_job_start. * Fix slurmctld segfault due to job's partition pointer NULL dereference. * Fix issue with OR'ed job dependencies. * Add new job's bit_flags of INVALID_DEPEND to prevent rebuilding a job's dependency string when it has at least one invalid and purged dependency. * Promote federation unsynced siblings log message from debug to info. * burst_buffer/cray - fix slurmctld SIGABRT due to illegal read/writes. * burst_buffer/cray - fix memory leak due to unfreed job script content. * node_features/knl_cray - fix script_argv use-after-free. * burst_buffer/cray - fix script_argv use-after-free. * Fix invalid reads of size 1 due to non null-terminated string reads. * Add extra debug2 logs to identify why BadConstraints reason is set.- Do not build hdf5 support where not available.- Add support for version updates on SLE: Update packages to a later version than the version supported originally on SLE will receive a version string in their package name.- added the hdf5 job data gathering plugin- Add backward compatibility with SLE-11 SP4- Update to version 18.08.05-2: This version obsoletes: Fix-contrib-perlapi-to-build-with-the-fix-for-CVE-2019-6438-750cc23ed.patch - Fix spec file for older SUSE versions.- Update to version 18.08.05: * Add mitigation for a potential heap overflow on 32-bit systems in xmalloc. (CVE-2019-6438, bsc#1123304). * Other fixes: + Backfill - If a job has a time_limit guess the end time of a job better if OverTimeLimit is Unlimited. + Fix "sacctmgr show events event=cluster" + Fix sacctmgr show runawayjobs from sibling cluster + Avoid bit offset of -1 in call to bit_nclear(). + Insure that "hbm" is a configured GresType on knl systems. + Fix NodeFeaturesPlugins=node_features/knl_generic to allow other gres other than knl. + cons_res: Prevent overflow on multiply. + Better debug for bad values in gres.conf. + Fix double accounting of energy at end of job. + Read gres.conf for cloud nodes on slurmctld. + Don't assume the first node of a job is the batch host when purging jobs from a node. + Better debugging when a job doesn't have a job_resrcs ptr. + Store ave watts in energy plugins. + Add XCC plugin for reading Lenovo Power. + Fix minor memory leak when scheduling rebootable nodes. + Fix debug2 prefix for sched log. + Fix printing correct SLURM_JOB_ACCOUNT_PACK_GROUP_* in env for a Het Job. + sbatch - search current working directory first for job script. + Make it so held jobs reset the AccrueTime and do not count against any AccrueTime limits. + Add SchedulerParameters option of bf_hetjob_prio=[min|avg|max] to alter the job sorting algorithm for scheduling heterogeneous jobs. + Fix initialization of assoc_mgr_locks and slurmctld_locks lock structures. + Fix segfault with job arrays using X11 forwarding. + Revert regression caused by e0ee1c7054 which caused negative values and values starting with a decimal to be invalid for PriorityWeightTRES and TRESBillingWeight. + Fix possibility to update a job's reservation to none. + Suppress connection errors to primary slurmdbd when backup dbd is active. + Suppress connection errors to primary db when backup db kicks in + Add missing fields for sacct --completion when using jobcomp/filetxt. + Fix incorrect values set for UserCPU, SystemCPU, and TotalCPU sacct fields when JobAcctGatherType=jobacct_gather/cgroup. + Fixed srun from double printing invalid option msg twice. + Remove unused -b flag from getopt call in sbatch. + Disable reporting of node TRES in sreport. + Re-enabling features combined by OR within parenthesis for non-knl setups. + Prevent sending duplicate requests to reboot a node before ResumeTimeout. + Down nodes that don't reboot by ResumeTimeout. + Update seff to reflect API change from rss_max to tres_usage_in_max. + Add missing TRES constants from perl API. + Fix issue where sacct would return incorrect array tasks when querying specific tasks. + Add missing variables to slurmdb_stats_t in the perlapi. + Fix nodes not getting reboot RPC when job requires reboot of nodes. + Fix failing update the partition list of a job. + Use slurm.conf gres ids instead of gres.conf names to get a gres type name. * Disable slurmctld-rerun-agent_init-when-backup-controller-takes-over.patch: Believed to be fixed by commit c1a537dbbe6 See: https://bugs.schedmd.com/show_bug.cgi?id=5511 * Add Fix-contrib-perlapi-to-build-with-the-fix-for-CVE-2019-6438-750cc23ed.patch: Fix fallout from 750cc23ed for CVE-2019-6438.- Update to 18.08.04, with following highlights * Fix message sent to user to display preempted instead of time limit when a job is preempted. * Fix memory leak when a failure happens processing a nodes gres config. * Improve error message when failures happen processing a nodes gres config. * Don't skip jobs in scontrol hold. * Allow --cpu-bind=verbose to be used with SLURM_HINT environment variable. * Enhanced handling for runaway jobs * cons_res: Delay exiting cr_job_test until after cores/cpus are calculated and distributed. * Don't check existence of srun --prolog or --epilog executables when set to "none" and SLURM_TEST_EXEC is used. * Add "P" suffix support to job and step tres specifications. * Fix jobacct_gather/cgroup to work correctly when more than one task is started on a node. * salloc - set SLURM_NTASKS_PER_CORE and SLURM_NTASKS_PER_SOCKET in the environment if the corresponding command line options are used. * slurmd - fix handling of the -f flag to specify alternate config file locations. * Add SchedulerParameters option of bf_ignore_newly_avail_nodes to avoid scheduling lower priority jobs on resources that become available during the backfill scheduling cycle when bf_continue is enabled. * job_submit/lua: Add several slurmctld return codes and add user/group info * salloc/sbatch/srun - print warning if mutually exclusive options of --mem and --mem-per-cpu are both set. - Refreshed: * pam_slurm_adopt-avoid-running-outside-of-the-sshd-PA.patch- restarting services on update only when activated - added rotation of logs - Added backported patches which harden the pam module pam_slurm_adopt (BOO#1116758) which will be in slurm 19.05.x * added pam_slurm_adopt-avoid-running-outside-of-the-sshd-PA.patch [PATCH 1/3] pam_slurm_adopt: avoid running outside of the sshd PAM * added pam_slurm_adopt-send_user_msg-don-t-copy-undefined-d.patch [PATCH 2/3] pam_slurm_adopt: send_user_msg: don't copy undefined data * added pam_slurm_adopt-use-uid-to-determine-whether-root-is.patch [PATCH 3/3] pam_slurm_adopt: use uid to determine whether root is logging on - package slurm-pam_slurm now depends on slurm-node and not on slurm- fixed code in %pretrans section to be compatible with lua 5.1- Added missing perl-base dependency.- Moved HTML docs to doc package.- Moved config man pages to a separate package: This way, they won't get installed on compute nodes.- Update to 18.08.3 * Add new burst buffer state of "teardown-fail" to indicate the burst buffer teardown operation is failing on specific buffers. * Multiple backup slurmctld daemons can be configured * Enable jobs with zero node count for creation and/or deletion of persistent burst buffers. * Add "scontrol show dwstat" command to display Cray burst buffer status. * Add "GetSysStatus" option to burst_buffer.conf file. * Add node and partition configuration options of "CpuBind" to control default task binding. * Add "NumaCpuBind" option to knl.conf * Add sbatch "--batch" option to identify features required on batch node. * Add "BatchFeatures" field to output of "scontrol show job". * Add support for "--bb" option to sbatch command. * Add new SystemComment field to job data structure and database. * Expand reservation "flags" field from 32 to 64 bits. * Add job state flag of "SIGNALING" to avoid race condition. * Properly handle srun --will-run option when there are jobs in COMPLETING state. * Properly report who is signaling a step. * Don't combine updated reservation records in sreport's reservation report. * node_features plugin - Add suport for XOR & XAND of job constraints (node feature specifications). * Improvements to how srun searches for the executible when using cwd. * Now programs can be checked before execution if test_exec is set. * Report NodeFeatures plugin configuration with scontrol and sview commands. * Add acct_gather_profile/influxdb plugin. * Add new job state of SO/STAGE_OUT * Correct SLURM_NTASKS and SLURM_NPROCS environment variable for heterogeneous job step. * Expand advanced reservation feature specification to support parenthesis and counts of nodes with specified features. * Defer job signaling until prolog is completed * Have the primary slurmctld wait until the backup has completely shutdown before taking control. * Fix issue where unpacking job state after TRES count changed could lead to invalid reads. * Heterogeneous job steps allocations supported with Open MPI. * Remove redundant function arguments from task plugins. * Add Slurm configuration file check logic using "slurmctld -t" command. * Add the use of a xml file to help performance when using hwloc. * Remove support for "ChosLoc" configuration parameter. * Configuration parameters "ControlMachine", "ControlAddr", "BackupController" and "BackupAddr" replaced by an ordered list of "SlurmctldHost" records. * Remove --immediate option from sbatch. * Add infrastructure for per-job and per-step TRES parameters. * Add DefCpuPerGpu and DefMemPerGpu to global and per-partition configuration parameters. * Add ValidateMode configuration parameter to knl_cray.conf. * Disable local PTY output processing when using 'srun --unbuffered'. * Change the column name for the %U (User ID) field in squeue to 'UID'. * CRAY - Add CheckGhalQuiesce to the CommunicationParameters. * When a process is core dumping, avoid terminating other processes in that task group. * CPU frequency management enhancements: If scaling_available_frequencies file is not available, then derive values from scaling_min_freq and scaling_max_freq values. * Add pending jobs count to sdiag output. * Add configuration paramerers SlurmctldPrimaryOnProg and SlurmctldPrimaryOffProg, which define programs to execute when a slurmctld daemon changes state. * Add configuration paramerers SlurmctldAddr for use with virtual IP to manage backup slurmctld daemons. * Explicitly shutdown the slurmd process when instructed to reboot. * Add ability to create/update partition with TRESBillingWeights through scontrol. * Calcuate TRES billing values at submission. * Add node_features plugin function "node_features_p_reboot_weight()". * Add NodeRebootWeight parameter to knl.conf configuration file. * Completely remove "gres" field from step record. Use "tres_per_node", "tres_per_socket", etc. * Add "Links" parameter to gres.conf configuration file. * Force slurm_mktime() to set tm_isdst to -1. * burst_buffer.conf - Add SetExecHost flag to enable burst buffer access from the login node for interactive jobs. * Append ", with requeued tasks" to job array "end" emails if any tasks in the array were requeued. * Add ResumeFailProgram slurm.conf option to specify a program that is called when a node fails to respond by ResumeTimeout. * Add new job pending reason of "ReqNodeNotAvail, reserved for maintenance". * Remove AdminComment += syntax from 'scontrol update job'. * sched/backfill: Reset job time limit if needed for deadline scheduling. * For heterogeneous job component with required nodes, explicitly exclude those nodes from all other job components. * Add name of partition used to output of srun --test-only output. * sdiag output now reports outgoing slurmctld message queue contents. * Improve escaping special characters on user commands when specifying paths. * Add salloc/sbatch/srun option of --gres-flags=disable-binding to disable filtering of CPUs with respect to generic resource locality. * SlurmDBD - Print warning if MySQL/MariaDB internal tuning is not at least half of the recommended values. * Add ability to specify a node reason when rebooting nodes with "scontrol reboot". * Add nextstate option to "scontrol reboot". * Consider "resuming" (nextstate=resume) nodes as available in backfill future scheduling. * Add TimelimitRaw sacct output field to display timelimit numbers. * Add support for sacct --whole-hetjob=[yes|no] option. * Make salloc handle node requests the same as sbatch. * Add shutdown_on_reboot SlurmdParameter to control whether the Slurmd will shutdown itself down or not when a reboot request is received. * Add cancel_reboot scontrol option to cancel pending reboot of nodes. * Make Users case insensitive in the database based on Parameters=PreserveCaseUser in the slurmdbd.conf. * Improve scheduling when dealing with node_features that could have a boot delay. * Changed the default AuthType for slurmdbd to auth/munge. * Added 'remote-fs.target' to After directive of slurmd.service file. * Remove drain on node when reboot nextstate used. * Speed up pack of job's qos. * Add sacctmgr options to prevent/manage job queue stuffing: - GrpJobsAccrue= - MaxJobsAccrue= * MinPrioThreshold Minimum priority required to reserve resources when scheduling. * Add control_inx value to trigger_info_msg_t to permit future work in the trigger management code to distinguish which of multiple backup controllers has changed state. * NOTES: PreemptType=preempt/job_prio has been removed - use PreemptType=preempt/qos instead. * Bluegene support was deprecated has now been removed * cgroup_allowed_devices_file.conf was removed. It was never used by default, as ConstrainDevices was not set. If needed, refer to the cgroups.conf man page on how to create one. * slurm.epilog.clean: Removed. User should use pam_slurm_adopt instead. - Refreshed: * removed-deprecated-xdaemon.patch * slurmctld-uses-xdaemon_-for-systemd.patch * slurmd-uses-xdaemon_-for-systemd.patch * slurmdbd-uses-xdaemon_-for-systemd.patch * slurmsmwd-uses-xdaemon_-for-systemd.patch * slurmctld-rerun-agent_init-when-backup-controller-takes-over.patch- Move config man-pages to config package.- added correct link flags for perl bindings (bsc#1108671) * added correct linker search path in slurm-2.4.4-rpath.patch * perl:Switch is required by slurm torque wrappers- Fix Requires(pre) and Requires(post) for slurm-config and slurm-node. This fixes issues with failing slurm user creation when installed during initial system installation (bsc#1109373).- Update to 17.11.9 * Fix segfault in slurmctld when a job's node bitmap is NULL during a scheduling cycle. Primarily caused by EnforcePartLimits=ALL. * Remove erroneous unlock in acct_gather_energy/ipmi. * Enable support for hwloc version 2.0.1. * Fix 'srun -q' (--qos) option handling. * Fix socket communication issue that can lead to lost task completition messages, which will cause a permanently stuck srun process. * Handle creation of TMPDIR if environment variable is set or changed in a task prolog script. * Avoid node layout fragmentation if running with a fixed CPU count but without Sockets and CoresPerSocket defined. * burst_buffer/cray - Fix datawarp swap default pool overriding jobdw. * Fix incorrect job priority assignment for multi-partition job with different PriorityTier settings on the partitions. * Fix sinfo to print correct node state.- When using a remote shared StateSaveLocation, slurmctld needs to be started after remote filesystems have become available. Add 'remote-fs.target' to the 'After=' directive in slurmctld.service (boo#1103561).- Update to 17.11.8 * Fix incomplete RESPONSE_[RESOURCE|JOB_PACK]_ALLOCATION building path. * Do not allocate nodes that were marked down due to the node not responding by ResumeTimeout. * task/cray plugin - search for "mems" cgroup information in the file "cpuset.mems" then fall back to the file "mems". * Fix ipmi profile debug uninitialized variable. * PMIx: fixed the direct connect inline msg sending. * MYSQL: Fix issue not handling all fields when loading an archive dump. * Allow a job_submit plugin to change the admin_comment field during job_submit_plugin_modify(). * job_submit/lua - fix access into reservation table. * MySQL - Prevent deadlock caused by archive logic locking reads. * Don't enforce MaxQueryTimeRange when requesting specific jobs. * Modify --test-only logic to properly support jobs submitted to more than one partition. * Prevent slurmctld from abort when attempting to set non-existing qos as def_qos_id. * Add new job dependency type of "afterburstbuffer". The pending job will be delayed until the first job completes execution and it's burst buffer stage-out is completed. * Reorder proctrack/task plugin load in the slurmstepd to match that of slurmd and avoid race condition calling task before proctrack can introduce. * Prevent reboot of a busy KNL node when requesting inactive features. * Revert to previous behavior when requesting memory per cpu/node introduced in 17.11.7. * Fix to reinitialize previously adjusted job members to their original value when validating the job memory in multi-partition requests. * Fix _step_signal() from always returning SLURM_SUCCESS. * Combine active and available node feature change logs on one line rather than one line per node for performance reasons. * Prevent occasionally leaking freezer cgroups. * Fix potential segfault when closing the mpi/pmi2 plugin. * Fix issues with --exclusive=[user|mcs] to work correctly with preemption or when job requests a specific list of hosts. * Make code compile with hdf5 1.10.2+ * mpi/pmix: Fixed the collectives canceling. * SlurmDBD: improve error message handling on archive load failure. * Fix incorrect locking when deleting reservations. * Fix incorrect locking when setting up the power save module. * Fix setting format output length for squeue when showing array jobs. * Add xstrstr function. * Fix printing out of --hint options in sbatch, salloc --help. * Prevent possible divide by zero in _validate_time_limit(). * Add Delegate=yes to the slurmd.service file to prevent systemd from interfering with the jobs' cgroup hierarchies. * Change the backlog argument to the listen() syscall within srun to 4096 to match elsewhere in the code, and avoid communication problems at scale.- slurmctld-rerun-agent_init-when-backup-controller-takes-over.patch: Fix race in the slurmctld backup controller which prevents it to clean up allocations on nodes properly after failing over (bsc#1084917). - Handled %license in a backward compatible manner.- Add a 'Recommends: slurm-munge' to slurm-slurmdbd.- Shield comments between script snippets with a %{!?nil:...} to avoid them being interpreted as scripts - in which case the update level is passed as argument (see chapter 'Shared libraries' in: https://en.opensuse.org/openSUSE:Packaging_scriptlet_snippets) (bsc#1100850).- Update from 17.11.5 to 17.11.7 - Fix security issue in handling of username and gid fields CVE-2018-10995 and bsc#1095508 what implied an update from 17.11.5 to 17.11.7 Highlights of 17.11.6: * CRAY - Add slurmsmwd to the contribs/cray dir * PMIX - Added the direct connect authentication. * Prevent the backup slurmctld from losing the active/available node features list on takeover. * Be able to force power_down of cloud node even if in power_save state. * Allow cloud nodes to be recognized in Slurm when booted out of band. * Numerous fixes - check 'NEWS' file. Highlights of 17.11.7: * Notify srun and ctld when unkillable stepd exits. * Numerous fixes - check 'NEWS' file. - Add: slurmsmwd-uses-xdaemon_-for-systemd.patch * Fixes daemoniziation in newly introduced slurmsmwd daemon. - Rename: split-xdaemon-in-xdaemon_init-and-xdaemon_finish-for-systemd-compatibilty.patch to split-xdaemon-in-xdaemon_init-and-xdaemon_finish-for.patch * remain in sync with commit messages which introduced that file- Avoid running pretrans scripts when running in an instsys: there may be not much installed, yet. pretrans code should be done in lua, this way, it will be executed by the rpm-internal lua interpreter and not be passed to a shell which may not be around at the time this scriptlet is run (bsc#1090292).- Add requires for slurm-sql to the slurmdbd package.- Package READMEs for pam and pam_slurm_adopt. - Use the new %%license directive for COPYING file.- Add: * split-xdaemon-in-xdaemon_init-and-xdaemon_finish-for-systemd-compatibilty.patch * slurmctld-uses-xdaemon_-for-systemd.patch * slurmd-uses-xdaemon_-for-systemd.patch * slurmdbd-uses-xdaemon_-for-systemd.patch * removed-deprecated-xdaemon.patch Fix interaction with systemd: systemd expects that a daemonizing process doesn't go away until the PID file with it PID of the daemon has bee written (bsc#1084125).- Make sure systemd services get restarted only when all packages are in a consistent state, not in the middle of an 'update' transaction (bsc#1088693). Since the %postun scripts that run on update are from the old package they cannot be changed - thus we work around the restart breakage.- fixed wrong log file location in slurmdbd.conf and fixed pid location for slurmdbd and made slurm-slurmdbd depend on slurm config which provides the dir /var/run/slurm (bsc#1086859).- added comment for (bsc#1085606)- Fix security issue in accounting_storage/mysql plugin by always escaping strings within the slurmdbd. CVE-2018-7033 http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2018-7033 (bsc#1085240). - Update slurm to v17.11.5 (FATE#325451) Highlights of 17.11: * Support for federated clusters to manage a single work-flow across a set of clusters. * Support for heterogeneous job allocations (various processor types, memory sizes, etc. by job component). Support for heterogeneous job steps within a single MPI_COMM_WORLD is not yet supported for most configurations. * X11 support is now fully integrated with the main Slurm code. Remove any X11 plugin configured in your plugstack.conf file to avoid errors being logged about conflicting options. * Added new advanced reservation flag of "flex", which permits jobs requesting the reservation to begin prior to the reservation's start time and use resources inside or outside of the reservation. A typical use case is to prevent jobs not explicitly requesting the reservation from using those reserved resources rather than forcing jobs requesting the reservation to use those resources in the time frame reserved. * The sprio command has been modified to report a job's priority information for every partition the job has been submitted to. * Group ID lookup performed at job submit time to avoid lookup on all compute nodes. Enable with PrologFlags=SendGIDs configuration parameter. * Slurm commands and daemons dynamically link to libslurmfull.so instead of statically linking. This dramatically reduces the footprint of Slurm. * In switch plugin, added plugin_id symbol to plugins and wrapped switch_jobinfo_t with dynamic_plugin_data_t in interface calls in order to pass switch information between clusters with different switch types. * Changed default ProctrackType to cgroup. * Changed default sched_min_interval from 0 to 2 microseconds. * Added new 'scontrol write batch_script ' command to fetch a job's batch script. Removed the ability to see the script as part of the 'scontrol -dd show job' command. * Add new "billing" TRES which allows jobs to be limited based on the job's billable TRES calculated by the job's partition's TRESBillingWeights. * Regular user use of "scontrol top" command is now disabled. Use the configuration parameter "SchedulerParameters=enable_user_top" to enable that functionality. The configuration parameter "SchedulerParameters=disable_user_top" will be silently ignored. * Change default to let pending jobs run outside of reservation after reservation is gone to put jobs in held state. Added NO_HOLD_JOBS_AFTER_END reservation flag to use old default. Support for PMIx v2.0 as well as UCX support. * Remove plugins for obsolete MPI stacks: - lam - mpich1_p4 - mpich1_shmem - mvapich * Numerous fixes - check 'NEWS' file. - slurmd-Fix-slurmd-for-new-API-in-hwloc-2.0.patch plugins-cgroup-Fix-slurmd-for-new-API-in-hwloc-2.0.patch: Removed. Code upstream. - slurmctld-service-var-run-path.patch: Replaced by sed script. - Fix some rpmlint warnings.- moved config files to slurm-config package (FATE#324574).- Moved slurmstepd and man page into slurm-node due to slurmd dependency - Moved config files into slurm-node - Moved slurmd rc scripts into slurm-node - Made slurm-munge require slurm-plugins instead of slurm itself - slurm-node suggested slurm-munge, causing the whole slurm to be installed. The slurm-plugins seems to be a more base class (FATE#324574).- split up light wight slurm-node package for deployment on nodes (FATE#324574).- added /var/spool/ directory and removed duplicated entries from slurm.conf- Package so-versioned libs separately. libslurm is expected to change more frequently and thus is packaged separately from libpmi.- Updated to 17.02.9 to fix CVE-2017-15566 (bsc#1065697). Changes in 17.0.9 * When resuming powered down nodes, mark DOWN nodes right after ResumeTimeout has been reached (previous logic would wait about one minute longer). * Fix sreport not showing full column name for TRES Count. * Fix slurmdb_reservations_get() giving wrong usage data when job's spanned reservation that was modified. * Fix sreport reservation utilization report showing bad data. * Show all TRES' on a reservation in sreport reservation utilization report by default. * Fix sacctmgr show reservation handling "end" parameter. * Work around issue with sysmacros.h and gcc7 / glibc 2.25. * Fix layouts code to only allow setting a boolean. * Fix sbatch --wait to keep waiting even if a message timeout occurs. * CRAY - If configured with NodeFeatures=knl_cray and there are non-KNL nodes which include no features the slurmctld will abort without this patch when attemping strtok_r(NULL). * Fix regression in 17.02.7 which would run the spank_task_privileged as part of the slurmstepd instead of it's child process. * Fix security issue in Prolog and Epilog by always prepending SPANK_ to all user-set environment variables. CVE-2017-15566. Changes in 17.0.8: * Add 'slurmdbd:' to the accounting plugin to notify message is from dbd instead of local. * mpi/mvapich - Buffer being only partially cleared. No failures observed. * Fix for job --switch option on dragonfly network. * In salloc with --uid option, drop supplementary groups before changing UID. * jobcomp/elasticsearch - strip any trailing slashes from JobCompLoc. * jobcomp/elasticsearch - fix memory leak when transferring generated buffer. * Prevent slurmstepd ABRT when parsing gres.conf CPUs. * Fix sbatch --signal to signal all MPI ranks in a step instead of just those on node 0. * Check multiple partition limits when scheduling a job that were previously only checked on submit. * Cray: Avoid running application/step Node Health Check on the external job step. * Optimization enhancements for partition based job preemption. * Address some build warnings from GCC 7.1, and one possible memory leak if /proc is inaccessible. * If creating/altering a core based reservation with scontrol/sview on a remote cluster correctly determine the select type. * Fix autoconf test for libcurl when clang is used. * Fix default location for cgroup_allowed_devices_file.conf to use correct default path. * Document NewName option to sacctmgr. * Reject a second PMI2_Init call within a single step to prevent slurmstepd from hanging. * Handle old 32bit values stored in the database for requested memory correctly in sacct. * Fix memory leaks in the task/cgroup plugin when constraining devices. * Make extremely verbose info messages debug2 messages in the task/cgroup plugin when constraining devices. * Fix issue that would deny the stepd access to /dev/null where GRES has a 'type' but no file defined. * Fix issue where the slurmstepd would fatal on job launch if you have no gres listed in your slurm.conf but some in gres.conf. * Fix validating time spec to correctly validate various time formats. * Make scontrol work correctly with job update timelimit [+|-]=. * Reduce the visibily of a number of warnings in _part_access_check. * Prevent segfault in sacctmgr if no association name is specified for an update command. * burst_buffer/cray plugin modified to work with changes in Cray UP05 software release. * Fix job reasons for jobs that are violating assoc MaxTRESPerNode limits. * Fix segfault when unpacking a 16.05 slurm_cred in a 17.02 daemon. * Fix setting TRES limits with case insensitive TRES names. * Add alias for xstrncmp() -- slurm_xstrncmp(). * Fix sorting of case insensitive strings when using xstrcasecmp(). * Gracefully handle race condition when reading /proc as process exits. * Avoid error on Cray duplicate setup of core specialization. * Skip over undefined (hidden in Slurm) nodes in pbsnodes. * Add empty hashes in perl api's slurm_load_node() for hidden nodes. * CRAY - Add rpath logic to work for the alpscomm libs. * Fixes for administrator extended TimeLimit (job reason & time limit reset). * Fix gres selection on systems running select/linear. * sview: Added window decorator for maximize,minimize,close buttons for all systems. * squeue: interpret negative length format specifiers as a request to delimit values with spaces. * Fix the torque pbsnodes wrapper script to parse a gres field with a type set correctly. - Fixed ABI version of libslurm.- Trim redundant wording in descriptions.- Updated to slurm 17-02-7-1 * Added python as BuildRequires * Removed sched-wiki package * Removed slurmdb-direct package * Obsoleted sched-wiki and slurmdb-direct packages * Removing Cray-specific files * Added /etc/slurm/layout.d files (new for this version) * Remove /etc/slurm/cgroup files from package * Added lib/slurm/mcs_account.so * Removed lib/slurm/jobacct_gather_aix.so * Removed lib/slurm/job_submit_cnode.so - Created slurm-sql package - Moved files from slurm-plugins to slurm-torque package - Moved creation of /usr/lib/tmpfiles.d/slurm.conf into slurm.spec * Removed tmpfiles.d-slurm.conf - Changed /var/run path for slurm daemons to /var/run/slurm * Added slurmctld-service-var-run-path.patch (FATE#324026).- Made tmpfiles_create post-install macro SLE12 SP2 or greater - Directly calling systemd-tmpfiles --create for before SLE12 SP2- Allows OpenSUSE Factory build as well - Removes unused .service files from project - Adds /var/run/slurm to /usr/lib/tmpfiles.d for boottime creation * Patches upstream .service files to allow for /var/run/slurm path * Modifies slurm.conf to allow for /var/run/slurm path- Move wrapper script mpiexec provided by slrum-torque to mpiexec.slurm to avoid conflicts. This file is normally provided by the MPI implementation (boo#1041706).- Replace remaining ${RPM_BUILD_ROOT}s. - Improve description. - Fix up changelog.- Spec file: Replace "Requires : slurm-perlapi" by "Requires: perl-slurm = %{version}" (boo#1031872).- Trim redundant parts of description. Fixup RPM groups. - Replace unnecessary %__ macro indirections; replace historic $RPM_* variables by macros.- slurmd-Fix-for-newer-API-versions.patch: Stale patch removed.- Use %slurm_u and %slurm_g macros defined at the beginning of the spec file when adding the slurm user/group for consistency. - Define these macros to daemon,root for non-systemd. - For anything newer than Leap 42.1 or SLE-12-SP1 build OpenHPC compatible.- Updated to 16.05.8.1 * Remove StoragePass from being printed out in the slurmdbd log at debug2 level. * Defer PATH search for task program until launch in slurmstepd. * Modify regression test1.89 to avoid leaving vestigial job. Also reduce logging to reduce likelyhood of Expect buffer overflow. * Do not PATH search for mult-prog launches if LaunchParamters=test_exec is enabled. * Fix for possible infinite loop in select/cons_res plugin when trying to satisfy a job's ntasks_per_core or socket specification. * If job is held for bad constraints make it so once updated the job doesn't go into JobAdminHeld. * sched/backfill - Fix logic to reserve resources for jobs that require a node reboot (i.e. to change KNL mode) in order to start. * When unpacking a node or front_end record from state and the protocol version is lower than the min version, set it to the min. * Remove redundant lookup for part_ptr when updating a reservation's nodes. * Fix memory and file descriptor leaks in slurmd daemon's sbcast logic. * Do not allocate specialized cores to jobs using the --exclusive option. * Cancel interactive job if Prolog failure with "PrologFlags=contain" or "PrologFlags=alloc" configured. Send new error prolog failure message to the salloc or srun command as needed. * Prevent possible out-of-bounds read in slurmstepd on an invalid #! line. * Fix check for PluginDir within slurmctld to work with multiple directories. * Cancel interactive jobs automatically on communication error to launching srun/salloc process. * Fix security issue caused by insecure file path handling triggered by the failure of a Prolog script. To exploit this a user needs to anticipate or cause the Prolog to fail for their job. CVE-2016-10030 (bsc#1018371). - Replace group/user add macros with function calls. - Fix array initialzation and ensure strings are always NULL terminated in - pam_slurm.c (bsc#1007053). - Disable building with netloc support: the netloc API is part of the devel branch of hwloc. Since this devel branch was included accidentally and has been reversed since, we need to disable this for the time being. - Conditionalized architecture specific pieces to support non-x86 architectures better.- Remove: unneeded 'BuildRequires: python' - Add: BuildRequires: freeipmi-devel BuildRequires: libibmad-devel BuildRequires: libibumad-devel so they are picked up by the slurm build. - Enable modifications from openHPC Project. - Enable lua API package build. - Add a recommends for slurm-munge to the slurm package: This is way, the munge auth method is available and slurm works out of the box. - Create /var/lib/slurm as StateSaveLocation directory. /tmp is dangerous.- Create slurm user/group in preinstall script.- Keep %{_libdir}/libpmi* and %{_libdir}/mpi_pmi2* on SUSE.- Fix build with and without OHCP_BUILD define. - Fix build for systemd and non-systemd.- Updated to 16-05-5 - equvalent to OpenHPC 1.2. * Fix issue with resizing jobs and limits not be kept track of correctly. * BGQ - Remove redeclaration of job_read_lock. * BGQ - Tighter locks around structures when nodes/cables change state. * Make it possible to change CPUsPerTask with scontrol. * Make it so scontrol update part qos= will take away a partition QOS from a partition. * Backfill scheduling properly synchronized with Cray Node Health Check. Prior logic could result in highest priority job getting improperly postponed. * Make it so daemons also support TopologyParam=NoInAddrAny. * If scancel is operating on large number of jobs and RPC responses from slurmctld daemon are slow then introduce a delay in sending the cancel job requests from scancel in order to reduce load on slurmctld. * Remove redundant logic when updating a job's task count. * MySQL - Fix querying jobs with reservations when the id's have rolled. * Perl - Fix use of uninitialized variable in slurm_job_step_get_pids. * Launch batch job requsting --reboot after the boot completes. * Do not attempt to power down a node which has never responded if the slurmctld daemon restarts without state. * Fix for possible slurmstepd segfault on invalid user ID. * MySQL - Fix for possible race condition when archiving multiple clusters at the same time. * Add logic so that slurmstepd can be launched under valgrind. * Increase buffer size to read /proc/*/stat files. * Remove the SchedulerParameters option of "assoc_limit_continue", making it the default value. Add option of "assoc_limit_stop". If "assoc_limit_stop" is set and a job cannot start due to association limits, then do not attempt to initiate any lower priority jobs in that partition. Setting this can decrease system throughput and utlization, but avoid potentially starving larger jobs by preventing them from launching indefinitely. * Update a node's socket and cores per socket counts as needed after a node boot to reflect configuration changes which can occur on KNL processors. Note that the node's total core count must not change, only the distribution of cores across varying socket counts (KNL NUMA nodes treated as sockets by Slurm). * Rename partition configuration from "Shared" to "OverSubscribe". Rename salloc, sbatch, srun option from "--shared" to "--oversubscribe". The old options will continue to function. Output field names also changed in scontrol, sinfo, squeue and sview. * Add SLURM_UMASK environment variable to user job. * knl_conf: Added new configuration parameter of CapmcPollFreq. * Cleanup two minor Coverity warnings. * Make it so the tres units in a job's formatted string are converted like they are in a step. * Correct partition's MaxCPUsPerNode enforcement when nodes are shared by multiple partitions. * node_feature/knl_cray - Prevent slurmctld GRES errors for "hbm" references. * Display thread name instead of thread id and remove process name in stderr logging for "thread_id" LogTimeFormat. * Log IP address of bad incomming message to slurmctld. * If a user requests tasks, nodes and ntasks-per-node and tasks-per-node/nodes != tasks print warning and ignore ntasks-per-node. * Release CPU "owner" file locks. * Update seff to fix warnings with ncpus, and list slurm-perlapi dependency in spec file. * Allow QOS timelimit to override partition timelimit when EnforcePartLimits is set to all/any. * Make it so qsub will do a "basename" on a wrapped command for the output and error files. * Add logic so that slurmstepd can be launched under valgrind. * Increase buffer size to read /proc/*/stat files. * Prevent job stuck in configuring state if slurmctld daemon restarted while PrologSlurmctld is running. Also re-issue burst_buffer/pre-load operation as needed. * Move test for job wait reason value of BurstBufferResources and BurstBufferStageIn later in the scheduling logic. * Document which srun options apply to only job, only step, or job and step allocations. * Use more compatible function to get thread name (>= 2.6.11). * Make it so the extern step uses a reverse tree when cleaning up. * If extern step doesn't get added into the proctrack plugin make sure the sleep is killed. * Add web links to Slurm Diamond Collectors (from Harvard University) and collectd (from EDF). * Add job_submit plugin for the "reboot" field. * Make some more Slurm constants (INFINITE, NO_VAL64, etc.) available to job_submit/lua plugins. * Send in a -1 for a taskid into spank_task_post_fork for the extern_step. * MYSQL - Sightly better logic if a job completion comes in with an end time of 0. * task/cgroup plugin is configured with ConstrainRAMSpace=yes, then set soft memory limit to allocated memory limit (previously no soft limit was set). * Streamline when schedule() is called when running with message aggregation on batch script completes. * Fix incorrect casting when [un]packing derived_ec on slurmdb_job_rec_t. * Document that persistent burst buffers can not be created or destroyed using the salloc or srun --bb options. * Add support for setting the SLURM_JOB_ACCOUNT, SLURM_JOB_QOS and SLURM_JOB_RESERVAION environment variables are set for the salloc command. Document the same environment variables for the salloc, sbatch and srun commands in their man pages. * Fix issue where sacctmgr load cluster.cfg wouldn't load associations that had a partition in them. * Don't return the extern step from sstat by default. * In sstat print 'extern' instead of 4294967295 for the extern step. * Make advanced reservations work properly with core specialization. * slurmstepd modified to pre-load all relevant plugins at startup to avoid the possibility of modified plugins later resulting in inconsistent API or data structures and a failure of slurmstepd. * Export functions from parse_time.c in libslurm.so. * Export unit convert functions from slurm_protocol_api.c in libslurm.so. * Fix scancel to allow multiple steps from a job to be cancelled at once. * Update and expand upgrade guide (in Quick Start Administrator web page). * burst_buffer/cray: Requeue, but do not hold a job which fails the pre_run operation. * Insure reported expected job start time is not in the past for pending jobs. * Add support for PMIx v2. Required for FATE#316379.- Setting 'download_files' service to mode='localonly' and adding source tarball. (Required for Factory).- version 15.08.7.1 * Remove the 1024-character limit on lines in batch scripts. task/affinity: Disable core-level task binding if more CPUs required than available cores. * Preemption/gang scheduling: If a job is suspended at slurmctld restart or reconfiguration time, then leave it suspended rather than resume+suspend. * Don't use lower weight nodes for job allocation when topology/tree used. * Don't allow user specified reservation names to disrupt the normal reservation sequeuece numbering scheme. * Avoid hard-link/copy of script/environment files for job arrays. Use the master job record file for all tasks of the job array. NOTE: Job arrays submitted to Slurm version 15.08.6 or later will fail if the slurmctld daemon is downgraded to an earlier version of Slurm. * In slurmctld log file, log duplicate job ID found by slurmd. Previously was being logged as prolog/epilog failure. * If a job is requeued while in the process of being launch, remove it's job ID from slurmd's record of active jobs in order to avoid generating a duplicate job ID error when launched for the second time (which would drain the node). * Cleanup messages when handling job script and environment variables in older directory structure formats. * Prevent triggering gang scheduling within a partition if configured with PreemptType=partition_prio and PreemptMode=suspend,gang. * Decrease parallelism in job cancel request to prevent denial of service when cancelling huge numbers of jobs. * If all ephemeral ports are in use, try using other port numbers. * Prevent "scontrol update job" from updating jobs that have already finished. * Show requested TRES in "squeue -O tres" when job is pending. * Backfill scheduler: Test association and QOS node limits before reserving resources for pending job. * Many bug fixes. - Use source services to download package. - Fix code for new API of hwloc-2.0. - package netloc_to_topology where avialable. - Package documentation.- version 15.08.3 * Many new features and bug fixes. See NEWS file - update files list accordingly - fix wrong end of line in some files- version 14.11.8 * Many bug fixes. See NEWS file - update files list accordingly- add missing systemd requirements - add missing rclink- version 14.03.9 * Many bug fixes. See NEWS file - add systemd supportslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsslurm-pluginsmourvedre 1706631261  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`22.05.11-150300.7.9.122.05.1122.05.11-150300.7.9.122.05.11-150300.7.9.120.11.020.11.220.11.320.11.420.11.520.11.720.11.922.05.022.05.1022.05.222.05.5slurm.confplugstack.confplugstack.conf.dslurmaccounting_storage_none.soaccounting_storage_slurmdbd.soacct_gather_energy_gpu.soacct_gather_energy_ibmaem.soacct_gather_energy_none.soacct_gather_energy_pm_counters.soacct_gather_energy_rapl.soacct_gather_filesystem_lustre.soacct_gather_filesystem_none.soacct_gather_interconnect_none.soacct_gather_interconnect_ofed.soacct_gather_interconnect_sysfs.soacct_gather_profile_influxdb.soacct_gather_profile_none.soburst_buffer_datawarp.soburst_buffer_lua.socgroup_v1.socgroup_v2.socli_filter_lua.socli_filter_none.socli_filter_syslog.socli_filter_user_defaults.socore_spec_none.socred_none.soext_sensors_none.soext_sensors_rrd.sogpu_generic.sogres_gpu.sogres_mps.sogres_nic.sogres_shard.sohash_k12.sojob_container_cncu.sojob_container_none.sojob_container_tmpfs.sojob_submit_all_partitions.sojob_submit_defaults.sojob_submit_logging.sojob_submit_partition.sojob_submit_require_timelimit.sojob_submit_throttle.sojobacct_gather_cgroup.sojobacct_gather_linux.sojobacct_gather_none.sojobcomp_elasticsearch.sojobcomp_filetxt.sojobcomp_lua.sojobcomp_none.sojobcomp_script.solaunch_slurm.solibslurm_pmi.solibslurmfull.somcs_account.somcs_group.somcs_none.somcs_user.sompi_none.sompi_pmi2.sompi_pmix.sompi_pmix_v3.sonode_features_helpers.sonode_features_knl_generic.sopower_none.sopreempt_none.sopreempt_partition_prio.sopreempt_qos.soprep_script.sopriority_basic.sopriority_multifactor.soproctrack_cgroup.soproctrack_linuxproc.soproctrack_pgid.soroute_default.soroute_topology.sosched_backfill.sosched_builtin.soselect_cons_res.soselect_cons_tres.soselect_linear.soserializer_json.soserializer_url_encoded.soserializer_yaml.sosite_factor_none.soslurmctld_nonstop.soswitch_none.sotask_affinity.sotask_cgroup.sotask_none.sotopology_3d_torus.sotopology_hypercube.sotopology_none.sotopology_tree.so/etc/ld.so.conf.d//etc/slurm//usr/lib64//usr/lib64/slurm/-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:32297/SUSE_SLE-15-SP3_Update/7fd5e89bcc53d38ed4c5fbb0acf60be8-slurm_22_05.SUSE_SLE-15-SP3_Updatedrpmxz5ppc64le-suse-linux  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]ASCII textdirectoryELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=81f7c255b05e5f54733189fdde6a2ba39a3af33a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=ea6ef8395170b57bfee31a4ad3bc8f86acf929d5, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=25e460a0ff5f1927e9b433ad672a2dfcb0a5a222, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=687e61581eaba9fd0b8ff74d28bb303ee6b8b5ab, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6ea7703b64b4a41ac32a0686cf42b909ec96ad41, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=1fa370388e9b6496d7f61a7ab9d2e6932fbf8154, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=2b759050d4e9b1cda59da8cd628740f4652f0f2d, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=5321590cdfc5a31f7c78a8c418df5b3c01ff4c77, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=ec391937658f6d493b940d27d8a5c169828552a8, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=8f41471aa0bed0a7ff4fa1a40e4ecf2d23eb3fb2, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=de0b58b0c0be50c8f3f96ee21b7e2b6d4e497d89, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=a169893990599087f2217fcf5279b41f1cb44c80, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=04931ba4126d538261242c38323d9a5f9b076947, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=2ab02f90b868976bd1bf9a58a89b705fe647f57d, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=1c24b5dc9fce4ed1e3635953738737c127edcf9a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=b1567400efe7bc9c0459922ccca3331e78cdb4d7, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=9b84e8463bfa7a209b91f2e1ce54eaefcb46e17d, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=4bc78b9ba70591c2ad7190e45173748b1f1fb59c, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f3dffcd6204f967ec971562821442ad0bdea712f, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=42d148aa41ddbbd05f07139ed3740d060f96bfc8, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=9a065cf2260699ed929a5b12544e828eb633c8fa, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f3545c7c641007b08bec587376e0a10d6597a33e, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=a11f6f00867f4ba059f10852f1432a08910051b0, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=992e50e8426515601885339a20f1e1d6088c1a24, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6503c67233c3e70323ca6715c9fd2e81e3957470, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=7dab3edf182153b4016d80a40bdc0ea1b3cfd92b, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=0c2d540f3585d52c732f3a3ecfd01ccfaf1924b5, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=23e0fccffcd6d752e3423783ed68266582c4dbbf, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=cc6d7edcb36b1da38973047eb22b43dfc2ca9bf9, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=424d778c6e93e8363fbbfce03bf697253b516349, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=4f8139f26e81d242d37102520ed657755a86945f, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=06a9ebaa4f0b3800a6512f407655f7ba6db3fa85, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6ec86febc10c49c0ea4e958de08b928881b48c79, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=1e2e26db1b9fa63f2848d7872f8f7d4d346e7a4c, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=8a50ef57d1007f3e825353cff97696992899ede8, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=3d9889812d763a782df747651161ad3372efdb54, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=29c6dc6e3b02cdd4ba7f5e8d20ed1e6c99e7310e, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=db5a7b84e0dd2fa578e7b9ed39a3cc82966d4724, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=3df47cee60fbeeba4bf928e41d11457538157868, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=cbb5197790e512ac13a6658d0bb65c9d4b044a02, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=9ba32a2aaa0e1b3e5360c018a89f61e078ab1fc6, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=3c18b6fd7cbd4250c736ae471e7d78d4a39d68f0, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=b0b28c5cada447a4c004d7350de4a1c50cb276d9, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=283738ba83103f82819b1c5270b0a39aef2d495d, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=da25033986882f48cafb14496b0cedf2f862b155, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f45a499823c28ed15fb8944b01c918cfb8e6982a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=ce249e75ca59aa4df6d75bb6c06c67b26666b0c9, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6bb42d92a10d13081a1514c48e7628a0b9eb10be, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=d5adf6fa6a0b40be22e3bc1ce08c2a5d961af5e1, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f0795247f09078de1d45c92041c5cc4dc314ebf3, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=16dd3c8c1267ce8c7939e88c1df4c381997592a9, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=7cffe76b10123a36a1f82d05912257e67c4fcb74, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=d5c2be0f85198d402089640befcedbf5fccbc51e, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=fbb5fb89a5671f453ff34f115440051cd311e492, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=e6b5ab15cbad78bec533b2a539b407857b6e6b94, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=5662ee2278e316f2611bcbecee9dba42dd1b1417, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=3c39bb5505ece01a728d34bf0ca78338987e03c9, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=79be33bf8c843a9c4d4e93bd10cf58be7a40bf14, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=f5815ec45872de522af6bef148848de8c6a49941, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=740eceeb470981f2791a18432402b8f8ae071bb0, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=b076575e20b95a33c2fe1662bbdc5efa9935f80c, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=d46c5063852972c4e2b0fc8b70464362cb4cc614, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=49c29df08010007ff876d62e4b89deb20f152675, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=19ce67841380e851890c10e10b98a609e2d82972, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=be5c1a53393662bdc1fa35a909ec70c2b2824f46, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=082d78832838f5cb7e0f3180d86790cf8531316e, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=1524483c33c67f49ebf1f1a5d2c5b603e50f6ebf, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=748974f0e3372ffddca53fd4df6ec59c8709f0ed, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=db1c0b0de65e9da785fbedfb5e1bddb3ef679bca, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=26820f226199fe912fafb7ee866939f3cd2e1628, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=430abcf083a7fc324d0e2c0ccbd7882f386f026a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=e6b7f1d5ebf4251cd256daf31b5b513f2b49b465, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=e6577d56bea1005b8eb3e95a881b250f42825207, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=226bb552c1e5623e7e0ceb02945ca0a5eeb13c16, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=60477f21c147d89d292a9a95b8f38183111d5ac1, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=0b4ad6dc5e40877c6186bead28808a78ec818ea1, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=459218b73b2a9afdd21f1c374ccb5396374d88fa, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=9ece0b7dcef2d10e84daa71a02dfd05d20ec860f, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6ccdfed43bdfc0c954e24859222d0cef70560ecf, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=d26e5d52bff5f7f3dfb07c2b15da718cb7c8e649, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=781d87cc031fb622bf74fc615e9c99780cfbe8da, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=e1683abe664621754245fc1bff90b109a0a439d4, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=359e6967d8a3b93cdbca1d5619a08214d6239d6c, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=af1b97b0fbf19439099469bfaae99ee03a463175, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=59ef206d144fc7125b8aca260372b1e7b0879370, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=9b003989e2b944f1699bf12fd3ae9b938a7a8561, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=bb3c989b29963043b45d6e2d193e9280dc363c2b, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=7ff0708560bdbe5f28595418120616c9f9e8e21e, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=23b530ab9a2b3de144a72c1ca516f5e78e78a05a, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=92af00f167ba9ee64a895f814303af389fef41de, strippedELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=91f717f861e3e377ac26328b0df3f8a912319587, stripped  #&,/36=CGMRUX[^adhknqtwz~ #'+.15:=ADILPSVY\_ RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RR RRRRRRRRRRRRRRRR RRRRRRR RRRRRRRRRRRRRRR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RRRRRRRRRRRRRPRRRRRRRRRRRPRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRR RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRzms&lutf-8839b13dd4e38d4db90265d2a7ef58f254d9882dcc42ad17b308ea178be8f0e90?7zXZ !t/]"k%XՊC>~y Mi?;*qUX3Vϥ<%3E9JhBQfNiz|^x~CƔ7CV$ۜQZ KG!9c[0d߭!Ga31ygy=ӺCgJ{6-orgrФ/iٮL }ԱQJmxy> %[?h6sW%Qɂó1Yҍ QPķO7LO~2-pNvnZBUJ*|ɖ k1䮎 OyEV+lki_prKT''C Tvv10wdl#*<нz}#B@@|Cp_w30k4͇L'/}C(j͍طGr٨5-Y0Ȭ52qжZ7!{jx犇5ZOS_xBV|I흾xnΌ[4' \L !X>\CS%l_6rĩzb)i wgM8sz UppV9IlQΆ=iQKM'KREYHF'm*l%\0W1W(N֚`7?*E/0s J#??6nC=I?fg]U4A^$B}΄?e(+;ROO'@8xCn{C2YAPoI4ē@Lb5<sӳQb0}1Cd凖-I`;ΦMw rOԳե7>Ζԡ֜¬hR$;|w& mȅ{G)U&zNi;xp7Ӑ[9D=8v>Q5T ?TqҽubA/0E P-;ֆAxs]gQ>p(,?h7=/r&27Em`ͅ ~v@۬5I+>G6[:'l2tZdH$kr$uʀ+]DUI.ξ AsIn@gW:Ht<śd%%ѐГgp״abVJÒM4͊l.?:R&,(<̴2N9vMH'vh_%ԇ{.gx IYE5%"12k}QJX^D(+r% d "s\{v ]ϮWɠa=^nΑ'1$w{>RnFBc-d^6fV 2;H l@X=v[+ .SsMY\ⷢ/{>q/%@]-^Z:K^r-.pxP0ـzrfwRN-`X^wb$:?.|Wb6k5B ͆PygU(|jN2(10$CVԭIk"#;TOi ؒCD{Z0iO;\ w6:OY={>@s>k<$ŰOש,dy*+T_/U ro7{#o !It?0fV~=P;yh8Ow1Or-v{ 0Zg|E"FDAٴގGӼ|oHlCGٰY`jx+; ^p.Rr iHz+ӗY2T"{)-F6B[ xjIXH8@_SnáIIt)#&7Ej. ^ I8mۅM+=0gq0lxb Vʾ*/F{[(7wXj}jf*^L)S%ƌ+d` Y+K|xBV`:@;rk*}R->V /.DcCe&~h][@p{y*/!/cXBeX%4Z`ME̷1ȱKQC[JZe3 F 6KLl&gev,V$&-O9s 0Hi,R}"Yb!5UQH7&4ʧ YQlϮFX7D^ӹOr5 2UG셄,\]8.Nk^uңDzX1>3wlAuᣐ̜ۈ!B\PReY$(VJa-fL&X8 jjĚrWƟ.W,& !Xxg2Sʹ"ZcGǓ,ђd긔0_ik {pViT72Ǟ00fl~3+BiIPrnfBnQ!!SgLP8@CMAؽLHJPqY~( |T[^"3v60چcZxlBpJ'+nԲZ굤h:nRzYӂA$3kۤ!On~;f{2Ju]n>5(h;D%nSSFR!%vE;n@9s=k:slP e"_yN8ԷW3e(Vo0Yl#Bܹ8D @'Rm2i_]CYɯ ozO)^xrM(hFP7VdZh$#v*Zf`3Y:E y:XnvqP.z8u)Ioe` )RSuרv첐zSc;v<_j{EŊ8$b :,$6PzoHz~@la2;01S 85e-J "$?~nJٹuމuN`xġ )p:^Y>%/SϷ+ SIPre4>Sh syi9$"e7Þ5*-ȷVJq<$*y^HU_`$j]V62p./5nC3t*Cc-A]PL9ࠤ>L2;qw`'86R@ 4K^AYՊxhѽ 2UܹRtXa]+ӢFc4iE2(@:n;8d>ڎo/¾X!&܆E#y<QsKtfB>kZ2 Zݎ".[bMn3w{wf%J^W3(}lxBؽӾҴ }|^kyP_r&wz 0}e'ԋ@6 ]S5Zdc4`%t!E@B)ox& 5 a{X  KB:v]D_.lf&ɴ2pJ*& c4z9kⰎEuG|rUn'~褃`sG8vEt[Wӹ NjQU%?6ZI8!Wnsc'xd{N;80lu^1Ll;S}΋Z3.ƩѢM̖6sECi)'3:ú uE^)tF>yV`i~jd1B !DX `!0?4}_#Ο뮉:u>LG^ y&o}S>?; D@L;1e?z#Μ'ڍ\Ōxg"pWr{u q^hߝ 90ˎ`*d%о̺u ~9ƓT F0m#mp> tR)sQGeeErG."dz kSBtr}2|_hc*dlMĕIF T?A7Cci,dE/ vMv[E$kA yJon7#`;=.~8pf{{FgVU /06g@B?_8*OI㇄nN^2_ fo ,7#5xugNn^.#ԅIƻK~@v.3vp-/fgCg n&deqӁ\9DWb;83Z CL;+Z٢ä~˱ &PXqZh9$y>t(gM5qn~Kf^mU/y|>Cj23WK V=Ͱ`=%!kSw$:>/Scsq.|^feJɼ.ʼ}z,/L9 ֹux ֓i'W`:ߤ1>[wJ&lD2zguJm&c y4{-b3[#ya0][wP-O*(Jq_ߘm?LJы~ aTnyVkbonۥxw2@pϣ88L1GNxoF7NK ]6 KqD մn rc SͻP3t.5o\47pUʙtkQ`@Z|PIDžP5K@pci.|HH$XrUG>ҍbHLWv 8L~|5?`:$-WUy:9  h4J.O%\̜lgx]4r /baEudePddRx~\y,' ~<ͥw=7!#]@bT6|No* dkr:rq_ֽB,Ѻ:y34ʦ^@%w]NhYeT2\ 7 « K XП)z'G i[Yhuv-$ү*ƛH!1;=dA''Np]06e3+H { Q`s "r߼DV~JAI]b&}!ɤri9[shi d*@ 1-UD<k$AF[9_l1xwK={Z|^!wocCNdp}/ ?W׭NdFI'MR~w~ַ@\il5hx.Itpm> 㖊$ܱQbhXk`vj`;>mS#5aq([$Br"uG$7yxi  ,L;s(ZiZ;í펺[Cҏ\G.0Ybf^>Ϡn&2K7ai2OK: 86z1/? :b*ᵿ?bl*巉k1MIi!eN} (4M) s\WB`gl!հie8]hǴJ{oB;K7bU_ ĕb!%?bۚE}+XXK>"ӉBA mEeUdl胕g,GaA6w=-v8M-ˈ, 8H۟,30F鏍U JLLڟqc{j]L|6=qUNc03˯{[5խhW^d/DYAcC܆ 49Lm}pk CZ$1R-4Đ7,{ؓn;,nxZ #" S6&+T,=r+(̬g*R$7)s*{xh+2(kڊa YXX5fM<9?JI %o1p}$ /D,ҭz#ݩ>9*ob Ln 6I",Y'PKis+eK$z$::Ӽ}mwdsP"T= Pe+j %*n8G5u(!=o T*(>5+iQ?2&u ͢mbsܢ&okn'%6DơF~ƫuype~XQ-7&lA Jb5"DKjn%s*ύ'|`F@I1߿iIHV2f̯ר>Do)7f|բ~6KY.񽞛AP|Xi!k`xyP\bnzr;Hɶpq $ K6 "?2Rv(Rgrv%a:@u FBg4/f@a5Q”Aˆ ;W){脿czZTyva/Hʨ~J<%+O:\t<Ә 54AzjLCr90_ŝPI2=z!Zsk3TIh,nJBx* EZdXq(#gbj}0IT5isؤL ύ2I-@/t[̈́1v]'EXsķ4 WseX>F0X7QY{)!ԝ Д?w3~hH/}jWvKd "t⩋=D{~#bjR#Ҟ ``YXlVPP̘]sF(Ƹ,w`H$_)fN%guKPRa ;5UNwRj^_h@1 JDA[-xcg'!egɤlP>+|qi "$uE;\;0꺧ڑ H=1#4zB aa*VX ׁn;7-B`,K^kA {IjȭTetG?dOWc=̾ӭ];{|3ko=\dPҪ,_ft NAt$U<.)-o 0?c.fT\7{ybIC`sl7:*/h5 {k*jz^.O$::jL z3KfRɇ=C`pG9 ?+K}Z\.2 bII9n"$̚U_FTy([h1D Qu CV46;Rm "ZMŌ!{4ֺzJ#ĘY" $`y~ w #^1{䗰0ʵ`-|?H1\!CN`CM@$jHibp%BIsXKYKo\%s )}:téMYX6:#m#ۃVvjGJY8R b]^ r@la8%E"W Bw0֋xE@&p%2 l]Tf'U(CviQS *Bgx3\4oo:sqA&@BXh e^sG όvtuSfv1QSp;Vn0](o#=PT.n:~/ydz_93zkAfyj0WrŸr{nσ}R{a. ٣IEdNL|qQ$NKE D[3ez19:2W6ˆc`$ 78#Ÿ6V:3xX ׀ȧ@^T#~MMjFTcD_Nf%[LX2{a %^Цl/RFy/!n{xX|j*tcPv!r6 _scS -940H*L1 HAw&?$ƓCy[ eh&4{@L&wQHphC+ռ>ItD*PED1dd8{%Q`(!J'l6᪍߇g)Mjf9w?'m%VU~w>ƴt59a2Zm:fP9+1^3u0g0l/{ >7Zt,/k+:߬8k NRSC!sщSfepCkp f,2#hj\:ϭr7oӿ:~a4rjǕAMv?}\`է]>D0JOlU'>8>sP f޴oUBׯt[l6 v Ul]pΕ '`Z#@1D6=qT2֪ .j7'`&tacp sĤ:_g+6ɂc ȱ6]semї/ϼ ;S&=U?B6$ qZcCL顤EE\]6Q#IS3(ЫOALMY bu2Rdfg4~;>ZV&Ai|ERk@ʼnlepyGUu0e[,akrMSf| XvaVcج$7^#u>#̬SoER^c)K=ilj75e=Y7"\Vح` ֋t]U3'=T]y_"//㨐8ݕ$ML9Տ&*vQδNKI5 S<zbL*w*;dF`nUq؜gmqUpE+wEH+CIjKbUy+I!;}l?ӓ h4`^ 9 wJO L^1!{ϳ 5q)Եph(ם۷z dlOEʈ㙰cr g 5KXqf̎LrxN]ru,7R;#ex=8ulYRvn6{5XܶO=M&=Xh'1C; >c P.x6!NO,@8mp$j_bŠut [Pp@&oiO#wƈ>(KsӪGy0:$`пUo/(6fg)q.(09R*T!>7Aq}1}CL{MLA1!Z@W?1;I:̥g+0(gg*ixNqCv8av}cyΎR# 5o \=J4:7ZT 1.u/ [: m"fe\E)\ ~An E0v45յJJ5d"%EQOHq:cHk5|\хcδ0 v5Zw*i S8*pv4!iM|2f<-Fڀdv29́EJFs>ɇ62n/̫ Șkzb^dx9x5B9>7#TF5{*R`V16]ĆE'~;6k| 4@ 'E\rn ; lc#^>Nnk(owLRF| M_pJDTgrXN6f=.{q9S3'zJ(s>Fc!PvXb&K]y Rj՘*?5V|6 T^m_z#p9/ez&Z^r:w2YK=pCX (m=|.k`gzEr tQ 4N!Օ`@2Gt;G9P#Smrs&7]/Bosyc(WՌ-@DŠT(E= JiςXԕՇ·=M:t1(IFDGXD>x$:w*\K&`Ze)\,Q$3BPK^p%5mo~ f8$'`ԍ8)jE? <:bA|G-MOk֘K ;߃W>G1J:/ƍ?5$U/Cn+O*O*3,9OE7= b?7d)`biؕ-"ӝҜC.ݳ#{ߴq)ÒsTeχ(hmV*hEq1 'jm280=4{nlEA$iе+;4]1^6rd1̸ |y`r[+bw>G$`ZB\?%PF__iD`s{݄UbhI #R/eO5yn(a"W-+dmtGe! >`\kt75 z?l7ad:S|Ð!rU) *"Ln!e+M& 0s@.uc-=Ӿp'Z=7ە w]'鲋nG-|V[\ HbQBJV^1p*ۏQ sowzϒef9sxC}HDRm{;%`ǯYLG{eU"ʸpnJr*<$ סض%"nk_-4w F`,̽im­/[ѳw_zzTM鰎k f%kW& 砝B{qj 5n18K'g{d\.is~ာ K{nuzLk,+MqȂԾ6"?̷6 @| ^יocsJ#=0]Me^QH0G`*ˠoxOWK~1tY7,#sDd橧`ּXE7YC@2:TըNق@(wY2p2`Ѓ47K pSm ۓ65;!m+Fl$(q ė^ISCuIV P 1 qDҿiϣC*PYp9I[ɘ7:iIBe~$&EӓPaZ_5b5 K!rE=%Us/Jףk3ƅ:q7)|#` S]XSo$D_Cg/V7_bDnÄ8D&Y' k7]6zÕ9BTH©%|1;y4=ĢFY]O%@ JƚRrS#P?3FMWuK)QO3baq];A m@ +jg[ᆴC[ˣ%lܹ*0XU΄_f 7MĨxɖaG.=Yvч}'Gqt"E~V1OcsS%0`i}UHw2nТ1ub:VI'o<@NZɾ)˹Kh YT5m$kY l0[ -t֎'ojG;j_ Tos{ÇC0\r%i^Y0r5 ';i5Z4=ns_J{%A*-TDxfh3r`7aXz5{r儗^i1OaIz3,f;`[dO٫s9z( _&56Lr86$nNP4{5ydraca}l*'=D oVؘ9璞>j5}\I%  3xwxEp-?=`O-܌8 iZPU^ul.[zHeʕ ,"J4]R nA`Rl {y?(k#AP6B6Qa.%j/c≪2Z~wYO[%Y \F3Z_} Qnǜ]WIbr'UWAq#IPhV>͔=k%fDžw7CiO kQB"8Iy _csw|7᳣Z8ʘHM`Ab叀KkbW>ۢxlڕF,qVk0]YXqcZda4c1/hp90:*;" EfD/1g>:ʰq nNd+TT@x -ۂ-mE'yeåmK63d. Z'n,L<_Ea #!-)Y@S9>w8NZe3q.:q[(MO}9xIKvwkxC=6iQm~ެ0\"V|33C<,ї&o޷i?v ʃ Eސp! *,dǕ爫k ewb0-|kjcϾ #0+i)!$7=Ӳ,*{&ϟQqMC`qqBQǐZ}G]rX"q]Cc<6d'HdjAm?d': ŒmH;>i%8[uT!K{}Rcd Fgin1r͸jeY~ke$hCnhy)aqSQ0P+Y` 1H,5nP"u wUGNE'~˹%jp+[1"yx Pp9 Tp MQ& Cq E֗-{Xw'?ؕOg p%F8Øp _sz'ڪeXXNy[/r͋6ѣ+J-Ӌf1;AԭL5dn| ύ@=fIXY<V !YC_uq1 ^lNn0Vڮ "ɬ6Pka22^܏`P n_5G=()8 -auejr'smD=sD.{m0׷;c6YI4*t,ДjѻtШ5/.,^U ::yu.Wd9v`E !Yfj>Oa*Ր[1f?L'|ddpSI$订&Z?r-+:c/7J^)bvHǟ-۰'ѷwk5{ZC#}󸼯$1u{-jj2_ Qlb5ڮl{ ÏY=SfZƝ84nw%t i$,Bs4xA>9/y0 /SR0+t܃3Dx w33ZǨVʄFOSe•(D-a!K؍C'#I]1/<[$pB]#9ӗ[3i}ܸcj}5}>V u4BJf~5B{:~[Eu ޓb55¬z>".Բ'fUp}hnP0P rJ#CB5!=)3+"*(hn*m-5w%DXuk5,Mg^=܀&s*Ś d6ԒS9ɈUXD]ڲv I}"rmN_EE2 y[qYYܬUVPV qY3ǭ^$O(Fw in9"P';,iDj" "y^9Ď  aΤN\ % ,,8I375jğ%VՋPw\#('2A%sN& ܘYG6ުlz2CBsC킚  H-%|kmH9uSPsa֧êb%V2~_/I~~AB3Rz<݈&t_+sN8X?ջr{th"u y󭈅%Y\p3rO>[ME2z"i{OBK1sTE }@I~YDp%#}_O U/Ľkk6RT~;z)8eX>ct/iE=Ê @B6kŎ뵽sJn+qds.EI D#|4b Qv_vΟ8+P !3֧x@"yJ`NI~2}ji1f/ʪfa`3=(ny2Ujo%ܔ&)H {Jh$t7A0+@9O^D69c9 KM uJFܶjܻRleHZE<נ:]AKL5Λ 4[ % h-/;l{-'ݽtD`DW6UG7iVI^BtOz:5,Ra%&. T'(c*4͊5"jöN]bɠ V~9x3%Qަ^3Tɪz+Mw\ .5m1<^b%5"ڞ_^|yza``Zͥh)4-(PoVE2A9Jݟzұ-e\թ)E}׉Ƚ}5 e}Al/*ىP\GQe-&M>>LлM#V% ѧaA}jgTJBFޗ}ư>HLgڊW.q*‘(d£{xvI?J `J\{xD0#I.:ډ^o.m .2;F yk6r'NT&'ewȖn Fs"-N-'XB/wQԁKGLJ~#9VuМ-}qcQ<֘R(?OCL9{O#<&P:n$n uH8O^?ĕެbGVD9;8%+X Z%Z J3Baʿ-bױ`V4cz>0#Ik Hش@] wz='qjӬi3Pa$D҅4%`Pr%G8kR+Ba6-b6x;:mMWbF]8X,~ :Eݠ3X6iƒgrjLdGoVf{Z 9f~Rw'e 9o6ܘ@tjz*ڂy ZCp#:_ GekpL}rEvh<fkíKldgn8)$ @fك?[Fo`JB~^xu-]C/U\~Lfo*IH!R19 26%K jb&m3hlGV0Xf pkz m;o7t KN 1ιavtU"UI$:Iw)Eçs SzGBa,i&"3IJ]U1jH%ߎ0uAt ":МL%h< 3|<!#y0qOQ~ 4 zL{87-j*ЅYrv!cNIQ *"\rWAp ?Tz 1T0>|j"~<9LK3Ogyۯ̓Rr_/4z@VF&*z%Qjhza|xO7@Yt3P gބ)7A%3pJgv;1*m'-p4Ң°7LPɍ#T㬔Gp*reE=hg& t;^B`&$VW'NnJAW7FBpt=7ÕayssvGo\`:RN܊wdO)YUkP `apFz-Y73cTg6QɝϢ?Gw)se`tԦwaT  [.:J<p}! CEOP#Bާ޺g0tq2zVo^maϻru2.r"GՃXR,Ϯ+, A~YOD3aXj$FS^,_vIO%rmU9lW7x m?cUfO0u$Mfj+'fkթY¢ᰄMtZЀ"ˣAiT1$jjVK^Bhn\ZH* J8*BٰcU_}{8ܐ F* ͖iӡ]_F{DBx>W*={,ß u }=p-ُPD岗Q(T脉u ›~Oqꌺ*C'ur5U&ΰnǺwn2ĕq TdX,%w$t!_p}{W6\qnF>؃{X:M(~@%iJ@3,ƐKKZ)M p Lji!$E.`eS^x6paH{[&L=M` HcDc7qUK[]lqeqSZ*[Gu'p+V B߁<[ 鰵>&5oͷ'+͋oD3%˺]*уn H<5cCM}(ΜH@-e'E߻B8OC0):!kz_N^_y,|Wz7*͆<@+oq0LsΦ)g%H7X<g G}Q{rSP 'B=>j*w\v\h,lQl+De1Y Xnk# d&kC᷐`U=0b0FW KΎљ!,QN)QjyDEqX@!$f!fqlPhzn%) e@#Do")FG~N4kدJS:)^4y4 ,1*2?a!+ 2mХDQtH,? zECnkk44b E tC|ݰSP Df @-q@{cjlRCUAtd @lՊU*d,97Q?OQOe-R5`25B T[ҭ+$gh"yIZoYzbH9yvq6 @:GxKoⅡ1+5{=Umjρ}5_-\ORmxh䃷ܜ{{_#rB< zHmw<0*dn# B ^(!j  47`g`ԮA ?k.,ر4'fgEN NL& .=|0;YthҚBb$* ~)Eb糯&<&ʺ e '.O&\5ȿ≒nJ@G @ 4W04V֓I1*$JHVJ?rɟq+^ ,ojqlA7 bݕC]!V$z8:Vmvav4j'r}K@-Է_E鮜Nh2ȉ2Ǎnt^7cM(颦E+WJ!%'.q5rK"@/yx{tnNiobj0.`X3'$;18޸ %\qF?vNzTr8/—˜25U?e;rXDBQڭ:yi`P-*څ]cm*;>2C.Ӱ=E[3_\n;D؟ՓJ7i$ݑ]⬰h5*J1k'ő2O^e>m9iFo@sM!>w6>X^o!K?"{G2R OvĂr&J6lOz$ TgPy -|Ёk?)_\X -G PSIBlQկQ~ krc2(@o ѸVa<ۿ/̳,o!A}IW);ܫ%*œ 3*$o㢃LaX\[ N 8nӊ duxͲz0N鍭z"۠O/@ЫB)'-}^LgDK*J$L?)grUqҜKd% Vd 临bc,I;i8C=dI]dDxia)j 3=Q)>5F!埠/N] ?AJc#tS'*(*Bˇ[c?`k]w,v#3u+&KV>sm;WC}[?ҙ2d ]6׌r?l 8NJ2V"+ɑ'p #]0l+RtN!m9(~9&{*xV&WPTk_?w.?ꏾnhH6M.~*}?"QL5s)0˻+*r2:xrP@a)y |3:t4oc\ ̷*!:꽗'?ӽ}N(ܗS~3e/K+~"Q8;]#9D|H'jP11V; 3VOb;~Fk!øY;1{NPflRb..>t]vXd:ɰu'66LSܙiyB@Aک-Yqh^@K WH,ƞLZ۪5~N5̇=Ƒ5/K/O. R|ĹM{ 1@r #]FtH(sOk 8IQ=rb8nQn3Tւ>w hNu^cؘ*jP_XcgϺzL9ba~+jx} s2H1Y:NT29AЊh:X`SzGIQ/ZW#lG{nOmZnV`>^,[%zO 3ukl/)SI,_dI T\(dNr)˰Sc =9_KҾЀLS0 lX1.ƳLq3Xz嚐MRK.yT'_rM)dքQCNApFމ9N %ˈH8=3=ߊYlb6LJ]VR׵  Oxy$Jk6HiujYL7M̖8WF n}j jPna0F04,Ou}C_'K.5ɔ FԺD-6fWiGN #G?;;“~҉ Udc+aMjMUW\dWvf3~QQ[{"JaYpK7{EOƻGID̉G:Qf(Elh_yZL=I͇tZFрu[Dbx>/tSuGbFU6q=NɣCX_?O@X۴*oQ)zؾӝAArOv=R ύ~$qEO8S{QbSF8:NMl9zlU rB83>ӵH&桸ELCtt}x$ `I8} 2tQ=E|iEH@*N~cԹKb Yk94/ 8&&qgh,-+^ "x| *,m1YaVe_T&o'&Pd,'x#jy\~/*I!=s@H; nNE)Jm4TρD6݊_ÔJWd>9-<\_ 4FH~^N_i=r<"~yc`)*Bym{oC.ky]fzRhס֣pj{ UJ]Xut.B\Xz&.=kXP\})JoZV@hf[T++Wh*}o!coUN,,Iהsf&AՌ~0Ս-UTjL\̇ʎPe>3{]̒DWO{y+( ;3MrˬC٫*!]&kmS0x++xĄNbq!A[9#$9XVb-՝J_ xh(N$Q/FdX{Wo! @V/QD4LH`RPIbp~ڻ1f9t FW)~VO/fiH r??4n:tx2HgPжa?,[X)>HA2wϟtC&zcۃ?k`w#"̳Kas \*GtG lL,%;䕆Z68yiUH3P"̪V \kI( Ve-LdZ1 wA=Q3~PWL]ĆRxt@T+-P?rP4O2Oh޼0P5fw5Rbf\?oh`S51 uNkPvIT d:oL\ ,^",T.&xW)/I(}x}ni7 u}/J[Bj0 f}lvg~`=0KS|hGBVHy99F(,Ljub!~vi[-]+BZܩ>RqI67v`UyY)P1x%ȝg4gt̔ ߞ/<o]̠7|X0I<]avB AF-nn^l_ؠ:PPO%ƒ'޳h/JzOဦh׏eB*]ՐgxJLi@ Z2$smi #4_5v0t!sK r-3`yKI {AS7gՠp/$uAp)085|eۧ٧HN.֬S:X9%<wG!Wv!<=}A;Z7kzot\Y#݌>vЄ˿MZQ 5iA6HdJ70åY3Y_ [ :]2Ҧ!;= oMU\ |є5qJ==w5IaGU2[ɇ_7B_WttX:mԃ|k \XvTD|m2cgȺOX['c[b"}Xaa#JG[ثf l S0޾SpTnƥjzA \ߎ>Z&ei<3^q*<ԋq6V!OOcwI}'F H}Ԋ[}tQJ)rV +UGE^^ͪd>%ɶ{:[ 49ob/5Y/w۵q?j[]3ibSs%D~imx;"]7~̢g;=i&:H MCES@mhA1ƭP)mT'oA0 \ Lœ8:7Z n3'c h5SZNw-BM~ç3R2&1 COkbu:Ǖsi2-H:OzJLiS6\Rj︄8bm%3rhߺ}}XcX\9TspyI69n IwLDpvs*ZvF+&`rn@H!Vְ|W@ b~ #:(_@FPW$1~FvP!yyZ2niPB4WىʼnT+%\i8x|QMm:zc]ɷaӐdyr-%$;S)~GaN֥tt\ p3+o RE:޻,i"}Ix̀QXfYt9tG?%80C ٔխN6|3]L6(4gl&PNKAXs0T0ï&!WL'}OtDa-UX'49mc ){NJ2!*w;Ns/'DjH?s e[.6kwqMЯLd KGWMmUN3s(q_}ׄZ4)jc܇kPvLf"unJ$:hHH'Q/f9r׶"2~XH'!eS50w <[/D,%ůX6>BLWgy 0d_aNO+~D'bmiJ)^[j߃qm}&j0:j).EQ6V0ZD*_hA*#,M?t뻡L<(L!γVz%BʜXA堒!<ߢiP9а _?rTzXI⧉U$b@~XQ3sqam{'D`:9y2I#,/\ қ6"k;zIoD<08@`9./)(dדɥH*YYR8--F7YKQ>KaxLd_۲8RDXeIi8A'k1A^7wt A4UoOl$>NLph=π9q*P`(K*v͙S-ȹ7"~'>7ظ;MG_Uu4  D [ o QnC_ѽ?c.SؗtJΐ dyGbAVg˽rG(I>:{6y1j=+4Ose x~9me\#!KG?x%8qi~ {!6ƂDkv6}LcwW_ .~y|E S(.7<}{ۦ"u p쓶ٞy] 4 kS)k?**9ʬq:&RsDZ/L]NUʊIvw`^zQB.tˌ#[18 PBVjίE>۳c6J:}ўԈ#c>|atwX1--4m%z_q/|fk{>! Qꭶ֜ vЯq Or5TU ֿU*MI"H7$tB^1 ' aDvr P7)~nfJ1"teAMV64zy#\JO%_V4HvݞfI9J]bEӫ2NELe&y{}"oPLG|яܱEߜ8"g\{v?;X.䨃eȽ![ a~X*tZ[`CYі ca3R><&kh)?|PޔCb#IF){8hSIm†V'`Ø+[6""\M8bWV$VY맰X guS6/39SۈCY6)`](X)/4J=<>jYf}kΏMfq"ty5O'"{FFE4db%ϮCM)Q`̰ԶiQ9Gwib_+Pz;Z|d snfլ)άBM>n,ܩG/??ΫU0"=^Ide|m(G?N/3CuF.YZ Dƌ2R)% 8.DC;ai]V:?ZR!;* Y ;qle؋?q10YIF%Mkrf 釺lh݄ngs* o1.Ϳ&Z WcWAH ?H3%߂@m": I.t6, rƖWϾůGqC^@D4^-~dő[%/<>QE#-&=4O# 푛J^9E2䬋/%);Pa0DB3{'WMI-nxg!'c( @"]'/ +գ. * %ΰ?L!ڝKFߖ`$`5@W%L]i]B>% ')#L& v퇩0N _xb5#]T*{hxebiR_7IcaUTф-Y]w%&sE:=O4Wyjii(۾g#|_fK&tA\rsGuΤجVL6|u_0ZCؠZ'r4  Q@-0Ъ ]uմ!N2k$XBI#AlTl3Bal)EcQhq_|}UCfI3v)y*r5ȸO/"GiKC0g ?ߤ02(d?(ʦd1CI,>VchP{:F`[L&~Bև#/;M[(Np!{-䲿e 6x۷"uRQqtQ/"|Z'\5CJuʚCeT~;l#PL@IP0+ 9vpwHRx9rWw؝ IyIю8(()G0լڬބVWe"}oNЀ&%ЪX*&b{۸r攣e u0|=EbN)ᭈ c% 5@{f *㼒N}2slO;TЁnUQBJ8&LEمޚZhQ,F\d!dP.9 q4z9,E[J1g')?r s2ĜAaV(4lj0G(}Q4J7~AwiwI=t;eDF{cۅP d@4BK w'3!]=;Y_}ɽՑbGK= vUnC0+KYd@#lnsv]%c [V63leLR2`Ǭ~2]`_[=s\991@r -sc5(b!z25" u}om-M3.츢$.DFA"⾂>$it}R\u8 k*7~, ]1gbU\M4i)RMb@;̜a _̍ X'R3#R7DWe-ML$>[evZq&N?I{Pw!sHlߓ/Uu}MPuH<{A g0WKtVҽقH}"a E/lJ=w/V-½EjTM额 N0ڶ&=mcDw5LR7BlFۇSq +nYzۄA&;cl0cz~Z"KX&' L[Ep8"tnT%*4u=>/ }4փ"XH=xhܨ4,9!읇gujܨu=m{@ lZq:J[ 3 +Ū3Cuiw~OW靹:mwUn흕7UqPM{ dIr&8`~ hu2/7Y5 \.&/ng!IcN{pI T\6MlL9g7/58'{@;HLk! '>=.eٓ(е4[-##MnSO8uWc1M$kl>45w 2=6.{)%FsSCbs.pꄠ$4p7R{(r @.;d9,=EɅu/|lhI(wגEVއ XK*& uLi_qGlQՅv`nRarkCBFKfăR=}5蜗ҁ ~0_FH"9?/-RlywM 3X"ў|pJG3VqO|z#Z|+O;8? d 䝫Jɒ>:EOTOBnQGd9bš>kѩ`,Ǻ B;w[ouIuTl=$I3-%cǴP%b'A P\317FԌ"n*b&FgZz81qAn۴R\6q7YQzu,]s>jΏn?!LZ2 0idjv`A =3nФ_Z2,@eoNNU ,Ƈ~s\=׀K=`ttdG.S}w!Ř_O+߄Z[$,< VR0}!b.'cN%z$aALΆK| B+E!U~XHݻ[k_9#!ˌA ,* t}6s[(j/\CnV+R,ik*uHkJ'3vJ`@>Wڑ|Zy`,㉟LcJy;;Aey$Klmx&"!ƏTg.A=z)y*=d +h=Wcz&q$ oܤ:6-R higCL<| B,<-W Ūd/V\Vf?@z(͍-OE>Ūe澴OI-ۤ8; "uv 9:up2=GE&ӵ7:+VW>GYZw>Q&Xx=CF|Giʂ2349,сcÑë2 #R!X=e]QVUwۦ-EbɷO&!^HHȨR[oY: u5i%X@ L@gf~%]uAɌyHu >5& ~УSP%+Ӕ)nX|^u"Zh6&̜\^f>K _) 䣨u=X|Oն6TŃlbJ @0)3]_#a:G9:Z]6Sj-т}I }DWnzF0Ua%oJjI+!ﵽXa{57vY޷˔\c̟!4_RxOx$J ࣍S@W >5Zܤ;;@?T gbs @#Ł&PQDvBM{MI 1:5}6d4rNu VWzhT^q,,[·rdw,F6O`}.C$W~D0[C&\Z/6CF}ba.h`@mĨń /C:l'XC- o, &M84wسN'=q>O{d6G(KK\`kPZ6fSP(azHS M_Թ)%BG>SֶQ棏nx8%nʩ)ۛ)~%ne)3nag9m+L;T&1L^ 8j8෍2|Ե~XpG#֒\[ 4?8UfVn$|!m5I=nQ"*&Xx䷛q1E510[)UW1fǔDnRcĂg}(Zo 8F Q̬[V4!-:g-2c-#]ה[DIK?yPB%߸{u7ϓ/ kd㘲@~>08\vnl ] m@|BDjnղ0^Xܓӛ| ~NN1X(6 YKC×quA`0,c$%(O'9CaZ+8~NK"K|I Fp1UV$[jX4ȊɄHҳ6l…ǃ|D+ʆKY$~G_V&|J}bS$] ᠧ,T_%$+f=( z쬟Q!lShR1v7`u3y [?ȜvT;A0ldɨDUF;9C~eH&oݎH1z{!:-_jS-_PH[rƛpY*-KW㝲Ӏh71D Ʃg=VVheٱ--yAxNBM,7t}ж"pd=^&J eݔ xn7NYY*(fgPmx#%"+XU+$|EP2`W=0n  X3~Fwދ%D[{uFXp7#wT7e1w m7?@M @g2],-xPB 1pcH¯?\3]ЄxP{J!.i18՝rbc ,oa{-}ެz NÁ7OW)5krJF:Q(XήcsѧYn!E_|EӦ:4OKjڡ@:H5ad X<˳C~ kު]51v[8b:4k3|v)>ЁTUFJEFf!1'/JKܛoq$wI"؁r)ۢ ]L=mtc9+4>:~i3@ s`fvC E܀:Zp1K#kKDߐ7t]?z~1.Jl-rnfC0yIe\Y3Zr8X^=[S/7zeJA*ϻy?JBE}]'6Wjͣvf>ƠK#UII4Z<ʟ% 7,l4f ]- i7)љ&yn'B$lDNWr0UŃ 6mSs°u\*^r#GfY$Ƀ0wu % Q| *ܚE0ZĢ>9PD#f2jS+3{RpJ8a`|I0%}(Taь8b]ǹt ,B"u&ލy%f:J>k&]w3Qp& U6j Qb9)1q^|ÙL$ | GE%9A&d[ إ!U}* `y 4b $Ăv+9ߦ)VyǓysh@Va}cZzVeLv9D%&p㛓+>gxA0|ei@tH='aTj Ėx> NbUyL$˱ zte,DBĝ)x2WA⮀;*'(|TM S/hp>BXGTya2W.ӑ 5(4Cl,bD._qUle A4˄GCxmDh0ͭ 2hM;i]XW,@/K"*_=f _PJFAjy21RPatSCryQa.#ܖ{X Т߻BN~{bQk+w JNPNׅm"~`DVlv7u'[GJ7 l-rBi7u>&J&.Ӱ0տ(iإ91t*< Kdʻ<RsYsy J< 5_ Bc|$D ߲ 8V-B?f`:8[[fե;wЎ<$w1m=xF]^&H'~!8qź1j~} ؽl.ab(@ џ?^)oP3|mD 29 ⋂2 bfK}P'rs?=!J}^B=yL8i:ʈ/|+08wXEy?FŅ:g'e8 m+-0i!i9h$ejwxG6ޛ޺: &%>{$n)pt7FɊ5~hdŵs|-G{&N% ,L:#{ kj{<یd१yѻkM%QvE#)x(9ئ qaq n3'!+(+`&F^kfݥMvơ%@V$ߴsaR_jЛ@-v4o#s~_%Hh#(,]j|t>^rARӬfп!η[,$fVt4/Gs`kO oK?"j+H]; zoʬ0XwۀchT 1 _?eڊ FK`!Rx*qy%&ˁ~c4M`u+b'w[pˣ?x\PӱbĦwo13 &^*ʧ/-~i PenU!Pt~~prLrP(sd[-.]Ix!(XJ}N:7W|y9)mSZxycۧ5q{;0ϣt&w-ut'?gK5r2ZdPmώ<@l-B:!RWMì*;β!9(6JP24dݐ ggsFɾ=bpƪK񝥖8qvez'毦l%Mr2T,ȱ 9dƜoL^Ε1kJ<J6b1¤\3?X`,{v:%4ECAU'20(Q4Io{\]E& U7 mz7Kk3OZWSDx+wΆ5!&nK5a!^!>WwgH4GR~ߒW1Dы^7C%[S-ci+w9[IrZc0>;?]{+WSgðekL3(N=, 8 cɉw_WgAh1N%)T~3G+Yok.@ >[۩rB/GmbQN#9Zi܀3bHYA˟MFs$M 5/*ƼPUN;'5X2/ Y5\Q;,s1ͼXdCBL `MAH[# mڦB^kABM||#_0%SqVFcCTGwvC"'Жߺ/ M3acbq3=[ 4AsjſCy}20,Z5`x~) $am^xfǤr_, pb/Ȏ!pV| 7ҳDvX((rFK~]BO%F+_ɥe-z2jDܔB1$ vMgqT9'([gCLoq+FCZ%MSWށmoTk`+Sn@è'@T\D+q"q >.MiKqgl%TZB,=8 c5ͿkLLTdyi;p0S‹l/׹g Ca%V2$Q7z4ie^81·^w&"_`E8oC1rI C>$N b)$G<-NDqy_QG$GbQ >z:„z^#E`m)Q)rwUY&DsE+Y`$ˆ_@b/mj9b9ߔ+ȫ[ :o=K$LeL֣f$L~.mgˍ&m).[2>o<9hUsvc_:|dE&ĐS6MxXs|[ Oi(8Hk+=LaPJMZ_e74ݞ'!ވ3#%Hn8gsO7PH$ rWSAb;/z? JedI,d۶ÜsiqQQ]f\ "D~)/g&=[ 6}5| X' B#<حsI9gE@䂼J?D|5X@[c"-V:I_n=ױ5'S9S,/@RX#SBPЌ[oG}N(" Bֿ(;e2^R"5҆  jݨry[Z+#x[ڬ {+v]Y_Y#025BW]JSn3cFBެЭc)9#%o5VIkB2j}K,eҘaì+ f.cOƴGAer 5 '~v20-Ef$oe `zfyb7ޥ ?1f7 /=jE?V"~iF6K?~BS2?;ː;.13Zİ&hW TEFY.`lvXކZҏW+zajҝ6&75էWT=d09LΟ_:PC=?RM h+Z{+Sڗ@ƩQ'!u$*Ħ.J3gP(X xSF IDwke[`$ٚ|tJT 3f]%U %t8LY!oMsR;A4j8)j?&=g@޵ot6kZϜɉ M>\ؖ:);@{ 2e] [>DzqD+^R*΢9'!DQCMg9zf]gjH_c!Б'f]^/+.{@3<%_?s>6'QO쿖tr妹ƈ3?\Bu$#w׶+"N;2t̡{"w"c-Q~tv#+я,+AyOdyMn>4$R% <KpcCh֓|^@B:X A:xoK3Eus& mJ XopLZ+p,awd8SK3U9Qy8ibADe(?!^J8Wl,߰fG+=4@֤ZR )+E J$`&X\`GS8 N=n{G*φ@D8O0qx󠄹KVK$>2A[` 7R >}͑p~Mb>5ղ-ATk.-(BGײDsUi{y5Nx噞<^.3F,REsC.+953<`[p'ߌsvWS>t G\ȹGW{Ob-hgFMd-%91cu{JS ;d{fԙݑw3ɞk;D|iz4B}mQ{[4Qhc:tW@ ]wJt7UIs؛!_ʩwz_X> V{Jm.>RJmq7Hsn?&7=n]%S m?1E/UG=*ԄL[ט;QzR };@WGSSgh1Zd8H53rdhx 2eKh=?V~9ic<_'PV [(lDk@ Ŗ+Okun\;RQ$ToOnˋ遄_&6F)]= " |p]^N b=3؃C,33mZЋ)Ž]JԳ;dOpۺn-dxrk{֖ À+j } #15+'(\$'UZXUd*Q$i;!A {ijw<<{ jE?XK,"H2p n"$݁f-M{زM䙩(E GYY&OlDjݼX{rh FxFqci=1 m2Nej5(4Db>̒ O4B5mpDžo^ډ|2յrqP P $Vs$A,"{ԁoWXHe 뮇_#b>, fl b$ {Sw?fYuDbSO4nB9e,Kvn9a? 'U&1i&&X cy[JZf)XMJدYz&3>IKAJj!(K:mG=+;#ƾ;g4*PDGg_P~ ϝ%P=&XKͺ5/4ͽܪet{)ڳt-`kM1*H?|$t؉+yEs|aSYڕDXGyF*> V~}-0',G۳ u:(5I@=>Kk Kr [Ď4j\(C;߇-ױ <2%C. 1A5w:)KviȺ@n&#] o֌ ƣ4^D"On0c&X,߿vjI]*]uCQO좣 W1e1+8YqM6_k}[[aPJ>:7k$R)jpi凌>xKa0ym4u09$r:Jo r#4e }(a1^ j6ylɯɅ #AFN} S_f뜦au/@&{@vq O-֨i8ƺͤWӄFv~}reY&ܶE3kaYUe:0~]En[h0Y]*8:V+P)=U#lqz5{P;A$&  U5g(?1{Jb*KӜB v䷰'z+{zƲ`q;<9oYkCvZSh9"=,C(h!]*/wtV `i cz =\9%.dEn1KM"LiX595-,,) &l&xY `q+mBCh庢+%zfrz,[-6naQPz߲rc pl5bwt\²h+Il!J)YP-?;'{WXu8SxX,ǡ|~RŲ]#0Lm8d}-eռ8^Vwj_̧ph})kdfQ2WgN?_㶠Z߂,ŅA1hhlWָ.pm!ef_xo++.{։qty^cw4цd#j4)xZa 4V (Sv.:g!PF>1`+%_ E%TA+"dA,Dʡwow]*!A Y@1@ؑrܷk+H3odSﭒ_h;&atd-[GЋd4w˖ҀڪpB@B D*!{ ڢ2X6 D Gd4`_2xr_*m׾̟Lb Z!QֱP?晵QjCGFK73'H~5&ZcwB~rd s?`u> -h8adNL)Nmz@PϞ{KfӛKLU"g"w_S3cZΪ"vz#SN⛳m3Tڡ{QTCzs!v/iT1-|1l/~Cz}c`!o^B^͊?:|C/iu ̑Q2 2[گ*0]nݜqH0q}݊hGQ@Xt 0QQK]Z?PhY`aW< j y lXcH r5|O\ʂi@KZ_h`(;Vqi֪iolDG08߹f ɫrPA]uṙ:B|v-[|9%v[\kݷǰ>5}¬rVl}۴6&;/Dڝҟt3GWB("1ʓWXU\c%M"RQoÁ )0rh; GfxC'5>~p iobELg-<SҎ iϣK)5moPWDsma*9U4??.TMhI*e 5SV7qo&%_˓-NrOq {48S \ou%#CI׮ qUa&9QTmw",{Ch.ZbB>ރ1R|qhŞGS~%Y`fyաe iMatKېhX,K0FyM}|$KVr.N>k@ J] X\둞֞\:hzE[Btmҩ{w` I->ď2nިzbBm RHXpj<+ҿ5BUu icQ z인$tJ޽i%' @6A Gx)o2ǟp'¦9$bve¦ C|苬12.56!}m)Nakuԏt²v/#Cx-Avyn]$BVe3]݇}7)Jw"'U2Y-b͚7."oY: VP_]h,٣1c \v[fԾ ] -WV{S-pA'{_(`^Mc)1D<b+ODVDhVJ%T@=y[F%ɀ,R3*BN:0Eg\9ܚXeR4Oh0G+%jtzQ\X Ja" 1?}<7cCzN9 V1yRQ6qKMtTKD(v'WՙU,Tzj j ."]T)SUiDʚw.inZސgl=VD@}?QɗE*vJ͉"9SקiA c!ty>be!K/Oe\OB|(T]3[NXZ\&ZO2p|0 6ڿJwƵ܉ja)ׂwwHPd FzDp@zwp Jm{!W%R ՙupFXqץh#6R"$@6=\Av`E%y7M$/vŽB꬀J(%.z " [ pp¥Wg/7|Oέ\T-mBqں~Sĵr*쟟GL8b.TfoY1a v,]쩨2 gcylc^c+SuĚyZ,"ž ER#Ū1'HS1HW}XZv7|"؄]H/rG ?gT  Rf$TKbS^}=إy/'dDȸ8}%)Z}*'Qg{Z{wx,-6(cj*p }N_bA6)w{^;kS2RBq$ 75@e9nfH%/jc e>qы6,BI]=b _GjGt[#/zPÜlC F'"С2cvioNKր ܭ64zi7 o( P߇j8x R~'PȩZK\k%h`s/Gv撡0斾RH=@5lP$rNv< b($BՈd&g >,*GluFYwQ }"3%asKܦ5\5EJ Oq1ٶe/i4^kz(JgLEN<1J GЂ|W)Q+7פ:ӜГQx_Ϊ ?רEずLܱ$܌;|Fq=uG!PTX,fR1*˦YwreXYgN‚'S,$-I :9A+ΖSP<6 /cl!.N* Ɯ::VH?'H`K[>`/(hiq$*'- Q08( Lfl݇>;yHMkݳYʚdBW&10AWLNjzTjJ-Ts t ?QH.vQozP`(=Y]j QNFi.1MJ%VtYFRm?Jz^7uzET x*@dN_l;;1Z]uOkjeA&ۏ]Pz ">WMcbޓ-:.8yyW,Mqc(& TQt':tgB@:d)=>4SˠU7>R.ӑ +kN|!IS[xW6N߼K_W-wxX,^sb@i*&^&>!0Ii cʀ+R UÔj<" n, iF< E6(\8H򼚵5ZYx s*v:@@X-D<ܼaP`ȥV@ &Fa(b+dX*,)XE@EE F1V$U"XXE"X"1A@Y"Ua@Y F R("v^|/sY<|lF~Z,d6W5rѶ睆7%'jx7y"˝8@wA7m*!}9TIMyf;a Tuj1F +jn{/~nݷ[n{b@$6D1UF.S![ni!2`$5ł-7{ @EH#ǂسqlq~/UsI]5U:TY pED鑌 c$@ 3 (B|-||La^"!K\"5kG c%F2fx׌ԪUx^* 0V(?L )b%B e)!@dA f"nqa*lH",*  wqm\H JU hT$D6T $P=^m Pu1@^7N9dII&  yH uA0 PI$P`N*uADX@G.z/ad sEAP4+s1U47"D @XEv2)q9GMMMD:axt]^STRZ*EDS( lD\@4 i( FT@d/T?Rڀ0/ 1@{5NP16E\N* ?a]QqDՙR #`tE2DW"c4@5iAON{&(J\H<u(@(;TS[T/D;#:₇ʈUL`>k(()x{(; A@  Ȉ#.Z>sޑ7A>^/툛`I!xe1?Dh".qċU_MJxlDOE*7_QdDD84E*G8 Uň PCb# 3-tMD[m T1zB:QP b; 0MST/ 4ʉ׃*_R$2Ț^Č.mZXn'}|,0ϖP g1H*Nt %}jT  3ta$үֺXʀQDg6gD-A@^& @3A@KѼvNp DTT|Zl{DQh',4LYm4A37  d {Tr@ـBz{'Y׊  )}|q'ǽkLP)~hfi(m@L$ V?u*c fbe 5k5 ڊ/Ȥ[*:')z!!tG5@Ē 3@FE/LC<6Ӏoq;'1L 8`\j:-=T uP Lk[egY({xk wE7݁k !!eQz%E\9-@@/}ن9)݊^ xi@xC6@G DiQ.I |,Wȇ,c^aHg3ܒK<Cf!ΛJ $$4IX-FDHj UMEM*@7Mq,&糨}G90J{ Oo<_"b(|fvk-^jK.3Ϙuy88-'XP9G20:j""!,iA&}7nP\VW ͵t9w䥉FS]It>j9ѴžC?X$$ yH<8׸keG:z•EInkb%!S`yWξ?qiv|'fvRZQw3nNOGܚc~yEN\gOrybg[]]<sEWlm&Rtpn h4nҫTN } QkuQdCFڣ$ݛ^^f'RswD*#V4!j/S7x:/M}]/{ nun͝t"$:ɶ{tuI{xz% xD9;947n?I; nqb*'WYו(ᡡ` ^ԙ+6;Cƹ/= ģb_o}4Z5|l/uO}}V4 ,k>]ץ]Ϧ\^7e)/;9"mtytx¦?H!V!ǓBʺimwU>ukJ8GgX y̜Z٠]"]$! yXipo` ,<[4ݏ SaiNT`X*bXNGdC IzP䇧ZK@# "_0$~6ߟ2|} 6kͤ;+ҹ8tě(1&dt:78O dG .-vc1>w * ZJ !O)S|mܤ NFArzizC`= ީx!@қɃ59nyâMz(3::ρjʩX'NMW"NXC*S $Ѭ<gI0ޱfVzGB1j^1kӮSlfAiZq(vPU/g'+J7.q ZeD6:I%f:̊ePuQ!AQLVMF[n>Xw=܇L(dac}iͣ+ӴC>u?=>t|K|пP'>b47PHY7t0O&ka$tiڹĬ<5kOc/6wM;1w*ֆ3N/}Y?Q QȗIl7FդI DcW  a_Gl?K6.ja(a%Sչ_wk5 DTHpaEA@"#nzm&YB )ĭP9Y]cq8 ڹ ky{0#N@s hBN*Ccݍwϵ דR-:8C wb[^bid{6.㢃`?v@/o !_>=Jv)@;+C8WaƟmְcf5qh/G#H5ZTZE?g~H2!H|&?h%BMo( ^fFop| "}t&J@+ad9~c12:D-JGpCdstԧL1 oN0#@ "ܨ ѢΔ6i4VzB[VPGȦ|(_CM`\6C9ij`[vrYI_7aw,}=8487hDHD!Rme__ !TɰivdDɎ^0ꤒhm*g Báц6hP-"!Wτt"b*Q(N&էR(uChuB)mM;X}5J^@ ۉf[%XʹܪL_.]rP+ y?. qs߶mI)`"$!2[zZ:|[4tXKZ:(h`}Aˀc [15P| 'fxyxu,4HL $6LJ_} q[9hJNwk]Y:iDB|4K/\.m90=}4kd@(hwN]2$ͼxa T:Ĥ@”ЀSmmnrKҕ10ٶU 'i{'Pz mHuwMrZ;8=[ƅV<>hy" ²Bß j2)T0?*89"Yq "";UԔyǟ=6GSWס(viyת"l &@tzGߠ AC`J jB@4V.R(^#ǯ`HY_#I8; 9I,@"p(2!Ɏ(z$hҋs=XQty~e h@B.`+0Hrj=]6~l< @PʗRZX],"<,&a @=&3@=u&d߆l„Us( @{;WD-q"8V-:3E*.8ޚ4Hஉ9i;#pe:&ij4]H5PLdsR FNQ9I8cBRKV߀ =8 0- ͆XSxШ*'q$T5HFdx9w6dx% 4G=1K-B)LA jo[UX'h(ex9ȗ 03T npL1Fը4_lB9۲brrZ)Smh[um^/l /jRnl|}uC m`Wg*Mqޢ :/5, ywV tKD!:Optl\3a4vi֠RDUe3qh%tsȂ"Vtl,fʋ/.b{Ccaoqz_hO,0T9>i8R*U& ~~-z*2MH0=tv MNrvs. Bc5Õ*(U}30}M]Wo5{󕆟od9]ThlODk*b 0p[fg6tǟđ8M9H^Ao&񠅤|#sV[qf_\c2o)bP+?k\?!C)PݕKU?Y7,EN%[HM@ss =hDזyzglnWכƟqX?vybv\'_6{ö9ҿTZ |:g5~n녁lh>1soWzqcߜ,g8q7yJ;Q({.:M\X;~n` hNC׶j`)@1-:Ȳmr+ $ei~|eZ;߮Eo wi R۔rm9g-vD"8QyH$#KrN,B'=먘O~ior BIxVB{g9"qll׭;$01M{N#v{}JHj-zkφ畽JhC%H(pejk[ط?>ܻ;1վwh{nq%"E4:ҼҢ XF)rpo7ޮo]mU&~%݋$^+-0t$R tuI]|/Nyڴ37f? uw8Vq)Z2֮YClZ_⯫Lߪ{{G6b@L0IP(Zbtɳ1|o|:Y|cvގ'3;+p㑯ph;){uetOyD=ֿX{t$>)+u}zqrAm1"CN?Ǣ67;S14,R #I!9I+DY"U*V[jD", cDY K jϗ>S_l/]mS+2" )U)da$I|/sދm^L,XQ֐bGU%~s.Us̡~G'nȴ~ ;$ kjP`ˤؘT祽w=UYȒQ$a~G憎[}?n5B0B "2)מ!xtdQMTJAmk^˟JiBe=ܱMNZxυ꿾gXv:O3ߣM z5(%TJ*@LB{0ffn=;lF#@$_.r }@p5}*R>BsddYنͳ*nQjX"1DQ`dJ0DU4; H !9]`5ŇVQE:L +ըZYqaU1?lUF$ACv"D y &hgoU1qJVŁ2 CQ d/8nrѮ>&dޘ;E'9 ٗ ;H-i K7ƌlun sن/`8;ӨH6gF8)ӨVD;SJ!U`NfbDq* @u ryKM6k.@S2"`;7M.DpCRQp3I,|4W6[yL ܺ\-Z[Y,08drĘ@ZiQmAW; bdJl@XRD;I"Z@MrdGQEnP M^KP5Q =l]6D9̈́҂k7`6⚥\L e|Ja@a{(\ uZP] Ƌi*ka2a0,TxvRxj-T9V%j(,[:Nq1')aEULF@ BaۨT@QdC#]c,/lNWt[_WfyKMQEuQ{C]I!;VDz(_1A"m‚ц췟^"bEɢ+ /u]ox؜lfZaϽa}mt {ޫ\n?ՏWszC;:>䃆~وdE9-zIA孯i&5Xec`>nsEK0^b#Veg@KiJvϾ oW<|.k׌&3:xCf_kO#8 WExVM}qY{oYq7`7!U[xEi۟4RZ*l={K\_v{^鷆mEh.~ڇC Ei:>b3o[CTFP s\Cd*,Œ-I~Ce3N >EҚp8#㤃zef1x3_>#Hw`EV G{(^!qGA43/~T4PEtTΈZ"'$(d-b<?|Tbq@PNj*(=@rP\x"xyw8CT^ e"!q 1N(~ !砨 yQ7v t/Eᬞ@$@@ŨG_b+z"sȠyo1Ft& u8K7t`ilϖS.m~sϚ/_):=]C I^ǝFc[b>-nd[NMuӡz\Q,d_af3h#1 b8zJՉտznPm6.*Y[\l7^z ƪoZ snsMpv)S& Xi }i }$v lG{>Zny<~& ʒ(^-6ؠ !1NU^K)=i3S#G-G9ªK>bpBC5֓s>x %f_T#->-kb9V+35+3O~VQA")?T.Jy<Ы (3 *~'|?+&-ނNpy9ֽQrj4˰nDۨ׆: iW,XLne굋21<"&ixzAk Z롅ϳ zB1 ScUPĄ7_IˣJƊ6JȏF4HLdD%u"Qg{>t< hvdr˾ YސفRą ɦ ,Q6JZnxM̦ r˽mQSl"LvM*,V1Vo:z!d8oSg\QELUh*1kS=OSC3\UpNbX5N7AFSXZRf{:z ﮯawft1s? "Kӓ/Ս B ,;)F$]s*@4@tQPT; U~x͑3Mq֡!̆|s8,imgxP. *a7oqjxVA? Q!loSonG RXzm X0`E\2PdƎRs!)4@M$*@,6KBla|Լ+j(I=ߝ sU!TTd[$5BǤ{7ˌAMЬEURSQI%dCTĈ&(,- RbCiߋ2!O Kly[?LVeX,dD,-*% T7_;ȰDx@$8B ;竝[n[%b~sz)=,T2RF4&L,QDʪH,MhD@DA*1,,f&%e\6:`,ZDHȅaQ_}_{[[m[mRDZe*Rda[Q2}Ӷ[i#G,)Uʣi18,l"\2oe;Mn$XL\"^I0[TAgBړ蠻yOFCD -QZzB$Ö\4[Rq:m\fNSqĞ9nL;q!Z-de@`"O` )/`^gn4,rXV;zVE8@[_CD߲\P"K/{AaE  Y9 <޾!p^{^Nu݇)@$ R#!A BlgA)ih+zA,JV_,X1Ycqd|4A.\O!kZVFaJUH.&,@]|\:=mn^ ԬfH0alBHe #+ Q<9%C~=_.AGulH v/CB9.E1;+z"QPa1GQC/v'I$ə $D &pgKBh(##2P` ?L@nkU몋Ka}&z m߂>|3C,>$ZU8$UJ3* PÆ D#25̐ @`Ym:d0u:X>=_SQdJz=g 0K_FHRAN^vB-9 ZpMp|5C_x܏*w'!(5@AOZ2gR @Bl-|&t5ng8v=DxDڋ;0r-wOEZ$nšq4Q Z.ct;{>DJA0Ӵ 8#}tY}" LA H}0$0W3r/fS]|UL݀_6"W^#N}Ȧ#A $hn0Pq C3W5H`9O=Qb^Sz@@2@.5|;WB'9X6 ~/X9i5*rk`.h[@SpJC,CVff/Gm@Px9H Rim2C0K^XGKCHBDIr60mgcYoal7|8"!T³y (o[9E]vF"nTHv!|6TAD9"L9f #gրm#yPuNuQ Aj$cfdS(^~R^(ZU2uN ><נ[mݤ(G_>'Y&*h f52C $2;̨b$9+KLqtMJik| tN;>ΜBfdů?ܣ*F^v䁐<$yhw7z2ׄfi*m:kmR A ZkO K\]oΪVcaP@b2eMk%C ]9Ub$A(Tm[ͥ)p_#ăC+LVJ6֤IM؞qa4+qiE9; 7BՒ,,c JuB 4=$D%kbA JeTIԼOt\9xQ2nK(Rs4g6MREVDj3D"fg ^!A * 2|`0ʩQ :,'"izJDPBS*c t৞w6(Or%%eښ*d[K;{C8(Q =) Gz3 `j?y \_%8͕y9VyrԳYFIlg>>56pS[DiVZ"ݸOIHBVi+I(]g$bW{+f>@17(0cavT Ml?J(tqDLX? qA__;6ǀ2"#~',D58viQE1ŁDB5@]x;/@$E?\ E_D2"g8*-4E1)=@Z(d@'j8GynS[A.OjzuVBIg^k4eB[Ort;sz ۶VJߓhuboMnV*>>\C>u14w._}igx*Q` $z3rn19,Jܴr:c1pYN5|nN>kO j/Un8o0~`\21,m*3 s|ۯWRwSUmtj>9N .+s0>s{ ֳ|j(!BAUU ~O 6% it'x/d14SRN 2]mV)g{%{۝>*ux@m`>Ҹ61jdFI $ή­Z%Y]ޚ;:,g qru6~1lMPO7!*-;)**%j⟮Le=o}-x"E~6S+Oܲ%zt\1)귖[ 8SEIﺷqdd+EeA ݩ3Sn! JJ=狳NTϝs ?|~?}\\x ^|ZwJv4 @7q?2x0cd@p j΅yِ-b'[K"l*Nvl w* "Ad&%f.4H$fЂY f GhGK:;a\FoJr9Euz,fJ>od"ɝ3]p݄ -P* ac,b\Z@قzeI?FrX];5k~=Ŧ/J문\:0~[lsvLKkI* eZ, GׯBpjئ _W;u;IC+TٛaI9[kKCywM 򘭮whK\ȶ[o[U:|,9&lNꬢo*Ah-r!5>ಡ`~΅޲Xrh1@ 5b}$ƒ h0X}CE-~ ނƀŀAm/]adLDW]G2鵾S!ʖ׬H}d 58Nm|~ʊt8iK^0>w9^M~5xp <*==885Bfw~ȹ]]8E+\zŹ(1hTjy &DbϏӧ<Ne޳u ^7kgb6N5M-6{zUp4ߢfkuSu~>ˣr]=Wyt.2 ]-*֗ek?nr3l;IBߞwY./O\qS:+j/u2/s9H]1|umzu}L.2ʖv 22t#yUdq|ĪQb)[(brBzq_Uhbs ws*}5} 1ƛ{(\<r|ԯml,sǰ?yů)^NNOqǧgi_oxz:1"XRo8+ B AN^*Ժ* O]xXn/ߘ`N v^s_3;)w/ ,Uv|ԲVa'l}2K6EF펒T]fPtAhgf&3=W> j^u8]M}M=rw:of?˶Sxe}{o+Ȱ3\8Kxgăⱶk7۠rYr$Shgr+ײݥ,I|";}}f: !-oMAht"/k f=oc}T3|-KV6ޜ,O!m>ɝC@w8+|E]# iا\WKrem9~tY(3O8>&_p}۝ZmS߷"Ôq˳o2Ck_B#5խzȦ!\lyhme ׫{p| c="We 1-WsuVVRz]Jܢj,}|U'.Fzk~T]ި>C%A\&cyRzl)aB$ZiY^(!mc,T/WpUS#%x( X$${  g[rv&mwk'J`q|ʜgNe,zc<jOOP)7$ +lHPMT_c"?Q,""j=~q9/!sOބيAH QPuF{Ϥ!mɣa@!+&i|Jڢ~/coLU#Fk맻zC۷ˁaOf}A䁳ylP3^ʓbQ$+n!csu%Z2^7,h9B1B0]k /ԏv7Z =;OsM@oF_t}{'yD@C* )H@P}DW}Lڼ*Q| `@>t+3oEBE{(J"Z!%E@?r"V 1D\Ek>x~/^ǔ]q}')spSwto*=5zr~=;en3u{|}{9?F݃d{!M_q GtCRnt1dzPgD1$[cQqA)6\_a^?YAL6ajхUWA`!ˁ¸\J.9%Ps u]*2&rRā856זi94szM7$' lS߭{ĭv/O}ƂmVx}LٻsqéjKN#<3kceRM2 p)փQwIvH6CAT8Ƶ#6}`T6T@D PS_ȫorK/ _Ƨồi  *TI3E;si)an;n~uW[3 e<:ϖ5sV~Ǽv*wU7IRz:l.S_د.P{[RvQL\n \³c8I8^7N: !/햮燍>- _t)R|k ԰o`y Di!4/}Cyo[+9 Ǧo9g6>~GE29N @ủby1#+5БDCda}WKP`%O}G~ _IO2  pNRI<Io0fnCs)=dWS,WRZM`<0-x6v^k 1ˆB`c2\@o-"IGdihnrnKǔ^bT* \}\^RˡVmx%$7mpnYJ[i0w5sp=5BoP~xnUޔ7&D~u~j{g?JU"|GVn67yKheg\OHϗk;n0SrGO=0.yo˹NωK%)bPKhXVռ .ycInly!yJ|W#}Yx/Ng?Nl*|#}ܞeCgT?[w݂Tq1PX[\hR+!5Qmmj[7Kަy16'_ˁ? W&jt?x EOAx`yZG{Cn,R LEӸL{{U~dw[ *ݖ'g{t~sj[>?jWhmO;iu,_/ab~;^DX`8^,>Ӡ8-#}kOĶ#/`-0Nkt!eL Y|n[{$kFr2*\cKs-q?:UBS`* "bxtԪLEv1PN \ L⊟.z 8CQE@F^ 9 ,DKR_EJ T~=tC H`cl9!$c$@9OnYMfįyx+ϙYKpv?\7}z=G*Z:ޱ|8;~ǭZsu}_EctrU݂UWu(ν}[9\Nh/5' fcl\f>Im4%: k @@֚V񐽷  uyF`0=;IE{ufBr}]9\;qw&cdsE畕F(Z2?7~3"!SNGO/堀bd@ !Av1-_U 1b"?. T|Ȫl?Ш ,pD )"..+lyfhQ@kb tu>R7],F09V~`f<{--ڏW֏gœV=65LϒRNث8cp/8{Wѐ{/ 72ͳcc4<)֥8usf47Lsl瑮eeZt+-d's\Mfn""q1y,0#) ևU@=>L@.GvpnW1E>/v60>kmGc>Trt4@u2^*8ot` ԊSMmZ@i6*}κ!໌1sp+zwb1o)=Hy1bѼqln)^QSxo;_{N#-l0xD <7F+BKUMPG-U(`S<ݥXN<KZ>-4))BUu2q@ YX7A:bxyOj0dYL#v1hQ{ յPZ%3([w4U$p!x46uP˪5P(EQ^aF{UrS%0/gD `F@(A Œ&? (8_?Şt}/JhF>em%tÈn]@!EȀL jߪ~dot s?n=j5g\P/6,]RvcR讨%_U_/v0ߐEޚ;}L}=ӳMaGpWY֠{<|FEUQơ gU6 d!dp}[puСۄ3r(ss66:T]rG!5D!Mln3w#yJ]W_g;j:|'˿ڸsڏT!wgL*ֿa;D IK8Qb;*FU3mx.WQgP,$zg\[Ɉ?^odž$Č6W+5u _OVdZ$8ۜ39>X,OcOq7]e`I 8Z9 |#ʸe0Ɵ3.VtdqmӚw9Sab$3'7w'fG]܉Wȧ `@]?O>ŕ8mw0V}e~'\#|o'yW w~;i7?>1vR;+>g9"s 0,>c3 )J^aٰQ¦A.QrNfzgMlƗCZϵ.DZ1 ?jbn47IUenCK9v)w \ϗBk9Zj+I0He4d=P܍kn,6n2j)q86ރx夯6gy} #mڦKlSr8! S1Ǩ#192x26(Q&bm2" @^(( ω; G ;׭(`xB %Ȃ((qQsP:zn6&*npwaCPdPIkDC~n yT5PR@>P:,'"Z'轨0QCTk-E;*Q(6tPN1.R!?D;跧;2IS8m6R7qJ6M=m_FF ,rqcwMyq~r e3j>=n= T;(NG?,2"&~"Z0DDAŊe* APP\b"3nao P^B,]4W_\xY#QAM7Az߽VF{a\lx͌St7NS|k#gsf}= J3>v$1d6.?%d"i/IUڂO.TǢW@CeFҿfP{3h(l~cwȇ6R`:!ٝ s_e_nP&,jsطrw8lZۧ܂39FkղH)ܩR"_ٮxݿuAxԅV(d/-^B%j\Y&kqmHo'SvmTQ|& nrnyCC_:k~rP1OŸ)HVg̱խYK$wSZU6Eٟ?O _ņOg[yrjd0уoNNHxFgYv.5#DMF-aE'+geb^ ULcˌ{$$H'6o<5'2G5C( onrTM$Gc,iyӼUELsjI^:lyK_K&DG=a Q" V~. dl\.лfy݊nN|m١V 0sT fR@q4Mn Ht‚0B*Fg81E7)ӦE? 9=|Zָ;ldDD@{&y;MD`R@-K +[IɮB"j}R[AZj!̀`ޛAJnֿvV+v9C]"}0{KRMxg]i2y٬3jDvY*{Th?̞b烘lTa`ZNo`Ao@/|6@YZtL4`OU UN!]ۈ] VG7}i<㞮F7s>A,wm:')ε75q<~Ww,,qE0hS}NwEIu s(gV8 ְorRނ; M{Ұg L@4 /wU7˾XAs#'6"/DA }籲\w4! Uz,?\>GK{?ɏ0{馯[ڇ־ڄco+=>:nulkrphH8;ccK|zaz*6G|ziO#h6&* ,d.]/gX]}yMШ&FG'>izJǶW 5Pi"ߢH/meoT:j*-@Y)U5Km-wmsлm}.^سgICAB-t1-@ULog,r EP?Pc@P7i&O9^M _SSy_QB0E@4(br*?^(:LZ6toNbz)#> GH 2HL;&+&e1RhYytu{HE_FH2@孩_@Cb؎q`b(V'h/=L*HMR@-G# ? 8@0AI-U"?Bt1 (oqf#a`U V8Z@K56Mv?YmqfG)b#+uĒQNl?Vg}%P>gu.>e~O+I>an¸kRu۟_ײ 5r(EA2cͅW~SԔ,`d@>WMpDDM1OST~,ݒTm#$B$ȁlDH_1;S Kʓ[@xP$ Ș N:RZ|Mcgp0gZD8@X1!FRr$r}gҿtg -_>oJ :&ET*ɏdO{!#T&%9$sD:0Z>ﶷNzϵGސ*dQ<lq! bN<Vrs3Aύzʿi!~{ES-@]@9 e]fURbKdN F7H_dI-鹫(DGQ9@jt1qߦ*]ʥu#W\=3 Dvd/[nx|!X/A<72`$"W1{Oқ"[+aT6Z{*t`~f,Z͞{47(gsbuq;A5X~Fxr&ED%`쀻|:KT߱w^a6 pw? ]yXIڇ t/oG#??fv[)t^P1|bAh?ޢhᴖe20:d3[N.2OI zuIJ6g&= ¹Nd-UW͏_ÊXoG"p7gHlŎ@b @9,iqHD8y՟OC_BdX!ns,IưUθo}[dHg\  ]Z=^o{܊\ QJ(yt<?Fۚqʌ cÍpӽև;9LIq!A+ƲЧkjif&Y+XʌDfվI,Bqhv7{x1IԆ~\-O9EK^)́fTf }Jgqg<ت{oUQ.>ʆXE7"r&cC0~ك.lٟ? )}~n>^X#+'G pmLe@QP$6#Џr *SyoE'k¢.~X^CSnV'%Mdv>9Xbņ'6\byb4 @H'3rEy=9Bcc]`f- hes 7Ui}vݤN m@PoB qH;M["Pֶ4Pj*,ˆGmpy-gTj R'{?|#$h%]؂sWQSb1,xG c#gel,e7;oBQE"˩ }YzY^[(¼eqחef:C6^QnYQ¿fU01+&nxs_ g&Qa本Bs@%V_NiѩO5eZ9˃ٛ(j N]A\6â )ŠB-RGYGYG7@Yuv[S 2l~7ann:.Gި6q౼xw[^|yPOaqqr;bkQj&H-*E*YTFƨ|N-L oݢحX3u$Br,Ulbu(fonC)<|SO&yxgI#jtBDIDXF(D@P(`B) F`O}Yi0BvE\bD4&(xQgr:Iq=f3ju  jfC[Gmǽ,'z0?Js콾i7TsXb*Ì\u;31W0b6MSs\@I; P2fHXaž̤ ce-"U"Ɵ9P P9 a1.i^<3mSqG"0$#'N (ZS`CT-yM2Rqƶk6Ff,s#C'Edxܷ@Q;Cn )Ppoܵ'H숡I梨C 4, uq%>Zn2EdD&@Y+'bp`zjkx?a_L2c̈́3_6f fR@xVPa.%ߎ%##2Cwf}O;4Rڜ=5@DXbQZNI(',2 0U<Rt?on&ظ{rѺ7&PcJՄb .ŗ_Sq D k/<;t#UޛbP3 j8^A4ȌlDd|@o,DY:zmN$S]%<ن`tẬPщfLlՆOHr^{yBQd@H@D pNe "g# vd[v)$Hc9G cIr;Q^5<:J>o^ò/cS=ϲK ԒM]+h1a0io0x+5]\6I:mc%1%I`l 62$B '?f6Ts"⯋J&q*yY:SJtU9k j"J>s=M*T%_H>$x|7[b)!,T/WÙ&{ּU* v2ULGmlָp^v]fB2 D܌s!<=N2bK.e)pȄPשSͰ>BcݞÞxă!Xw ȴ-քK2o!{+L$I9@$gAN^3hG^_CDr"Qy)V\KUa1q*>$o˸(.댹m㩂 v( |Uܕ&I>CSa2 (j#7)zZ竭ehR<bojy׳ĝY_p~kFnoPoRi'j{$"״HPdE#A"hxy7#Pe۶s.*Zt^ y15!t/̠k@͹%Nr`Kם]@SQHfDXIw#(y*N)F! wsj!v?;3P8.=`@v.*Zې)w) 6vFqLp˅Hz.IW,klٯ9] }U4bB!NΘ fbM PKq)79 an$(2e7b2D#vPbtNxPBs Yo!.@g)!2`XȂe0IZjqd܏.td"2Eq)JCA"+x@aŽ.Ut +`ȈHcsny=3~C䩠K_`Apvm-+N[r2N@*J1̝F G~+9Sh|4N Lĉ$dpՉ"9~͝{[Me~{eذnqYKQ6GY? `.=@XoYQWntV,]uQC|n+Q (hy~A@Aߝ@_R C?\H;P)9qH_=Bڠ0|hVE#ٶ "VOK˵Kql ܌&@ %Ω]+Ow<^5i 8kƎ鳡[ ]Z vpA:]~<DTTt<&_1.z}sʁCֺ1w]57g84c'OJ^|uEnj^{wi= e= ! BK_BO>j;[<?N$S`'tL1B#/[PWn|/3,!`"_̝ٜdOUL>"bHzw&qndoKh"Q# \P& ႪVƈr9Bnο D`D9g"H p@BB>ȯQ @7% b|h 5p"8^S@r@LK!AUUa mN$k09' T]Z`E<ݱ G;ȅE4SZW[&1-ctQV\N=lӼ@{hd\N`.?#ox86v^ cP^[.?iB9A؈ )m4"d0DEq??IdPEf T uV؈s`<QYyׄ 4^Ek }]s7XiKK)N :L掣Bq1w_l(=[i!@z!)C힆ȾD.LQ\{P m@[;xP*91X~;PF֠|o[J3{o9# H!^]mh!'-!1)8 y@^ {lLrp/ftQ$&!++`J#gnlJxXC^Cܸp-&'q]F rGކUQX$~)0}]V߄[h3t Qixoks sq'$tJ[ "2bh&Kqڲ'+D>N; b|T G6ݛI/ 65+51(7[En 2/mE7 4 ;י<؈ "9E]i P)$= %e/2G^nn2$ݪ5<ʬQ[6Kxpe>y`؟|lyۀ?lPBH^ckW$J6we [7Nu?w-}W}ϒW>#GR{u$DP\GFO(Ji}'K$DH7~F!: 0Y`awΉx4Y[,S*aJjsJՕ8vle7^"'zW ;4ٞ:XupJFzV}] 5g⍙Y}E|(ٞoB662P`n[Tq+vXt`pO5PP S݀Z׿_':sE,k3 #^dvb^9ז`@6>,b1[ s%M!WMO9۩]65,_ bKq:,d,~Q~`a0< 5wcsuSze0@Wvɇx^nGc^ө" 梊hȮ.jsLn "~'=|==-x9@3^ *.Z LPap`]e" 7U>bj%cqu\!˕Lg!VKb?XmUȖ A#պgSp)}{ ^i IÃ$rL3aeɷq",ߠOE?2|YoB?|k~Ə9 _b߸3j/O9Uʆ|NmQ274+S-55ӥ!(KؚdqfdZs&AxiZ,spmtdjP?LwL+-O=7ɝu3jJ"{Uz6K!!#҅x&w:D('0`>hʝ I礃qał%}?#|ߗc }g]7wM(sˎnj/[dzzj_P56  pŲ~ΫuAB߁yRFwT5rv1 񼛭Gs ű;9ؠrq C<^txPƀ T7tro|4 /Wzf[y xht{ط1s/^@k\ׄ෷_#:41 42-+]vdw!C/"t^ 04n>aS&g(|ibªHFr)nM3 /lA}Vt^]$:mY-D`hH6`NY ^]IOA#t>84qdu2 lv?@DYugLYG,uZn f%4oR'ae`Y#Ty97)MƱ( PO FM7u97ذ琦-94^e!ɠ#E3.njښ~RץNz1Sa7ȃ]]a! eɆʨv4xB: {l#E]`?ڪ^n"-##S GSy>-PC&vSB+)ׅ(g3-077iŽ8֡/z^N`HT2B—k@JVBIM6kzq}^0)2 b=%MQ"LnP%QRXv#1QC'wѪ@lKLq!J ҙ8ˠ0āBC{:EtjDPCf`~]KAyH XT7Jb~It}hc[ і+&"U. 1w=n298Msroh־@b @H@?SMHX9&vT! .t-!]-*3tZE>\WFie?!Z%)ɽ}&ifU:$pinʷhtW#xOŦy~ &DМغOv} ~;o2˳۵IiCڢ{/|Kf]|HGO@r D d],Y-v}E "ud=ð uP_Pf6:S;(eB+~vtPD=]tDۿ֦c*F1%Ĉ8J8Þ>=k{{w̷cAH\^_;5匓X#9#А\ّ@_I~9|ʫKB}>"qGCP|ˀ>=@=9y{g͎Q :: ht&-QJG $3fm)kvq:%`uCdgf:\~> ]U]Z&*ri=Š &xϞF#"9deS>c d_2̶X&O|3m@dU>ؙ`4$0ٲڒ(,O%DT/\pX b{`7>!DrE#@ef(ӧs#kv,_X` K9ODbeh- _E Dr-RmSȼl:^@+چ+8H9JdK!;忞aH1bɳӒػ_A`8£lKůT> GֵWu;0gz6د1=|31$cn#҅`ۣD;Hxc}xmAl6CYt,{3WN[;^l԰'W@΂&dmrG 8M o?1%~Id,q¦ #r鬀lf=xIeiYT\ -R _;rK@u C#H_f!n#B {{x th<]s-v^SJ@(pPF /TR!M@iJ-?jr57NҜ.762vl:{=5g}@8D!!s%^~UjS[TLxX``$h&g%.s.%t.~sGy.POT0ٝ"2a@9]=u{=GħxMMvusUH =1Ɋ "5D>cX^ ̺` ds~QCrƼRUQW#3?hȸD1"ُ\vTSÅ eoƠPs Q3]qܦ.򛧝gɕ\s2āc?XhY<I"7!'7efu&uE|Ņ - {EOc<;_wu1lLSIK9:TI((ꊅaAd.ac?(uOWZ9麃I *}~4VSrWYvO[)COxoǬ{b? ĢV`?SqUH_+_>C,u³ZN NY:1R({Y^eAoSy9 p] Nxlݟxf?r̷qi_F8| A_(Hч JƢ 0ULI))'+髓wy;f~ ԡb^[ww@w;92(uCI6b!*P)#)(E1Y#*ei1a1#lRä)kx c{pJ.s =iA%ʂ)T+J !(`ZIRlLNTzPW#[921:$"4rLJӯ%yȭ JQADU,RZkarf{EZZXQ(+g =-tlf>%C 98k(Xv13SmChgɠz%\2梈 eݺ;v.ݳg`v0gG4!8{;ud!e 5R /oÈp n4 уxhPJ(dBwIZ = EpUԾ)*<Е@ _>㣞~ V4ͮfʧ~lfjȣXzNHt )߱,i  u34 i@b̌@T@PoL1P.J](- )>Mmv ;5eKPeSXJ9^.+͎\C-璝:o7@uMYA 1I8Œwz:h¡UD AjiEfr]XnkP(Qc`P깈()6)l]L.硛'^t:5N7dzqd5$Ym^ Ȯ}P/AQ qf0RV3 G$Ă*c'(8.&ZkB9ߓL DkQba[V<4c\a@1Cg П rXwǣkIxC}}(px&(v14҂.3#=K/^ȯO5dgg@]~_7ݍ* @80O )A\C|WѥnDV^=\h)I5zr;|LEOk#"Va謊m[ey3lp^s<َίԳ OAps&VoVXlz @4 ռY Ơ#Ղ6:icٕ&C m\=X3:p4h4jX=h*G)4Ђ#Nj-å?@TÜ?}: Y/"QsU"1 E ǴxNyU 9kH+eyby1G;`~Gx~ v`G.Ypq%?P9BGYp2)R PW 9,NF@Y4i˚M⯍q$~[}ywP|б$IM.6"[#4C8K`ԒLB|p.ј݌#~s?fLsq6Z5,b]&m=&cw)isŐRwi 9n8Bc`q G ;=d ) # X-bZ.|˂tݥ$+NExUArKk;_=ee*CW/Gg'n$I2s,Quqb5NwŌNMAz}'CW=zkT/3x0Kc?8Q˸/_u=Zdsz[J4v:ƊDΝ5gmұȻ}k/4^lF ]^ecݏ_(y}p5q^QOɁfԅBA8I@(s!xPݭ%?!tJ57R`rǑ`ζ%xf#v*`>n}mmRIa?{^IyUs)+"Q228@ΔdA" Lky(]8B.'pF*!U1/v S!;>C^l^|?ؒ!Qޓ8>Yd|X +;aTTy6 HnW%΢7Nްc#FKEiz}{m"6%7SH| Œ~0U&fD _m-Q}{fs>G|k"r٢=,* @ IJJA|XgmV^VːiKi ^ mCy Y.MGE㧾L$|B<}4HCŶ4Qk\ *XBtIh_Xe8e[W s&3z~hr5*C(%*JRf~ (1/^Amv+SF(8K:QQϲ"njcv; Eo)8-fQ݆7}QV[?N`(Z酁<~]cEedp2]v^z??c;ۭO6t F7PřF`SúY %yFp?n sh%E&CY~=<)d?m}$pV~;BLIf*TX@S\}vn"pGGieL'8a3P+i <ءFɞP9q(ys>E}f!nNoSRlx/9Om^G?rs%+DrMٙF~A]Z D[ 4Nyg_:L㯵{QZB$**Q)r6>շmnjRںonT i؈x5'J` p2`dV:3m7_ !h)6UA[¢b^cc_q327ui™PQ`1O/Y/],g6wߟ4yN@Zvtr.EP $o/sJEּ/]BnJVH\줍j \S[8QW4$Ο_`0(TJ31f  ڦ*J{Iɯ ^Ɇe ^[,b*yf{W=)Cρ~o^DžW;-1{$`cI@B9ZLsF $,|姪ֺ7M[$aw#9W@;YJsmIZ]p%4tN@9-2s=(TZ(AN)IhP*<.Mﯪtl_C飃on#[p c $(18z^{[B%vI~U{a9+D2"(a g9LyPW "y!~!WD?`wEAIXg{ғe`K4s7moiezqP7g< #Pot Zkk'j{5r\Mb'r.kȼR;=pf<Ͻϛ7t].9+ȳ^DkI2􉔯 n}觬g^Ut'hl'9[lkkikxT }>2BymlRs+XYlry8{G=h%؛tW@;tO`;\gKLN[ 9n.<#NF5''džWQ`C7y+nJWӚ .p_l.$ C/zS$vp@"y+h2"h"0d]&*G|~}2ՀX(#t~1~0l@BVB-,vP !\,k/t3?vޏK~¬Ԩ## G;ơv(wyTN37 C+{{K|/{/gL  "15 D0RuW)N5z5HN]A-(ĤAwYEtwjwM( QsdeEdZS-˼̧u^;}U2]/%v8@t=߃WJ׫qy7VtNu`rt5@V?ȣ ~4>[Wr|/W:=50ˈ"߿B-fo߂}k\+hn0@"99==,*.v.GUwWc+ϝ6Y2.SK &G蓢 r0 nh>wmj:pF9> ̯?ܤB.JR"D%?0O @7x:^ffSp{yE@^?cG_-Dx4uN.y{?'3u}fo"e$aPtrx7n/PA0p0!lA> `PWyT㤒;f 7N6^h%662 ZB죖!+h&ya"@(Z\w}3ܴ52BM~ʂ-۪;$ډC'HQG*žn5?Cuf`oxq<NU!PJ7(ֶw "A54;\@zȶ kGk?f+bFyW HLJMVLwTHP91q 96&c4 g Y(1 p{>5TmƟ_;%h J_{{ul+6~fㆻC1Q~yɗ,To=ax@ O!v=!(ːohSjRm hPUQP-T; ] E7@D!{ׇ~[D"5g,=$ xZ''zIosjRCԋF[d80%*1IXkb4}3g&ӀЕu8.:N1]`# ,&OϔvR~+ÑH1jycbq$>]{re$2 z6|zH+D"R|Y06U0X6.gO4Lb;`\ \l&f:#٠mVs6[qK iBG̫̒ 3 'LHB\:gLi+}[$1=5g,qVaudg𷜵A斄>C~| oU%~b=Px9~|qbvOU!t=bOyq>VkUO%=FFMKhaq񿿓5ԩ3HY_8nj}gQ ܕZI0@M Pטion\^V,]37u9dy.3u$ኝrZ0jIܜBĜF[9iȚXr-x^D5PT`< 7jWx,:]A6dG3ٞr6~"5t]vz!<3rƐ!Yo5  FYzwMNv(iK 9ZYkx/NbLHYnUg|bm=Ta'=XyC߱ i{u͐;+z~*[񥋨:'ϪB%>w+_<%ꤜT*H P942/e}zw'_Rdw'Ln߳_@wc Cc{老SY|ެcʾ'4x\Co8'j{CW%#9:{94>?kďGnY!L]n`ƿ3eW[;3YTx?kK!H)رg͂C?]fpH)3}pc+L!VKй/ʩ{Wxc5Ī$e<[1^c۪m?Tq fBC]ŀHaܫXGZ+;Q=ĝ{wm * $db4" S暫d4.GO7n[RXoJrXWe$cU@4rFl~U015N7<:i®ٌ?$.ml/{ 'o aFaNۗ3k@w&5r iԿ >wc]04ز~1 9OC ,QuOLSloJc\dKuFzC5HZ"(;P<ק>&j}4Ex~ vڟd$n9/xIHGmQO#pŀ??ȼQ[X~قĦ'j,fx!r/j?ܭ +͟ѝ|HG"l{ pr1#$sG!z,D9Ģe7嘶.-kz\1Un6Ísxh8w3f"c ñ& (kszuڻ7GkMd7(RDv$ ct Qqiu" sӫ]Â.ZRVB'g X@, D*$v{lx/*"7A]tx~F9-RWlr&|%UJ2 ## H 8}D{yf @ @"EJ C_d=l~gp!C^B 6TE uf\($+'$ePeWAپ y;Joލ`$= fCr3ņR w>8\ihDZTtS=ȗu{\^+"0g֚ƕ8%w|UxL>Dfҙ&:jY@罽,!66m)1D5C_ߝO H@@z|&S[ sSj1KNdQn 900D;8|H}t ?ƹCsI#gq/H 5$ `z"Tʨ@AB2v]g 6]i*[8bX9Ӵv^uehg= ܦfAjn)Pn &h"r0;*CjKGޯ0 @D U .W/y9[s6y/9AYU2|\ 3>pO| m>] `+ OКavzl\'60\'`$j&'c~} aK^iwKڏX! jJ/p|/f&E;pp;٪$@jCdY 28q\%0W@AI d@y66LMU S{cys%vo=pE p`H`FEjkjL6 ޶*uPm!ˍqRw<*qѨv($3٫!+( 暔1 ڀoD@-1WOu֋N@k\'>e\I{ߟcS%Z;8O;7+mx:qXK6+|U6*Ltr:Uz[/"TcVС`! s W2#&R YuB.%,Ja#tNpg8j91(0 8J59%"{s'bAqīxZ:'^yPl &is F1 k[m]_]GP8Ku\wtp9X,1@w@"4 ^(ĺ^(h\w"ia%cjyS8;e͸L;0K#0p֘^ Z@ݍ ΒVqyB:,kLu9反rurl_jM 3qݚ ,<V "0$ Je/S'Cæި;Z /gQn+_og7]‘}\>mvRX D,NekxT!z群v>˽Q7oA'Z#@Z[=EΑȽJiH9L9x*j|k'U,C1WO |ZhNT(_=BxJ;";"=K'e^?B"缶n?fgVE}-:A'*@.pϛV*'ADJT+>G_#H%fɗ0eek6L [[kT+Sm\t'[vH(3@tb7-FD;oXtDZ;pMzShɍ"&B O/jp~99/dאk7,cW+E4GJwhsE`H E @EHbREV@/̑&|uwz@k"⊹Nl?^&/NNSZxeCVKf Ji!.˫ aJ;|("\iZ[".\,{N~b$H&CVgn~.j K}Ϭ!B$d) /5WAl3J+e!u[΃8pi&7GPd#d9B}!ս-˥~3$;D vKLfd8Yd3ʃvti]9iy< zdTx< 4:%Bn÷8x&ш ,n Xt{#(;j”>6pHe)G=7^w ٥Mk&l} " ɤQ)x~Tǹ8L0/q 4^T!51NکZ4T) KTsWo5'c7k9[>;[?c1M70+B!Oy_@{.SVZ%IX7ycbmn15nE\ܣsӂՁn3~֩cNt9}^cʤFj99$L4S埞. D|=#hKsC!E|[K z?˵loO? Ħp\.h6Ygw2[et_.)U{Im ^R(t UP;v_R0d|xtM'c(>lOc&4Icx1#Γ% : GߜfUl{k0k J@b9d w%x9eP-WıE튺 g(?^_ᾹJ|g"aȭ61GG6at(=oxw% Hߍ~ bmHma`w.nU"%u}ͭ AA Fe}e%eίpy!9<>忌_?Wq~7Oß~,^?eAAiپü]i`nqyǨ?zvΫݪ5rq[j òLqsn‘p/կFqqtcv ށl4Ҿ/]vҔ]0c&l Sri/ONIx3ɓyop@ܲA4Z/&U/ڤ7{Sb /V_J+<(_>~W|M,3fw# fFcm,zj-/{a/I; Wʽ[N)-$!p7* }+6:`\r'Kq>,UGH@B}Q4 l2$JWp o-Sd(QizK$PG?N;zM `E v\zm*;6gStw>ΓC1roN{׆$ō$ucXɕI8#w㪓.V27n;LEr y*+{deC.ve;NJRsoT2&Jjjrb:pb̡Xf CIQlH.!Mo" @6(|Odq>F\`rӟ"bGO $TU.a[+9]/ʐ% y25ąAXW_ħ"Uw]X!u%|`nE9)צs-"O|(<@%h ߛ S*Mm`= LG].VаlbB7 `TO77~ .ӖQP{j j@UC=> }sn-QAd<8+,HTUԀ_%x>|ࢺA/d&ksQjyok>$tAg# B' @"s`3T|m@]yd]юF E!Щ/kʹkY[0 57D}Z̜3:#BLB5p`=u#g c|.__JCS݊dZÕVCdёc Fn/'U <{Ǯݾ!fj DA,d}$vss2wT2nQ)zʊGx G2fHVvXa7VUn H^R3 UOFe甬,{UEoXV& ?.Wg{-}ď"zU4w3M7w_] epB A8ϸSɎD Wd]f<dr:|a*M@r{yoǭީj7j|2LfԯD Nх/`S <$([ѕqdTJfEˌ 3r ǐ)~%!tC5̎X8ey)P%y|o'O~1/%46UcaV-=ƀ R6Vb\: ]R oSr,-YiaS&IgKg7**[3krڡP:hіͅX/Y)t;6Dߵ6@;#Hh'WU_evˮ^T~:^} Nub\K\V5zoܣ(!yJ\v,I8aT^јCc4CGc{:8ӝקy#\EZoYX&n֞f/8y ݙ!)pޒ~׌G͗;Xm!H&Jt-9Tj֒0`nM5zb/>7->Z@/|?hN_2 PaST(Df+80<ڔR a‹>! "ǑXiؑz:d!h":Z~έ\+ԆQ%O,wNNM Ym hYZ'OкS!Qu3l,{g%qh'AMg{[X>?:}YYJH{ȳ4dcvV珐/S"0墼S6 ǻFOJrrυs^]sCXZ:HwnonlzE<%n*R lM͏PT:Z|uf 4w/*b식Ys#dj [ewb(>ʡFYgAaq˰ns?7{ɐ'Df|=IQ >} U_0%g @ؠ?(w-z,e;eOC|<_^*짼3pf??}ݺkqu(D9@K_q<8+;ytXa19y02n9 ǮuY1ɛR SsE#0'R}onvI 'l gnm9r'$Ť{4a8x|, 2f`I[0ҥM3h}@rڿG?$353A=xM^Ďiz?NY:~,J5(m** x,QZ+{%S dcZ6&"smYs {D #hUxIe8֖Vm8?Հ@'M2>OZl׆|eF} f|Sn6 lX=7YTgq}UUPx>DF ~N*kʮP &HFvAy>V@ԻYۥt}6E vv6C& 1U4tH`4$C?WcƊ E>꧰Ysk7jnp1EVGe<8Jr=E_ ԥ gFM=s&f^z菮t][KT!f5rE U~r7ӘI7aygݫ4۸)37? 9n|eQ48%Rb|+vƣC, Ǔ Zr)! =^0YJ春:K(t?7Sd2|ItÖt*sQb] Aolڛǧp$,=`1u&W"<T &myKCTbR acE"_DF{FM}Oh{nF7A oJ*0gBiÊ6&̧CVO|- ~rş=;!SvĎ=y {X#Q6/JI0;1lS|cCR?_spAlA}gAlj[sv ^g߶z$P;cݬ P2%&}B%7b n{aȪ8N526xB ޛҷsޚg _)$Hp?9"(f+W`|W"}A6F@%UH`C@st/a:(CMyKCǸ,JGA>빇0A_lIRiwƆ;`D6s @ (P:`G]OOݷXQ:UAIď ʁx0:JP9=$& [ZNB(aAƁ`j5cH5{% 3[p( x5p뮌c E VQde f? {Lyt7e}כsa{fctyZ=>7[,j[J1Z .G@X!h8eVNltC\cKxH Ij:g<IC!bOJ"AJX0lV+ۼSbݣ† L\s.>g!$ oU$g@4n+v d#|\α՛ai뷖Ng!`\v2"/b'8U$jyLm's]mWYѲ lh1}Z+zzh+a}QwFU@B_B!?7Nx:C0i&cs!րoRZz,zTjc\s %Zװ>ID H4ԕ/_'?axq T,$]HIɅU1^] ι-rްptFڊbT,mrlcOoXor1H3ߎ7$n{Bg:0Ā@~*m1$mU9`tkg\=:5%$na ;rI Է;NtZ #ZB2=\=W3E* %iQϵ ʼ"YW8 }C]w8WqeӘ(G@4\69@ L,֥ s#s$H ]>XsϠ]}qy&V3{{faYMu7 @V=@AwMA%-E>]Vܻ[WgRZS:|>ykBd=iGTG= R>ly?Жfb->MU]{ ejIgqd(J=n=^eys$k{>Q,4PPLv'q1)u`ݭ\jYO&?07M2\#\n#y_oo~kʆ 30I\(HH/1Gᅫg`LVz$fM'biH>wp;v6@k: ukpKXK~2 Ybk $0.9)$܊Nz|1tIs[Ąz4fVM!zfYI[z2"6Bڴ; 9cUoiδ3Y X#%5L'耽0j]ƶbc3\e c^/[ ,7n`P5=X:ʱ imzHp̻sNqɥc as[jieitBctc{QNNyzaǥ:NzZᡪTR8 lfW5]L9oz%ڿ]K*{pMiJ O`??kYmޠ6aҪ$E9$zf~ LϷy(3 Ww W3Itz]2BX6'1>#HViLqku xD`Q[PAZWv`hj" b9'wzMM1h^x0tv@͹0!O( ,fhI|,#PpˠP&`,Wǝdȹ SJ6l|sOA;< 6N w*Ot^ezPd.  H}\jXzkA ͉lLN=":0ٴ|S8M#qjgD`,2P;ƦR(K!/GYDIlힶپh~n,]c.Meo'EFdº4 i:}q4!5 9}vSsru5js;]JdyRqJW/yM5B: Lpq[uȵl4ɿF n?dv1X4f??ͨzz6TځV7ykʚ$!U(ڜ&(۱[0q dX57΀Uh3zqW\{]|aQ/X4d{~]x7zyU~-_տ_򜰞Yw?<'4;o#x7gjoϔE&.t{=gz1|oTe]grs|WYa+ں[m,r 3&AY]T~1]Bp䬶s5Lzw+2u5ïQU Sݙ^|dx %Pc`H 1_vd+ZO~\9VzޮEۨ_j5H!zw&ǬnvkHZxw&$U#M=K4?oscfJa}~հDP6,MP ns(=[ uLMd,w'V;q߅Ļ{xմ;ZMDyt9n;E:ұKY>ٸWGrI;\1e~uc6 B6N5! Uˮ^.1;R\#YA0j` <ǗV(Oi7 a>nv*Y0xf[T[VcǏ^/j{>_OC:f,x74t82?Dv)PrϮ481@Ëeaz_*廃To=ݧ_Cs `U侾}فrdxjsJhɣ\UWsɸ&,\Vuv >"U|ŗ>ھNn7^Brtmc8}"NwIPa3V[Wu ˟ud;q]<?nz| s>^+HVו ~G;נglA[-="ޮ`I6q%9p"4 uj!E7f+m?sE;dW_Y Ƴjp&)v=3e0CQbGxvYm8S+&zv@y|voɉ)bbm7=zKY.; j};t+%mVh~}M޶{ײ aR U6LҸ(qnϣc~暦 M?>j/~u'HK[wވ# jW҉蕲k(jpy>puiW_M{:|)7aUraeT!mzFvbN7,-8e#} h3^T!2{w$Nf 1V D˲SfѬZy-I4"0A]j{L,) z|O9խvtgRFu!ouX ӵ=q]U,bs\z$ [UM Ե=s#7TPppz5L'x? O+Pxȁg2C{/Y4 B=+TFtOكHhM'۪ch⿧Hi`\ f=s \;;KΞ &ãjxwXm:Qvo \"[ұro]B$uq3>KwKnZ<:ݰ7njQ<2H)2s ~Z2o7]SN'^ H2 *֑4t`גqY_)xep&eN !r6H6\l0Lugc_%.?iːضĴY+K%yh\5ŮZzqq%pss=^`4/f4Qw ^!ߡܳ ~s)2^QȵlF{HDiʣĈ Mv1ƊZ  <>xOyZ Ks|$-b`T)?_4>&Tyzߍ%/J{?ɂzGWM ~*To(d@"x`Ĺo:00F: k= ȏGC :D@0Mִr4Wzn cS1KYx Y jeTWbmU'#9S>Od7):.򤒳wBPLr)  6t3yY߉?;4>CK:dQpD#y[X~*qڥ[MJd9ޣoI1't YKS)7!iT_7Tqm^cK#WƤ9@/d#h뉸Dkt8VttYAyM\@@5ԌBhb\9uF#FmACImXź?3[[_> r NGG}?DZP-!{N/b ܿ5o?#﫟dڼIkS`v1 x{S+bq9H@l!h9wΧ^N7bܮ`VTdkįӰ(2q& B;dG&*7,~aDg#w3 h uw ui5t S[IiAI:X#mkF~GU9rR<Ș3T-W #=e޲C(@Y@6V6Wq*?_B`$`P`T2|']I`D0`2@%6 . ZxυżD~`g˻׵Wߵn-c~HI$d!hS r`L{aǭ5.f`{8f=ui$VG&U'DnQ N47GNYv^=?>2g(H@J 6i˧~]dʤnIo;_5H>-)̆fyz+>Z0k(VHA) kk.AҪ8ћN?U9W.շܚNzukfIwx|4zǐ@/]<*bآ|K*D)thv>iGDU$Lks|UwIv zCiHi A2_{"Aj=7]ǹ:q\Jv?2aUDŽ%H\6ËHčB8!  " E"11j0DKZ KJ F FDDAF R6!qmD:nPc#_-AiYS >1L,, CCLn6«0;(H *JGQYD._`3I2E&zarlNT1ǘιr|}<7zC'G+lvVuw& ">u=<(dv[*K.Zȅ 근&XJ%6ABG\"CfsȄ56 9J lYsHVKgo*bC^l g\%Q6|ξwGDKEr'iq(ޕ2/);+^ok;J%eN pfs=!J& rˣ^NY(u%j9iy2T$QZM.KTu@YϠuoK.}jB'y##ϞlMk>зYQ);~;})L^iw~Ȍ:5SN6g+85dX1D+ }z\XտLU=_S~td|<骴pn(L؁ F+t<{ra,Biօ4@ ږ@{ys0}!\Oɑ80FA-0$ZasoNK+Ç߼=; xlnLg()lODɜ?Ω_}篯RkfK>+1xtٛ C_7, TF-v|@x-ltn9؃Qa):lͮNlr߫)5EM\~WY-}+~ԓ *xl WMƠ:j\aǯQx e^l2Z]Znƞos-GS>>S3rV> rnOO.K8\2AӸ:9g|ubȖ1Z#>Jl8Ei+3@:m}NQM \u7;V*  ψ <` N} IC๞IRhւ YzXp5 1IЌeeXqV]m]ͫ@dr`K1n$JQڊy dӰׯkhz{&$2ަ6 a͈fwɖVm+"QeKd|$Tj(` ¬I(,>3(N)J-VcdK^>&uujղp[?`fߪ'ЯF`YَrH,YZ=y^ #G<["҂ N4bCueȱ!dWO׎W~fG?tml2/v gڔHI{s'E|oC&ԓ{8;cNprvzyLLƶ0fj~ ;<*Ed! 8Gcn"ax)9xπR 1P:fOO' ̜VUt/AA"w={ôvݬ9/53 {yjOA/d'5I*ep8=&O@r%b`z ,YG[>q @%5I@e;4xb@ZGe%ǍZFg+]rӦ7mB,IpAi2K HQQ? H F%Z-)]kʶنą|Ҷ@>>' 瞂j]g#kw_q U2vaֵZIF4u=f.пx*cXz<,Ǖ4sc=;.-NP ٰ*YV쓪Tia9)쌂:,cHQ#&}$ O5ios=:@lZ|hJQzT(BM `MS'F#2awݕMt-ϐ@( Gz|^AyYr7m9@c43C#th Fs# nżcQe;añawY~hBmL6+Gd/,_A-އ뫍f7ZtH(MP=Jp3"3 R9@Bb}3 r=n*œO:ظCt1BJoנ9􄂳^Η:C3;O.B9qig$5ڎRi#$F ډҝӾ%:z yma{-&|3(D㦶Nl/m-EH*_HL@Wg/p/GiX0.#"Q~7*==pR-$t r WcBcb$J,B|Mp){#URXVD9f'T?®U*bcQ#W˪)k u=ɉl%:<^9_Xaur(Ufv>!sMAfEnDu#XP1*OCikX,Q+"'] oq>1%5!\`(Us}wSȣ LԬxF6Gη+A@FAaVق8rj@ ` E&9l3n @'ZHef`Qvu1\# 3QMY Ȓ!# ^j^8qsm9@B$ҺrߚRj;螏XIeKRXzuVgezlWG&kUS-Η[4z@Bd.;Yƅ nVuޢWWs:Dq!˕KMN*9L{e4"PJ yӒ.J˹~, G{-0sQ]#jR膮;9[㮖8c2F+"ޫWJzV"s m>ϙ 鷵`bRaT}bPG(Eh3Ib/u*̽Mp {3ـ>v$P5C4T6UĎY.9Y-tYLZ+ u0|;\ C $$Pw0o>L2"q)^CG8{BЍ.Y,p*TU]lq ̐?_?PGʣ8wE65dXBiپARA<1r9wv ŀ|l+EX*#V1X;yq۩%A^ymg(=1#n6lkaw3;M;x|M[hݣlnBx0 } P(+Du8D0a3DNfWzP_[%MB'}{rS ]r2C f+0|zNMSǻE)5 &mkcMfl<6-$V6v_ )דL5Tmns9=gw662ؘ?\YX}~I+%/3#31SPl~;},Blq)TE/Upi* 8*i #;',f>dSC3^l@ΎJ׽DSG=Z(h` '1/REaF xA@6¬==ͽՈwA3 1 +DؼۨȾFRI6Pd6VS'Sa[[n5^,f4p0|Kjveqf##[u=~߹EVFc:ZAL9pr PHYFYb}%>| P@~*E2iKW[ҙBvĈG,1Y scMAڃ^쏇Ϝ>|:G.  @t~J'#Ym,U+S>'?*Koj\^W$%G"&LXa?UsS1vfY1D D c$)qPR d*R mB=0+OW=Ĺ0F6ɚSLk^N[cÔ\BV:6@H!:r'F=d+;)6mgVxwT_Kƕ0z6Pb *ߌ3%N2YDQ O JbUXDcȝ1hp=+(B] L-ksP.f{%#AYj BSwXxD٠:š* JGY9 TI.o[V'n_֩{RFEJNF9  ?tP?⦅#[Ix„2/%#wB9=|2O:P%<:cenj^gf=>X!k>=#Vs*&n]%[+ Pd(|S82dt_JJ#rS;wAFeM p(ےIERL $>S SPbu-h]$+Dey n_MO*@t  뱐L݋x@ afAT9gR7V3Hd.]b''-K+oIӬ[Ϝys U)f좩Ӌ(IW7 U8zݤ 0x c{I Q\$Ē ā`ͦ;V玪 T{ IIPmIwz9ƳIdRʀ_O}`JVzɸA_"go?sbx޾)J:'O)p ԠYq@e#GRcqI@r' `w@\ A??½ɚ b杺IX1J`Hw"58qAt:bQŜA%SA u"i G{r1R͝t;LOXLWpXv7fx~)Aۦ|;Ja2 T5E\E䌰 0eyObI|KJ5y&i|xG6Cs ]D(@-sYs_$Wʵ\Q}D*^H-Ur&=y;˻M6 :Q|զ\Mc l%Cca/OVE;脍[:c0a&CniZ%I7ܢ*cffGiI"Gð䰺{Ur3>Vk)el.Y5TBg72 `ܒmL'w6ztn`]hg9kmw=9L4@ct)R205z(b30>a SP_r룉]锽??ӿУfveʫǫNcְhvmXmО T͸s]iG Yoq|:|WBw1fov;y6#>:9cZo 1okōi(@ 6]1m R$E]%.X0-RiUZ7t=13-0LXVUBp65n1LD-Z D(8W^ĭU^ +!3="jJ-1~P{4 :;z[Czȿ)kj\U;O>iAk|p2_|UxO3 ,sD. WDKUk9u\IZ[neIKݒs e پH={o=Oi a I~#hu_"5ot]k  0j+P̔AEGcP1*[iצT5JP1.#$ #r L)M Kـ Dۚ;A"JU:n1 m !q^&2 D %ݲL+8P 8S r譋+Eڪ0ALC-4;‘j~JA'$5iN&}yQoT?}}2y`d򮗟_w#!똦ͭbqJ=0O> IJz_2s<&/#m%68}Aۣ/{-|DSU֫5 DqgVCI٦h*-C% +N@Xrbbh3s{D B01UZJ2~GjޫN &pȅ[ASڳKv guv,/w2v\ʀR$O^]20ܪ(xy6'ҩ|)~u][Eìne9`ӿ7\u}{=?S#6ewНLV%8ečì(IAEҰD~*b(ߒMm;;2O$";S<6ׇo9Z߯ӛ *F9EgkD[~^=퉎**%;rj?t-T;h@B9GFtO{WN[ UN':ύܤcyU%@}\WprI$ @A@ "FĬZygM8d/?=*iJb`46{ W4+r #$KsOσ,Q!fvry۳{n_I;D(fшQ[<l0F񻟖a}i#޿KH.ȁo\Kly>ga}i$)oVOw| &h20_XuA6j|Ly*APd }#J_ -ҋ%]-c\&wVh啰}j}2v.7w|P' ^InW?u6bqB;3r 0|EHb՗V&ʧ9$%7v_[nyf{h1$Tˬv< Qzxe(avFԳTKg8H+Bz \mhš̆Eaxq;Gwl.=iB /e<|UoOPOOӞc?;7+IyG:1a߅[{6 _^ ~:(;26 O4j(E}vtmW>,oW(EOu2{Qv^BMbxO_Ne=")?߉OlvY؅Vlv͸S)Q DtmiJ7 W1VpNFM.Q P{8]0]wt=| dT,33"C"2-pR`&CZnq݆:_^ʙ#qΏ!68+wUؿl݇tzK%a@KdmJ|XG +;>pI5izxLH5w^ QFi{\9M7u]xor$IΡO3x[đ`(ډ7وZi <Bo9d._ӈBQMU4@'|;LLB¡ 4>H9w<;Ca~0r$ɯ%nsyTr`sT-Fշž: ,qKo#Rv[ƈB0O [.M z6=,ѨPKU"njDyBU*~,HewN஽_ly_z_<}:F8?ݎ&JcXne0x*2U瞓D ^ ĹMڒHӇxj2Tbzx֖&Fʏ]y(rM->A&(V.CtXېe+`P eQDUEdg?{?(׺ӑ}U>ͮ2M?u/?6Q7N멚{/ֲ^ Y *+/je(qF'{ݾ|=G7>z. ]aX 2dFd Ȉ[Gc{;w/w;yf jU'hcȾ{^cgp-, 8qFŃu۵'M~%+UX)*?|)?ln {z \|g$rjU5IUBCh 3Zcqů^lFdRyǓ@]\ѭ:9E;3]/ɯQ/ sHkQ)i+D}7ŗ?Rh=~| B 0xu_I)r,{2ݛ93|\H #$, t>TR(|퇓*/&jmkub vh]۝"R,e!K+ *&2 ȿM1$qHqQ C%a=<7$do{N6;5QkIu n_Uh"M޲aF#Y'TȐSg.?}ߗјOrztUFx8wiz,pkhzM-^ruSab+vq#ܾ{Pz>c߸#; aMld(<zNG|,e|$#Jct1~zvkߏ.onWT~0CydH=2.Xڡ[بo 9=\2Q5^ApQlR2N d>Nߧm픷vu47U33Kp}J zE%# t-ݯP64W8s% PkRl* F+^֬jm]Nu*# %&w8x;2oNGˆ?tM{J[\"{ydg|Q-@}k}0֟74pY_43Ǫ"JV(SaCC'jX4X8#1vv`ns9:=;jgfN055(CNQ<u|gM:4 <Z3ly&y` SA!SJhn%R"[,!XzCVj[dLwȤ6˺wӺSۦ{qc^œ:P Zqƭ~bp' fɾ=Z4JZ1,G]׮Coow>3ߦJ<61Uʧ%b?:޷e֥X[NBy郌,2 E_XuADkx>WH2gj@G>ЇSGL2}\lN:ƽvNi#&<=c=]=f0OG}ЌYA3aE9BNso}R0Xs.I :1[3+;00 Rٕ0QphCNd+pX`Q Uɟbjere%klƢ˖H"H7eS*ڲVC(jq%VJr&]cg} PՈxF$DK|c-jY%ϨӔk-8 RpnLrn$6&ܯUJ|4[Nftq)2$67zjd]l@8AT?\S-CngiTdD_?Pfz>,zVS\:DzmNU~gU1ojR8[̦\/cH"ُe8ӗ6㪉`9=sCj;`%^;gfJ/K_À C[#~!:I!.u0gwxfZџ:vf$zh, @L4f y(BvP8WގUb>^EzSSCS2?Mj ?揫ɶٌ+>/_S=m'!c^p]NL򪠜Er8*ᑥu^^+L&2$ѴTL%f jthaT-_# [ZZ`d?*%F)1G&^InW*7ĖZУ0DBiٱ1soD<ަw+uSC6FuHAxOyJ G_7?U^NOg7J#MM:`z9#8WKeo.x=w^ӷ`m˩`FC֬p4z-ǖA A?K^ ^ӟ<–N:f˵ߛG([@Ndp'}Cme3M2S̬0țP?ds`1Dtlٕ$ZX~g<-Q< *cqnᑗp#|5PDחyӌHpVL)BQ.*;N')iwj5>h/ً] {˩kgH+w,*TBCEv"RU\ZO+7Eprgt3SL wOTPU[7)g), .5{yN6Ҽ6o;ppˁԏk+rL 4$aV~jeޙ5784 op8 x߉_{>sm$J$c#`.EG_9cO  78DLW-AnK%$4]ulcY/[Qs{گxk9X ڇUę E8$$Ac(h=Τ-^]]16\FÆ|<@LlF *'cr]Y H<{!gf[B!΍)⋑^`p8ѭ44w/dfY<> ' (}b)>qddC}8IׄYao-S[(Sd H rP ɞOz+^7>ޡBK$BVeU9nocޛ .Ȗ'TVBhD 8l4l-6 *Fڭw\k\nx9N\P˜*i%I4?N3X{  ,<9GzXd,/~Q>uƢ` D1CW9~ϫvD(P0ħ٭dnWt4Hd׌s8PA UmmEnf +D!bHC&Do,| TNvUO6t~]r 8sdJܷU Dݧ $IB$PrĜ߿GbypPH5MKS[w|2TG/2(~ȨQ0Oڛ@zy 6mȠ-$,T1Ͳ"wNiGBPedU~;>cj3@10$ü+U.kU~Զ1{K8k1^ly|ݜ'׬~`sXgS8ľ~PX]X6Y{:s ,cuia_6%G0+eSJ6QςJNl]>:bWwdYOvy, vxc%]=T*UDLBiguj_{]P=u:`ۊ} SZor9hdӯ3\C.>Ӻd8ye5B_TMޯ0DCO\T|E۲ h8@MaMkz^}ȔPC WiԽ֧k6j%i8^VԷf9<#U4x1H{?EU̿Q5U;'vo9C>\(I6Kk'kIWuWAYʹL{D 0B=y/aI ůKfOD, bЩ='ԧOqO }_G7W(u"E[չ Ç1 '4ȢNxSbMAAr3V%ekg%r PYvLe 8_Jc%+LGhcjc(DDB ~B7e%̼]]}UrONDb#CzA2hxJՖn4bLS-"iB@U$Hh"NǶhf.7OĬ U@߆V~$Gʲxg4/C+UGUV >;YwЛͷt]$O#tr9]Ns7,'M-f휯uaV@)l'UBPkD"6:A9oE1VK+on;ˆ/=b1i @;Ӆ7Yk ?=PWi\/|Z¿*u.GETixY-BOo>D (B 2@T/Y |W/UQBsS>.ԝn[R連6ɷ_S8I#@Wz޵3LdݲNֆQ:bX*}RmL 1rs򷤲'VƯͺgܯ;rn)ɉ|Ru3$dqhT7}2ʩב\RoA:Ki}w4FkT0:I|@$f_Yfͫol"!<ⷀƘ_m>?[+36"DCfI(asX}˟d]<+_yo ηz{JS: ҁ.,%.%PـdK6)&a-.u֓(hmk:=P-l@Jr¦ݪoA&_٘ DR6Uk@õZKQ_%LAO{\O/=݁6N]hfX9i8|1 nnA9z6c?j4ϯfeNj8_oXt}^_˺JK7v3tz$AI/ xc* L6Wdjm;ԧMoj+ U55yX!IRBzu*_h81aȦ1pn0W<9SGW|wW>Navr鉧C %aԭQMs4 <G&=}%+ZlTlTДgՀU MkUit xm]3F `Z>W4bг@1 rղNz}l>~ع}pE|qNKt~s< *ux!;*߽7Ѻ`|=kС׫|O7L:!L7ޖwmקD qYpCvfrqW,Qe+ŭ~a^sIao(^xyY9mgߠW3<% NՋ y93OeI$SiN\>:( Yʣy&M>[,{TbP% o>נi45-kXt8z 䥝K s?*ӒisgPcg"z1on=u;I=.Ib3_σsP/g⯻(n:r15þc ogpXHx|}e~('G% '\/Foto"s4쫍Nݚ]@(P=ދ/ rSo'᥍\бky*sG`k!l._efhVA ,\8el̓U3DC.A6m{ N6ND2`1{Nӿ3iN S b:s@U. U+=jOݭ4E9L YaP`WpDh1Қ8EckUwF1f7$"Ũ7E!؝,ZK*k׊2dmLfm9m6w=,]9.LeK-6 FLw왚 q /@mכlo$FyQB%j7QR gjA(TI! ʕ]3+/@`I(&ۜvE&f/UWJRmL\pȩk%~+g$vn[.!HEŊ^cw6g!?J.60xu#yDQo E,4ЀH×W>%Ds`m'JOe47ʄBY ¨ޙ͸El4dx"Ӡ q"5NG>+:ێGi cѮF)ɵػUZ͆aN+~aEøP~ݾ>ثrn#ڨ?QHv^43 ݫe䪿N.k+¬|ϙy=q{jä1sDȌv;q5L~E>>8m ";b$BPU/dxG1}]6\Р5 e,_9ކA1;Ww}f Q *4ct\ u81(ZhMbt؉͹8;axǫio?@$ғT}MVwLa/hO`BH]߱gExMO+ #&~^8an7s;sD9:Cz ovzVy ǂZ疘`׵`VnGu,At. lm*M2`:q+{.ɰj#jc`m4\hjōA ~ٯQ*bw+pY\l &#sw+TCqA܀j^:t:vPZ u!?|?ʮZԧ{ˇ6kGС<> h}}>nCmXɴYR e(&ZH5TъmB?c΀*yİBH)ֈEE ||#e ?7P@4Z%iK8:!q`(v~Kr,n+|o@Q5 xH{nI(&A!Ch6[6g_z^NnʂA#?O8xYU'$P7 E8J=gd0;v[œkBE\񣶸?L,a(4 6wxꬴd]k*i™ۜ" dF d.Tv]/Q[NW?'Ɛ]tx(f^"O2YXUu1n&r#w3ψ~:"5qʯ9=fO$ Dgޜ25[?F)/7 fYXϞ_U20g͟἟]ݞ筓߲OymWf1 CM,^м&QEN?p<-jy$ϥiWF>Mג߶uݶV߉Y#ϢU=%أk΁453;ydcD& 擠x?oe~.6གEľ+pLImܩVۓqQ_g/]n ,\({9tm?iݼx!:p&M^W2{Q>q;lanKf<4yS3 6My/O2bE9ńg@%b>K܍%'XlS O`1'9S5bR5yMR¤xTTHMlrU\C%TW!Zq@.|wm;Cg߭w'/%NvQ+u7X]FVMSren/{5=uS=-99g%ӟeiYl6)rr򞪍I6狲BΝ#0A1 %f*SϯlFs/.nG~Y(ݶSMuutyc+BӮq!SW'f2 50x/D $IlS](a)$'YV%p **/#cp0Cr5]!A|% JR<=>©z(I?3Drv-Yy3q 4/CU*`\g)~K37flI/KE5 03]Q\##dF5t JAÉU_wUxȮ";_:iԢI_,Z]7/܏X'0vfv+ QO|}~Oꔹfo 5ڨKTokv33m|'Xܷ8V4Fu$ ;XDVgѮD6Sl{(wEq_[h!B}/@  ZNόR_}2$}z8'G87Kg V!!iALHZodE#P *@dέM[0jɾSS7Ó^'@YX$.Yd2|=azFf9->[,qA*"22$4\H;B|ASN,a;.3q(0dc!@/Ĉj8olʁ=D\ +ڌpV,}ͩm ahQۥ dPp[: B3gc#rkDl/h?BO FjT+̢`_dʩo+슽6\PSĴ&ٰng]5_Uaue{+IIJ'QE2Dw(e8L Eu#]5SL847dbr hNۇ8pzLFjQ)HJ7 `jU'RYɉ}'$z*"^g񛪾'w>lՋ8N Y.`0qI"kPE1Y1|V2NUsFǦ1E(#؛ÖҠ$-jV2c$(%8{MtFm|y/rn]sͨ0ʠ$K3pG&|UE{17gQyKb8#/g*Q\m̬{\$$oFg*#8ĥ1'wA/o|~ :Ƃ@32,kҩ1Lt>:kNgӒ&oT'eU#] lYQqP3K-֫nZ V:'t\rWS_QaZZgI~kkc?*np\ z# eugm[^b8n(\+[ :2$>CoFV5xn-52fs\,r8 3wd3+?1R:n1)UM}[Qn] V:~`m[DI %Jƪ՞IrD7( &DDqQFGy0*y=/4Y3W;۶;Ĥa뱪x2_k^wvr|7?aR*R*Pe/_ki&hˊjc)^Y{W>3 "[M22C$eY<n(""!DS}:Us?[]i9O2fcZz'~掻˻j~XϻƧ1CPl vYTDH+vʄB Boq p.;0W+͡fl̆g8[pc),7 X@HY5At۽-I7@Te&c+4d#Xla]feݔmpY+??aS{6tR5eo);gYK(&G9lsS%JU:nAg>70e/kEX{Aǒs r) o+hTeĤjkZK/q-VI4W؄H5p_VD19#&th}hrLb239)$[Ҝk>>}LY.ӷ>_A~/[uy䌷\fBPNʏ™jPo;~}~U)?ne[% 9oXb\|a~Wm׆%Z {)]G>Lӝ*QS6wZ b0ߚ+{BV*SUE1mmrz>0lvSv\ra/[Ʈ+,5F "|2ȔS_6YMǾ,N ʯRZƗ[?'fls0^Yͩw^[d^7Y;"v0,33]KA%N8M;{P ۵+ |zk7HÊU(-Xu~jT4RZf/ɣӹvǜ/0Ul'}P  ܼݐ(n8>G_6z ș HD&SuZ?*1+﷓Sź)(m5훙F.f#^[mgr\l~UVО`jV|~&u1 Oq+zt\66،Mf[px8vЍ䑃_jaxOPB~%12oIإ D^w6 XfIN|r:/){[BJÜVB\3\  cW;wwkg:Je~Y_Ö\4), ouXN ұsN2O}\߾ |sN}javbL6l|91jY/_n&(1G|| Ȁܕ Jk!CnG~_ox/_QRn$gJY[SngɿM׿_kb->m6\ڶrs4u|^K!/^݊M~XI`竞^Y6&yh6Mm=mʻ.5.W\_GIYGG <`fLrĈvI>/!r1Y-yB ?M9K.UƇ{rjZ߲3w_rߴtG#+bmf>gnFNiX ltwσ!}]F#jy"a#$U[_BEJ]sL/ut7/hmP7:_}iS1t2ۭG.%g/e 邥fmO&Pe UN@)RJ,\T|&Ҫ+:ܽs c-m &E:k\dvQJ뗣7` v>vnѦ/3g=>r#)"ܯLuWZ>βFJ͸ӧu|5gϳ`^u^; [MցGNҾ[tWʁKGc÷Ɲ%/AHUY@_m,Ad=wx;QA#~uDjo6;Lͅ2k︜ɫ&?wyޭB=YU0#ÏqX6n!o!j{OIYfY+$CZFW!paG7 X^߷-ˎSc3#!nx {1Xh`[}youk٧3^G|YG:̱{=ܥ 8>:b`֗M3.JӋ>3Hth+Ֆ?ΏT^)79Ym=%?.Md^֨^SS$Һ$7*+|#Nkk5U,r/Bq봛8dLCO{ 7PȈ cBԣ#Ex^ptۙR)ؤAS x6ͮC9Ys&ytM; RXDT<&h wL`rD,N3@Q={0O\NqJ]KJxX=s(|AgTNe Fz.@S~=t6i>ړg$' IBI$gѩ\2?iQx;~C$0<״zXp53C@0`%"&g{KOҜpGDJ>GBd f`[Ϗru̙U<>u:,_!tݓs=Wu2nˎPƨvQ =n#^N!VG[17}.;nʝ?-Qٹ<<=[Am0Px7o { яhyò nwTƝLw½,& ]z9u/(hAc y='n-zU Rmg L)LJ s>j u!ʷbrs(3?kT٧_qo6MNwQs}Jh?omߪՍ H^z|Ksկӛg]u ͜ *`F( P5dܸfU`?VНL!= H)P7uy#_dj++`C$2u)?Ne̛j]}oA+'! QU4X"k$OX O*DƇ3,plW-[&=nXaM39Z^eIjg&Zg6e Xvwk%ev=hnh761*䘘l_Dl.ϧ6NUc}n\K'ێ<5yzS`Ն[n&6]YMuʭ{Yr]븫V;\| י+_3u a+<6qk,][ȹu Y;Đ[a4OQu/UːhO`Ӽ9d`\Qt3dT`.~A}Z[/Gs;<3ypDmx? [zSlL5E#BfdD 84I\I,?Os"3&ⴊ*\ZN8nXm([ÇǾl6FU^e6w w?Zr-o8M<8RVa1lF#yJ)mծdjDXlKqYdg❱uLه{T:S2>(\󋦎Ա&d$.9͑׈:ao=w])@O($D%ޮj-^Y*l 9:KW]PV[u.t~_Y^)+%5!,M)ţho//0-Z_vw\ʑ!Dg#s oᘏOׯwPoдWyr&SjIXuLǿ!+d Y~OmGM1-7u?qCp68NûFk+w g[\/f-?Jf6B].Y<9pF%*= wh\}Pgr;oLO oIoU+4om+ q#y3 aʨQdc\8YG!ʈ3/qP1;6hg$5)po&jmgRC[ i&FI,ҤM4k 8쁙dHZM!/IJ@$!4!XPp$X@jH) T + c2@"RTPJHQ/E{VN+rH2mSd9)z01r_ ֋)^u!G|:E&~op/6 1Ӟv/k}⻹믭^lg)kg=g2Wx;v\^}!bPZ.Od9 LbD< 0s ly ePp{z&v6*v~UaiE,8&qpIeP*V;]}C|+jv'%OW/~l8Gؼ4,W[1ïuٱb,[|q(+y֑{Nr{_tP9=O&]\%%FCw4S=Zv:]_gB)!(DBdb%ID!AUąe,EV"*%Xc"X$bQXp,- ײo€5(缫OܯT͗ 06X2 Tnd6l` e؉;f3FJ06o!ϫ8iyN,Į7;Ż).zN;HZ&FDR bϷxc9ƧZ~=\WZ ۙw2MW>Ғ {spY?a7q3#@R"T *J+QB* iJYY!BE(deTZ T JB`DU#X%lE$Ba}?~Ռ}SL "4KKh妆Jedl -UQ%՚G ֆM5aPm*%RPX%gL3< PAF *bV! HڒAh`Fv]w8X %􆧅 s/?7@X!&72f` T>bHt^IE()Dy_QÅ^t`{;ҟ?#x ?+X|I @o@(PCD'~ڹKǐaF@,yAs!>U&wrmD]SEpN^7A8]!s^.9"N6X굑-E[C@\ DUcr/U0@˞ r ʾ03Y/YKZ x Wk[ɂ 'm6DbGnX ?19R9Qa+:݊|MCt6wsPDAb#|T(ȬPL_J&F@U$%Ɂ޲zZ$?|~V ߲@!cjc3iV@MDcV[EEB(k+:Z3XCc00g~ڭYk;0cS]o2z;dP; ){{;?b>~7kLa~O~fT}mxaz<l1L﵉^`!+d1:n<a4yy缥OϢ{~ 1#}y-4 \imHu})OSm#˯vs @=mk0S}?=k]hZ"?WeS̜蕂glt@Fбs Qo2=d <UȘC"22!0պ:OB & H>%ڿ/w̱w={ν}p?f:_t SM\08Z@q(XCˆEVӵy APO..26QPz)ӶS ej-![F~.&N4w!Ŗ/z3uZ8u&]NLy6 IFN:w.|1ppG5(jϑ>Wү_O2I$YXʐPXbE& e1)X-#jE i\X VAQXJ(21@bX(( ,UE`1&&DJ$02HְbB4"y-a`Ac#f W RilUH"U+"BV2jRA"+QbT" Z U!D[` V """" *C Z`&P$ 9`J+$cR15j騱c ,EFEX)!(FDY@$A9uv;?qa"(E (E F (,bAb#2 R*!]M PD`,d#*Y EPQP0AI >7wYiם5Vܸ>1!XfB$k?Uꭵ$>W'k~7(-iuH"2H 22 d@F|DH$BOK=w+Zn~Gqg^`d!E0 RV dEY%,R),1%dp)J^3n`ve7;[Y\l8R5]h?G]Q!>w]"0 E]Y10`BGoa*jF2f&DAʠ<@)DYK XPA)[$e`[QmEBjL X ,%)m$X(EH# i5&BEfP"R1QUY*Vb X e"0YcZHV@ *(IdT bȠvmP٥!h Fڝ˰z-r~X3Pw+ O3H")@UVid6%2E*E+aX |,?O긋l#(ʕ|nCI =y !@X ,1UED@%DV($XBY̘nV@21aP2%aQU[e`HYXC-,dVQ@T%`0XĂ H ,Hb\ Hdco!A!MŊj$` cFIҨARH$@d$R d2H"B)Ͳd!'2bSDUVH(0A"1Imݧ^S"z@ұCJiUE)ִgi36'DT*nPΪX82Tm,ɬbOM;%dXnI)m̰9nd9I "*fdg`-ޫl$့ pc [ w=YbEIq *kjUVۈE $oasvyaY1&I fOໞ~ !ˍzm8NMDx=yt~zn0H u`%d;XXGU{60 c #!]ImTVa!%iHi A"Q`a`*n!R*@0X}jIPqKyXH(`\aR韅16B,D]oq˖0&uF{mc'F/!7q8=0g9u0KQRBN: c)ERw{}>2pw?UFweq6Hnڿpf 習$c"S}'Qf>z.]}FsHLߗyNߝFY7}$re]r͖z ``@H" H{Emo'q<+cd5P|Ͽmwr[8J|>cq䰆9*$!"$cS{qd 8Oխv] E3GHFP)W74=䜨I>ŀ wR 3$)#*T=I B,%- 1%>_q%`6`#QA˔$UY4$?j`?=ӟi?W/!ݢ ;` Amf,ʨڂpo |ZN~_žϭN44Aڪ%軾~9XdU'gϫ͠c;\pC QڣrbE {=rǣ:ӌOe>WgiI9fhYYRC"X+fY ID4#u-K CR8Hmk+$$BM~%4[hZJU!\I$pB3f!ôM7jVljٖ]fXhňELw4S՝8D 7އ 6 6[rC4)FBl2q_MCaC:jŅi4hʆ +emJVAPك4XU/_&C"MMT1&.jd12^''Tb”0d^& @I+`lt7MWqyiݢ19lv@bW:0m! 7TuFZD} YYF"L`W3,圲2[f-t9mn˽id_OڦZCLMiRmX2| GN:-Y/ܯ=l508R9I wѬ5Pڙ$$$(e|["*`b+ ((-AV,ְvfEJ5f3)"ʅjJ,Y+%b" ,sCiڢHҤ*U4ʏ7ln,*ʕbˆm}ziF "Jʩ*yyJ|8|~/pc?mDF c ǻ-B?wavE HrR T*1*#b*X 5 V"1U TCw}?u۰@dI @ddA$H#m;kzINw)0!0/~u1QCAӂậ`1 $  T"`@@y``-vn_OKb` 7[HPSL(ء?޿C[c=GPU޺6\nN ]q;Y%[V Y͙a@0b@RX|Z;U}y1]s:߽1YD,Hb hVeTvTW$Y6-l x52ŹN: |;mEKo ղysn ƃxFvmKbM+-|K6,(+ 5EzW`2 bjym{y8:k>kv rt&)GQb,Ca_ ˈpq[~u]شNf_o5 KC[L1`؈e5JU$ur }=P"߱_75u/F031l]kI}} ɼ[W]4|O=ѳu,YiL1Յ !^xwiW{Qh۟ig(yIJeie{oF *m3B§̿`a{{:d֘ΏsN4}UݵzKz**s fJ77h{ri_MC92'\RbA~Q$"i0zϱxj][(K,45hֶN)P`l5kpΕŘ1˰֑U\V4Ѯ^fn:kJC5*p~m!iUUR*wӎxK)YFTϪ?yUt1\VE h"XO(x۳)ue?ess dP b=A?0 al1Q8 !ࠂ|WĈ%ϙ+opY`I~#;ޱ1bh\W T\twʽ.kkaZ\a=iu1iMJ(&=je 6#PٕdԐiPG.I.#|! mZ{jFjOoTynhjI6%qSk{Sa",8h1Gۮw0G;u,w}FfqO^aUv`nwfeΆ?DlBT=g{l \8ɬֿo=큍~!箕Y~iyr9| 8Sޫ,h^a:^UԒ9s"g?we-=M7QԸ=9yL'sodD [ضq> B~ ox]l>&~Ƭ֩tr4n=oj 32[18d]4nܚҟd!m&nZ?>/\1ϑ ?[99]%F ͓u *\9oP-pDs.y&}arJ#A}>zAaUmC#IZWٞX=y.*+ѠZmSuqBZ*i Tzl΅Ez++ݰA dVx6&Te"`(7|7L tHb2|wy~ϣUqpaddĂ"AY OWIeҳi>ÖtD$W~Mqu`ߵ!Z†o,O(5wE%k  vJ$ ~;$[5UŃ2#wE5šj,ƎPGPi0P$&XQ"g~D* nw-:Qk(㞻n>$k'?~ٷL z>%H5F0nbUwL]ܙ$ղGlˈјQK mCaòmW Ad= YՅ޷<}4(lȱ`?Vb(R+mX,XEy. qJnVAB36t׭ 40SZBl 9IU(֫?4"д6fi&l\DE ()$"ZnCM_W <Ewz =XtWk7c~q1qׯK)%\ifg%WRLL05:DOu]gXc7#pyk泦n(nAzhx7W̒k6,#g_fMfcW}?PWoO*%O`\8 s+V]_q4;K_OTתW޿pu0̹hoJv3WlkꑱP5}׏j~O+?]*Oos:Oq`_KO@q )\n R^ڛBe<3,]v)J;:/2|wp2P_Ho&6I'e2ZpBK 9zf n Fֽ1^ҹ]>˱m_w $EijN3tSS}Ng=^V{P 6>=?s߭4=*צ?q}Zf%2R5[c\xˋ][khYc)_߹`ul鰝>>jS칼fk'/M2HE! $:MaDM@"0"V~:j.W IF]Ԛ`VAoJ),j_I͝cqqobnTx[]_+Gvy8J0MX}nQbQ ܶF.XL[Z1Db(t[0GrmD"sRԚbTZXxqvk߹+9E6` .nK#)C5`~na31hZHrX_a;Nn20o2[iu( fk}vTUFRk&*f5B8X%b& wn?Ze7ppؗ "2Q?.Mwa\ ξ<7ty:= |- ->=3_\h< "҄NWr}jm"gp"1'[nݽWμ.\SZal;L$p@LNe#C^xj<.2Sq,,@0NgR}@c$Qe)e37P⠐nK? EϵǾp11o./PFg ןOYjm?զgΛɄ$00Ma4  \PoĭuM:J +stU qM8:榖>Hi (^n]o찰:-^?¯Yw]{Y:}Z/ؿtJ^g5 Cwo/FYt;apWtLRZZraئ2Q 'VB1蘕,Y1Z0ujUR Roj)DbXTE r1XAQ__'_g'O^!-iڴBnQwn zL ё=5RU{|1?c>6+9*ȠH$"4&x&cͰMPTEAA٧~=-C[~2V,Xڳ@ᨪA]5?`tGt?m,ж̻jcf*v/~y!'>N]1T&.l];E_O\F>ï (+g M Y0) N-S!%l28T}-,(?šNxSG4v[J5O~:~Ӻ,Y=4`0A܉ „}>O'dAYKe_makm( )x(H(깬ڢ[o>Z$-P@Bltpf {s0"VQڐ=x30<=+a5.hހ5 6E-S|QoOײ:]Y NwǮ3#{Q,tPb'Q' !8e FTA4rL'z alv<ɨn< ดAB(ȱ]s}]3ˑ N%dXD V*&"nGhjvKP %Uҿo2ďL [*!`~˺O+a?jlY'˨ !$`pKb<ǞL$$DC|&xWĈ9|#zHE {u66721 X_O~|>2/g ,bc}5MTAiTaPR-Ij.RR kQC1AAEcBѫ*"5٬ &famCELk+R"JqJɻ4(,*[k4gɺQe AAb%e`-.P,%KdXKF"RQ "ikAU[Jb[ -T `T1E2[`*11rZ4 3HdT*V(,+R,X,,tLD`Tբ*TTA]RHV* (]E VJ5\mADTՠ,VJmlƢ $k`(C8${Fb (ɊR A?IΪ{>xM&;%|bi]˚0Yڎzm#kg'/rnJyؼwwơNei{U+?¯8Rp5 kf7hF}Y+LaLkmWr lRlM|e=,_̓ b;nf z=&!`mOa=^ӷY]uG>2֢k'0ZCX@LH|(hf (7\Oi_ 2ug-fy ՛t+-UFvc0Z"4q6'"^,5];pF@ #0m5[Jǟkz BԮ 5- TU.9;yU.k\<{Pƶ[ KF1ĔGbLL: @H}ޞ{}rnםxP9kʻq·۝̝׽ys8oᵝW-漆}sݹuV 8Hӳ}xnwl۽awOsPD)`boueu|m2s ]{Y>MmOyoWO>xuY:/Zequ};V6Ԛ mC@R kM>{OimϳG޻gw[.]V.=u=`PD Pu@aSP; K7]=6 P5ǯ]5[4%͡@lQCCUJ4P Zvt>wގei0 Q@S[zݞ.asΧg^۞lj;#޹aR⧻(]wWe] w@ݓn]w;@ ]OoG[zfI2I>aݘFv}JJo>P=Jcn_}맺 =]뽺wxݯEnt ]{[5lT[ÐcwOf7w9+Yݳ@ ny2h w[ prvϠ0;6;:'NcxwN>Ots}{kg|Z}}kQzケgs(ͤӅǽ$ƚ9ket _vPP"`/s(v nɥl ; m p^q٣ͯy׮UD BUρ`֩& 6 - tw^:^t { k5>/^g@:ޱZ@0@4-:wn}ۨE:YZ}iT|}oMX<X*4!)JIe#%!8ܶ?yHq]]S"\ԹVˠlahU_bHˎ6AqrF%r1إtj29"*T ze\5 5) ̼|ᓺCzzq;ӏ{-)m`/=$[BwO*ӫe PR$)@];|yqsn`ڠ*J4ДP,&ay$Y$% 꽛ySU 6{Ee%,{(<4x{}.00%IOZCR5 dM lER!@Awj茢؆AS1LP"(3,B-i,Vi4Ҵ[&5dm)[&)5*H4LšYcRFb1@D2X@DV(Fb UTUExWͻ-F 1DbFA#5@gt99''kAA ]U?t{Z֯-?]O:JqAaDr1pLUZiCvx_yڷ`t4 ο\n[|7Z ($P˟.+pԿ8lSF8(u 3t_E%8{ki6+f;;{+ T@z,˴C9ZPAoM)Awr˭eD`GM jFrU)ل/$,D= DY4X f^._30ɘ'Yd~nkm租jj1Ru{#=K0,V>A7ӅӺ+"7SVJ"e^Ћ h T5o.z,5f/ys/WbeoUZY4|!d,<;*cadohsUDtN0IΟZ[k >$sw?iȨ8|G;a㩵XM[BV`D @Iw"t4uRǍZfSuXd,x-0ױ@BěŀTPJ#^OSC̶ӺCOL:-bDYpa  hFu7sS\ܝ;c?Ù'g,F S viDyt'W1 ֽ2rpfBc/-+S]S gi:'}yi縻hmՀA @EnEN7p+ja;]unBt"E44v,;b0;.Ad@/'=g4ʞ0}t"v]Ӂ ?,̔tP<<&֘ג"xi[jƖߣwc0[eȻ_;3"dqdm$XS_/Oi;n{޳H)@;"p-65d]O~K[wMSaĸ H-EJF A^%a+YY`[2Џb eh5 >=uw= >QTNx+vz `J=L#>N+lcAESQӡ?.e3ڌZ7G% )58Jd:;yvéyp"{Hb~^\3<#I˺Hb~cqwwVD6DD1"D,AExxwUhdWOv~W/VBeJG!q c<=勐LXa9$h`aim0f#D%t}_rPG9T  +k (D*HOˀ@2"A/խa~/x]&ymu=/w/=o淩I`,]}e -HG WP2XMNCcХJȀ)Qe~Y\ǧ~>IdSk^D2iZUfւTj űhѫEcXѨbRZ}muͶ LUmTd!~7s뱨fj&Qb#Ik@RREC v].hԭBQFeeI]e/%7t^V tQTJR6ƣ_ |{? gƇ"Yh\I_ۗhU~E ek i|[Wl.^^x p2+B ^m\H`b(Ѷ!]1L& I^]xxҘF1_"f$~m꯰im>_{-5* z]YYkEI0V=uHEE~~W,Ʃ),dzrk%Qh6lQ0~Q-$ǿ^ǩ #64l&-%FU,X Yk&ƐFX"S6zxɤL"1Εʤ,Ƃ` I*sIsndY! }`|QJ?qboY:;Mr9xW4gGs5Lu2G Ar @=@E tX9e Wnj3̘ "c|n!b.1l9-qf/ BseuK1@LUP4t} `r252t|xa &_33e1,4AfDh/ߣpy$C)1hm0͔LHBPPiEI%A!6((ceIie&BD٦&aR iS#9w<^..[z=FFW7幼W7sPB}[&3 YfU@ΆLr5yh h],a\H yRgĔvw(za[_vPa!UQU? xC>TOec+PP\-|ɷ̵Z]k# "5|ϷߎfWD _Ld6qS<y'V(dU>ꯄ!m% 01o*KagXZj07WcOh]O ?ǎ&){a ]-3VƵ0Vj#ϳ}fmQb|X'>\#ďok,NIݥL]+wZҌ'DAa7|H5${,kF2`AC98Dpcg{zQ6";`xܹsfvvO573Cr2w>R;<Oׅ4N~51Ez>J,^O먬fSjdBRpO  )8Z HZ@7Kdٿs<)k3 O!=O1ZZire$ArBY3s{U[/}Xm?yfEJk-DI)Xm" VZ d5!QTyx%6)"*"Ϻqp+q>ڛސtp8*Ѫ4U-X߱) -KziTKdO{*}rg졖Kax7&]tW)5U}Ls<(P%My#w28/(mroX~kBv;bB)C,bh1H``MlhRj.FK5,+yvޛ|6-FD%Iɒ;z= A"Ay}~ux9߀ ηmaXPAA.cF%Ka= fԲ,kߦ{8FL8OSX¦pH5ݒxF'2ccGo8=ܱfIaIX.$߄AX kDG钐5DKozΠ!n j÷~f6|".Ŵύn-Ӊ4Ld& `@xWlNvt{>_K0""X+h;J>N$(D1B$(| "K~ϒw+GNuL(J1JPPP@INy$jf Wif g2v;KHFIW1wLi>=n&,ќK%1lߠr(*(iS7_4vfgw\ᶤI%:)ۍH URTd#QAkpϪ!a AWxc>g:;9sĔu[#vdI$QJ,,tO4"[0b&>_zPdW_>_=/ϫ+ #je 1e}*9w|fP0nb:9pn>uiy$Y9!M RIUFܾĽS \*7(.([*g vZAh*ǿcCwf"̕Cwµ"5֧>ӢܯS IƺU$nhjqo$a+~R)+U*(i ZkmvΎ#8yҤ۪`jMZW h);3L]גc6XɟxnMԎfmBAzDE(Dpr{Ʃ#HTkJH(A8C3F$H#%JƉlR߃Rz q%xlyƜ ]҉BP~l9g~&קL;bmV RH):u'[.FcOKziس{V͋xu6UxImcz8YKm3ԃ@P>S*U$%eӰrz\ԛ R43gC%tw aH H!E ]_9N8q6.;9QQg^cYdh+\.rEMN5ks5Pܜ*)SZ "fF!u S 6Gï[7o}q)*P` ѯU[RBΒA26(#rJO`D5|UER}UvHwo9?aZ8לí|pc&~} 5;6him0tu7yñU;L9C$Exau$b3h/UjMlf e0Z1- ˿˭Cib @d@FxVُo=m|T)AHSQZU)gM* ?e O ̝ccL!j5frՒP;B$ϒo$'YBRa*CHa8<^>ɵ62f]ȆgW61mIx2DEE*>>J.xhw_;&[i8QZ1Zt|NؼզYJE DJJf)R?Cgٶ`Ad5]=JFhEmTJs9w^ݾK]V L͐PwޯB)O9)Q+mElmmQu8q1䡔+AHoY\(Id0A fբ]C032_avg`C"=i촶 X0%xߝZ1%~*P 8*~w|1V_ߝU3#Z9&܍sD1)"%cX F$ U (, κ?&~9 ;ݾ~zɡ|ۗGq'WzX+",6VelmV-,kPj,"CJ EI.c#":*JU<.vU=-1Z>g>ʽW[F,*6FY"@A@JmVj; :ւѻ/gK/G||gdGvLr~r =52 1$Hy ͱCMUfvqǹLw?tW: Uo1 '5n\XA2k a;.1B*3)g!c=<dp 6nlx7k+rp݁M|-c`k%6ƝVV<~) IJΪ{Teh) Bȱl_W4uv}Yǟ+=m_>z""*9o [s:x8T4bz3`l . Żk ju *nddmmijGw{}ҨdEilcO}h;D*erDaXPLe`uۓ|O@W(C:xЯq1e DE[ ;(lxѪ6BDll]u xɓ9{;nbEu94Jyd %IB"WèXv;G}s7?!4EM7Aԃc9ZB9_ɽ^n>2ĂRE;귰s/  >giwn@" }4-:sJD2P̄ DBm2SI3E*0`JM &+W%Z ?PPDy#CՄ;J j"%~mWZ-!J,}Bnml:?c8#fڡI*4K̰R"RޱSk7x݇$~f3?ŷ9X=4:48PBBRAsӯ~&z'qքd&5M%X9AA@JAԀ^XTPބQa$ec>']E87rO.S5lJsX$~r;Z}i8"A dAGs!*HTDQAospσ~l/_<-<2&ǝo n\2Ң`ZR$F!sFspCz EQ" ~#)Eĸ )S@ѫ:.3I0($ D-RcNԿf?C蝏]ɱi3'g7򴴟_w("D0$SN#9k퐥)Gwr J=U|_,`.[E(\)D6 (ʺ{ .ʮUeNі({c!IJ1rf RI)Y%SDmA4x{_#>e=6^7Vϋ (he*&Ny$Vb(Z4di)#o82S2>\b_cE䫢K0Ìp4,RL6t yp:G G RDWHiD2_}8NPۭXS; X|+1b۲U?̶ 2Ivw?(AF_'M?=2 CԿyZ҇㟑B"!bH'i/N#Ao="-RuK;H֟Gۭ֞GPZwf%/b6m'DS/y MFǥQO&h-R7EAq m &3MbĂ}Z>8z>bgdā@ ajhWƼZi$e5⹨'\xgyy~Fon!c1P#ʀةN/;m tQT ޿oppn@&O#7W\?@CQ=JAÎa)-*fOUYeÝLoO3~zM).kn;/m7N9,.W7lU+hyj/{G.W ě-c5WO6Dc)z#23`,ٜU&{29vrEȶf6+lT2dX9fmgaG39KGo?W77WNƅOe (cXZ}u#i.I&$!I!ܗUStyiuOA޺ҎzMTYl%Wy̿u2J ,)젡,:KR^9ZKXvYN-YՏ?70lkp!g"n79nr9\=$gwS-S{7Vƶ34nyE [LHŠ=KY/--&!D: iS`:jvzlQSьl:şVDl)LDGV] [m2`Pj(+X7K[|LϠV-\p7e?-MV'KMUwLEzz2 ;5ŭۖVbe ""t}#gJtNhڋYKu ~Q-ėD!E^DU-P+ޭI>'1A[oe.\k%uRwp{nrx<Z-YZO̒r3D(I(˚I !M;TYcZxc?^QxOPT7T51j[eisgMCBvrY;lBlm$Q]EȿIS31U%ǜ2DdhVDlkY)q8)~|-Z-5Kә`,JV!㚞7WTf͞r\p-"b82DfF͠F(r/vW\uoe\  $g{zG\ _6|Gqe\ƳV1Ә"}ۆ;bˣfrMH` ! QnL*e1i~,Rm0蓍%ZsMvRpbngm6ut4ҡ0d`ns;5i eɺ=#S[:zV]-r:7Nk߭HpA`Y0/nz*P:{y/ӏɊx 0W-9zuh2-7=5.;]1L(TM| + ,r '(SmF=#Άt_#7zkŬsq؅>^5{.;nVSsD7cJ>A@1/}\yhҋ2 !==y[55 z]bA8jrZB=ܻM˙h8͇HB10 |rB1EQKj'%1V?azr0 TJN7^^+\O7>ϊo}-웗X:[ӄn_-Po=TRh~wd)HDSr᪍e:idKЬ/hbb!W:Ģtk=#Ep8[kղ~#oPUOT pܹsrGvl;]pmtlQs61ջ^6KV*PRYxŎW  K{%xdPIJ !%RbƇ!Z(a :F)xoƫ+( PI4sh[+Ljg8f= rjw2(T^^;Ò6 |JW) h࡭>7nYU;VQZF^p06Z4(^ ,ƒqRT `mK]ҁGv"ـes]h`H\C0A߭acoTUN4;*9i#x$! @0I90ĄBN{_e=eW^ݽوCJaYKqα",E>Ф >y3Lf BZP &@ȣxh! qbq(0R쨣kmQ[$/?ϯok]6OͶIB,6ʡeyW  +AEX )F*a"}~]hCMD14e͈1Ȳt7w%B X)wB-kzXOL7RdڤA>+D2CdpΠ%捧(Gc $tMw`1 >>>Oyċ @9ȰXdџkTꥭ͡Qf-oM2DY6lbt}?/AB" k'KcؗfddR?e?L@feLA_dDzavy1Q*$ 4ggn<gQ.oMyM㻮]3*#II$؂/~F[ۊ Zd%fy[Ὲ؁ 1h:hW<:jdnMs Rm'r4r*1˦}W֭ ;\] s/1 G#\8>}e"3\xJDdA1bC` q- .a"RbwhW{y_~EHZLW @FFf@¾8}>XL;[kzZzBtދFeǖ26d$IH6RFo$cĜ2q+CnbkY , b P.18c2ﻮ}osVc9*)ՕQr1H$HPd>ǿ5'sGuf^[YyL_Q1X[՞aƓ\V'꺦dH)osS=ԉ^#aַd;u} ҲKY3$̆#21}w\ )e_sY޼6۵Q[b)|c2WV/o~}J@0h* q"DTuh>`Lqn<H~Οўw1 3b:Q2tղ?ΛHbS 9qT~ IX~R@Z\gs Ovn<@0Jh|ĸ!bCcDt7״ ޞDsCԨfu Uh,tG^,̣&}o0kv3Q29"ψZ@6 E4W&^޿(lńjb&L}+-mjT:9i m ռ &#pkݒl8l'C[]8!OU$&"L<0zp,hƤnHkڻ4tU*ᛃȶ ED=N&rR4OC ãO|ZFdR*Oz2aao߯玦t2b)POUGHlx^n>`@B|& MQOpFm"M:S]s|J}PlLzFW";ڱq!1c:v뇇]n7m@W rTR!P,ِWFr,PLIԞk KstAjGjQZ;A)Sciu,cZ* BfM暸"= 5J'[G}P7DMl8ufٿ~(]MTSPeH'ϙ0Đ k籚61 Dߋ*)35;s?plyry 9jHhS;pQI$)K (/mљ;4LgTH:{iU{1bؼld݋w0V,X ߹8c$/9*bqneP$M6 ` ԁ7ɻz7y3c uoWFI"PgL8҆=!sN{~ÑîuOj6&Vj~yRy.;&y~_lŁ0edGvh$k? +'(u7ԕ< Z,}rkEj:aKT0.*;l&$tkQS+{*v.&L GMa̓a `,P_q+:U^yY'&^6.c1bIq$IFB(T1~_@ $EA1t{댜y)1ī_tLGB$&I3J iT62=X!w{[JiX}U|bMqo /Mر1w` m£i" BphT@2\^vޠ}h"(.91 mA{c.޺n3v!2M`Z1\ê^o41TobccmOh43$(,-"w֜M[|wǎsP."a E܌.!mUƪp/Y;WWC4(qSTxM6f]=8N$@R48H^Ye*{Y{1'))zx̂1IC}A)V ٍѼvn+I%0-rXeagd 9_ӐoR`8G8nkkOts-% NŵHfJU=n=~K0ve ##`׹(S`貙T+ЏF MjE97(n$mIcm7n7 8 p]; W~v3cAR!-*S**R3 W]=odw6Jq< Lp3Un(+$VU=>I%3̒wag}$3v{4k;-+OweZ5F>$@^PH v,ي:D-m 9 p}>.w?ҌF3%Z͠z]V=3zzG_mLl-ڋez=+LH+ SA.Y3TcKPczdVh>ig6r?9G0B%&P*"0`Zvyf݁b)6rA7Zc2Տ')0`)瓱]c7v*y+fx|HCti/A4{`F/um ,λBt=-Em ~Z~)iFP5=:kPŵYT(S(02sk2! it~nqxy#I?m]=aV-t[ؐcyԱ68cq, 5SId>nAhǛhfN .FE# D⤲Bx\ݏgnW7Í+G@SBvP#^jB욍"ɐLW /opxd1H-R{ We<iC:'J+}OCD ώgYc7]B X.F,gKOl&S:D3~J.a@ԡ /tkﷸ\;8`N^M}x#Wz0Y?n Erj^|aȱCiGKι oGgNb9s#єjjS,* (D:1J܍U$+kCxPM0ҧf~^~ۖ&V(l\*7]kIV#W2f9ynPE@b٩P=Q0 d9$v@δGnzg ?W Ag.^0C*r.BA$ig>49 )<1Ĕ8:y*D_eD~nLԦn<v ) YZȎjg`aa3S-UvL\x1 2ۏT 7J\VkeSMTvCuyٜΫ9qӮY5tr4YeHG13e:ȧ;z%yPFccۿpapÝc ȢbɒֈUJ(g#9kɊZ< o5HQ)6*B[cÿ3뷄3=`oq3S\I؀sV#T=2P@\}\-<<} ʎQxAh ^A'Fh t8tmǙ,pb9ȐE9:W|Qpwjb|N O gpۃhfs㯁" ΈA#:#(nk#H;0)HI$qrB(0T)ӣzkr@)>auad2 >Wh@(ӱmqR) + :=罷0BYWPӣ:w%bMX[bDB=שd~u*#(ZѼ]$mA .=Xe3' 9PMfMvfG7+xkX/-!U@J./[W$1rQ=%/oNzEHPQ=(sj댊A9]pp|zge)ꪊ *"TU@c#u(u4ԨAs#[nnQzߌrc@+`V<;PcˎrD9 hS7ex2,57LZ Qn";P+ gb[LV;G ;ZOQH*h>Fyz@Քx>́_3:Zrx5k{ >5;QLNgT8n9]\04 6k{Yk,5a8ZИt&3Qc ZYGR2cn'BcK h3chZFY%aYXqYJavg%![ZFau&SR[ ^h^m\#aڱd`SI`wq!phF`YL%%":ۅa\0 Pe 5Δ+gL/1 e.̣A*H4l 4" P~Q Aې4@.%ACzUSH *=  TZP ThAOA BB%4+JR)%)BLFVkF4TZ">ۯ([G8n;cmMdc #=%sYQyݩG&[Ce. x3yZ&4@r ʦĞn>n+ | r} J@P\"q{~>l0@'c@nqq S_!{)>Gs>_3ւ oixҢ uerPZR&"BLخ/%zȀ"JZ-=C=b֤ _˗¾S{(uҪv_uc_w@^Xq s0KPg`|0uwM{}!rxG|NED U&mv DCst\>]O|kwiy?oKrO8e9]5vss#wbZ?Ƽ"cBB@!w7c w?bJ`,Ÿhl5 #r5P5U("""vQx/vݖ&"vUu>y:!>PLbe]$ݻY?ݰ-Dٴ]??7$Oi!T>< qM2s=/VbOxDE@%X{r@|Yyod^ %aI?s5ʀ\@|@{`sQrD ԐUBU.o[~~Ͻو-! (6P[TXT@;.t&Ƈ׀ğaⓟЅAC{"pP|^zZCvJe7(g;(8vXPe ;U86?Dgc$B{~~%]Ot/s%AxS؏]qꞧ 6Q,D @|t 2NOF -0E(-599ϼ`y#B;Q}dZHK}|Dx9\ L 칸W@BLI3$qWK;&?/~ TBTDy"4(ct"˼lpZ)pfH c˞s̔ R%Gr9Yg#i{_ }AȨ@g2W'rvmurp1kWk;K䊏yd@7D@7t]cqDAp4t?s GEauX8ܱPVCYl#Eaf@CPv\a$'ɣQ$m Muma'ҋY!o:_=#,b DOvaH+8A9U0$Pq(_ ͫS65ݥ03u|Tʉ%]FeaˈnRBv= I& ]^~yЧ&RaGUU^~V#5$-&jnQeuآ0̶QDW٦ wEwxyx.zӲ 4 .0@ &$e#{x!#-$ c6<?6x0P Az]rU@uZB"'c~ kT/ c@ݠKa9SU_C6 WmXG? 86w=Y_|@/KjC Aעk@Q0LRqfҚ]Mi"  ަB.QKAɟvECIr9>>{OmiJoz5 i)"&]\P'@ ҏǃ`7GYV"|ѐ>pCpw4YW|_5CP 0DBv7)  ;B2n\!-N?1dx;u,`B.Y!RBL (K8XŒq픽Pr;wuu3ܻQBE23FH&IߎLɤ!ŢOı/6==t:=7K<5 h$8PUi&#i$+V3_x#ORhp)0b|8S9.nu덼-.-ˉcsd>4]׷i $iQCGGU}! L0'H 2VZ tmWZu`ϵn^ΙoLmF DbAPA1-[av-}PAo P+@Pǔ"qH*rTA4Nu*+ /}T #0(v0lB px*4-`{"6 iE(  1T)"F J/o dF8ߡ9nQ¨ .T ӶNT:HF9!$J#N6꩕ ӔԪNA8jE']PV+a \/VFP1i ,XAa#rvVݦMFV5uuQfk Mvsbv.s]sutʺXErwqڭ[CV{|e$9Q6YJu09}ydM"#ؒbnJXI@+kV""C"(LTH &J1 1"d!f(&$ei!FljLζŪ٠*ęH*rJ+ɀE3*Z^|* <7_rƼF;WShݺ׫xK*2Sיw\ۮt^Qyx&z^:+Eul˫\ yw4TdRr )&)67Z+Jh b 5B((tm /BEMS\TCT;m,DDP1"HzKgwbQ PcAAk`DQbe X"BiFҊ4`,)  DF)LH&$-FHƑ,e4I"#ki@f7GP@k%CVTXo4Ʉ Dg D 6jJ*F)C2bw߶Uj٭QG<)q &Dv*SU丑 UDAl Rjb*H@x>R"P`D@)8 V"1 m nzPij(b\TW/1qs\!;%MEU1En.sA9Unv76wo__"zJō }V+~02,>or$ypsoMcdF$IM5 x&Ԁ퍐Ub!1$3C:,T QF,IKG# a4 r(Ԃ;r3}A>?-Z?I2I0Sd,L(b(ۮ(H`$fȒLauxW|_6ɊhJb#.!t3`lWOZ`I}ThQllPQbclFDZJѪ5m,h IEIBV mF&Y%FY)ۨI !MgbնdοFo]̲`) ԃbYQr6!1׻Oҵ_/n\Qw-m@r7"0:/ö5kZ'v."( y87Pt)DRU%%*J)06R$)64I0Rd4R!M46&(QD&XRXAM1#Q JHXi4X#dD*l4#f !&j )%,&c'_^\&@5LPף>V*9ΙAɱ1: ((2 uV*D0۸5ܠd&P*NpTEF'ʲwHO/\5< c?6=_˝/Ik%߰묀Xb, MFncDPTF*ōkQlbmjcj*hm%QFDZ4b^|`Hj Aӌ}V*&R `dA0zt!Oo5U-/ֵHc&E7 :214C&$Z阒y9[ϻ+8S3\HxALl'~(5H8ƽhr!w2*jLAj/ݹ2fWqȺc*LȜڴZuDoc zww}4OZKEF(1"-Eb1 cHXŌhe%Q(-#(ةr,T.JJ(a T&nc6j ńæ֊-EF bZ0iQj2TRQg:Զ`g1m+6bm[)Yqz7m`kojoD4QF&1fĢI,ɈeBEDJZjK$b a7R|>K^d*yd  f[]S8 Ruɶ-QjѩBQJ(9Ȃbɱ(ؓQmAB(CJ¢#eV3kۭZ6Ш=*G4ys$%zu[+ m(jNN0b )W~߶n몝vݬTr-*6@x;.]u+GCsI̵Lf2Vr8# oMEE\qݸP!A5NIحM2a&.@Mv9$U@`#n_[/8s66C@k[U"LQ pR1}EEDk$qcmk5fed,\g.<y8uoNLzi PiuBR۔&|@"گnp_5`Lfc("E%%RXI,FFMd5(j)*FbeIhڦ$1l ,`42lI1Mgs6\ѩQ4hHiCe$4Ts3۲\fr0:ڂ "H*X$IcB>_/g;jc 6F FəaBdLTLbHHRҠ0IdD4(Dm )DI KaQ32ie"P)")!4 ) oI."v\vwg*`q"FJ54CE՘A+C0_MŨ<3, @3o6rڴILED[$_GN+$"UWmoҕvץ5\M-Uly,basÑv"BH Q J(Xb(I# %Eą%L(PCL,l"i3fPЄQ,d,AFh(SWMiBF 6]f_λb e$b_ HY.Njvq`E=I s=6J/ңTTH=UL5c\g AȈDsZͭmȄXHcB}ƅikG!.^![7],^2l&rF2E$V/]3y4ϒ^AjPt J(JҡJ&B+ 0&8 PR%W s@() APdP|eJiQ~(:ÝDm*U*D*3su׿ ..OF /Qgn!L=Vl&myoyӹأW5Fx۔ll[T*jEJ4Ǚ.iR)b-`c j$3[hm1)[)(l*FhŹKVׯ6:@G g#1eR7ϱzP Ju^-u/1+muɈSFjք0ȅMb$0Z5!5f# ąU1S(ѡT-lVJkkkb^:I뻮KZjͳs37z6Trzsg\\칷Kӝ|?=,]Uj?NůM2*Vn[jM(l$Vڦ"n1V ,a޲6n5 -\/-[\ֹ](84%4VEH65[}5jZSu>yfu_=%Db;sLl[clookr^-5.ŠV ń\-,llmz}͠;3[a|C47CLo̼G+EnniFS hXG59EZŒ2FWZIbIDC-PETٖ7IZ m7Eh+%ᤊrfofە31_CzWd62>&yiKGHlb-*1Q]1,ޚͥoiʋ9mlXxcz{FUʺ\6¡k#yAI6:- )laQ|ja FqnhIݥm|Z!,\ *k(rT"I߬- }N<7Hج- ӆ4r &6{:J8)@ Jev^Y]OqYnc0]nbt6 m ؄}:MwnhP&7wۣwᚘD+)b14ޱeF1w]tFDkQqܹw:u}ǿWǽLʠ`be~ 6z 1pԔgv%AhEhLzDk[x:kr'u*%XƖr%qr/m\kHhV٧8}U޾j>xl~'=r~7^Lf2l) I6fF&655/< ɒ4Pls\^1г[+dr^YV(גٽ̱HreGx̾߾nPq̧#'$VXVcbcaLq0r(Ć%n\y+(Bwqf3wW}d$]1/{HNNv$L-nd-͵rUV#mmڽIMdw`|;ɽ>uH[l Zqm!KnGu†ڷkҷJ]w]DV*iHMЂ{ؘǦQ.vƪ6iK[P-51+;1pj({Ijq;iX93qnu6aWSFR+WZ6ׂad׳ۮ4%ɰMzK2$"Iuۺ^ Wz}{okμuƪɶ4m*)5\"MrP$B2bzkEżƓkDU˕u\vb2lUm˚nD󫤖6 #a?{>$ß5Ok) 9+#_=yCi؎~74Զ[;i].0-i%znxjfMVǗ^h 4hU"tI5,ۍ&IM%g띦uZʄ4Gl!m"6:vmUWJb)ё102M] ka08b_~ox͊u<A8AYQ'1ֹb6閃Xf$s., sن$ţ; (#vFE 'e=zk|})x7% FițiU4jb%A3䴲AEB*\uDt1`ؓFu.$ |^ކ 0piYEq@őArﲲ8Ē (p,8x Z\e 6ƛMDw o KF m&:HBMVZi2)&q-J46aVatC)K kϿ72icGH^/s/%PHqqmdvޯm6QFfxe5u-cVR7afkWTN<2m]c/DK>{] PF(69iJevVK뀀ci 鳄r tFZ4aUEb[&a[(-;V)lcCAYWKB4>UttY1>g-hOi^`61c}Z]N}᷁uroҊ1˕9źoCcfHӸL.=1a4>wf#v֤,Sju!@)q`ͫ4|mM7U0IlicNMl8f̾mP<#9毎>m0\N60՛W.8 Vt_kY+4E\$XlYmu4qg[f3 0^!tk]v`m3킓coin=ٍI qT&mC*)T6)̈́D!\6 i:~DP@"AP= Rݐ75ʙ[2*J"n`T9G8ޅ؊<8Nd!dܫB! py‹uxM]~coB۸(@| % ez28$S(DWbڴp˦6 9,u0k(]0P:DMc P U P. FD@ڔDa M;hD1er:d;1^{6$VsKB@xB7*jz0)`v{|.Īʐ) ݵ&X5pS ӌ+ёݗ\$_noJ` tJ%CPu@&Uչ"0H܄7%Bd8 {xT7W~i]UR %Vei:w-oĵoMRE%kro /`A6m]Uy'i.8c^ :Pr&<* i#܁LLý 9~7VM$ -auTR{BOܑC?G JP1Ui&=#w 1"RxQ䓉TT0pl1!AP NBA #_KiS G[P%CD S@4Q"$)Trc N @3ae0DDYo-xúFS]VgYCOZ|9(Q8Ԡzy.pnCx m>Ug/*~@l'@jGSr?V*qENsu""U-'-7:>lɂHqGu9gg[q3f E1kk_=faё2{`T3^+4Gl;S$4 ,<5#s[h:Xcwsrr"4gK\Dj.ۓ[vĕF#jPCzkieTKX\I`]Sж[t'W"7oA(;AAƻ)s۠ {t@t_@#0/j?x{xwoh|WE̩~ z{-:_ӰA{b#,X]N[+$H^!&H0fp`44Z-=6dݾsդ j4m&qNIxOYC]WR/m3W0/m8ۏ`~Kӣw~r5YOtj&0ק;(8%&6P4*pϟ> /[EN - >pxIMQF=? ^^Sc[`uN](*JĄoϠ}tu2 3\*&ShN6 LnۆbK0rHjA =5Σ[dLFB_u.TJiV&KjrET֊IyjiJ<5 T g/w IHPs̾ts-m2YRݞ͇i(JjDB-|Y?5P"%RcKylޗӣ#7eEI@u$}~_sIظU'>ի8>\0F=,D_pj^c}rpL(-ZP.G;\B QqL4y.>ZZE&(ArV4vj7>sS+M5A q-qЫ:©W~ـ4@y%^{蹾 6Twۥ~u$@ 0bA G%JIw?ECbi~Z֢7hߢ|~FIB+An.r?.:/~Eos]_Ϥ}F5ˉkGf`-) PܿcXA=w`wEbHkw U}i~?Mvp TShk*/ag Jh>x$irciq¾Oyse27, cǝd*u!P0(./ϼByKI&= !ޙ}v+0 /@U3eus!yPCJϱTMq) Zk]'o#f˻|6of;qN`t}7Quj̟b! 3H $ ɀ]4ag w}nyf6~Rl.3xni;}D!Y-@t?g坝˪M@RpM6SBFwCD4pdn];\Db.?=:5 |wYɶw~:aRQ`_t<^04p'=S`:]wU3Oc7:\._qy} ȳƃ(Hԕ H(TfC@=*#я>Ou*/ɀDu Y{W" nJ`Q7(H=@E)*O}Dgk*Un)1p*O /"ߗ[t7\_ ¤]~%5sgtڞ+ҳ4g_h _Oҿ}KKﳜ{7w{Ӄ2?\S%TD]1cӢձ1&MVMZL.M۝̻Bn] kvm(Yv7_o5MkL]+GuuFȶvή9Q*mmמUsm&=RVI&Ӑ#^g $bۚƹtxfCnz;ywS;̻wx.swK,[fFjCR l8I!ۯ3dmTUy&C۫ǯ%BB))(ibEm~7yzunw (Ӗ2bΡuEU6f6v)BawiQdB2 DA"q8 aC*(R8$m6c).2tKCTJ1{譲ҀE{w#l4hM q.#,UQtܻDP:t֖̃ f  2(TT+B#*QFI PFiUU47E*8 .c Tƛdw%2SAڻUEH"l R281*ءE]$[QDڶզ:=aXk rQMQP`䐧$)TQERj@ ,c#A*($ 5D^݅mm~tj >#I筪+7ꤴny+7zaa{¯W|YC.a40/N:x 袀2T7>4 р w/܈_z[0ccWJ@5 SO]ٮny)[">Dd`EeP1(@t!kQ MiIUņ0.*㴂mF+fb# %\K4RCtbC Ȇ*A6'bҢ˦8Lǥ,$a5lnImJpih V䃰 -{)*lhĕRҕ115cb `3CVP@S yx7{).4a%VKAMR4t8 eM%&+x"l ?R4taY6b v8P5u7K)St@kHwMcUBܠ$P_%׷6a8ϣt BPrƅH(Օ!mTf DaxnBp:MF766Ec41/\Tׅ핿kKF|EJE׊yQ*m#)6"j m[Tb5acLDhq*T\mD+l:Lfs|ZMiqYMhiݥl$]@tn0c.ay-`96T*`@k*"&(Cj71.*63, &-n;\ݦInxv# rD2$#0\8TʒJ(I[3 -Faa YK'w*E *GebQH\FGbLժ豭Yk!ce2 DSƒ` DQmxdj2h*&iFImdq$dl=mX+N95EDj0.Ԏ18B4jL1޳ e8U"斩|wb^˻HuzOOFc6 3A$m{yyxt_WNxe㹨ɘܸ64jLo0%˝tBvחeDq5NUR*'J22HiAV!CcC4ve% 24E\"'HZ| Ȃ=I^+*rA=ǒDQ@v|(26"!_GYu1Gqa|ޫ#7긅߱|Jh&*)3HJRؚ̆T!=N#5f6fi`4dц("23B HUfr`jǎ]|-4~]w qZUR@0Sz^K:ɫzż["+6(QljwESs+7{Ų9'HԠb P(laLUSH,,m]}XfeY)*B6Q)$touwՄe>(3쌹s;<^ǓCYo\X|<D|$TZPJ8˛2'k?ݚ,u`?}-M2٨HBɟPx$$YD} J 8|Bsl'6AGh3ׄ|-Y"NCްG}QP)wX 7 Tr]Q-Y(g: @JR^zz$Zf__l/Y߁9Gt__MgmPem,0쳊c:z^Vng+rͪ[̍;x7]]P}; @3+>F!0aq S!J U" yD‡/g !QC}eDC{w$tXz&^x)$"SBFdc0ILJq; S-$@cQ%PPV6 1\:[-V[-3Eti$__a~wާbGAȠGyl*'&QO((D}H H<Eݑ~|,;[8Pu'A-cD31dZSbg~6 "*}BCU`%>ѱ 4S30jhT*G1+T@Cu1Ro6.1 '(PUV*)7G0tq^)JQ*yxבJ59vX!C|)Ix' 0v3fbJTf1ڡlVM+јS0&k+/vqsHTO=aȇmfV{O4[E8s {nwJ?6Z.`rAOF\e{ aPySRTgRϱޟ='K^wWhijq"NK QJsG& b@"&`jj#+ْ~=JsΔ i/E )$~.~N,G~3ωȃ! ۑ4ǘngv;P*mQOhHs;`5,:7Y$2ɉV[`\A]FXOV\uViZF dvvۘ.wd2 lMR)F6P+Z(B'B +@@  QokAC63.Li_vnVqw433x{a]icy-O.Bn<=?$; ~'kt)K1EPqh7ӝ j]7)q: `g:'D!YH8rFJ0I@!7 ~ЃHT}X@"Dlh yjE[ H]@7oc3ܥ_vP* h .-tK>qٶDÑRGft/j\@xG !P ޟt?.G602XDR= Q"HJ'/;}IɎ'HzD4.rv~xJ(P/yl!KD⩲pH:8 js~,./ ( "iq487r '>%!A{.b(@Otz8j$^]=lp>cBIh֫ϕ *zSz?M߃wwːX"BILŠ,ʪP{_#i8xqݷr0} NRӀē*0\rNfoqkw!$PdQDj:U_C~f3>tr<=~Y P>lz,{AR!O-<_v;7[N螉YrƦ} {f~vn֭Ф307_Yn{]7Z{Ac(-`vVSV9x{(?}QH2B|%IwoսctoIpeW%Ƈ-"72p-0[ȣ5I"s]nZQ>/STCB |Gɒ"/ -~ \T0;JnX]!spoX{x?VM:۹WYgU#n9[(߫L5 ʑNbP%Q>a_"Y5Q1_Y{me|_v۷~h^M3"j{J/'ksS*N_x-Սe5X~ݥ~2I"Le<G>ZK"ۜrior9ۧc=~Ca  q|r ߝP0v\J}zgJ\ѧ]x{\&\{6[>>ܜAQހ]頿YD<#Ws]ǿJfRQST3[ y$4?yIDhN?G;s%\O9|5f^đyQQ]H[R)'^g]}W[ VaF0AcȘ_崼%|x$\j(U N8wLg0@́@= (no~bG 9 @*#菠] tWq1l~ՑNMx $?]P`ۢVyeYR+ck[uy4vg߯-ƥ9.n}Nq Z!RXy>?'ǁPxPڔDf>vW?1-8tޫ <.cFj0tJ"U5QU c+| zwt}/?5((1 =,kƙJv8h! 3s6_-7-yXoU l[6ԯomQ4C=DX|OXyBK7 |/r!xΨ:Ğ2d2ͪ@@OÑh ,8XO^v;nr~-AΨ+L D5(l*dTO@ .p(p<(`x.@{hp@B??/(MҦ4m ^x`9#K;x}d/!D_g?*U@"Da [G[$˙ G#0"}<( q嚠bl Lޓm`$(RM\)KZvk7c)iA urG`$Uh>D>D G*9+&*L`:ټBJwYe(dY diThxn(DML֢֥*#s7_FlIh.CAt?9qvWIX0=bBovIz|z M.Wo2p@t8c"$VzfwDb'f~0]viJdAh--fM^1KW^}QBEHX׏~YTryl=>YW(%vo)c%_Ry9Qwrd3Q̈,cZOIX?/4=U`"j@ߥI=Nf$O9I隨F9-.Y7hWZj'trtz}u@0nfà;HAi$Jd0|kr}ԯ>%-bO@RDTd@6@-"O :k5\Dx<0%OzyCdz},N9Y!{9@1(he|8^ل̆SptHE+/bPT "3*}J knsםLG&%II cV8CJ bXa? Bzw`_<;A># ._)>I\FpH$R:4P%r3W:|A $h vh9J3@%XB,Ӹ;ҿq>NYgʆR- B%C]-! *𶁭t_Y55)kTb=loH/&D8@_)R X%(0Ym@HL(1|ܛ#6dًOmaFǭD Z^plj[wM %ԢϹPO-]WAZĠ}>І P=ZQy>c~}my2Z ;46$Pwv./(_/}7W}[`d@ڔD3ZZ(@iDEcG&'!6;gz#zF 3|c-K-ff)f3i3!&RW+kI]A 3LXUC:Bu\Y!2c=Vh¹,,PYSEL EƕŬLdUhZ|~zOoy= MzsxPrOfٝ=Cx&;fP4KWpiG/;xeT"q3tЛ*{W`AST*=?uJ, dT[_7N^/e܆(QCB@FgRcF@O2)eE )S w>FW[l|lAܧqAzUXlGx4ٜ>C<_-xePxa"ʠ7| *kc?%@M&ú6C>Og 1O3&7'+y:F~e?9mt1ե͝S@wýs.-S3* PBó xR+ʬG>Yyq{EʿǼ8g:,b`T~FҜ/u78.ZIg-IˮқU 4vM PhU#CfV vm~UxOJ<ޯd* ɶwL6&m9b tEASY\wjzꚱsŧTܳ<ΰ7HV:ѫjM41RHAa1`dTQŔCE5tN pD6huUO5`#rcLDŪXp4J)VdMnYi!bC H#U|0[^-"t3#A7C )/Zi[\( |"O2M'q7c>Cz?`j9K[jH\D3hPt2Q"J^;\XYzOᶮ=9ú|Yw^2fUIuHZMWf"5/W49o5vVc0O6/8~-O@h ׿N$Ƿ6qC՚` JI!g2|i<翑mJ%~uW?Fκ3f/4ph.p;)\=A@wz!(6MhyкIN-h;xͩyZy{ob¸ķ{ T!)Gt2 -,qzkᦒJ fڝ~ͭžnK͛ūVnwg,{:U:c2?E/IMZ459W1+UC0C=5 @~D٪P$6lA)$=BUS (۪=WW2Ιš6yS>Bzd@_+h9[+6F]w>}E>|gd|Y;䲪ĬGL@5 s`+L4:Eih3kM)35Skm_e ^;ZGr^^d]䟟E@F i n^jpprOzZu/.sH^u uF@G0`CYk3V*4%QF2i!; _k^m3OfGʖ Lfϛ!;~0O>QG"U {:}w$8jUlC[+՞#QGS)f3{F_ٝke_4|E}G4m12hB6߫O%֝A 1D[=@Bqls} 3u7Z/G DpiTSG\$XN$8+ΨG(|D  1P9;h\^|6*9'Ȱ^У<=*"% UB sGܾ77dȏV" Kr=(;.r4\8)ӲzxxDzf}8ѹt>oyq+G(d]o~U :|WπyLfxЪC #PLS9"݁ڷ(: 9ǚ^sz_ ۢ Vrnw>NK~RYd!)JYK%\XД)e4+.]ǫN륅rh<7z;/?cFS{ߙ}IL=$Ki$)Rg"IRѤxKi9ގ>/l^h~V/w:Eڐw#*}Ltmn80X%J qV͗O.k`; "L:@#AiO\Og!JHBv):CZ}@e04ˊvOiP.)ԸT~U ÅCmt Djj$?Gwz.kgMP494o6-y֚m_^5o2J̣$*+y$8BIhj[Pr DN90e_@H  \"/Ҡ!F}'7}W;9m Ca /@D_ vrD4oGزbTf{ێf9O ?yx2)) C`S ޅ]@@/Y`oIYXw֣Y^ThkTmj %d(eZ6mF5K U)R"S%Mi)Rֈ2'uI.ufEM-Zei6˪ڹָkuӊfjX%έbTͪv-uwlNuivw.둷;&RM]vq5wufwvv&hkl并(Եn+$vUr[$[Lɶ6*46MR*ZF*M33ZF٭*WW_o]Ɠj*BZR( ҍ#AQF*Vj1gUryiݵUη(6-˺$$TTcS5RdZbũ2) fZ u뭺x۵KZvZص2Mz]hv]u۹w & ;TxUDvT7L(wUɑ2'$˽}nUIД]KI ,L F>}VsJ*tQX N%19%GZ ƒ"BM6o};[ƶoŕHBi3)b 3EwnӺ*fim1*"ɫ%)uR@ǰh̥1@ VQPFTˆ"x,܆֦rד A賍֥0@ Dpکm @(\EIqڷh7ѱ}o(.f{r$Ve2tos<;$)R'90ah|\ʿM`7Qi?Z5;MܪilB`i[L_p- W_ƖX;=d"\T PQ~l?zҋ6@P&C;oOqu*[OK8=bqZjL"LW&/Q  Ǭ`NvZseX靤e&ڝ|hdŤgvU/SsRoWӊjw׌F*|v.ſ.G6}d> nLl$3X<7hM;Y5-/(*Tԓ1\ w. $hUWv3@L;h uA"O_*~ ύZ:X PۿV%A:P7u44w/0r,p 0.ZNߝ_۰r[կ[ޒWuSW.,sxIcs`ؐq KB"?i€Vxh`Nw2b9>xx ̊LkQkjV-f]u[# F`()JP&"b{@;˶0Z{]n*5Yf,4( CUE&ԐFQ0=7V(xPtHg ɜvD] 4 FG#w+үvl쪵(`COjRM("@CnO7 icأbK2ĩ$,|CDX©>LH&w{P̥P@^:U~4Ґ:[.DTadQnƓa}G5K A851Y\0K "3 0<Eq2@伩{87dD{\r=vz ea'%DO>"8=G?г2t0,֭wТ8ag0DP〲YǦVf]|Kl/ETl:Fէ}#&bUlKZ Px;6*H?=!d M3*=4WBkg掉kvdڞBAmWkFMɟjE%)Œj*ʬQХFy?/M6F P=CzИ,Ǐ+K[Myf'OI}ђyۤ e`0\˴jYUqBlT h\~f<.|93M8T? E<0gJI^RQRhC^G&~+=ivqnΐbpUbJ%nIYT4ϛp=?\ۋe?uAF crꨑzu$-CIC;H} '=@ȂjPCr8`3'4Q0,J„X NOBqsKAy[{5!{.NI1̆_`=@=*/;&wC[(mT>$dETj4C}7הzٝB[Boa G|Wtj5 ʗfPN2䜍kރqw?iBv:YK1+D)vh2Z=olHa>^,4t0f6dogâsYQE3hoK'gs ldAϳ{9jY{Rv֭ٗ1)q AaXטDᮉNMoWQe*T1 7v^] m:BԺ*ۡ=xv?vݰs"Hћ+G̈ޱewmkXhQfXRW|@1+gÏ}<ܖ_ElkiQG/vyq́gKE冤AM%pJsc^o? PHQ0Ee,̥l4uI<*xP!Ocq:{7&D=X}8_60/n<Uw|C dAi Nzb$15#*@qhnw^O{4`)8#ҁ=|쾭lRT$67]!&oO|HC `~g[JQJB)H)1.u-9D4 Z@Kj#j6#{콙!3ף\/0 LA>oh+Sکª&\]q51 LK'!)G^-[E\y =tC* !޲?ObɫPb?la7pڎ:ΧS*)#)`Nd ΰoL7=r]Hj (5j2q{}ݭOwVsdZayH CoK]'|B\LK1*TP,өp&Vo{xpU?qQd:Ue9~ ͘":MJѶ*;Kac^3HNeTHJsFzYى:5խwfqY7x"\l*  A;Bq74YoG%L;B,3 a(k $WU-\7./[kU hB%Q;*!3uV^/UYNе-E U;:E)~8z 'ҿĩ_`ؙ8g.,2[ g/_X #C:ſtē7%pokp6f p;̀;zjljZ`>t78+ l $tc}[ӎLst*yO^ˤ3׻x;[MC7JbU l;_+Öm:udvKG0mmlYpjJ.]շO[vE9_؛ .ˍhꑎ%ۉ'yƎIύf.3vtz1cBfhڻ\t^Tˇ<~/E/IN 8µ=ygs V$7`}{v6']m]{E"1u74t usw<BUT[˽mW^ DR~ag ӒzE܅Ҩ{%|'@2e㠞uRG'~ AeP 1|wQ`ы?hB+TEN)osf! jhWde_>wpH{6ӠOZ3vk+3 Rv WWv|,E D1~( )( JXcjrŃI.|{t@ !qk xL# m oS]5 1`3Ns"ގB{[=~I=!2"0:2_m"3kU_Y0uͽt(ЎtkG7!n‡ϭlf1Q!\:ѥ +7d|]vкeCIO䞫 ï%ulzފ8 a-ueϭw#E.D<@0cV $1!%bԭP 眿>x-C89Cu [cT/h[8B \ v"̽S8m)dBIҧ8xl@~lSnJ#XQ?J) #Qr@ 8o]DJBZ_ߪN}{{(]MD @+%|H0 DE ۵Gb+=~)_X3d^J`M Do2-$zˬ 2Z1c|XنPJpCJG<$6M&>"W| ]WhĒN>HS!dCUŀ3eC^%, mB%GL"dĄ ׸)qR01 k=<=_2)LRUMMt;OP sE *ZV8N͒IY̴d W*Xv9LOl7/p!@QI7uո(1`3-=r4Ei% lq s"`ٚsڀNhJՂ@NUs[U @2+s7ܞ*ŒM\LH5?j_16 o=b\Xͷni?`ܭju[= jɳp(cV<,.2VFLBvvΜOx $ F~o܍3vRD??/S IIP:ֱhJgщh2zgk%g::_3 G:C'Hu*gsQ qͿtpNKm];E%Jt%|51 miϫa)̽;+mB誘mE8}2(@HT P\B6ܶQKd 2I~, ~NSؚQ ̀j3fg.`Y%قGh%I],Qzn4!Tuz?C=?m'ln2NP7Y&}kmMٌ)C".7MM; 3S95գ?٧lQ7)|<>,KU={e֒/o+L}{Mb7Jq\ŰWT@ PB0בv%KO }>ބ3űe9^gʓ|泟/ž)3IX~lo9ꚈYYWOSƘ]Pan:RCik$ëa#$*!AG#g4yןت!ʏ |^mf5$o;-w .DWd&8t(ݴrwk)#PݬiOWglwn]?0%H DdDEi(u\rk!v$$;U9 #{)ZLaΧs1W9wȐRe! Ο15]cGnUڰyaX_a (ZZ) #&M3F`|z/{3G` ,&ͽ0O4aw8^ Y_輩v ^ᚪ?(AN!<Wyl\#S*&d5ެj-gC3C@pU8ẃ]U5GU\iaYBAwȉd͢P+i,'#nRqӳѩ$wam$ǫoK^a)`a?W;BEЏ+_ <鷽mh'1ZF{^6Ř^[.z|9y%sPP1ilеfV֢,Jr1t>pm?ɝOCڳ]Y^ +QOoo?!!NhaˣKO( 4NZb@4EI_G<޳QgOB~.#{wϭzkcBROvCtX6fKPH9KanCGG.]ټ6M1]PZN~z4N^#o*u{+D8u3$6YQSɟ_u:pWE4v{@ (å͠AM߮9m|t^v.l1nh[4ww1>ŠIEXx90SE3S ]c ;SAVUR-簖R?zqTPH}`cUmVM QXhl.^excj ]l *9Ť7HqkD _݌8DEt0μmj 6,TŠ|D\Izq >g< %]p&[F6Z c9)C0Kc)$B=?m׳\8XA$D_z\dl-Dª6U%,,{ 1oW^z;uNܝ-)HU8 \XHl$};n]sqsU`'Lf1h@ bS (Y4-}QZXVTG?;6[d.׼ 2!Sb[e寧"K|C ܠ8SYeJ2cXT ՋXKľ`k4.f8/k6jX"1۷n#8XxS9E* 8f?/%.گyҽ-c DK҈6fcoL)6P_,z^cȨ^A # RlSh 9;8+r, >jPCˁENPSL{Ynn8 Ujd1 XV 0+)_easU FtS}'Dg乛aM"R}fj|G:UQJdO 9(afϜ'^__2 ʔI;(Hd 0P@3r 0wQgB` ,Uxeffϡʘ{$ Vks2" '=AKs!9ꃴ`paH`ReC>av:h.N?{(U<t_ّNO|Gr_~T?}+(S" ȉ㿥"/v`x &MdG'd{V0÷O4'ъk0a Q+a:tv^ۉD{&O5fȰ](^]*.J([:曆 Ɲj5xDcAT!T y@Z ▬!!Ozy%6 ؈ć*[$^R( s3ʜCcAlk0 MnEAf:N$ 5&.:EycPhFp*@"H%6z\/x{ |Ul/-`#>1 2¢Eb-R\R!猪6*n 2ˮvyo7g?W*۹Ƿsgw171[3Z' UWgPuX oDDrdT߀6d~/ 48YAu4̣YGE(BvOA@`b|Lzo8עv1ӚJ,5m ΣǠ DJ|,IB 5ʙ`<KD'_@Z~ @2"?g$HMM hdYsag as4 %pO D Zei Q0Kʻ>NT k>8٩sJPiqD $/b>/_^0xpь}.pL$Ȇ:YlhV<#U#휢Qlz&\8A6L@@@z;Z۾4& N9Hqɉ ~ i8uO?7߾^v._m6ҢЃLj^ ئzl>.[=m@ Amq>Tо.0@b$T}%f4R^4FqfB{YßcXy+ZNuR?`$M+|mG`CuOuD0@m vLwH@ʆKN ][Ӿd"%2lݡ'h\B@X}CX-bL&ea2 &F2=˩v n/+A5.j/7õH­hmTaϠXFx'b]==$rrzA څH4ܟfއﵡLӬ^)6_?}4p34~3uRO3^'B~c7?\^}_V[O{!?ڨ}keHQu[ 3q]X͈/CJ=nmt_"PHRϳtP2?4SALi-7}x#]{ޓ'},ZKX4"AI% =MI-)fEnI3`lZZ:f Z&1EF brP o0w0^JtSWKb9Mr)PUzF|A BP  8Pc\}(֟׷P.YvHkʥn9DMuQTVXE(2P#1Uh[ ܠ,Q%s lj2`ZH 4"7ҏqwwu\Zgoq_RA6eV)(XZ֍K"E'vBKج~}1AhcV?4sX8g"$?gK }.-mzV̮5GCt3ɜTkܝ8c<ݡ{Ds~~ Y:#>grBJd$˯_5Ö[Ǣ; =EkUw{W;YE[Jfp$\Ԣ B'd}7l'6f#2eoG MDCU)iIA yC8+$jڔK `!?o,Rrx1?ӁrW@CH57@n!!`NǧWw;?glM8 }A'ԲfF X \,Rp?zD9_ֱk/.NVKx +An!37 _x/?R0ynE ʭ~/,;s$SŤ| 6Ms{fUKy~O>xյfkV7?V ׀l۽l'Y?(A51SBU(KMdؤ _0$|Q\.}S WeBep'Wew'UP!ߜ[,a%"f-&N!$6 ڻH"*wK(znO5 -+H[6̐(P|-P*G{V!? Rx?yӎolX.XNX>YeFh>f`UR1/ 3O3bGeSr8׎1ڇ `9ۧe8p P̂v7$'̣N Ikfv4a9ߜ4*h]c23c.6٘G$̴ f?#Gൾ]lnw~jE,{]"zlTr0E 0y^#f{g6øοE;Ylr4̦eU Z%u(~ W͵c^$+~ đ oJ-Jtw 8:/ߕra]I~epXܾe?jԐqogt{/_Y:fk= o9þ}|4 ?Lnߦ%Y=sA~pC:Λ\!,ǽ$YpW!, 2m|%=õ^Jr_#h-RjjPXpa1Ȧ l(;-FtmX;[p0]x7p::ӕx[ŀr,n gH+ST3Z@!/uC:}[ È 20xdEMzh!nc̆7Il{?O5e32Xƨq,W28i#h&a&JAcBkRJ*ڡRAX#Oc~ fF10] z=bm,VB3窧|U/8  wr7[7$rCy:B1SI)`ldo+;S2!PL[@LO]̠z(aX[6SeeY{B ,L=3N;>znOeO 1gviY8v-𹻸3Av"lIR anLJ].dt8|~uLEFC HȄ8`@p w&ߟ ڟ_c/y6P".V+d>:B{a z&+ꎁ rxfffo?IڌYwIg=}E{|\HzDr˻ 5H@vdXKX13_Ƌ>|&T3#-^@Asߵ$() ]?]L:)>>}KK5Z&[iR q"z<DR£"#)%DGmHX("gtw))(6X+(i6FQn2`C pdsY:ZC\6F""L;*):}4]Jy !&@8OTߥ$PdBxެM@]Dd/7pfo66lC b ! 7>J#k7t33G}?&ڌDn;4fړ媄}lO' U5=wkml1Z͟7Hĵ4M r*nj( :CyӰt^čOS( ЏHQ &fnTm64Bf<}kI1t֛,LUSAbA)B`TjYthLֶCݚBuURa ~S~97xmNr1L&MWqn4ڴ0ݩJJw4Lq JV>ZzV䰠:᭡+Q #Yl{HYDU7Ղ+r@Չ 6\nR ++'l#sҺ<v~܁cAEf:55Pܳp7ֽ9W ¶  [AN톪o2e&㔻=Ι,:1jU"Ѓ"Mu..=]5eu7/ݮ`rnx+2e<9o̢@)S8bۼlkdND!E- jb{2xzOP7D [/NMO. eD9YblXxm.8kM8\ao6p"JObRs;sK`Q7X޿Sp"&}\_χtqVĄv>9nrx)vpv?غ; I`h8 V%[j;tFns49MJⱨ0CPt*6gRRl?WQOl!qӤAe ᠈ciKѬ֜ ӝI:AMͺ ,KfK漤7S|Wvdئ8_8!˧ޱV<'sIBDՔb]-{_e? T Qչ^a(H9$ d*`k+Jy@ (] JaJe/su2Gzvڍ VOjDJ &"QJbr#6LƢɧ%Sanjʹ^ ֜'֚,mdseS)R)~>^mw: `GAsSTˆ'ccϏÎ&B /o\kh_T+G-y?E]K?C[ѐ~h&F@ڇXנ ?=:Qa[?I( ǭaS':7r^d?5dpxgTl%iHX^_p_o~i<4?6:]o35hY/0pZ9 br1#MAohfכxQZa HP6 r+a&HP8 r->Fܐ-pf0j! _'hձ[bZZMt%-'=R oĥ$U0 mm~ _o =Np~緱^VP7\d>czF>T~Ŵ?98_Efn ]q8Ww8|>KN]{@W41B_d(#~ʿ2QyAM2 3SfdI&s`؃de%$jl &3̫)p峀@0_ v' (e2-1YA \}KPM"( ft[O~:i'+\2''X} D9H}C&̧t 1ˏ\4#|߅=G+fϷt隸Ŋ=T*ahy":?n =¡EdK*kWDlLq/oc2E{[y ,*]0CY3]tj04Tf"W#/w\z^6an (^Jٓ@ت־ [%75#[ZT xGv*͛cfchۊzv}y%3رbkH~xD) lPmN7g 7aYßS)hiS**B鈤vP,LL`b.Dr;AɛrӮ\6h" y&62sE' ;,5e%{b{l= UsA͏Swk[o^CƆr֠0͖L9 `ȺhXm;6~Y:mq!"ɽTΰggR9|Rm{tYx%Mpf&Q`-c?0v 8#3wU*r73IX'/)>سϦǃHg'Pz3+`eV )woI+z=NQ-pZ+Uv3}8Xb~ش`gj7#TܯFX H` ];@-޶nt9e7&w٭2qx9?>=f17 1H\ř0Zqtf@C"vpyXN/}pz#F,Tx; 4KI|5إśâzkA3U돾n$p%tvj77m|/_2տ9%w4?S7 ,b8EGO%s.tpMbS e$!(yYᢺ ԵLg2~=̀l)]ECP!`j=*\d ߅!.x~"CmmVY韚}miw!'Fd[oUGHYlu11!iPׇk Tm Ɏ^yung7lJM;~-sݛṽΞT!  ؘe=! \1|%P9e ȑbbL% MͮOyξFW$JkÆk1(F>mGy.f{Pd"Azo!{B Z6Ecɨ_Y6m5z3Yl,@ɋX$rOmJ9֠6Yg?H8Ҵ-hzkT.{|YHr;CLD~/g0vǘޠ@?PㆀK˯7dAo58v~fZ,}U|{im^+r$]# wDGְ^?IՌ3'JLۛ6G.3m4y]ZHa0juN`ʨ! еוcnAMh5MQ D)|˄6e1[U%3,TF'R(ވ^F&ݳa5L-i(0k]x.>x5ܓ澳yܸ3#y:Ybޠ@-ףu .CCzK5-喒iC?"uOeY-_s63zJ@tֹ$׍)C|h?7O>b̌gD;uvHSd >M!P|"'bxzGDYtGutf koG_ˀi(?Q0T˵ymk!` ¬$kvbn]oM_%{_:#=?4K>?D Nm(-vR{o2Um}^w\'7<5\h=z0'2XZ瑝u4jJ$P)uqm &fr*%2煉~%ڝyz~wbnvX V0DK`z_*kzH@(CRO> -&ٺf' J" Šv2SXۈs|˹.]kH%miҡjB^b.UߟGM VMU1w~e&9g<2HYa©mG.zs'}WŚ0j>?η}fuD}qu=%? >Uquܠ MM-(#*'>_S把F$#OShZ՘ՇQ3 _zx>N|A)fC)y^-cHQgK鲰b q 0czT[DzuFA| %@Hӟ2ٌI1DѬKf4>f_'7@A[\$ !ȼٯtnZt; %( pgm)#ifh'cN6vN( Ihwf :B+8[˳zRJX}+5"T@Р4IO;OXZZ!{k Sō<ݍ`ɖ {ԢhڻyCo*YT?W8&"~D. 49j! ioH}l^% 1׫M*Mtv !]W]ge''8 )?Q)H>B8~T:z&}9URa՘ܒ4*!"*1,X5M7a& p0XU-'˥-Ν {z8c!Ub4=w9y/;D92ӍmmTґ23Έ ,V U ^-N_YxJNˇDy|__g>@2j>cYL敋[%娶 !L(/3Uhĝ_\5ɝFVbYS] BD1(?bMf LQ]pjyi&bgK51_|_ŞJX4Zz|(y| ihJp <_+ھEҒڒz?=RͫRo;n !ˌ3 zF2!ϭ|߹(3ʪ =4*ە,sӞ/ʻ3w.!&Bd!|X7sōsW9ɐpٺ݂N(svxNw~׭BLcfz'bC}RE`k{ΐ{$Eԟ3_F_ΠxܷF!n;WA8Jt9 0d MṈQd:waz$ 5GeCo1OT_Yj1S -x-9Ź\F+j4gQTΥ ~9RZ"12@%8|ADOgуnfDzsd GB)"'M$Խ[Q[(JnbS5,y/=OȌHz-)aYf IWO^/l ^Qί`ux{*S$Kt.,m$g!͟|- *-mRlw,_Ll#%@ۛF 2 0@̨'#_(;jmcb{SjƄDNE|\~Jv眿BنL(MSvCPL| 7~n)Ī$벇Sl+HV$n#oq}x{?,bU~J^qųC_.8|p2%v{]}V9=jgm4!4o~kz1Uƴs1o[ً tI11@ N$A}W7!] -xrQ?/u 2(?s{N?u`+Rsvן#i\?a?u2SHeTY@?jlG^>Jqp?ʿPg"sԙnWJH6*PsK3R$ !Bk{ Rg^=%9=gd8G99yIM$ZibVzLMpA'D`CBx6sbi p|1sf=pZLAҢh `dI 9X n^t )Um/Uƃ44}[(s/-F^gNO1$ ++U($GBow>w22c42z''Tkj7=T 2駗vwOF ?awW"^' Ep6pMЀ_iĎrHYnklh}D8ԛUyߝe"2%Auv =\>MuÉ;l8)>Gl^K;{u,RwUUvg, C%ۈ\%Ky.V<up(4#dҡ_&N}M;-))WRk2ϣ./SC?lu9|PlmQpSⳄkDxYaIqz S|iNg܁f/6or;OvkB$.§z-^h}~DA`9 #k8 ųmr+b.HmH;#ɘ晴*M )V6+yNqeD(s~Fn{x{Ɍ]+Mpe?߽Bi29EݖG ~傟+#ďl02e;UW,wȚp .lV,h^*8% t[c)LM"g20 ""ǿD""ʈQ8> zeO:)eCn% OkoWÓt#L r3+2Vmkbd,XDc&e/f`QB7e0{R0''r ?;'[qSr'\;ooT30T]_u>J{fk?{362`k1S,j$ðN뷋9Dm;6cwG'~nurHoCfs zS;Ѝ!>C,f5K7n:(f+Zs}f Uk dA2r; J\q$  .'*ULg }P`㗞A a\<(Bds#~iATaDV0y icfxMM^3*ͮѶ:1[Jz8 QX2AO$O`w%?3m(گ#ca!NǗ0Oh(uz2 .zs5 r7yOfrFh׹&FP&腧lImQQofWdH \v jXӼւwnS5VO\k< mo|KX>5H!~ఙx f4cP^SA3GcLsP5m# E:^hT׶HWx 6.IfxҔ3f@bNHrف8v,,~=a7w77@TRVO86퇤kÝQJA8f``ɋ7 !T=r *9\ڇK CuJ{pX=@\eai`L1ԥZ 9% Ll` UɧC ip7F}KX@ˁ~p)QGuX[7E?*gak-h4L՚]Q)bzɃz zj^;}Cj|;8ޗb?ʵh,~qF;8EA+ĵRk%.Kvif͋L [MnlxV;4dt䓥wQ/J 3Q1Cr _-A CuCr& @I ޵KɁay!=}e9} k)ь cl :" u޴Y=i~ 5n:{[L8r(厷 2=bGH5Kh63vFz*!|!0 żB] c `#oEv'Ls,T0E0GY|eβanhg! U~lqHq.ƹ`4Hjt\>Q AcsV1d pW{QpDl yمŦi Pdj/"!=dBߨPXkǔʍa!# 5Z [%O'V۠v' mƹX, g~f0c=3#M#&Mzt2FwXR%#ʈVF~d XQ5;طҎT,JUC܄4LBiGj > YL)hk55VGt+zil~EPgCd05,] ͫԑDmI9HGk=r]?휚_sXM4SUĬyc3[՜POB@/֧oǑlj7h8hAI !P15m܇qòrKj<橅M& g:}v}|ˇ ۘSrh=A:3&/:iȊFd M>~= <rrF A7FƇS RP+p .}DC6#T'Q \c5LkgPI+5FYrTuhB(KxӛkvHn†}j0!ŶOyi2B '& {T%^cëLd}:cp hǧoܻ>l43#._bZ[#Mهg JXtudޓn!vvaE=Mk+́!FbU!G! ]Lȍ؊mpĹ,1`U|6K=yh˅^t~&kOt o}\d:,Κl~M (GAL%_c+=^޷M V 80Eā >:a/ ~ZU* noóXPCu-kOF%SFlK]G͍zzd|[|HtQn5K@ӋOI5_4S(jld2m cYM 4Nnjf!]`z,Iy2&坹-"YG5i+5/$_=oVQOph^s9Jʲe5zV lYeqʺ?8@G?&1ӫ.sy[b}UL( ݮ_e?z3aւ$c,!(ΰ.>BKE̜4y?5Œe,8(Kfl|/}E%fxol;Zc#R-R=1휷`0f\ȂQXm]H/J%m̍\b=U]Hy =(Dp$IPMN2>[)a}c(4jqtRj̖zWHx VL aOr[ww[UE]~xJXaK'NO$SP^ n 7=CEa?ӾP1ޛO"opeNz ;j,H &'P@ ,+%zm gٲ[0IсrA#0^Y—x E噏wBX/\8sW˱߲c>R!>T>XO N@Bno=ԿeIf$]9:TQ%B9ӆ{#a8=){z04?-0asf{JdJ-1 5Ic;}[ vՏ|5 =hQ#y=n\EE!?pE5ys+XohS# 'NG'3oy~e{N>tjbٸ7ڹ*$O0~WoOiW)T{"7]הlzqun]UupB<Euםo @Wnژ%8\33ĝQ^؅6|"C7'eKSɽ{F}cè3FNѭj2Y@Sۅ5BVjmC9in J43c3'BB[=ەmzܝ.y^ +Xf']m0z7 BP0 3 Ɛ1Ӣ&׊lLp}^^(:FZz˙>fuz:r>ꎱ'܆3p}gó&'?V^_m7 u+ ƧˆPN>֜o  F_EY0"C3b.Uxm(x(,2dZlssKGr\5<2mzAц.YK0%a@rgj7kEϭT䇝ð6=gYV{eӈ&1Tՙ@|Q6uÍW\658p//hlap('7Qw{M,Bf 5T?5-;^QMkT?-MLQq#-Y\-kЮd7}4/062( yLsl=H͛_aDDbbGhF#nlBy,9y>!;(Krrbi~:(=O?3~Y\cB bYbڣa4ޮXfW`S >GŪ53A7ARv3f2@:ʃ) 3*ASg>Ժ< i Bc˱Qi9RÁO&#.Vgub"2 *eoev af-JɍxרּH[/{;sCμ# 9Bg\SA`\*eiQbӛ]l{Gg[yS)|IYWo:/6mkaG]mdn೬sNekwYH)!ZXꦙlWqQH$.@,`I7yXsl$ uuU矶xhH+D $ُ=nJFx{ؖe)Mw"i={ܽ}#Ө(}߲naq`BK`lWC?C**s _GAO>z$wAUOK]~S1BX# ʜ( I1}YWZTWIy,*P F(w T ag[OܬI3md ܡ߮3m[h}lEH٢DBNN$NT@(~5^Yw q&徭.TVE׃waT׍]/ 5 .>YBUjC89!&iͼ:?tq~/' {f bcjbȭŝ.p9\פ6 qɌR$P㖆YbݡuX$[̿jJ^Iz?&(Ug ? X6I`|a|1YH#OXw(ћA3 ` 4AH> IѶ (HYvlnu# Pm83\M_bcf|'!;.og j MKbO޾^eBQx(+8y Sũ }&{opNaGp{{omHڞ/c`G2 a!$g‘T#^*]$/]a $Zh4Tʨwk)dd%Z+x9_3r7FɹV0 )DruS;v7wR YqeL"G2d!Xjޠ?}Xgj/z)(!r7mjYJ~lCb`{!Ǟ2*2(W#y~oJA^fa,5$[4wrg(SHi~h`Vڨmj'ؿ9a,?UAn=ogXӅϚަٟw'NBRz6r`3:zus.۶}^?BnS*Nw FE(H(( wWe7%mXNAbhc`m8\CD Tn,UrZW v`z3YBT^qMeOj'KQF[HTXֿi\m"J"j ;~Xp:xӊ7?αAL1NnqF(+s"3_:?E!rb۔M}5\Ɉ_vk;!dE fVc:#[g]jX͐=S{4Ɔ; »-l^ѯZÉ% &Fl7P{?bDPh#Pk*/R5Of&eẗEXR.~怑p,^[;]+mZ]Q䗲s@m|ӟy^zrz~V}x󯟴Vݵ|Q9&Dv'Ԏ)Vl5m﮻!]9::5w&+EC-aZN̦chNo[bj҆=EK԰G_) gQ9=~nz>@hbo[ʏ!dou(ljd9,Qd$}pG!KM~zIq`"PBRH4ayg09{ؚ͗cl OZxZ(mdlqI]$>3aEх$M[ںC&aqU vd̄$ 8Թ ֜CfC):T$OFj2`Ҽz!K4uKӼB9^x햦,1'3fKvMjA:W9l`rw>m77B&lUS[k|xK8Hs0߂￳~`=։[?"bM Pcfl{yQÑ.:ADD*{xl6v{no]air8[*`wҤŷ7ɂA])kekg:Sk`8e~7gyy: ttK-owl`3zM~yF DLZU&̋e;%WefxR3v9Z2[F'Vy.!_r9{9їjϰ|hP/h۝pV5mufg,hLCrr"3rfc a-c5= 08Z%zfQ{:# jlGN\BQ͌JhW쯮ύ gSV;(dȒ]QA\sܟ>+B1\42EX`B^2R9n4u )#hPPMX]S~g- 3d + }O7c.N ww񼜐#l%y,J0w ;4x"#/Vp2jHl*']>v;b!3vrcnB;;o |#ITEywvKa-aɛzU;`v.iP#!EwV|{FƬ[[m Wj\ S1Y?nzlz)y2ÖڊV:Z:G cKHǬ O܏M_P)kU,fռk=[^O 8l,|ev1U3H}c6m[B;y]: gLaKr;z>KP  nk=Y'}E}^4Oô5O%s6s  4Wq2jn{&~泽lt5mpm7ow> ~o~nHQfFops{VgNlCb=ҡ_%}qMBt1ś(%}1 $w@Gki֪g=m *; oٰ4H=1_O/v+^rgboVrt3YRQեBF uY;X.`يF8y˰afs/vf{ =gz.)]'QV-O[#c3L`".OSTmgֵ_[:Ӛ,.M}qZUh.kqz*n lNN >dQ>U8S}! cP]]lvl<qna^2<gMa_c4ɌiϮG;[T9ԫ' =N ^)#sDgj5'XU`lA[,}X;ih EP2d\Eh;Y)8F"9>aK5BOnf t:8`S; ]|l>CVMHZRY$ӭu "=aor2/tl#lm׸mqm-s3P0NSGXH!,q5o3w :QК|Bf5'S ց+݇7=h-fl5ȣ TiX61 \ljՃYOOx\7CܕHm0lv]1Ԇ6V6D_`gW_:mśO URo~(/r+C0QbXЈM0$XRA@B (2n~)jMBDW@Iy[#hBZism2 `]aMj  mDV*(az4uz* quY[c$yWPې֖8VX=\n1p}YP&ߴe[:Ӭc45I˩Z]Y/n~^;rd}lzS;'g:|mj؍LmxS쭱ԫg6nK/V˷p{X7pJ#]6o'מO;?^Xֹ rcnM3S+|\~d`xy43"3ϻx1GQô9~IGeNX$E-=mbd;1阧R0@Y}[>N_Ᵹ g}N6fzl#8)aJJ bRh]ʓ|):}x~i϶}y C ׌hjfX]ԲBCwq~hx4<[( 6G _m_}H wf`6vfsϯuՍ}7*V6Xv$>"~Ihz_]21礁pkT""xু F;;U]viwӦfgdg!ڼp_7wUU<م#NrYd(o:tk-!OeUѽC VUNAS0R4՟z)-oԈGF=-ku~ ~ٲ| } UjȬ,Cv 7w_-Wrfgv'T1g^^=뺏T:ӑ71:uL)sΗ-a:f{k'^fSQ#^rXh?c.A<he-nʹϑI/KѮ91ƃGΚJh#;qkqesFejx:òxvS4*wMFh[?"ǡFf_oK> YA<Ƿ&ӵwwwZ46/|U#%Grx[':&֋gٝ ]"*f9.uderLKm{Fϭ/ji~~ӞAF !$<zr 쀰yÐ !9*8޹K4|3jA JY1`M8% tGDq] E?Vٸ6ҋ_`*0.@Ps^(FUҟ쇬9&q6TXڦi(ĄR C6&/qߢ߿# n1!m)Q[^S.&r~ |U77W䐺eTܙek:Zv]F?-5OKi,awOFf/_0>osu4b^c*!IQ?9 OK)>/;]F0)WR/fG NK9YmVdp)ws0&nGq;zP 2N+cV*F!߸LVZ 0OZX°l|&NΞlqaƻQXCF4aO|w@: F+`> 77PT^ @PGQg:1rCP(YWuu}?'֟*8,R^(Mnآ"x_޴b2H-7{vl=͟w4EtQ)jšuMbid׫Hjp<*:Mמ͑8(?J41]3FnՊ3MșӓF쌌hiBU lՖ;W2ˆzsJs77˕rZeilk}ƃMiiXCCGgZcc:p\Hl]bDx[Og& PѠ|9p+/Hu0m:6kӄV՜S!s+F*.ʆ/^8ߪc+_/Lm{;^ eRBy:wbȳF6}g3>ƣL'Wܜzdgv̯`k=m? W FF^:KIow1O[|@ZQ='׾ZTg^iE@e38Sw-z^XW^nHz ȩG4@#ʙ|EAh" &N}WՓ$CkH(C ]3^ oP-HEai蹆TIƗ W RkI׭oy8QIs~>6nlDGhFWA9G' B+q⎈W,*b!졨k$@n]A*ѴN b@PHHا~.90-<˝ }2{[3zlεde;S0ѴWDٻu"6f6GQ@ [!MZ(N IOi' :Wpۨ3 A(+ hOQgO7Q+: r~_O D*R(@%"(+ ?:Õ:_ {=;6AҤ B4a|p<O  ~^m\S >!(NWhC(=*o啤 B r&C:j'zP+}u /J_WP@u/Uwo aT&Q uI@i DfYA* .h.$ An!4]8D{^ͺ\L7weǘ^7㴔 &0BTPOa׆DM<#rv$CR0D,$A V N`:] Pq;uE.,t2 n9<@nC=O\ĭޢp0CӵNȜN8`l`H CΡj;.tI'4[65aSHgw 4 p1! DpR06WLi}h[K`^8J7C n8ZN),[V{xkP1!Z!>:Uq"v~ʹP);ooO-]?lXlpM`527tճ,QT":f~XDU٩PS(.{AhQ)%J)Z@mZ1~Z^MU{運un/ed /Ʈ \x* D >*KkSJыzֹE3b'rj<=S4 EHu,#; fNy'붬ljRP:nGI&g޸y?v,zYEIGש F}1{XA#Z8HYʸNW}b45;ix5!)`Ex8­@ FhZ]/jVJl#[K8NIuXkQI3n\YGƷoI뺂>@~{s2+{[Un~˘p{x۲4 ,A"ŋwI=Xn˽a1cБ]Z~H)ycv!1~AQݥ̄TIg3V+9,9t!꺼P@ )LRNs5c2r68>CnJ/^B kɬ,͗ch>7Y?t# jt$!(?aN86̇ăPA@V8{QY~w?y9ǯv2OwesOsu\)*Q]P0kſ=5G} - qihJt xH31 (H 7F!z(òM)j"eSR@)2㝐m eף/h0z a:[h{)15ҵj~vj)}l|v> VĖ~Ͳ#5vjZj|SVİ`Fwnq,N-!s敞{c>Aq[Sf-ރ:LWBU.t}m^ cUk68F-;[ɢOG<39ylN;*ў~FJkw:GZ2t#ƖOOBZKGrO=Bߴ\~˫(YO;+de?|Oqo-GsE+%slL3rݒyLq;{;q[@F9z;LLuu2ջ,i#5?RV5bŸ*SaFb4fd\Anvhm_A Nufz,,)V5U.eˮL TXsk- =?ާ!?M# ^$na(?.2S(-NFF7\r*'tl6c ?/d?? ǚr ʫvݖ3TM!q,"'$gmXFS'tftoG7Q{LϰPf V[gw=?2]FU5 7Fʠ4vbd(x1!<ۜo|/f{n|5F l09ahhsK!dEЊ̢oRcpM  3K¦- D˒Ȁ1j8͚}>;dL*&4kZ(66=ズ3ʾU gy3~TJJmXTnou6?+<**opPJH \X03/rHS3:n *_͗Go쀩rՇVX|OM &h%YJĂ&A|M pѓƎQģp^ W TED;ӴR: $!FNa~!t}Q֠}WLob@usWl~2W[^s(Cq\ʍp{Jjʖ?[wig%N/)Je%K!чᓼC)H61dѬxsv2v}.T v9%]¤YWvMlx,1 ]::-mXP%8@ׇE_2ƺ X4{64eg0f-K8T+ҳxSq6ɸ^m-WƴK$q)wΖzBĐ <2!t(* Ө 2 \8'7J4_zUzb\ '9oo?46,v4g΅G8p)o!++bORd27 ^(8%~/x+lWR)SevA9A7)s 3j'6%K[VR03$É]airYwm6P a!JU\ntxxu=w^s.:F&f4V/ϑAO8x:fX6bwIc/M4Q⮉FԶEk8:7i:`7gjD\ PskUWǍ2BsLuLYX[cWf^mQlҨr)iڕÏ>w/\cP#t6ASq245 tU9XAGc1EՖ;WŊw#ۮb`bBbq2)r\Z:0*a醢am1BC8n&pjPem&f*NPli;j;-G#s1s)Xjp+:e{&HBm1!nJ 6%r aN0auv][IX Sc j]w*T0y{vc]KD,@el#c#l8;5kVцDYn[C)P֔p hKoZ,9).cR_^ՠ'-Й(i+cӋq+ڈ mvf֩=)i ]dʪM{ o9qocJ؛D)T]+vS;5C\e(n,an5LmY2L4HLQvUUUBqB0m°Oq&f!=ۥm0mFuP*m&XB{yv.W/]yMr m;@qBCТ`)4W{ыѽ|o5ܷn:K  daV@3VDIV?G6h KH']/+ BO 7,nUJ`ɯ3Yͧ6fcB0Ơ* 3!a8qO=TS~q}4A\8ڦF!Ôfȉ6 Nj'==6 2.RX8U*qx{Rp eǪifH urbPJĐ"#p;UNε|NxhoD7&]i3Ș3Cʆx !3*@q3<^564TꄌʲVWɑ)L <+{e(tz']l3PN"5x0f996ƪ^TOE:G :^UˇQN(xne{{6h jjmOYsaMNk`xi} vpGmnޞͬ 5z'*Cq=+_3~ҿ `y&,QG+p(>b4F  {ʲ0`OA+|6kJ{Dlt۷䵰Na`qHCHP Sl>TID5 2hwL+ ;c]CzA!i a_! f`z[$R5#dhƺRZ GXjÒmu$ 6z^]XBNe#1/FA@AL?huA#$lPяš&43 {w޴Z`F]8_FߋLG݈G:284ŌOSq \Iq@aas[ nb1f |ά&`/m`X#n͌+GS;΂叧񩀠mFxw=O>*Wl~@>d7z]ƂP#)õ=og6nmJ]ڬn/o>`D@E3;V^,圦9$I]<="]LhIHtiCntAX:>B{aXs@r.N_]ikF=cm "T^bcj7Y4@@3kpqK;ڛ=lVDI~L%f@eSj3ۜ ,LU?cJiL$#HQ3ΥIq؟,W =S}6odl"lA;?E=faZ?Ydֽɿadx/s|_U6U[FӴԮDDC}e:3MNeNE|imrc"~3WW޵&Ð}7RĕsJPmZ3!/̀ E}sUT S_7WG6\`kZ־( *ciI3ѤIF2F>th@H6=j&SR2eHa-+T@AZ9ꎳq`:uVU݁osfL( )DčŲW4^.D/D/~43N&XrF T0bB]ߐPy u{Ql$ҴKo}}ފJѯR^Q1 4pB Lz;Nܭ&ѧam.ʘ(XUX'BTAWl3I$Ӏw,lFHks*#쉙U@ nleϟfM¢U"x)4-J%" PAS5ynuUw;[:;Oirlp ɪa֑|Jb AD Jbau_}g1@M޼MD M$4ʜ8!Ćps% ," C:[祎qL(NN(jd S}vMŽJ*Hɜ&t:i*RUE *]&㯈iYbrwTٸ$$f&tN׿:I(Yzp1$94zqق!3`HF׭rz}``!u5cN-@FFZgU}io&n,%uxnQh_Mc3ogd  ?wS-y,.uޣxU-PA A ׈p3b^EjeK&8dBZޣ1M:58tIo u#lJALl6x ps{t\.~WG~ HIl`=p98m Y@3kL"~nv3cǣ1 `b X{%= 0wyF\2&Ό ]͝fU 5ZZdE=4Ma7eOz[XQ@l܀?cZM gy}#kwo ČF/sH_?[< t-gǪH]M0㧋ţ5Çv FX?摂SMkKjzti|7d5v .3(l: Q**pWe8 mYX8p rWϊq@f Ƌ ms5:_^v7Mϲ{}ۣuW5!54_Q qڔQGo&?sӃʴu]{X򫶭rCk;[h[e{|o&9aG=T߼?_RXn,7Wd,SK&15{iYtjoR8԰4yZ-)p:axGbHAQ~w<0J/Zbwz78ڊ=& 6o&&EFU I1 P)ͲdC;( G#bKKJÿR_(Eօa+bcQaǼ7Iƞm9^ 4Ewt h0lMkƵ{tٳLMim6nV&馷9=z8д {gύ ucM\e,--l[X+m;OA,N9xӋ~=@b>o}EE6" ^Q4~yfgLՆ4o4&i\&f&Wyc&vF.dϔCs*̴DRCJv$*EF|{ڪUu6Ѭ:VjY$ 4m#"3MGL eXX.YHz^U=̱LY|^/MCf!~d [@@ "-WrN1ǹϿ+0ǹ90: _{&H'.O:_"b\%[6}LA7P)@RlNq/3ۈ}^MhWCɰ<iNJskl&RB\-#&GUUwS|Z~=ѲAB">|1Կ_Pz +~#'m..:)Dx X:$RM)$A?ŮN4"ȅ däHa dlMO5M.ʶ(DX"\fgI$b$KggpwK f瀩V]ecom: y-~2o qD$›62^0)qmr 7Ow6fڀ, f`}>Wn@!L,R]Ln[>.}oרν8ݦm[c~V`KFVR:8]]7na2\dB5ḫ5N> {v5KP1*,D JXjz3QGype7XY?)Eȁ.vqA+j d환ѝ'g]YJ}Vefrje1ᎇ/54E )_+բ>^ }:L  '-qn@˫mn>B$Bs\頯 쨫y/K?dQpVN] 'f߇&9oذrH9s9 8N!T $`6v1?3/s77W7#vTCyFˇsoˌTUNkNMJYޖIc#Ke'"F˵!yk 3v'wAHZ}Tx*#wK47eA_GM!Ud_>qb}$znAkBsfrlbR)xNUvۃ#5AU`x&5u ~zr?cvಟ͋ac/b3a2ms !Zc wOSM5ef&gF# wzlSRƫw{U}*VHc珬0髁^pؔuɬ͠5/ijʟivusЀF\b[V_lZ Į ,~7>}U}moY-S[;:܃åvOolz=9i_~r *?ir[G#7f%jy?vnT&o66*6)P.o+xqjTQk VemwΈLvY=ʽ7~iGO ϬH=UyNy15yCkxa/W7e헪dC쳶\6 `J < y]?x9dW\9x,zl.:U'*R!H%x($!,³Wt7-g뷡Odb>( .z.g붘͒ ` 4DFOY6P)*O28`*_iZOS*TWEGhMwL6(8,0RqG ~62Wfښo.PVTKA >oFL Hu9Jei6&<[qq,.>vb^$uOE<%:z]Ȃaژt" l-ǧnMp2+k?Nr໺;>&҇䵁H1;9jPjDGQdwUkl/Edb u {/5UQ{#WF@erYG>T2޳c>W+LGҟz0f7/۶%%)^JͶ,.S#ЇE5r~+~fixxfj -8T`D*s͊l/}^oY|\^ngv$y1v3:v{xN}kUB]{g2}h2}O?/㘽2LdG}..E>5Mk[xm (%Ru/z.Ye`xтD*Ҽ -ayqeԾXs';hz'~\ܫL'eˍY\ot>Yѣc5sW}:?WlS 69878$HADnЎz^N/:l>DVNq?#wOcS͞%lǭ:-to}kpÅ0(=Nv7$E.έ.Gz.F4PDAB {mkQ_2߮* 5͕zƺ}zhH P BzTs6nLyC!ӹ?Go?a7""2hp$n:2* [v]MuuVRA-Es>iU4Im80j1MDvE{T=6@TSc5"=?L.HH2D++6 xC*s ԑG5⦪EI"N.Z+Ǒ+ʍ*6,-RDǝ̺A2us.ֶ8^-ۮ1pK0Q9*'D'{e7ηF5x#0 zPpr9` g'v""ƩLκ-zv̦w\ UR@q~_=%xv@C wA@845#u %)a~-/̖2% F`r, 't?>iTGi3/dD=\3vFT* @JКE_Vm2 q /[32((DıP0).)Ch4A ϜFobr`U 2o/NWd>̄FFN2ԒړB?n`B@0D@DΣUgH=3W_;n'J>: DeAѸl6}CG8s45B @{8}Gt@ûxVDlП腀`(U}MݏbkV:c=W+NhC(uZסs˜4{X:WTe=V\j&p۵p/J3~!EksY6Vb9u^ V&^ ~uR:FgH0VШ=`0Dh8DIG'R!4[ ᘋ H{lF/vT]c5bTw靦AP [9+eZb"i>_[y 6^q4tvsH20`LıOo3Dt%Tcjq 2k7-MF43D{"" 0CG3h#|d Dj44yGmnUmiO`/! >ˢ-BeT i`hEi!'@~٪ ,TwlZ۝yfqG~f]3N$7mv_#;Voiz<5kzޫ61c5OS4:$Y@elB{??MӜVq~c2k|Fay :c?fy _ﻺ\?ϲ{9 l>(&gr20h )DC "|8o>2ǰ~_[9pA!(FSt399>ӮJ's~_$29.Gw p*{%W rGʍ69p?_)(cWPpGu콼J<7;|{n ,=K=QqW˸!J.w̥<ٶ@Evz~?_aH"+=]WJG_ϭ4bcOղghrzm,BIِ" :ZYY&4zSosgu$ʈ auR胲; H]kbJ0#2Cxn&_󰡌N;QǡC)J_~8=iXk ˮ+|l(rjTj30fYV=j{K?1Ӥ@XY=y|tO1/VXA2P ِtu?Sx -wJe@ۙ! w+ίBJs0^ d^K,ad CADTOܑw FfL5/3`ȁWF LD ~0c0ֶIpBEsa2X60h~/hֻwv"SK@ޥEݹ p`!wkn֕NQl$'Z<$d~&O (8" y@Jc,Co3}qmWvCf)h.5I1r:Ktbۏ#)Le.d?CXU PfO| h1_tETMjR*# ۞G(7op4 oD6,G(#7Lw$,ÌsϺt'[C{p'TsQrcƑٚ^zT 5֪:M.f4zVwnb u{mzp3_qj WJ4@Z­P#O4™`lƲ28Ǒ :ȳLHۋ&doPblfrUtV*ͩd'#[B#gA fb]7.9ϑDwGP3\^ g ^еo>D:9/50KL7&N:g#`o*[s7d)HtL| q]p.-l Ȋ;A/H4яvG ݵJbܫZ=ˆ\#m/(z1=Pwܢ4o7 n}U$-1t^鐠PO^`&% d!?ۋeDJ}ZúTߗ (ӻNyrsf.ϬE9 g|5̕WٶE`.mvC- k|RgVi@5mAw~췛v$KսHڌ/ҕ;LO,Q2I jcEk;+71 lP[Z}Qv2G3G"N km,,2]@)b>":kؕRq`s%xA7# pFJXEoBMN~`AŘ]$>aR#-c9;  \O6w6Cq4SNrk{ss"; *UL.!;JumӂO[r# tRˁ9J?س )frJ?*)>#15v 28ħ` M3}Do4vscMoC,eމK+u]oPIS6 Saۭl : C5TK `9Drە/FIZWܗym*;!wO|hBHz!'Oe+QIoVnhZK!x% `yqiUJn_01-9a0 ,;i/^,I#0(cx' ZIv9+J,2KN6;3SsI&,.yCzӷVI@VxQM M>2ԂN{hnh ~B)o%4Ƒx꽁kYuF!?3tKΝN#̦WX1bZ:WY=ޥ0xqkWLȰR݊Y1U1'ZE 嗾vQl.N:Pa[⎸99cRkC Mrpr"&W ZOT#Wђ:QD{EKE)G{ ~n(!*UZc.CXmIUt_7UG1'$b~*.nax'Z]aN3<~c5yoգBXI+ f4kl؅zNEȖoY+jZёT6؄,/[y?<^\\EHyg/%pM1?JACr46 /PhvIh$'¤vSX%O{N۱+qfiQ)gWĝ?M-JHu3L^wZM Rԙj%'FOM+M^_sapsҏ|/:,|ߑBs 7;#aiv<3蕐F8,*3R8=b+<wuWùN0 fjɱymun@pq=oe稇ZZpR8V r,zw qG3YB6 ssш4yJ Q:-ܵsuԵNwSٵ)){4 +a9M؝D/PQqn|h5Vb>dWtŅ7)nr/٦2jˎ.sNd׋q9E5/]!үE;TEZ[eyܤڇi@ɉeXV-by儨9FlclȈV]m)^9<8B/" .`--yG*^#ɵ1PFghJGv)7qqW 6 qX2Tj + #yu' ,PEoKY[|صpk<A':}G,'kRbWrT+hp҃r9}6mN;R!ms}N-p>E.>jOU*{?9Y&M{Zu8(GzZTť90GR>2JMI*1'ѯvۇfrLsZ<:AcH81r6ͺnՒ+@ wгqǺ$m'o`Jnrx1CqƏCer'J_İ4ƥw^jGµe*biFƑϺ[!L;;ٓ{e:L@.&r3$Ool@be1#\AznpGӆq<[ļt)P.y֢A\; c?(~7脺8v~K xMѡ[Ps[3ws`g 7,iϫD9-$BKv7Ru!Aݥ*|D=ybq-Aˡ H<@7w6²6rߔa-^9G;ox`vt{6+p;g.ӸW1]] 3Վ]Pf>K {V<˱ ~;d3]ޥpWpS!–O蛿`K~,W3]mxnI*˛P;*ՙ G9RsbЭ0 "_ w퓴 ՝hf9Vcx;OD+ eFGzxDUshм[Ip92-E|O۟T` 9B7YT1a`;U乑4irڼcq\\ „e{ʛDiwџ&o$F[*=4 *ߙI7ĭ`R bJevnvyvz`eB<~5DHet&fks %P]7eD| Y1jP.[^}R kۖXUc6 Dȡr͵D *`Rż6ٯy~^ &;qK޷ۧt'|ȅ|!>/Pq sWS:(toy? d*?ct ؽYrfkivy@7(IKp\=rHDwz~^{P&Fdvt|}" cz4euhJTA6):b떞(ah)%Rd9|l*qh̖XiFpғǵ MsL*4?.2ubMES5gDQe0<6,Nj۵X4[h8Ϲb%p<F͐K0Korʵ vX33Q/,t|ꔧs94t [U1+ ,e݁W[b9MS+N@q ;+XgVM7꩙њS?P 2Sfoehfd@'/JE_/ۚG`Vpx*wSUWʔttx*v ~l1qf_pc[zgZ+ħENj!-kٙuS7^ w!,za+D\%ǘ{cmVH f_r5 w| W&N%K<`(57ߙT 1Ol_S%/#b%N+ޅԾgU<2gl=yi(hNRb*q D\$?uyu22`M%z銘qjk &2/Si.:Ihpؼh7B6=^ڍHg"2 ;\PTgX Xhl(IH,"T~4a0 DN/4[yKD-RWEt6n@%9.ܪqvQ*f,vi?-8%T-n5[S_VKVLu7'rN TߢijZ8}Y>Ay1עSHĴؤ,/CЬ\FR\"yו)|fg0֔Ls̫\Z,״0u\u4*}"d0|.@pr2c ^)94~||ϼ3'^QZ~#hx4ڭ6^I[ԋ\'CsOeg24_>MӲNy`H: ^:16肳LUv]ž"5Éc `e(ۍO- 5}h[iucU v9)YX;IY1r%+F{,Չ,,I\S tQI@ ~`6b|M"Y(QG=CP}OpU8Jc:w}]Д=o92;uѫH’G^G;Aox%2լ'ط N0DvFdpjYkYs' X :F(p1Ik88:,%Z"h|;-&*t ϯ~!ymb64C!/S9DwwOP@ -ƯN ߲ -"x>/- oX֚6c8X :{Tfa\Jsox{sGV㸒nq|o glcAtHiTVjK\pH:74}6zBRL֫xt>e]`"a5 ܅X0*I`~3MYR6SJV0)=x^THƋzVRY Fla\ ;* 20z'B52=䎞;HnG)U@{(JEMܐehDgg@56+ (f!w\ ɶOp(>Ngc8RF`&vm&|أueaYo]%(L/Z?n}8gu]+91)2L%ţk}َůw 4{^ĒH5QB_HjHq۹IJeMo}OԔk$|Vʢ85AGcV@Ƿ:6:0[}amפT)UeBK-^-$ss-8ɵ‹}KZF\Fjs9VO)蠃vE{Gռ<Ȥr%Ha}$151 vwUR˜y=,+®„}M6 ʀ3[@ǛrݿP[:II7~'lwhɏE!"Q[s9> ߲X pW촐n T`-J$VUh}sՌ5<{߾+ђ`JZw *fݼL%93 =82(ϨM.o -- . 8'%^Z<{ ű}jMBgR}\Y04ҤN4Vjx@^~ 7xG[c̕!d}1d0 "&I7A_VY+2qhWNh ֋,E+5 OpA+rMIĵO)*{m4o-;u~➖!v=;4if D~GwlbG |M`B^Y`_Xޥ8GX-ٟJ{Qۛ y@oh[IPHJq49xD/YLJe^BmO7r'}@ݨW QءޫbJ0{4_ MW#Y} NKVK4 h5YsBsVDz%NJ6^Gi~nY؟˶_hjlG!rDZ}S |Pr홙WXO+*?x ȨRh}+PȥT NvI,=e҉&XUBBU/StuKdiQ08π3J. f-F)<;LX8&MM.>f_X@Q`YN`YL[Rly`W"ƪb艼b:mf_RR"am]Za<5n&:,#VXT̿6'[+1Qn@bp[J K51 "Xx}b{R x= Y]# mnbjdL5~4?|zS3|!`j)Ks7znfuxt¸ YZ