slurm-rest-debuginfo-20.02.6-lp152.2.3.1 4>$  Ap_B/=„DE?ۋcus+a`R@zd?NƝn`I^ b ʓ=Ʌ u2Z$7%q^Y2Ϡl$Timv6SrGk<<<ԋZ8~K7.AJ9l:ޛJ0 ڧzOAgh*<=(?T%WcҤrQVC ||QgzQTw*rEӐG]q P{E1up*964158aad7e6523a9d3f7d51d20e05992d3f2a8195ab316646463f57afa2d1b9e35eb0a084543da592ee089dd87469f7dfdf7e1d0_B/=„wE$p}MXg8ų:A3ƏiM 91qrXQ]9%gBSI϶BW`#џWT9HxVN(e {*rԳ۫xRj@Pѯ+?wfv!ag3ߘS$I7q;Z>0Q Y롮 /D&LyN9ܼ7*=Z .E~zkaNzp7s :RYGmɻ{J,D Ad.>p@&?&t ) R'0T m    L 8\|S(8c9c:`cF!YG!lH!I!X!Y!\"]"4^"b#Nc#d$e$f$l$u$v$w%x%y%z%%%&&$&(&.&pslurm-rest-debuginfo20.02.6lp152.2.3.1Debug information for package slurm-restThis package provides debug information for package slurm-rest. Debug information is useful when developing applications that use this package or when debugging this package._lamb73)0openSUSE Leap 15.2openSUSESUSE-GPL-2.0-with-openssl-exceptionhttp://bugs.opensuse.orgDevelopment/Debughttps://www.schedmd.comlinuxx86_64"Q)0AAAAA큤________ffc26ae2af474603b1865b8f2cacdb4850bd94ffd110529671b7e3e2a0ecbcac../../../../../usr/sbin/slurmrestd../../../../../usr/lib/debug/usr/sbin/slurmrestd-20.02.6-lp152.2.3.1.x86_64.debugrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootslurm-20.02.6-lp152.2.3.1.src.rpmdebuginfo(build-id)slurm-rest-debuginfoslurm-rest-debuginfo(x86-64)    rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)slurm-debuginfo(x86-64)3.0.4-14.6.0-14.0-15.2-120.02.6-lp152.2.3.14.14.1_ __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@TVTVAna Guerrero Lopez Ana Guerrero Lopez Egbert Eich Egbert Eich Christian Goll Egbert Eich Christian Goll Egbert Eich Christian Goll Egbert Eich Kasimir _ Christian Goll Egbert Eich Egbert Eich Egbert Eich Christian Goll Christian Goll Egbert Eich Egbert Eich Dominique Leuenberger Christian Goll Egbert Eich Egbert Eich Egbert Eich Egbert Eich Christian Goll Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Christian Goll Christian Goll Egbert Eich Egbert Eich Egbert Eich Egbert Eich Egbert Eich Christian Goll eich@suse.comeich@suse.comeich@suse.comcgoll@suse.comcgoll@suse.comChristian Goll eich@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- 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- 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 supportlamb73 16062579232171c87de5dd7ee9d242468c481163044032c7cd20.02.6-lp152.2.3.120.02.6-lp152.2.3.1debug.build-id2171c87de5dd7ee9d242468c481163044032c7cd71c87de5dd7ee9d242468c481163044032c7cd.debugusrsbinslurmrestd-20.02.6-lp152.2.3.1.x86_64.debug/usr/lib//usr/lib/debug//usr/lib/debug/.build-id//usr/lib/debug/.build-id/21//usr/lib/debug/usr//usr/lib/debug/usr/sbin/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.opensuse.org/openSUSE:Maintenance:15121/openSUSE_Leap_15.2_Update/04dbde8425861376d6a7f791baf4913e-slurm.openSUSE_Leap_15.2_Updatecpioxz5x86_64-suse-linuxdirectoryELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter *empty*, BuildID[sha1]=2171c87de5dd7ee9d242468c481163044032c7cd, for GNU/Linux 3.2.0, with debug_info, not strippedP|Gm{gBslurm-debugsource(x86-64)20.02.6-lp152.2.3.1utf-8aef818959c2c71efabe07d5f07832825952e39ca551f4262ae391d37b81d8f8b?7zXZ !t/] crt:bLL V;" PqB|=ik% g^}Z}.#^>eʭN(Z=R?˖[@;Q-Y?Z&!R8O4*~{rJ@4A9`m5o9PVUmr)s7Vep7 zn~M-Pk',.붌llxa__9n`C פ`!QN*k+zOw6aVŴ2:C( T42pj3?p&(_ӿB,롓o_uuY\%^IշIgzUMqvåO ߯F1 sҟ "   u{m%L2z%e!q ֤L+[YV~v';@fĆ,ѶM;wdnjL1W>@b}r'qį 5۟7;i#JjF]đmP1|=3S6){Nb*XΒ&ꠚZe !>7AFT}0]37(XPˁR6[} p.QOEDa&&`EL8Wfpv8ޖJG<|J~tS 6SzZOQ*>(L2eYJ:*"fOwH{8Lp@U!1AZ3OTc׭*m)~*_JMTC^|~p?)6%@["SAzWyqZ^dej[ŐdV|/vD[:,aqLa:x !6Vzr"p:w U|q(3hx+ePxلR+蟑uڬB34XƼY2z.ǔN̯ROiE|fےǡ["?8͟- npӊ\ ~gKqxhU觺u:拏Ab< 7N+:vAG?G_f4WGtOC (|JYalQgID|s:rgiG$pQH=g ^m"?gV/EOrM%!n¸%YbS/.X9 fAq[l)+;6[>32S'm #6<*8bE@Qa}I'9.m3ⷂ偡)M݁b+VIQ Ʒ@O/NQb! kQ+>g+zTyD8`9E{~b<8zLFwyMEH)$6 h®wyA:`M s62LH):x. `9rLpLY iF݅wΕ")/eY}" gGVaƦV;}.?r)0/u ݸ2,tnٚT>6]s} 鏷LFamg4q;!%eIP32OZ:O}Vq2-c\挂 ` Sz0y%&햺Bøˁ;gȜxlMQڑXnR(3¿=?u{z?^̀Bz4)O@wZ~.酴tFx3 Pl=Ύ{6v/ w&]`Qxs$6)Zw KAmQ ؅] ЁÞ U2e=|9/1mk]Ϻ[*0(ܭJouy481܋pkmr ;B$g89Hz7Wg\rrR|EK`j*Zs{@vDxyM>⚍]>A",kz}|k#M'[2I-}w R7CWuJP! (sS -NQ!J'(',ճ14;Z[rgl#g978tRWrrD|n5hA|;(bhM.R@|* n[rk lw+]q.>~x׆^#<[T|P*^# 5 eiƤΘ*M`D^Gӥ #քc_2+C6%{!svNvtȼl ~5*cKk`$qd Vd1Ej4oRY3PcbO NX.5r] ~Va,k}y6xHN2QW6!XqLm8*s}t'̬] ,yKE5b{F\e *mn򐧝*GnrY sNCPLAovŦvsT5]7w4kqgpXVFOHLj;@VσٕKsly#||TsCP'tunTmvV?)8 ҳKv#Z䕫|#w$t¸K eYSpbGyUefdɳSZﶦm̺4oγ++!Fz-YE}\4bY^+!WF,Fe (o./?2]3|vtk dP-+i 6X\J Xe)-#MM(gBUT@T ӏꌹ(CȟپۉOᄏ&Yv^;ZėL#ĎT }#p&aR0)sv]mŋ:9ѡGpMI諨Gx,"%":.Ve UpKu^ab_ pm 2 nqW%,L/qp|Pj.n(6յn79jJzE4}|U WIty@ҼԧLOK/|D pڧG;ݗ:TvoBOLsz,iy88WN:qQ~A>QOd"л|%!;W D42 Hz_3BK} qFne[/ sd ; a:b=u@x' A7| TҕFq=gj>A,r't zo@5 $ O[V#ѯ*1`xH *yU#&ϼC]?|si&mz5k1ZWd7WxwV. af)=ִ 4Q>] ><@Dcy+iվ@#"J#rSFI;Az)J2l }py5 >v~CAQ7/+; isu؏Mk';0(QOF9"ekA!Y#N3P?e8Qf3(N;㘤 n>nBoXӅk<|5.98pS`(ZClJ=1js#Ր(ZwMk=m֨UtI* [D?SIiIN[Xft+H?X+Ato;Yv]nhԿ_@5%n/ Њ𖟋2, _ea3)츦FCQ\߮7/㹪R6jAXKtWw"&{,XZJ_a$)hҕYƘ+A{)wHnJ/~ ˣRNI񲂾J+:=x06% վvUQ%9u0ȒT$2a.֣]hWR^f4wh^4w:pʥjj[mEHQצlqQzU9dgHofac$)J(m85/ks 6T`Y J2i>@i=sob ~% ErƢp HB hZ/yfF;/5@>Lm]MGgbv:gsǻey >;qc$9Y"xņ{5zPW ϔ҆7 igUdx6Cvx.%@&# ziS-2Jޥ4F/=Z;CIU ku茛:.G!1g4!a%>}V EHFvסhGo45!BG` dW}6KĜӀXg[>Zalo4^(!LYaWlKL\畼=L}FZjzRo`%p閑ʚbR|Gx ~CvEL[{m5s.3BX,$^gWZ!瀮R2х' myyD"*pyQEo:v؆Hhԓ:%hN̜MJ!^mi =o@ kM`u2mzE)kپcc%&x>:-[w,e3RbX?=۰E$j- [D=sbdY|2f1?h-P&pN> HF&9jB&|;~U-s{ {9w)vl+;tIS$;Lyw E]y6[_>: F.1[Պa6 j Y~Ϋn!=a|\]!ɯ 5b߷LY;SKE?p݈B,8,Dn.jl1nGڳIe7rtXmI>?ȍ?ltյq\ " 4g)a{z8\;3@KXncmR,܈*&r vU`C'YfdEP|0lڮI\|uVԐ;v+֫Ӳ7ٞ&@S5ῩuGvz`,(&1db`dT@X.b+F5 q.0SjX-Y)["ːQ$P'"xDkx@bwl,a`fwA Qh-pA&BuߞP TЗ HɊF%f O.;f滊^4)Оv(־6tKAo]Q^I|t~=J _CCژNa ,@rwr:gh7+bC^jBN:NpkQX-\HәpV inADOH4?,>Ū<2,pxukkJMx<=I8Fy H@@#Q~gtE*;/]grݞ0xH"F_]QZuԚ}rr`;4(*MX:ʺHΕ4CR Lgs`58Qeۊ nc{z&Ͱ\/zT,A8[l\HɮP$N{88+* f:Gޛ-&>:\W/ CIRɰ /r8ln}mn !y\fwٶ0vF^M!^ZNw@~҄Gt )sۛ|E D)xmPyy&PÓlطr >v} w.+/Psvhv{yK&imЋ+8뤠HZBb6XPAݦ#]|B霱1̓`_kl2Ήlc2s73^5M*6}u='Ot.̫;0l1YCh2q1L3A39g-ɨ36')T 6ONFL 7 L^'[X=z"T0oq:zn 2L8qo|\?%=[" i1.Ƿ;!A^ֳ;ӂ%GR?¯hH KyXR7|#ASNs*ah2# 7%_|x"M#it#JLXԦeM4( yc%p[n(HN"$m5^O/t[lttz?Q˼݀ LODF kq||&8Ѧ{L@ QŸ]^10RO،c 6*DL@g KCJ:hGGҞXV -|*}jɚc:6ɹ]h))ҢՍ(2LJKVtw\HP)x%g͐*RR#UME8+xu2B#1.L+;cW$DPőx&O?bHBOsjk.ŧKqMW|{C*c3t_ ׍.[Nt>_UAȈ7y3h݈{r:(Dcqq%Əog/R+%*scH];r-ʆG趠$A. '.V^ Rm 6fq#ݍjLGs"cW' XX5&p*ځ\!ja('?n'4*4^3z*\/epd+;@A-|h:џDd49I{DQ*8JB.C.QrX\MǑ%??#S\_Y䡍YA6A-ңD$-p忇hmf0ؿ=.'q>+#FkYr}U/i30uFI/Pm5WxrȒ% !ʖ7ë%i_[7R-c~_Vɯ,"%@zR1R("HiN9bD'5kZ@ ki;K㡱8=<򹊲D;rezE%fwmd :8A> &2mC[HZnŁGYs0C놟դЁ8w- W;b؅r!+ DIߏ2Sf^Z(׻Lus.!B8Ìm" krċ"LJqg#R$>2[/D\3`n"UU o0Ǭ-byh߱$bEs $B  9>MtխcٛKNEʫ{-"4/XP>$2a*/_c5 EsMnK4m1V&ƾ&So$cq]E.k08u/]vKH[R:%zSR,5d lMqnxw@Wbf@+uA@*`11Crb5'.Dx5pL BTtHF֨@4-_}ҌM5LQzs5hlVǼgEgV앗tQw2Q|B^F0סVEß<7s+ UCgSWQ[Z?y)kcՀNSPW$a;>"#Hj0fy X47dh Ts3T:*f[Gj'u95 sTn"}U%MUـ0@}w +:s=Ya #\SyT-V/ lլ+/dlQȸx5;evM 3]Y@,fFOh̓1h)`t:8U 28u,,6B fja;h<2E_Sni(/a@MwIoMW~h]zγgoMTwxAw )S^~R*nȈEUsvwBaN= MX嶗J|@0s-Ė~?den~yh=Y 9G#g%„G4(D)z[+҉ra!3'yMR^8[P/k9` ǥmh .|v az\̢)R 㝁7Azӹ' ٣k?djSV3plgoW[Ϟ 8;ݹ f& /kc6,5~CT5tL I%V s]Gaq*wK'Csb<CUߛ p h4h,f!脭Z~VLz| @G] } \v]|&: H/?nf#魰n_Ø]^xFM+Hhoq.$n?XVtLPM<v4ZGP9=<(45+JӗW|m;ͱya-J8pv!ҶXgP%$2-VkH`Fi[+=e#V-v!q^}ӌ9BhNgQ0.SמZͅsK[„)=}zv9T9UC[bnVJ\ i8B1c ASM*1'O@]3EfjF޾O_\FS_IM?6ܮ dW ë9RU.y{S/Dl*Lru}/wMa63/ƦE u{9?AB: t31$8:O]GDpF(lp/]=ՉBb/TcN5^]D@zIiX:(P^L0 oTZKݎdP1s' E # Ǒ4UOt ;i&Jӷ~g llmY" 6;2͵"DN-be6I0R/>)OJIaC0PmBJݙ2BYS/ $l*tA=^iQv͒vSa/<(| k{$E|zm/Ɯ=l l-C: sJ:S񻖌g$#_! q Br5_lӄt wS}3/Vmsn!,tT'Ecx/6Tw8@^MI iʱ `qZrq~N:o37H:~j>>r^CA*'iUFky b1e*S19'ȸ{ܥI5[|n#^(>ո#Gn  iLZX~&@KO*,Rf23#9XC%9]&Q"t%uB' dc.I%3}?a5DBsTcHv]O&'USa77!IB\u5,we[>Zӵj]R#żk6[:ԙUD,yy| ؞H9j2l#>#9ы0b'E.%iTʊ|[v.vwYvi|vg(<Ȍ /lz_ɰW&Ѿ)@])f{p{} xTV=#'g VE FÞRlUӫVQlu C :ŮʏNyR<`JGKrIz:TߕŧʮY6& 㨄=uj8?"p]_7Qft=AP2|`aJ!ɠ1ư Ԯ Q3,SBQl b>tl3Pz/L̈́𡅯͊:WO#=9Eɦ vg̯ZpWρ;lhYj֬ /ԲPD#Z`hq*vN= -9,m;*j$bfA@y5gHK6} Cȥ?`ֲOdu.*jsul6(n$u.j2LǗOAb*`HWieh8+_ Azd$\ cU)@HOڹ@+7Z=<E fd\XVAw! P?]b+ϑ+iF&2XcXC"$theHUD N-ŲΙM?@;1o oV}oS32PDI7,U)g)HVj̮H`sˈHrEƢ\Y1g6qw&jTJ}D*v4l;] kv͒Oxw;m膖I*1:Rق;] 1@_a? =-G+K!*p^2#foPqJ0GX@wMmB_@i'WfXιWӁQ?Z>g>'Rܿ}XY'> i!3IsPq+zA!x[lc1:al,t.a9Ք(eY WY^W$\ vot^,68$;@€NX ͷY7w^^'헴]dE"(0aR+RŒH5`IuV-C(}D[ dc0-6.UNGF@o|)ڽ(C 7dUQn*Xpmp? ͯA >9NW~L]mr>Hp(civLHRgDB4>lUGuVBvya5 |mfv+MEJɭD|~ 4f`?Y9 ƅ<u;ݟkNVl#p`zV֦OBy iMoQR&:8%<;dzNe dtsҒl*KT`d0UYVg:Gi(9;Z{]eetH̘ud!nFV6MsE쁇,lV=a u<.wgyh M^Op NۺJ|Op}-@W_h;A"b+#qcT[E&+f.O@rd;ǃƼ7#&,>ڸLeMe</3hg%}ª; =6mj`\m3ĸS!ejw}Oux4F_4_ ^E-A0@K]PEqC*MB{p-=\?6D=|sqlMKYuY[{gQW 3%m ;{3cˌR.R\cM)@,#sR /ȖS R$L]ţ6O ;,xt@Nb *BA|fl<m$Lۂg \wQAW,%-Sb0 @L%5Ƀk!).`E^`>mJQ67G\-X1bV_t/6Ex:}>^Ӻz{8NIvP~+?,/glo-9wĶȅۗ8m{瞞70W'%PҊMQ[4y"u,/8ȣN|80_4[ 竢R[!{ G4Zҍ|c߳߉̲cZ kRf G++s/v2ș%Sq c[U+|dZo}"cJbCUМ^8ٝktFjf~O}څgтT7ś;B|Ma13)#f9EɆ{B-8Ty YZ>|<0LЁJ\!hܫ%^Y3, [֐#7?ޜK N2 ٗ./WnjPY%MațKV=(of;yߕ 4CM/x(xΛOD (KTIuKWDf% hz#Z_ rw$b(U$,SD.0iF*Ⱥ,LS4RU{ߞR+(bzBsXN6LҾ;d)q0G=zA'\g\Tv݀=/+VGp~m ?o>$"jhc nsJ{$ėǬD@(D#2S֟NJrr;"CspfhI87ΕT9qdSiLh:kWUib!i#mА̡'R@hmGv{O*d(.]%_oE+6d_^$ɢVZJfn3!@*Btcpmo|"IE6U0/hL 2w Fv#덴z X2}Lr_upwj?ƽx#Q5h7)cwN];΀5r:d^V:F 7}ad⭆ttT# nwQ7"cJ5LnFif1WI)DFV"ԓe1f(QcY&UlCPm`" e=&+]ꔨq`09AB9[ z`,6X6꣮P6 NZO*L'F߶L^4'+b96]TV0x"2NxT] J)n`¥NJ69|/"! Ԏs\._̺i#\LɄ6Y 6v!i!˼aP>XZ@;9+ÇknjsODZbĠhNF(3/ 72Z.[흯0Qk”n44c 6,(Dme fʹU/>xY]Z[20Vee‹on!Y=ўa{@SG,D;\65S,{BxGX/dzbBxAL#Y`9mks2|G DsZ:auaK< /]t9.Gǃ>^xrS 4.!:JȻ.RQ0p3X4DR~EɰW/Ӑ{EF:4m|%?v" Z?}48JgYyXw&_:C[qw3 ˟wBWuc e~i$zjÿg9MI=6sR)u~&YJT>(Ƕ~?t+-OViO#gͽ(%eec#6(rn<۬?&{n0lwbE9,\T Kh1z"9F#㕼}).:[ÆЛ-o\eG\یd޶fts]t2qhKTet1ٻŘPP‹\g3Ґ;+3B`LH$/MmҜqӅ UL9j4Sn34cW@ov؃MښMi%!3(.]wNmw4l\_ʓhD@GAmH[nlDN^ VLXj&^4_k67Ov/)Can,}C )b ,s-ց$4Mb8R|c }c: $sڝE]@1ecOK=/irIfOEi)Y䀱lMom-וd޼Hu.QNX^6"H>0ƞOTå/R>\39z~ΠR@q jLA?ri ƅM&kz"|u tzJ(Dկ₞} %?J4AKZm%F*NiCCG{-xI/{(L, U x 0bf6B_ YVLw~΂, WhF/3&Vo [ =K-H''Ej0|3z[3wg5$M "/{]c/Ƭk mulSmqast_.*YUNޕوAL*`71Ot䋿u0G5˳J,i34SpdBՒ`PGS-( XOג/nܟ\aIP$+ ĝZ kX⌕lr nštuCS`+ClkWUvVTQ.O랄2_VpQĎglݷ"̚-K Mk te`S@(%G_ 4ki؅\}#{) 2OvB+N@[3X+#UGUeI+]jVZVOGpe.m,WD1Iv]\, l[?d6;G;L\6-˽[ ʆV+J5Cv.Zf6)L#GD@H9lB;T'yCBYFWf@/Nܧ.]weG*TmH+/wc}9QƮK)/o;a,^Ϧ٩>V *|lLTS=_"_3R[i`Yoj]l7{ZOqh9n{~Dw%LP@5[aCswGH68sڂŸ\[#nmě᪏|#"t69,> "  X4gfKEh3G/NS%*sB㈏FItܿP>_Oho]"Ngl5cėP])P2K W/VdD\<Ř (WK+4)&lK"0`UbAHhک^臋 GmqVeeܥf̍p$n Vֈfk"ѩ]"檎?h E3LmlУR=OVJ _z5zkAH_Lݤ< <6կ`ss;9] 1yT'1/ח"˩ּةyv̧zܓ $sTd2|>VR,>[?v0) L{^~Xr?p^蹨QCU DkﷻVJ|LA1'1>d}߸:wu^A(_ tvzwR>Ay,YP°pNua0y^G.I(HAhEdYr 0Íeҽ &][W;Ȫb騁)Z6Ԍ(/SP"Mw㏅nN&Jv`0~%̓ >_(٠ 0੎kH=<3{[~VQ3sM7MX3eAh)9:h*-%h ΌE"Ls5sS\s?I>|A~ _:o~>ɰ L}=_7`× hP{`3JnKp :PYgRpEq19< dz&%:>(7&WA)wSRk(hJCbƵfbΌ(ӖpBrP:b"9྽um!qTZ6ђdb2nw&v]Eؼ%;(4;rSV:ʑL#BYo| S0>=_&y2;t'=8WuvP˼2KJܠοQY;$mVrz-ZҿZV5nFB] !aQ]H|a\Zj怠6_¯=\3MXz LJ(e8l!BC>W@ TMShR ݜ5`q EKV;NQ~2T(ӓ`留`y\ ,45, P[Xh`eX Ⱥ_`}Afn7Yj <651RF+һ#R=g ҷ;̿FkBFށvn[ i0OPue'9lSTTZe&8AnA_aZk *r.H$˗ EPݙ3L;dتG>{%pϫ"P$&ꔙMoҁy?  bd,/Ydf )'0U=0Vpf3VOKssyִx@lg v t^.6xz|]Fધ&%FKxn =q7v ~!-A$dU8!09f5X ʥr`z,9۬ 9*Tz]ojT[9ߦֶ!c$t5vg;) E`*A/J;(%M!'X C9DN1g]gՓ7Ľ?NKZqj(5z`*8JIS} 7Os^r&0KQMǢ.¸ڷp&HOsQA܏gN^ku~gbrȌxמ6@o8L(^<(4$;$y2K)chUgT#.CfzɦDi@eTRg%(S [Te鳐xM#^&\Nr1MAPܤN@컼hՁ'dGL?,AXέR^eG¥Vx4Bba,Ucz\yTjv<~0͒ }pdmTÆ<{l=Yk:ʱAwur(!0OŞ>f18 V~?A$9RVcƋalf v0<~~3QHY(U:x!+9r(}K{["l/ ÎH':p:AދR'AX[6́t^J]^[8t0tshTOh򐒉2}s)R1)/xyYɉlR7 6|4%e>QB?v-u,񸕲}2jF&uC*U;nc x^ӿcXYop<܄=EA-UK ֟lBluN([lGy.lvCbDzೇwҞr"VߟSr%eG\  ¯0xID/4,4|(]ٮ Ysa\PV(o"u!߄ϔi=a3Lcc(τy%2UF蟀t1OAp5=5 hR_~"3:`Ի6g7N: /1>EN3t(ܷsZ&>'-Wi?k{P] b;'DMCHޟ}TQ a2$5k)̄ޚm1{6}~"֙m*c&k>bqp2/S0odOgaOޱcU0_X a[qu \H~CDQS݀-wW] 7Ɋnq@ 4 4ޖtvĘ8&R<, -Í F{ޜb=#ڥʓrs!U:ธ}ȑ'>KVanpT5 L<7dOh07rX]CU:v]kq'`l׵I1~UQ#Y"fw>o)auȍ 8S U%"&Aq?{DTQ}WP9ni,R 4K0x,cW:5oi.uCfi\2Vf;r :4ZT^I+mip//1*A 0̘2u6{1lPS!ag%=EZ4`J}@b("l )5۝x+D헴ra Q~rƨkZ1"+)A@#@3ZqoI3o0sj ʲ$S0]*!%p˭] 2K T.c*/neV?貺hBzLJߊw-Q tH}9k|W]ʾXk 8҄6.޼K G涣S;{8FXzAw ;_~+mGS rBw$RSyVhO,`m ;A/UЀpC:c)H;iiY|V!@f/y+>I9fgGFl  Dq5C c2 fsӏB$e[, fejSp-nT=G̏ =%̑Xo?:.r7td;2 ͊uxj>.+aNUۤb m 0/9~RZ*ˆ1w=cVB,hw }T(p٨M&b#ͱCIkݢd{x#")B,~[wVJ=p!L̖]<]CLï39`i,` 1P c{kF i&@Ik ix3 xxEHw^Ly)+Is^ϋ}#FfP+kKoct"K9m>P]&^DLJJ{Sx9+45={U % }no\R8(xr=ģ zlqQyNf#7'ZOUݔ˹ŕ{"^pA|^LD.Nߺߤ7N UUvŭ`)!?wU WNQĝ&3S葵g"bЗC'F@r]B\{VPgRSq́2?sn --56&m\X-Ø?ZL?5p70Y"9HNC"J\걲TS9j%U=a-H괎2WIњfqŽ-: ۩F)Jn6IXYRjp`OI]]U}\mt ^me:&MQ+$G!`C&^J[ߵf+`#tCBf*lUk&TZKH [[!FШ(h0\U$W٧ɖ\қ}VF]UUYGwzB]U@x\J4o&ņЩEV LdLw3A xCTe愗`#'Z46,1H: Iy$}.OEGKS|a!INg"-'l f~Q-oM|(wMll3(_)ĵ71^˙4jX^%,W"Ga :'.\~XuZ3gRGfԧtnto=zڼ,ֵ WwEZ3p9$wϞ&es !(FOϢL#M{y&yٓJh\!ߝoR)΍ƗEZQ54X{ɗɑ)G4lCW5"Oz#G{bL`, ;˳ d=d}xTZIQg2XŒn!ޫY%) o; 7n6oncD$׀W#s&Hˉ$҇?ĵ"16 2e|B=Sfp;/7N}~:^6eLZ{M} W"ӧg*NBl4?TT+#Si1ym<ׂf_"(Tqi(3A=~+S9St&r7&o'] o=pli&>K2.]6nEdVH/"튇4ngU< ?Wm^w9qj#hV cޖ3s6`d17z@\(Ys mc lڱxO饧/mDIu(yɄ_R52HQTZ SDۈ9o :̎l@8v7vM{-c W;փ&\c`t.]ʺ5^-EQۦsU6FW,zy Q.̮d 5)Y> A;HyREsNUKcMܓzkə pN%ė;[Y fێZ /zԂEs4-fT-dCJ5O zrɟ;U1 hV mzKkpW5sYv̄m%HzS5R,,y5(Od:7 \ͯ!=EBT%*D>}tJ 2H+_P_L$(iJeySIBŠz;rPL?8)ײ9FAq5+UC'4F]0t|\42u|.TuAneG'!S!'N&oh .}.f:1F 7x ޴5: ."t=IV.EJM,>_I;kb߁5gǛMG'؅ `Ch-ա!E 8uD-rXۂbj&l¨9bZ1qVZazM W!`sxq'f˜xc$LFC_JŔcbRRMj|sqt!`"S cc3R K^+zA#EJU&/?(Ps6X? 5#³1߲_ضz gg(e:۷? \:B%Y*tXzOP>fL'5%e AH[} !M;4/ݣv~qhj|1m&łl"bPA.jHP|xb.X.n$"jEh>ˑ#&ގ(KeQϘo89څn)?i=ƌH)&~xSv0rZb϶coQH0ZH%A@m|+x{OӚ==8D𪌸~I )bΒqsZ'}0{Nkޙ087 `}p8B_߂⪖~lv3A8ڳX+UoƂ\Ƥb FNr|hN{dw4h\%!szyZj~|uN_?K6';MDd+]"rRL{[N۾Lk8)V[,dHx g\p^U0 v |8Px 2:49{RD?4U.*ē5^ү 3׆d#)w /.4L{Ajdޏ t~BV`Ć_ּWR%sLnc&nQM aTxog@wOYehJDH2i\7nfoVg肺/Px.m 4RB7R--*N>hvSJArvy0wg+̾V,qP_v*t[?蠥܃Gs5=Ni u:L-eAv*L K&Ŵ]AZ횋cYۗ0wK61@<(A }!M5yC =+õ3F-P=ӣhQVx>8f#ŤMө2GαDXR#H?MC8#jXsR{-5_@w׼ 5RhP@G+ׁS%&e^y7eZҦآ&w0G7U"+w!ˠoힶNd 3-l!<.@w+p""UE^2i PW6tLԂY"w dlfX$ذ,9 uA 6ođNDZaqYo$Xԭgb0FUr @/ݤdϒQ$J  ;Ⱦ|(Lj% (STա[x i, {ݤx8ϭ՜|_KeR[fZ2#+D8eE ѷ^ xg9SA[<~_;t4)C ݦ~7>" K9t cDrWP>~d1M̋w%$!(=My1po}ά-Ә :lJ/A7]i=n3S6丯hNCTWZ{mK<-SSe#g[ 4s8r-nҽLL) ;#I 7x$ћմI|\H1$ d~ 4, kؿjLsrL8fV0'!rW2WP}TcQ&d/3.wd׼.MGWskh(PM@ H3s s\]1\7g!#B MoŚ[^(4i2 pX䊚}6 q69߶5{Mag}1ߟPj:r4 C.Ɲ ; =dcWZ6{G*$?!s;Z Az#π?ec\AzAѝhA#-5 1YIU~$mwFmޮ~C VJ3czypP" WŶt&w5 'ђIX*L팍ʹkBcPvs|_|[j;'@,e?:DChJ(Ed{Ku]+% k~M٤ޚ"HїOFR_-mx@n-vyס_d{"7n]4 &O%b ̠" JVcȗTْxwYS׺i9ٶ]pntvH׸Xy㛤|j1,[& 2.aTqB<ZTOϢ5!] Fg=W;խDc<Jl{w_~`q`\,do}v\EnO( St≵@o:4!ܒW)xGG4B3b 32VkD@ڟݖ2 %^vŴaQF q [P;J{GVٻ1FS9uON$ɤVO(`RK,8LW" =:Џ2(O O2rK_aӫɞĞz,SNmWv.fL˼̝ƪiy #TEБ$to4LnT8KdP .%X(1o4q&>[u-y/ZwIl1.0RF;Q7bri8R~T8S|6uK gHM %R@Pjj+4l[WT͛bIrJsH21<XQ5& _1"כUֽ ؗS_LQ1SiXܐwں|V<a_ăF;As x$?du8ZbVK^ wo*tNqI1KYbhSxe0 <3+kY9 y{r7,Fϰ>ޣꚦs_4Yg&pbnIq,'R1Zj0-h.r<]mMfLFϥAIj O{E(@g-:|&6ržq+%EQC_vdMA|їQkE)+:6AC q_t>Y$gGc0Z6ɠ8zyV,Eb88]m^Z&"-(FH/wk*(d.YJA R-,p}nҼg\9AO3 }_3P@;fhS"02 fs"yť-)FWgft0ߜcOl7cGƠ$8ȹ_msJy?d 0OZr}~_[Lh(d!(~AkƻIhw(Wrq& )!餺~`l*38SXCir "S1rCx+&+T=JC*vz<w.uabզ@=RBjxf׹<  ~S}Km3`3_ |b XO hX팗HzIʦeR_H\,Ş1A(|M{"tqמ/#K кtF54xQqaeaMyf4c 3dlaĢ x(Txܠ(3V!)X;ӬX۞A s4PK5&j9Gzck@<a|mf<ko~h4j"c^Zb0]Qt5̍bS Ѕ6ąޭ{+hK*e@bSt_^>C7`,ǂdM x nf/P9Y$AHtjk43&ADNhv>*8Sp"bՊ4O쫙Dnv:jጔ1zEnؚ$DU5/,Lj򹷂.[g(ʋD8Z37ޒ|P ԡ8Q&q3UzUk1|̵1)1 ˲jS[k0Su$]qaXx#PFC:?Y6śKS{.Z2\tp ZݚX$n%{|6\ 8ΘU!/j\;(q=.oGYZdCicaFR?>7Npb"mnfbvEVLmd.S~k"&룔TB ;Eщ3Y:-n^EMqm1ޯRg?J(1 V|2(D(^/VU)P#h0nPA$yA_w5gDe.| 0\y8FK/UI%hG-lUxq^+xcE^[DG7WkR7* т&`nO,T)Vw<٫xԩŐ_ v Mﳈ .Lu'o{+v<Bǖ}1Y:йFh6|q'w28%W׊"MsG%OW39ಹ݂-R-i,ƴx5w8.thgJ܎`=6i )=W'0n.7}B;VstXぺ%-S!mvcۭ:*?柋+5SZW"J/3AmHp(>(%z{:#O<6}]}ż*;˫"e|1$|!ߣ8T,3nb+hM,b"0̤/Gj]Eq'$ B`p%Ýtd&HAD2CbF4˪p?IhPA9kneAdd~ҡA$ Kc;+^ܢ5ZJg(rH+@֛UpZ`LSPSEtdXR731VNxTa EUB3|K9?m2I~pX{sO7y VGDE_7މ>v$ T|BK[dn._K!ƚ/F֥] Pa#$JÇw ܉ƁC칚Z Q?Tl!a^:uӛY5,)0e K~wUUU0k}]2W?&’PAͲ)3ӂħ*RmR6VkjZMZDn96F~G^&tUvIqyQnǤpeFֹ~@,Dthwn6&klz_ᐓO;!?iiړڟ\ѰX;_r.D>Ac+E.^ױn ';&/-n8z`Ʌw@`gT@BޒwnRX}tJǚ[S'EG+Т“vO&m0(3c9%Ήa$[.[ThrcoQ{*yDWR9 Ze -CL*̟hأeO4UDDvt+WG$d!8ȼ|[gԱ &BvQe3e/lxC\J\T^pNl{؅.+c,2tzc_UιfWgͧX{  <χ`+bSzn@|c' NeUŸ&XmL:Ԝ/VvzN9ޫOfx/u阀U^һ@ b:i$H#1T/ΝsS(l?A(sBVLMȔ.&@^#ӎR* *C0#ލ't5 ]X1Uۨ)BlžjG0USs;yRڄ`݀mze#b\'!H.eGJ+וژl! * يKd_|Ă8qBAWK@Fʚ/LJ@0M\ȷ UqA ^>x~OVm#QZʦk"֢PyŠ}\8uS%mk_0ydOWHıHU9>J1J"ݪ&{klfڤ2/ &C-\rT5Ȏ!Ks` 9hˇ^5C b7uь18.P 43ėIWV O _ɄPf&2ۚG:?:z;')'0"iJcDKyEd2(R0*Y-trFk=kz2qgC AsE`5kP?Z ȢobF㆑lۿ>< .-wk)ry-s_+[͙7 d .ުg De7(;'ҝb)'Xt  n#@"aŖ>%)eH3gZRti4zL2 'h<lYpz5F"p jE:G0<]y G-`Ksr*$q]zwhWVcW7Z5xS7"ͬH㹩c?L9]H, ^7jފi4t!~^4J{®OzS'\In Z_JzxVGUܵZ$1RLƐS,1y 0 q8c|[6rx>ܳh IY H)o\_?*#+{tɥ[@H_`DN'ÛKӏtr'Yy*}tpI0 @t-j!aV:W%-&2:to T06]E&0O1:cQ9Cdc`;I -oZ ߰j9_~s~ۭR'$?h42i<ꄬW (d*p.O/I7ըh^ -lBRϵҐn@Ѳ B}@Ir8#,E̶b&YwvGq륪={5w E >i9ȱؗdCtyWmM$14&l =)eMxf p4->qЇݧx,6nOK$>F|͊ P.icU oIUHkry.uIG䙀V-=1s[x8G-䠎>nlܱ[$n0\~^!:'^ʩoH c|v^fF|`bR 7hֿ5@)~1_,ىT2k*kH4ZhIяLiQ-#Dܱ,ĉ6T2eD݊F&h/L`9F@Hrd,!EJ:,g BZI;X,v4 aA^݄I *;Hǚ-`?o899:j0`{k(!-*=^p'ywm3QA f@&*y,$%G.SF4`owL㸴=\3ݙJݮ:u FއBp .?gF ƻpG E/FLM5pdh3  Z2 w N)~E/HUu۩e#I1f1h wWEs.ZFa|K`R̸8(oC7ޡ<2@d^nBPhOԵ=d@TBY2:>K<|>[2Nm ǻ|uO2r)E%g9gY9]4 Jf~uYEC0™eӭ`rHa_8(8elaJ-h?鳵͹pBO۫4Q'yNdB9@~iD(]ol<$}qgTOT`zvs kDezHGYŭt\ZFry("]PRLBM޴z N&>|Ӳxb/k_Ny{ 5Hp`{&}:n@Th dK*KunmQg z!Z }%Sk4F.oh;M>) kP۵x'Sd oT a4wRU_5!wIJ[ռ/K^:qg;LƵ`@_[]xbZUI+}S*Ӵ[2&wbt~:9𾯯*8==xd8l"mٿgbGb,^;Do#h|s>d]Ӗ]I2Ԫ:Xghę4xCs+LpVbS .U)8Uؿˆ;Cw7V`Kԅٜ_o0AAP8Z9iWg8=5dvu`2rqV0Aho' e5Ca ՚׫aRC9EZ,2( `#Dr+ݖ3Ϭ?m1ďXBJ`DѢ;u 3E K ؒ!MF[Д_v!ӣOt0쑉#/ԛp,V& L@8 \vh.5%,UU S7`H_ ǎ1j5J~qobflu9&s v>9DX:UDo CtvE 1{!:HaJQ][C|eX }SN,^喜9"A-΂9~#4POŬO)aj 1DI-3 W>xj$`Gb~ZA-qj SNlykmKnt\@Z"~G2C4ymEQLl"gŬN `J]ar(qdIf>0.JBI\O cw7je+/:lm>eR 7_5!Qk *+Ḥ苐ƦURmGި'u˗Ƹqu;VzGiq)58&=x<7um&|8_^䔥qD#OSzgX̭zMLxbRQƑ@]h+^^z q,s$_}ߊds2G^_TrF7nD_Oݴo\\&ha0i^CDzHv"G#.225JC'ߖj4PiثFT7 hdlt0cc[e8ZkD wF&&XA8 asuEV;a4C٩rX<2ZfH㯧 pHuhL1.</O F*(^1C?2q 4VDŽn\w|yر GFPԴE#PU\DP&1\?K!vFM9j+zb5A`1pd]q,4\ ZFHTax@{4?6"'dM臣TاZP6u;_xß16N Mn?/d j)$&t2R>W,fEͽ>M,"灴#\69u!e}_6`0ɱ;T;Gq V'a?D垳B39BZ/nnF\{g?w yd]8 P,,]Dؚf-5BGf{?#n_ҟ_H[ /A5^2G@2Z?V95+c~w` _2p+y#hgck`3rC>fԚ= sDP9! xXBj6OnR&oXqznieajd#׽{"ިHΓ_((#< $"^| Pę\pі+T0P!5 = Lơ"qY})q0:0.snIƁ` qBH%a_nUP۩pR?{eG+Ptyx1 1k$Iߞp9N ߘLf9Tw%<YUgÌe?EBF^uw"BSZVh2u%ܸ& vﯽg˃fseއRcPݏc6PDxHdDeuKJS0K`EMMBNdB|)c 6'{ %jp0n8_;HQ-"Lb.Q!PݹG!m6I>,6'ĮhǏ09u;zo L#P8b1'C R%l0VZX?~1kmI2 `7rὛ/MG nqVZUL ;_:}emhSYǢ}roMbJk2vr-W" oGP#麦}rTez#n+ID7]DnҶ]A|W'IW_Lm1mʘ*<-~5ɞf.}2< $QȢ>Tl<ל)N'kc Esk& k)B ~x#CIJQqshELB<6ŕo8od_#'[y"լ[Q`c 1᳒m6:ߋ446q<Qd57M{c54m 4c k|~sF@V׼%^rAfɌG:?U7F@(4~`9U=a#Z* zYX<Nȹ<40!Ba.ֻoֈ>J]2)v[/wA&(?}[)0ϗZ̴+ӄ9`|@l3Wʎ$E^2llwfj=襁/7sr'I 'ùƳe ǰg4'!A6d҉%jǶ8uc!Xpx]÷ZrNi=}Xyj` c{&W䗓!\f5nH`ЛJ$E$M}PYi/{yP?yY 5ƒE3)8,F$qq+ٹ8BZ(rxRŎ!Xm]}FâcǴJ1NM+0;sDL'SpQE=|q|l~xӴ^9]E}?Əc7tM@̯yu^Cuw[LO-< u M=2t<*};3ԮE7vE Pa̷ܧ܃unf}R@s 7&W_(KL Ae8u 2m%$]@' WllꭴO$ٞK=PCh(zD=Hdߗԓq8z6ѐeB%~"v1TEfx:zX~>f! wF(ѐ, `c?J݊+D| }#$.1;}^ĺD/a$=חRAHc7db-Nw d7$G@3g&ꮛC;$=v,_O>&ǧ$u]M㯖Խa!2zVْ;VLO[<9YgD:>`GS}U9/jľ @٬3mÅ1D 4 z5g_[L┈VSYKF: 8>aN73&Wi}* z(>MyV80 Y?Ar~ŕpuoaFWh`cCPWLP_h jJ3=or^N>,')=h0[it',d-҈{55?9c=HHaFÿq&I}2]˰Ȇs$10CWw`².+ZA8E>Na.7%MPaulpV<8hqx^3 TZ}5 v%KςcTm ( R*Ԇb{m'x)]<;DϱK,eCջ]=^-ƳGk\bʼ@^KWI!%_)5|D&t&KJ+zO- QTgc!"c0Ϝ8.,zhuOa@qV v5/lfeM] ڌ‡ n-շNf( ∭-X%ruaf[:Cn{کTd_Zd0D˜z qA 6`NfxqMY$Cȴt GY/@'(ӿOƔ*QPK6IWURIe)I]?,2ĊW=4#/"[r.9eBhR3} b 0ZlE8/}\@wh'\-ܕM.l)Ml9meaW#PZiI\G6%C]{RqUD1otl孢뭹G W-iӳ 942>Uh.`BrdWW~ܑv+ݿ^Yd²M5T]p ¯p%=mZ}|J~;^nQʴُ`o1&4oLp<-3/*hA%F_|AjPhm ji!4a"flM&aP>9}_l 7[=%ti$&Ӈ SG2Ѓ{./ڥyD> 8}yW8Y}|vv",4v}~rl=;=|-q|QJ<^$icqJ1(ʫ(sF :|qJsFB #|FwYDC1 ]VI"1$gGoX|/X%yHtp+ _ 3lN& o$~R-Gh /e@MIA)O/%ZQ>J~@6P+?Ka2# X3$Nu4Lq IfΘ2nw3lc{4XgQK2#c/XE?yAd 㕑viPifis&`pe9'ҿ,j]X,eR{z !1GE/A `oSԃV~Rb/ڴ'j'CHjluq0B5O#i[w=Yӻ>I-h @W7Q.hFH !f*tKG+>bSm γj_EqҎb=cJ ~J d ?wᬜ,[b'Nj)'e/-]Jo62L"ID9+y8p~PԊ|cЄJ5~esZ ]„u#HxUV#48_Wv鷞bJN(]ɣ5j.僎1"vQ_Ztԏ~Oq\FqX)el}?̵g'3%(/fo\"h^7(4mɚ{G/FF~"iwvAŜi9\R{4јĪ=,"b;鳖;Xn6$M#\В@_&`%'d52McH: SـG~Xc[pmX5h5T{/FHU]}8-6$RSXK1 %I6.rHStOg࿝4>6`La{XHSIN){\!)tnՆE$O(sax S"XKJNtܝmu\ugo#Ouʬ<ȅL3N '!I nɶsy訟 W0Y"[dC=B2@Δq,"iy0lJo^<=O@s@<W7@x%ZkhV6;B/ 3pX*{lnET6[IN R k~v,~.?nE\Ң{?cG *+úgᦈJ0dLаJ})s K?u0B6ځm_%K?I0D͊:馈tjk"2jء[]P_d:-+K]dHhfe+l@\@EZsqa^=lcjo37Rg)<=ه3*H(ҘͅbHH2Q"wJ|^Qx:Ww|aX`0ܨn[c#MОa%oDtFPS %EN**Y^@dHnPsdZR̦7CҤ5fg@d\z'#BM D)m}Y_Y'}όkVhY{d:s :ft\Yi MϷww߼X4=/Y w#be̵8U` ^s2&YP/1V{|_R3:3>W' %xՓOqв8f0Qybɸ,i0'C;pB u}ĩΔ&vPT{~wk}^Sm#a}vGDh~-3r4~ӣ7puЋnnjw\X[[=zDòNA^[|:?VA*#k:?нWq&ua `ԩ4GoCk-S*rWyg5o`f+_2y 4 >2/B ᚲ Lچ+0ʏ  Cx` Beꆴ:<*O_/FxtTF ܖ|SWX6T꣓Nh8bV,8wv48*?J5dՐ$5@> w?60XsAϖБW1 *d F:VkRr2bM^t'OUiCUrJ_1xf{Р2/Hw`C($;|!6wyΨ/f.i<{R,$YT!0` XV̝-<,b /XDf*`И-[_ٺDM_TQ-z76}TvqY!4'*5c]& I?g zһO?I`kS:ZC#rel>f) B[(KcVҹg/OL5!<DgHDo:elBUY][hX Er|DBOhRm[B) `R )' Y.@<[MoN4Ԣ9yd]n\8Оx &ԽSV0 +qOt4ŀ7:]"Ե]c=ZIl. A1azﴠTF脶`'J!JmEHnۋPd>H{s+cyM#cߧ' l .w.9.dtTM],\y'ľjVC=QbUd$(eZOg4_UuT~-v$8M( PH8-7Jaa@QxG{bk%mK ^ y W&|4jd$>lO03:\6ɷSNw Pn>s(a׉Z`++4 [ܯXˑyR:N#NXb8NJgKt$Krsqo\uXKYql ?{KL̒%c9(*e*v~uxĆc&ЏpxC^MobV NZ@ 4>PyulmkMk !7 Dfd`ң`FuкHBeKk^zAbtez͸6g_5('-xl<"FabZgİÖ 2" ÞfC⡌FT7"qNlv6g> %uIꋏFG,Т+#M~=x9T|(/Ks:֗չYOh=3LSpu.h Q>^y~i54xT.]%uWo̩Ϛ ˂W,1͕R7J)SdNn<-,xz}؇3ث *2y6PBsN|FF-s,6Jb2rl9$?##3b{AwB;Ae|K7'{jvӬɡ&sS*wt'\5.Ťѿ&o)'<pb:/2{dB?{.dr( 1!uϢՖNEɕsR.S~2CuAG.CZUOK [sN<;E =!jɫ5Cxo)Fd$\JUG99؊5/R<+cTe ;vDD&搣ַ[ 7+Ff+vVsMO#Yuލ]6\Q)Hbɝᱞq+WEiIoy p+6z 5}N-/@nD=hAj)7\Cn芷WR*^=I2N.jKt"hH/rm麇PSnIU!Dva'_1}Rʋ5Sj(PDZ Z^*s[In3V G-,p8g~y@lm&}z)O4')C_0z}RvRӕQaHTD$mwi_<,6VYҕӨ i~ Mx:@#HȆ(%p@+xo΍̍-Vm#ۋ fKFrQp޺⻀IA\""{4ܰ\uQYFOƠ<1 ^R /zw% kafUcCY3d1tf^x2fL&69>0uh0 &>Ch饄'6 _ GۥŮ,5s]OKa]'olq8jY~Y/.SU3dvj N63#N?m* *^ؿic}uTLO\P-4lhBbi5E*.,1={U_ЙIYN )5£8+89bE{Mox@&};+⾗CFy@ůnQE ADLc}.+*'9PO y*/ԙ7g)Uz/D+|jd+WGUԖ)^()8F;~\׷\5mb4"]fU/D\M%3C.&.j8t̃+ܾPLS-k-o"?Br%T䝉> 8] )I1Qu?tb~kEKѐs1<G3,lஇNxl5\G ?;_=<'V5e(&[CGCXrWO_`ު?#)]oA u]VKJ0l7{fo~ysXp} n5SO#kQ!폄W*3T-I{;X*ֶk_. 4Xk"*D֦eF :XB>ſsS;$ }uݎ|ܗC bܛ 2_We2 ~?#muϾQL/~FFڙ+?Nϟ3ĿkS&PO<75+A [R-*Ke‹:DW6B= _[Y"G`i،iQ|aR~c iDxF{fWRut5۱|Ũ<:sLŶlit?_{5δa^_j+4^rT1Z!uU~E<*3&hƜ #:MNJI }]a&h^V(B>? 'R** unwWiM5ATZ۷by6 fbflLDK_^JߛZi;OmA]WMw&.SS|B/1䳚siݽ һkf$bm}o~t@(yY} xeq(+,?ދ7+C(]IA?jQoZHg[V Ԍ0>nugT&0u3ihYYY&9OiEHqgx\ seAxDM7C ȣ T7Fnt/ s "qP< hxV=mՑRtdsׁr'i LKv͘zL|yoBxpg95-)dZjjGi/fpN{myF}o1 MDN҈mm$ m.9CBr6Hߵ$IuY4f'{1P2*+@/dۄRÌ_ZX ]ClrX|a1N keabjnqS8: ͧn:p؊n֛BͿ~A52{PChU48yo:kLl@B9޽_AaBt5䋶`6rK*m:+ } Hh8bN$ң_7Se`n]TG M4pJ<-TFT"_C v!q㑨!:rKU=HjޝgkK.3RNqj>E{H/d8b"½6 EU!Qĝ:-#yP8r.'y 4g{=%㪳 ;$J QjNKIMU^ŻebTpL~}>njsA"~ԌKHw!  |i11HƢssX"NKZO"piZcvzJ+m,=aPL!aa#Zxw 7T٭|9/Zha>IA1hAĀY%)\!)arzuk 9۱`+x-x=4_0J|mj&»U ( T|Y3)69}siu0f=K\ʖ=_reH ɥI)tFDѶu{&W3nDy:!0퍕JC ΗFJ:8ɫ Q!LOwiX6UP1k b6B=tnn-ll(!ww.*Sg;zvc |#TM6@[]IU)< b;i5Dq Լvδ#j*svk )Jsȸ!ƺswx(zg V&Vi<~*u+߄1۳ LL*|)ψ.S^~[wMR<̡qC)@#W%mψTtsbC*%^hv:ASحBQQ*&p8^pFm/Ckxwfv˵ >1"`~\ F|ݰ.GK # 2tB.S@:#h{Rvŧ"Sd=JbC5S7=NBp9uCXo#c?M%7w@BO[|z_e{+1^:{ RS͍<܅xffNJDfj'/dԞKl|%*hee# ||C^? -q.FK,uTn ŏ Y[s<ڕ+($Y+HJn2g@^4*jH7Gژqۘ\fO=GC#Ek.VZ(wiƾbaTK-M}G 簯#5b́L綻5جPoH 6: A]xϼf,Ir]T/2/²q_us9DIcѥ uwŜSE2}f}6liQ-LljTjg3}lw(gJǢ:fR \ ţIE_!08( @н A;\@JΠڕhG39Ty@t>!% i 6>ZPHrmRf2M$G"AL"xigr3qF|P#Zy&K~z1M4^@ i3/Co-lӪeS"KpnULMˈ+}0a}*y:Gi&X:WwK8Vg`ԈX )k*'wty>m},<  ũ2r./uUѺՖ]֚]rQdwʷ#X-N\ G.5B'y&53Dja`s ZsIäI77 Bsf Ǚ0|5ʧ~:I왩Ida>1c.%= 8Ɇr'v6& "!z u9CZ5B"rF~تRo^Ž@D#8·thȇBM:$F @e*^:܋n5Hop`_C׽vl*#;&W֞Dv֕_ԯ?3Zq{)uZ~Ӣ+{FӒct 잻_/pʏucu'D})ei+g`u&&S^%b,PP~7dX mb\uvo KK\nџ+rXx!5Hn],q6}Oe qg\ӑ's䨯mADB(7y x{G)(k|2Qd8#h$i+pSk%OD@dH683nBL mܶ;¸ԸQaPT0ص,ՓC8s4^S LM*)\W8h"9Rs.dzI}JSRѸf5φ3?`lIse(c;l"(fPDasQ62V& Kՠ ~AH^iG}5/p;kpK1Lo/Ж, kU,.-HRH ~[}"mwT,ߐ*'~= 9a=ٳ9RwDg11>Mx#Q::G΀=Wxj9L'mnO f!'a?vo"`F=lMr8 dk7MMvOݧҹEjTdA;ZrP%dT *݃eEb_<`CÝthkuEYa,%W*OzLS:^=KN j87l OX^zu|Ōs ˾!ϕՔ:@!nR GkTMhVP6Ń*pl^<*q.pi.K1}=,üR5Nk!Wxva4zV"AQ\ ` y%iT|d?q/3IyQNF~NO~.̹L44sH0ZKwi ` ]*<(:I}^͒nnC?a e1 ^n^dR- Q y擾]n pX42'MF2ڪ^~Q+# ̥Y5ET|gQz.,15v~<._4'wel4bUpegG{ TJ^)x|nS_c̀\OgΔq9OGBo5 #"|zH!1M !I`wX Q'd߫r;*c.>@|YD# Gr[O;2:QtkF $i msfᵸN.6]@LE׷pZ-#9^HTtQb 7ڪť{e冃 .دmExS<{(/H]FϘ\wQefi#papϸ)7 'QK>ǓU/9s*lnWGg.N#h[A籀КX*)\Li[4[ km\~4A3ITՍ298Ŗr 3`zq% i]ytFoP0Q[cj UX]OZ8ذَ%GL)ȾPy-0uETc( '6HM`bhPLD`;`*t\,A-~_NM5@j.N}<2 &] Ef k5I#Pq%6r?ʕ6p\{hIFRhbJNFWݤkߖ"~eXiJ߯nN52ȪcAF 5}k\2v6_'Ӫ완gSr(zcM]ĵk- K@Mg̠򡫩( ZE>_%XE :X4 /;<6${:PW_-T#Fe5y6]~›QC?t74 9gzo$b|#O""0d`5 oZ32kj2nja5%W;ZHBO~[װ]j{QP5*ON %:Sꁏ4$nͱ;gd3[þ] K iDɻ$ee KYt0 έH㏹thQ4o+XئQO~[Z6aa M} y؝E(bÌ`VD|5v-|ڏ?̃5'FLY{/-pAf.;P28QwͶQD"'i7K2 [ǥ_ LzPXۜx:}K-q*""HDoDť+E TXW5T|a7 FML=*\]dlaq6.{l :!_+`II$YOmtm9LTFM)#^|4H0@fgRP"ƪJ[["JtbImԁU)ų,*Kex^'q͓'m48c} ?]m6:s@OٔeSJB)c)M\&kfu;E ylte֋q lAFd t) vϋsQ&ȷXܡJHu:؉{t9}ؘ~H pZ}p6A'x".@STjEDj(-J,ݵ#:͎0vؕr׍^͎:)DlU*aSӳhHx3 f( #)`Mþ`i\ld'gBԩ(D~k>.gW3]7 pJ$=ѵg׃rM/(Nv*wo> >%4T[kLt'nc޿mVc |W|+ڻCџjfsKEO^'$&rX:Jg(ZC;(bH=z/Ԁ +0Q{(dr)p1w/Ϸh eh9[jc>j+^<MϤ,#a 7 Rbt-6gtċ1tBU:ˠND͆_M< oX0G {i"1X[-!y⼅dЩۣt  Z }-l _[K:sAeb#F7H,p?#6TNx<3ۤ4OY{k'ؕ# O`L0{=[mlR[>YVzCQ1oLs*_(nڅҡ<Ϥy*}sZʚǦq^tx=bSr<Ŵ+5BO<ݶn@[d% (Zah]RaPs*ƽgͽ`lq2bNz*tzN-&vtݰUin9±2^含 QOP@{P쑿H"٣e s_tI4 Q]՗MK<ٰ'|cP%?`؏nOM4qPJ ƛ!E8tA$F̙B r#l32&#ܟ?F}K,lL ,C\d*Fܷ6EdS=1\[?6G.y|[0z?LiSV {?nq+uvK_] \s4ez]CN? 㘬غDh@5t@ܠ \)6I5)x"J޻4iױr"Ѻ1@GS#A5Fi&a[ι^VjcPiV״G+)+&ه}Auغ*`e̺*NOc2Y1EEa>ۢ%y\ࠄ^SKVtØaNZ<%4^Cm64'7P`H%9O F|KB߇\x6]NYH ~*e&1Xa~VBN~ulm\*g=xD4 "ONߺX4>RN y [3F)?]93\g+k) /F v{Aa#etmFO& 򐁀4Η?оmdJL IRNASɯ^1Sގ72XI7TZ<#Ih ؀"ZKʂ`(bs jB+Qধ\|Rr UIJ3L /؀D|q^5 |ϊI:OIrZ3QXpM^4 !k=b uxU5.q<ɖ X3O `z-AB׿!V.ҮX-##lw*ܡڟ&ĂIVpv)yehIQweOًtS2+%9]pW_YcH8IRa7~]Y8[T\^)ev7G'%S%Q+Ihz 2Ӣm[:Qa,#ݔqD7vT5'Ih%A+M N~e' m4a.9hr:0lt dd>Dٿ4fEG[yPvn筞4b p~亶3StW );("<:ŝch w~"l؉gfcHȵH7cي?N@;(=<}I;} UvŪ-Нʞp)WrŎ[RIDJǮcFN&[;@&թsIJTe0bT#h)d>L<#Dp`JG(ԭBUv ch!J *U2- H2aSUOAs{R/._މ6CKT[ H f{E--|?抓8 hQV0KѶ *E9Ǥafjو}10KfU^s"ý׳&,ŧs#ƣ% sg_".+E{BDU;N4): 3,м |T0Hv_3ɓ2=A@7 Um9es,ej&\01ymi$ߵ =Mm?BMҗ׈9z]r!1~vuj4\n*Iܓ'K., "(,x.@ cIyiX#"gq6+'e(ȼ:#=C<6y+ U:7S|㤕o-,um<6+R"EHP#:\\=rfyLfkn^.QӼOs ({%7LOܣ!ˀyUȫ*09҉UUeax -l=r1##0d*6ʼ>萡'=-C ҭƅD8a%.749wlÅBvz -H Y}hRGz!YṂKJ@icM<>)&Q4O_l .:!rLNiL/@Ј&sj8VD mi4-ǒ 6:/^_Z.7܀ZH}\8h}qMٺw"˨8zTۢpPEFR_@6)KƻEciyG1uxy4x&'iy?NƵdxc|yRgHΩ V?vy ?1^/>/c4kEX&͓k[i };cx51مqe %Tˠ释Gڛ χtw<C0>-)c{$@L/rhK8+\K1DE kDU*H셧&+53?3i=:ѬP>-UZ`"-F؇*\S4gӌ̌k' CKqYCLzAt89@0 f‡H;:\ٲ9m,bo[z3@0lNtai[zoe̽9fX'[Ӈ؍oBu!jn"kIӺ>.WP(PM8k|$@X*^'_; ^H~QDcג73{nԾw%G>$odR@lHt<2&pjIPua{MF:Ii [ro*kkDS7S,@C [m}>2:1ٽ/ H^f5VѤP؇21j7:9ht fFUZT/s@vuW,ʪ+Lp &1 !wT2< *Xs֘@~EE-/! =Fz+wX֏\L:)RR`}2)W8\ z WsM dx"B!$YrmI42qR"WM!B*@^ Z##Wb3^k_`sx' z~ **ܣRD BXvI~4aaZ&odg!֓~{5Q~2nVE[&>!b4Z=ظzW 4rSʾ;OYlxYS" s!f!H>݀]ؤ9[[h8Ӌj6<籍%_EcDI)bݥEԙ&QyA8Gvދ)>D"Wt޲lڊ!m br6*SUrTC/nl5qt{."I͸s xTa ;=pz)/SKrx<7k kKHW\iMӖ.D=,1&.j6uPX.ȑk"  sDSm^0:vpq?Kgn ¹$lK` vpIW;! ^ o.oi`T` @`GQ7ي2%=ǿ{$MVܱ+!gMڨ^ RHI$Xk᱓[η ]MDx*+EFY1]>Zw捽=EO<-V6QM"Aʨ'\z  餆UZ P>,>d P?ňGO<Ј#&(0^3 Uך 懩USl)b'SُU$kW2F^U-S;֩`V* zl![8 mDZv`/€#M⢣kg1{ib6s#F z_Hpt/&`È[-MkD 'Ua>oR:Jc ɽ|Ǜ k܊s!XUd闪dr<ะ1=]W .v`X'L!b]L Z=#m 2[^hшUrl,Pk,J)_6m @Ӥ/aԇdp VRȮcM[LSɪAU]L[7'lZI #nAaҿvIhHx0#0T] ޣQ='We`Z{_$@hE} C\w!yL6.h,`|_5K V<3 Wdni-+!) W̠D# _haf܁}t{ݑ\RlrF?0 Rhom+ͦr;XbGbEnSGP;sF28ɯ& \) 76qvF>Ei :.yԧLRk,mN R1Yi>lC:M P=2H&Z+}j.T7+>[nJAۘixsE"_,uΜDE*qv<[',4#7*ij:b|(]5 VWhlrŋaGe.,`E9Y /MjVBssU:So> Rˊ4Y0%,K>ZC7 ip'Vځ.GWAp~a[OK{_84jn5QܵYXO+Sl˵f[X!뿨D 0UC/%xXg*Lq} Kj[\ YE7rFU9PC0f-Xp렵5d>VgZp@ a]4wm7jϷ( Au9Fvr9`3 ͋+GjV*ՆSndtj}\(觃Kښ^G}g"1أu]de"hT mvY3iJfv?bJ݃~zş[0@Й].Vbεr乵:%1_rb16 i~+P#XM?f=cc3| z >q-?9tP:7D:/tdIaV]/rJV|X̕(|޺ 2㰐hȜN-}O4ڈɵ)/3̀Tg߀IbM)ʳmCT=DZ~=Sh2R#,]e鉇ҫQyPֈ|aS&GG)r"Ӎ߅,)aP++BvALAH[_Ru*p_f-p|^-cg"AapİĪ+YbX5p̸i E9+JZ@sT0R`sײ?s}.s: 5.cٿZ<"Ww,DԠ) "G`oe6,!Y5w/Pl?I|RvTl\"X¼JHD+8֪;ŝ%=wbm&ǿm=)!/OS_j6]T̵~xKĞ:@%B #]o] \\t# U%7`amOnCg%xTěJ%:?qd!r0voxRT^3:ꜻ/P<^ǫ .MWA`g]{f&d>2*ҫyЮ6G&Gr$ڳ%F#@-H^ˋªއVmvVȌ>"B?r&RhWG,I)?OFuP'O}f˭ YI1 {T9GKtT$gMZ{A,=YOl^lx=u5aRXUw6[:!KRghBSۿʺ6E8"_nVw TћnB[ni!?avH[o"SGx|QSuϵcEm#$_7-54K잷hL ~bMQzre|sӃuHA]L]0iYVorbjʓ4҆)<ݣjB Zr8<RNÿN.H_n$\FE c Ob|FW\p3oob|g+!^m0E$Vs+ ]PԶuc C-> tvmZ١I"LJA%m TY>&wZ(MT'Y94Gاٿ2"iƁMg#Z8XME*cpPRc(wXEqIT4K\7 y2B cQn3&B smY;dk֟+:&QMC]| %+mξӖw,yhN9:~x\{ͳ]=aH̦–.[e?>cTeګu=6o/VYj*`:ihoGh$P9$M0Q([b} ob﹟rv0ق"fр:,![vN= xU쫫SQїi9=x}<:'j TNh>T8Ln"=  b܅N(@GELNWLŵ?]Zv`c隈'# +Ъ}mٴvH\9 Xݯ1?@mGVdغDH $:9k&=$g v&TPsefx,8i_Ƿ-фorhQkaYݢc;!91MNsPAYmۂ4^(4?jXV>(!ݶ6 ҅Cy1A8MH=i!eڈeY%=.D_`#j(1U.7UBFT,6nbupܙ5ϩ|.k6}g"~1޴pW ʫ#g$P8KA=]MǽsY(ɫ i;L8k{?~L/qf~ӆ`lUFa=ͼ5GǷ[=+Ir1$Ϧ3f 7TైA%J Ԙsw&Vwe561UfnTi9zz8-dYC|wϯk}#$P',Yd4ZS8h(͑D\\_X'_'"]8#{ h(zXA2=3~sTHյ!XXp#k˨7 شey۔_?BբCIiЪbl~q}#8Ak> JyaJ7z<5BSęu t -?K "x߼JqM;g}tܹM@ n>:os73RN>)9ƎR?}x*a:/XԭE,f>Q75nNU>0«/HQ 2< <،<{frHKJr\71i* IސPRY"Bj`*5]Rp jk!/vBc](BߐxnTY*ܟR3a6=W'\Y3żs8"?Jntx8te哜 5(4}\0Fk7CQD-$ *%@J̓KY6Ec"?PEt(gI `,65G84a8OkT3Kڦ$'m7l ~ni>71YOruQ = &]7FQP]0z \Mu]""͊ݱUS4g‡W:yg! -="⬺~,|x4< |i;^${è@Er}WݘdI3k%+5yՂeV+W)/c*0 XgI>{YonX>MUH% .ZfVTgouh^zMS|n}0}vtPBt 0q$(yIV&:غu1= 1bw}z)f%^J*Nx*gH|dT dXvbK~م^Z,]I NW;X0#Z nAiANC %0`ݠA/ޕEs^ix܂Z<.^MEl`VۚԵ ņݏ x/3sk##.Li3H5Y<0"tCASM{H|bg]5 cn<#,k BX-YXl!QC MDKȷ#%%T"Esi>0DI-Ő74lL*)~\hJx\C.%īIG3l1S$&Tws^ȓ-.\ߜ:2VR S+2|?rzDlj]URf5򴫳[\ _`sac&HASf#/RʉmRnD^ېF' 4ýu>B`=.JϮՊ-EbђzPI{~>m D3L Ȃgcqb/Σ KtNXÇ5AMNխ/Ӱ%gR BW[-i m[OgM9c@gt᣾^ ]G8\Rj}K[=͚>0H7I{!r kg1e!>cbxnKT*:xݺ9fڇO cޞTgӹAŔ+$+R'J!bx}; y5'P*DxElqnvEzF$o /H;s=s j5(U t0st1V! ŒL[];Aq6imS.iROCb#< $0Lٍ׫`ROep+!ҧ+$xK{0nNoढ़[>rcVۚ_⥿[4iK7GED *ڎmD op.$Qt)h ?H3/I<}Y{Ms}„]qvR+/6o200P;&1c_ZyQ]̥T E[wB&X34^(<13)lJKeAlO ~۾w8,A|HI{9 ]#oF:`uFe(y+o9FXrkr^Qk UZ[kP5]Hj-WG./Q믕;- ` |Ctj>~vsEOF} P^o Bg%n^橂߼صH25 T>f hB 8pkQĔouvhNJS9~8F]3C-Z ;o@ b{7LM8[bO#ltb 佼e}ق?c f_,z.L 'B}olмǕiS@>Yn͈"F]nm~p~zaG^ԮěA]LLj.m`Ԁ \[Gw/Z4 -2[6Sz 2]sVNьS E"7IxV:#%cu*jBg !m7{rBe==;2Fo% 83p Ga!sy_~gȃdnS';a\q%<Ő (p:?[,`+L1Z%03V~=ag&E|S\B_V22R{a֧ʹjsc!Uv'(q:Ӏཙ݅GD^蝖ocRwT=Mnq$ǂ.B!œEִO& Std5' )(#gn?N)Ѩ3mhb4V=j`5B,^ev`4/rnU p.gttdUP͓:yd4L{2UWcpI|#{TFWDǼ-| eN?Rz T\B騥~`wCͰoa낿xn@thtH#pʿ 1B1W IUÝ/XS%ܗ |Q#2%aƠ̚QDir,4qZ{P,)ݗ *+cNxcwG$:.mQ!IpȟޱZ֩דa5F#g=W =#ߦxp~m"`rf>O>Qa%{|c][˩e?h3zlólV}B>TC\Qȫt0^m?Enc8S Zc'3Iۋgf, pPmxD[Yj2.K`EkalKoc ȧcgey|qB4^5%L gn>1B0e=jq*6\;c%;%:ym*fT4 AuWh=f8 i 2zdd+Ȋ{ Z 8UVz3L$yPr`FxӡFes3%8 _OHGD">ދӦKc۳sp|kJ㪯\}-dAKțP"th5LD[{/D,6g:I=~Dw]Ji/ľ]}nC;owteW/GIs5Jӧ02JAM97LS[CWe XQtub"u - ByCC^r3*y2U~rpGSu/ʞiId4pD0#+A7 I2:((ËFKulCW[7_]7`2V{㢘>aRlE_ck&:gsA. %v_E{ǚz934A+Ua+D#7cs{*zQ9pߓ滴i8i@Jp b kxAΥ7{nJ˾8^^H1):&-}AA_ `i.7' cϏElny"N## ttm*q>i[՚(Cui~,J&>!MksBQcH ,U 4.]FO&Nv?#2!6~Nwg3EYbkޑU_Wv/^F?VOb+,e8J**Ā5VZayg2_WtK v}i5$t#,5ɞN7z}AFjd Ӓ?%$a-;nF:R8̂&c)tWM|9bhA"A0qg)lXp4K@LS?UuIE} uw֊=/l\'EͰ}3!%|;$@XZayvL^t=OףqM6[?{Xԯl[΀L۹u4}c=scVl2)hJK>88|[-%oX* ,JI# -&p[=(LBP_@H 稻1| e(7M2;)xɜ 9qHBdUO .U;ΨFe8peHGvLYlIF닠OCB(3->x;$ f(/+iw@5GDi!pD:#!-6mDS4ǩ):X X=\-Ko8엞MEbKɠv2FӛrUs;B9_ҜK _E` Am2;"\[R.rtDcͫǧШBKY7An̘ruLbMQ;Pn5 4RBMmlxMxveϣs%HrjcR b&u!=Vtӊq AZ͓z' a!ѷMy U|=U!dsqa-AYR;i?܊@3uCwYD{ǽ.!4i~.NU ^X֑NkEYNs#8'njU. IP{;#Ύ=ŏ<:AW۸YX3uN*:T9b֭$RA/$CӸQJH(C wNQ!֧O4BLHcE>5/l38p|-?@I[fg AV^x%+\@_vM+/Ą8UO!s<]!@68mBB3#*gM;RBTCX -MX +9vhD kP4B?4X`:@$A DLPin$g64=( F| ?r%LՆP88'@nJi/0]i E"])5|DBծ%Ӯ?i ok 2kJ,t'I[|[r˹)Uw}TcLS#CFOՋf3qG(Ӑ# a"4aw>+4E.#kqNP9X]=ͺ"Q= 6tgeQ|eןݩk&N|b[DcE?'Dfwi\..wY:w] MT=p`h?hig eRh0[ ዏW/ ;}}D·Pls.w^t)8 zV" RHA=upt9h&7>ӕ_מ="1sI;CVdL\@_(PQ#(Cv6! s`+JjawBtĸ电'rN yp*;afMVgmscpZjPW]F~A hr4Ь'DY/fuQ:Ѕ.'n0`ͭa)]~ն}N ׍eBa<?*:zpT\wR% $r( fsȚ2ۑL(Ufuh*<-ʽ6(! /esD$k)^۠vQ,qD@dLgf_Rȗw?تO<Сs;.CDHE\];enW%ętt әL^vvq"E&5I :SdH\^vg7`c"k7VW>>;yV;|{O(CeOiiH8+N]yMJֹ|dY=@WOO*-_}oa{ouxh5G‡A`ΐ#ξǛSyWP\O`13‰w} փB)g}EjBe&Z>4W0+ N?C\]m@P[<*:iz7Iļ9¿1:$Wt#!oHm ù_IuN5B.İ8%;+P½OcVVh{vYF<;|ް8NmG({>ԖBj,Q&BpԔ:EFR\8gs.zxw+g >Důi V[>*g<2jXH_K=,g7S/뤵))^6%|ؾ3vj=0*Q%jsX"}/oa)}`yuڷ2VO[H BlN}tF?4qU)W6uƭi!DG oP%a ̀5WkO݃2yj_gLVl4WZ[;'pxPPBOQ\ 0SԐXcunLSc;vU>1scŠ'r &*FEC.ȏ߷N%h*ØXR& h#G(1a-uIG[Ҷ>6 Bw]OF&4b1kIu&om8hb^vKZyV T@X)mtӁ9g 2:?S_Ѩ6q&u.8wԷL#7 j6%J{)>Ƨ [@01kAWr׶Αa"Yp1sj8p%j0U.ŝY*>ooTbX20?'7?f neyXE'H֧ WgSF{eN8+[ ƭ>YM黨LE uk&C S8ȹ~k-{"茕{f7q4?8n* `=vݕ+K Dz=/ o`+KJ3o5El)GB-U(2u8A }`;\wC;avdLga!gTz5J[ޗcyJYzcSҥV{E\'jNn=g`IZ<RPQz{Fi ;AE:bds1WdRݾڏKNِr7 >`ۤSN"w5(vrjԝ/)\ā>Qc¬3aJU8X]6k¢OX?D\u-c ؅0GGo5UGmrJoJsME]Cp/rv OfZ؋*}(6I{d< Ɓ.Q)8]n֮T]4H(DιbrWz;^Y4y ?K ѠpèӭFJ_6 Xɶ' M;Z!BЗ:bFb}Tsi jBt_UZB7~e=/o@blN{۽I!%\h5θyV+\~/7Q_frdSЪ K-c~>$Oeu5|ˇ֥gC,=A|LD5:uTusn s O he%2t \)]4 +&g+&*tAn5X]Dp4μwʝ rZPƸ,Cj]!_l^NNc#&$]l0DEѐ~Oo<ܗ+\&\(ooZYn=Sl&T(ȃŕ<7Cఏ8@d]> hK\S(4mD@/?VJ3Øx_\zr6h}Lj4ySP'X7i$it`iVXFH$!/5( FՎ&zt^>S0me{{H+Px>ub&d7iGang]:9cEPN38a-ݪ;{\Qj4?*{f@o vA"!pحE_q@_@b.u;ʚxIwɔ&2ٍwpShMaj/zg'V MD8j|p^8/^'Q]< T"yMg5[\SZ7V59PWNC&8T6_IXzZF%ʻ!d8Fw/ڜgNHpG-x *cS6I0ꆻ҂9,㝌x#!9Pmp%NT>3ذ>Ox,¯B`&+zBSF\+ }.33/-]2ΟCH˥g+ Ovd*7rɥyI%'e4kٛUAHHxZB M,8\GҀ@ҝU*]͏]h9O)/X>epwp^( ӓ (V_F)dӲ l͋tKcri-}eBEDg\/ />pJA8 ik\;gԫegYG2X^enl8^ڋJ 0WTͧ;5p9gK GwOCȡSf?fٍOjCgKhs3˹+`|clWݴ!6\@"$hDCI;K[f?98{xڷ_eAaj &0N#M(.GhdHyhňBq6s\V9?z=XU锻'qq t7. |:Um:;,5ؤR}`pn0ph] 2Ov V2Ӆ3 v^\5*#d-xh*^>7$6yEzҭTNl㘼-dҋ֧I%Na yh`wi^(HӀI6KV|wqgs;~ ZD2&"$aPg-7^>deG{~c`r <HBUcFF2r[S}~sz=ґݐ@/EQBRNꂳe-)CĞkPxM8HbSEcvשqXl\V#}/ Woa\|[Jԣ⤞^bChK4ij@^gTϖV=\lEP&+Q ڶM/%/W> 2]%Yh _` ;60O㺎z@_̧s}j#bՔbZj;V^ԢsT*}99Yff?ԙGZ>&jx${ 0ۃ82qi{7yOg[5a詩sZ O7l`]*BZbZ|Z-5H S4َ+WTF`QSI ur,ň6V9x˅n/ozKۿ2ag>7`;:ms!$l35H:;ڋ6bܹܿ'Ho{h䃨_Ncbx>+W,_37̱rocTzuedX`SX`(l pRdžMYoW{O. JCꮟ)i6hFZPn#8+s%{͉pm,~N2rUh_ @^*xjO=*GJMn~=pqRUc[/)ki:"q7F=)4SR,)r7mljtoe6tWCAEWGdXgN߻dn%;t}BL? z=d( oSVf*pzNOÇ셅R,G.&l9Luu4}:p=Aq` __,|g0%Ͻ[mll\d*|37!/%Ԥ,Ca,螑wa:OyOU`ޘA \,`s oeZ;UZ&\9nao'VcR$BtA| F&*qeQQW|{;'PAUiІ(R*70ع$UiC>&xÖ6}W5_5AŶzzrmn`T7^7=apjX҃CnKvcc/J:ﴼhAW>\ շu7|㬩dFPv$fhOnfYc6?BrR RG-6E+w+eq]#qKÉg0}Ϥ hkƚ Z.uKujo̧봚]I]ZMitB̯^Œ&LYa&d%3uVe}^T#P9Ϲa6@fDGRh;ۋAyazl} f1j\) LeOZI>Ņ~qwq[BKa~X.myћ4+WHv^|bX6 io8ϞJ2i,jaƙ]P|6*+O6w3ol cjSPA|I2Ld}D >B4!5] mG̃lTW4L H-JYy+0X$D)Y_' QtZcLPOԷ5w΀k\5GVy 2JwvlD:/HGeI鼸9&:Z~ 8I+Rzþ=*Gӡ𖍭~ğqa'HDWSꭳ`PqI*9@);B9B!9DwX^} ڑ~ նaSXUYm ~mC'>Pлp*ָQ7IzUg jDa%YFN/-Pm(F9⒙o`_j_?˙o{vS<:möKɖwn3gY+r&ɨ4xp@DoLlcNϠ#uO&;O-*<\jDնk!ȲH:ܳ0i:* k4:ynс3yGB5 ǚ_]%!|3u ~-&Ehr^vEJi sA'/ذGa)`AViú"˦S*tHn8ip"otZyn#Яzoch5xTٻ;ۗϷ t6id-o] _8> j\h:@r+=] zrOXQU0 i-cC)G83D/r7Nֆ#]lq~x#ЀMS_jT 5w]A0.6W5YOzrR<߀@ aس$uŊ%--.4]t7~ySu1^P6o'DCxy>xGY)#Y`Y=/ј/C[^zuYG=)Qz_\ή,Icm 0 )Oq-v +tZWbϏs;Jr%0l U b(-Y)>2dVɱX?*؏MₚPD83ƺ. ;Ĉf/A|^ 6V $aBLhdhSWv1ڕ ,j?UfvnRN1^H9[gC3v@e}ܻJ]cUe(ȗة9חX~gGd]K)(e$4 bhveb;YDT,=0zMnl1ӁzW'1rNF訅 CkdZ7%Vj03}j^8F$N+.Tci(* ܫbpެ㿇(H׽FtW 4ؾlt``9UCe.9W@ԷqڴBޒl* Pם$ Ld1ZF~ ay 8U.-3񌊂"^Ĺ]]|hFS# D &w2TUa/Ͳ!wT~$'9`MJCTe9m[~zWnbPe$E* v0>Xx8:m6w°˲ ˡV# ,iԬX'2uXT ' 2P85-u}J=l~/oYYΗm08e ϼ1z rQfY_&Ho9.l,:⟄Lq"1bQ1n\'uܠzQ/nMac[J(M ҚGj%͖3'`K?5_OǏܿZbXni*>osgWȥ\4z"Cvt6=[Z!_rknvp<=>CjЈx =Í3|u6jxIw )jMRD!-<Mmv\z]^*?uۇ=VCyQ`ݷ^9QGқju|<tG“4X@W䪡zbil:/;X d~09:Rm!7~4rKL3d5%Nkƿk ٨m!%o?%Xzh":,:. A,@m9]!P~Rd|E,A顄-m&|x7L'BSQ,0gRp  kt\QyBf^9*xġY&;5)ĺԥ3}ψl*t7,?—<"qT2\fE2aa v;F%Ft*mgz̤ P/Ker>h2H8U$I5<6OsE rtl_kd7a0S EJ8&@ @{NDL9['=bc4ͷ})״.'BZwOEcp|$=;l:0VP~la5vsI `,Bthٍ1NјB 2z<6Caaͻ@9\b633/ ?P6zFۢ@.NYb $m- jd?5.LGZأ;E*|r0xI(Ai@p-'0@"aY=O꜊s@Et%:\d\7U3&Hp3߱Ė|&J[h<T^Oxa'g?Gyes ,}Y9&O"rJcmlebrg$&x5 {OPٗ q/*xfFlM7&6]>c;e8QJprP̥M_9$ȮBԾ={p rYNj[iX\Ȏk)ү Ŕ@eB,9 !0}|gtnZlI^f3YѡwKwFK`%B*A6l~ L.it.]U.36}|67 :x6,ݾo"0LpWv=8M1kCs 8 x׽1}/%dp g:KܭIt;m{Y=XIf .M1CD+ax촯ʪ:NFh|z| O/zz͞oqWQ؃b"vU{;,v:;aN,\77G^t+&뼪,vdz.8FA*I%oħ5|;GT*G>F3hbu#N6iVԌM UfnzCkkMF,BXsi CѴZr^7B紖Fn?8J%qnK[Rlʞ#_ecʠ9z0ƺF U"- Čc83R ȳ'9`nTDz`QE(+cĔZ!`Ǥ35Ȕ.hu^pf =xD8ɧGJǜ+=@=}ۡ2[*|(ڰ`נAR-N1X-+4rumpnm%&$=J@&"/R~u=7VXƓ#%{X*۽ՠh{#w /)m8O& vHqD(HՎJ&+mw d zײO;Ei}9 &zC axEOʹhN;KB6Hew^{*h?qPp{sԚ+LLԐV7x5XsVcj0:|,'cjzb^ s}:>mY*T&'Ynn19M]a vcQaM#5 4B!$U10}E!F0р$+削f-ۮ3j*lu+56<5ͪ1bN/m>¿%fAgUTUj:s2飤qcHDV3TFnþBɑƔ*2L Z2,Db\4Z/:RŎ =lyλQJ׉>hA %Bõ;vF6G6VX;Bi"w:=3_`)<US(ԋ٭e)vo eݨ&blr=@OXauscpO y!ǙP(TQHN#tLHŸa0Q9( 2. .ҝkȹj'S-9B@nTye[RK ZIu= -d::ЧolFHs}N9_)jawC{&?)@&FExM*lN\h-|{$/p2ݶPk,K%uMxY Bj}|T G?Y=32yjw꧕؈2|m9< eZ! Wy~>pmnXO9 a(FFviWQLjJӠE*;ځnIIm^ ^@FYTZBH*,_[cfUtbx&XUp5J:2F(J○i0ҕB%$n܆O~Z"G5:n9ٸߠj5vP;zT $wµK4;Ԧ+D6pnpvPh6=oq+G2hOQ.\FDhʼOل'@<}'="*z|{C (g:gڅD)f 1W9zgs;^LbT)3>9F!#ɺY9ܽ+Q;u!fC x8H NJ_c 3E{{/e2UWum8? vkQI.ЊCoK H&lC?J~Ŝ#| mN ,smQ귈n&ƚ>dj74z=ouX< דU۟TM)C"do]DlXKo|p0Πd9՟RU`Zl3Vb!~Ye 8)_ΜY|KGucEZ].gcJ?%'ܙf<)-8FhXՋǴhSrV2E|l Qn$V~ܛ% %lO#UL:U}m(Y6O$h1PVC.5-㭟f>?pڤN0x§n JU!Y&3SJ!>.ۦ3VR=hĤ-eWsU xF)<%Ķ5**gj8:#{NK)Ff4a-:pNdȠ }eK ./Ay;h>D<,nB7\[ XMˉ Gv$#yV6s- L0i 9D#ͲS9gz^ xrkJvvQvF'ѩyea-w@V%Sɗf)F]"GLcQ.'jvgC^K;3) ҷt LklgF;1*/A.{J4̌,4$záw>/7,xL43ERfQ|\~sod5-2m^Wx5-YIc7wuV' q"~ LrFȃx4-O-4 VC D]9ήD=4t?I7"ˮ5ЏBgƗ(y%duRw;` |.{ڃQP OQLy3tdJ;N#$ZXXg AP!r_*NVI+×M܁[7K[S;=r%)@H'3vsZCŝ6"p艉jc|܅xE<} a%L@>Aaק.)W]pS2 .KfZ,1XG$0iX8&A)-РUXtIj;?i$sG$6d:\ iI[(.tޫlgT23uWR3 = l:"? 82pDzCr Uquqt/jFAoh_ 1q$,+*К>5b G<#_4NGf\=RZa\$qK߯ #g9E ܭFGHAW@r!}չ T8u4DH؂A"> ̎I$$M+g ?)kjUH,gWD6kH+@ە"pZ8_z%V>Q /W'\TQh1)eq8m + Fkʵ¶ oɉn .Ur2G20Rm^Aչ V@'[ԚDr0hih%J 39y>aVpg$퀨5Vyr/fE؃yt!+\{N ]jOXI?6" e1e }'uar b%E]An% 28۠Q΄t]]k{0ٔdlUƿs F 4h1ׇ +R Or.↿"×aa"rd[.2p Л)< N|4aZ]b_OT|a~I+ð#Nc ,xfr)sxcF+ee𚠒'ZHy셒7*I2@Pf8hmcW7zjAseW 0o#YŚN*'TʺH:gz,(cK:GdFfdu}p1`6sRNMFQU95ǰ[+,st{ኻP u! yj196$LmُYbꫂvurxsY&a.K|plRz`LEV4Xbǔ-`R!W_9 4*eJRX *yW] u[}e_~XVKXYi{*'+^ `h(aܒ5Bil}&ms>4IbfTS\T@ Fptŕh1>vz[>o5*LqS; =ty/&h0A^һj!{ݪޙG#p)K)2kp¨@$.{A!os>w={:Y9 w T8 Up`4\>2g?X @}؋kLoQ?ARBl[F~0!z)ׯ1 v>|{><ĸZ q!N(2Q`6`"gAZ1_~aZU 3%-I?YycMqT̆کf+7Ni8 ;>1Uc4: e Wg7{n;\1~xΜ>*"';Go=B|k$P ax$wFÎ\i^H.vn4W9BT[4M'W G{#>&8nl4# 贙 oWC`ߚb|-ɖ xT[aO,zt!@4;0s䖭VdcXB$0je!uH$QqӧC{JPR]^A2j 8`R*{b[ Vj6pJF`у[w.%V 3HC0ԑm_d؀"_]}OP} :P pVY⭺0tz׀Lc\ѩWSVg$hղFU:-6p*S4}OF"Oz3F7[yb_ypd4_~Ipk-+2eXޘ&Д Rtr|9e`Fsdogqy2 ʸO/u%I|w Cx$c#"9yVsꔗ3H; mf;XRbS @\ Nݢ.߳,5b|zGqr=Dlgѣahtq+ _hOPjUb'{XtҔඵ3@K0KHn.jӅiPhE'w=Su>vZvXlwc4R/enrmr+u #eqMJKxYJ9ǬBL˷y_BQH>M?0FǢ nqk@[t `c1dĖJ_֖->1WO'] {)X)C?h~i띒N+/ybtPg޲'J<{hu:6VO5֑SR5Nlү o}" [u֩9g@X0bcz<.Ö%قH= fB\͑Wdτ 200]}bmd7Ī&亸4.`-} fw Հ@FS|UU%=7u`e7Hr{q'k̦&n7[&D \o7ǓM1Ҟg-1zH}Cјe{H)Չp0g Gy4cHK$/-@])sKVLm.sXD&d:$Ҟ<( !iBpvQX|qF_{<=鱂3e( BgU])=ÁI.kN[P l _ffp}$_^;=+gr}XKח1Q- VP線AOV/;e#ȣЎ%}N~ur%<tVxG@lrR7RJy.8bg3r(f$EgeM\o}4=_aKG45+ݬ]ȏjI9 a>|#V0+:HVcl)V+%I5pz 2;14ћ pjΧֆLI_Gb l#cq]qTUf1ao9)AsS%+ϭnqcy)Q&X=9 o _ܦLKdd3@ Se ʡPuO7czQړpy˔kO'*DMi@ӇPFf!cQ };pCitd_U38;2JW cſSΪQ 'tr]M/tg!uʳъ7#Ӂ塮 @yV*r;v\}jMSLz<8TSA7mR dr6Ńp;2ZET< ɒ2' V[ĘtY[e!|>zMpۄ\3y7 j[%,)\{oQ    g8EPBc*N2 xIs&DvnPOv:y,gEv7zhh NkŎ"9/;H+)(LFM﫿 hG:}x7 {Y:MZ{^L[p f fkZ~VVsJ V-[_`^!؝E f}=KlۺɎl >7X9{抟 'v%?AW^]]* 8@LhSZ|-f;[8v/*'E'XIYFS愽j0X^Y \m-/F1bAwF-V""ĕ^.$.E"i&l˭΃kLav0x,=` ^Z!VVYϋ5\ h dm4_qd] 7k?$ao[(wMEKg T ^3i*دVʋ4O+8m. :܀M\EkU<& hNqLe$ߘ X J GTYńS}uCk~#5<ʍ5ŀ5|\a`7KRGJPʁ6.Wk<Nꥄ;Ulޛ@9\*;ѵzAemLa> bc#&YwY HЋ0?AHÛUFI7# ft u΁BMʳ|{ Ib&>Fܘo\X#kMA?ye}ZE1,̳`A!6bWڢe}%@7@Re[ MxvYXseQH_rrqҖ鑸wa<"huA~W&A"vb&%& @8YƈB>SJ"?TW(M 3r+IGp/偳0, ?xX2ՠlFh|uL\ԔHJ/uY蠳 Ӎ^ K X=|;YH8z#I8W|G&t( |TYnYT$O&K\]+SEǬGI6mS(Ќ-GM3Cgl#$`yLgɆ5`'TCEj}+8z(K\q$xM[cB#U鷦D]fC]Mk]r^( gn5HQzFS':;'/NRL /iKCEQXD ]^!yJxНC*zR`EV!_ш OxB\̬/,-]~ꨚ) -Ƭ;F[1?KUA 1aPO4w<**)BN5a*#3j/N||⩇8Gbd!;5 i tQȓ﷾ `&iV^0KL֧&oFdpu*|*A–MМb[fb_8Q}C#a Td) sf(k0ce(~Xwݷ MTb'.5D_NG,~'qmbiʨjNff@-/&7,RC#a%X?6CC}/>wd`F%YE/$AjM L^em6{|HLhhw\y/TqތT RW$Mt^/bSy4%Ja-!H&sf ɀ;jBZl ړ 7sY%Y6KP{dzz;8 IOgzMG. *!-V@ÂB&~84_0[*ᾦF83g%V?O- h0 ?܊ElDnj-~A'Ф[ jP2P`F|`՝}+ \Zbn] ;fRҊa!HY\רJU0b%X|`EkM 3. ]t&"#{.?5ctsV ߟiaͽEF3+mSGn+x4#ҿ ' ~[!s ,R x Է,|Y$9'/9^Q fKEFTvnVg_Ux-3yFUꔧgSNLN =K;ZHr?M YZ