saptune-3.1.2-150400.15.4.1<>,Pf zp9|Da\6{>I6s%Z?bvg !r+m' M"^i:|I>mj)F+yIkuc45ϣzC PLWB]¿Z\tĶi628aG VTɾH;PK?d   W ,0Ijw &37z9z :z ;z =pz Wjz WzYz\6z^^z``a,bT(b8b&9c@&:e&=>?@FGzHzIzXHYT\ڐz]xz^bcd:e?fBlDuXzv@ wLzx4zyz(8Csaptune3.1.2150400.15.4.1Comprehensive system tuning management for SAP solutionsThe utility adjusts system parameters such as kernel parameters and resource limits to allow running various SAP solutions at satisfactory performance. The utility can be used in place of sapconf.f zxinomavro4SUSE Linux Enterprise 15SUSE LLC GPL-3.0-onlyhttps://www.suse.com/System/Managementhttps://www.suse.com/products/sles-for-saplinuxppc64le if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : for service in saptune.service ; do sysv_service=${service%.*} if [ ! -e /usr/lib/systemd/system/$service ] && [ ! -e /etc/init.d/$sysv_service ]; then mkdir -p /run/systemd/rpm/needs-preset touch /run/systemd/rpm/needs-preset/$service elif [ -e /etc/init.d/$sysv_service ] && [ ! -e /var/lib/systemd/migrated/$sysv_service ]; then /usr/sbin/systemd-sysv-convert --save $sysv_service || : mkdir -p /run/systemd/rpm/needs-sysv-convert touch /run/systemd/rpm/needs-sysv-convert/$service fi done fi if [ $1 -ne 1 ]; then # package update NOTEDIR=/usr/share/saptune/notes if [ ! -d ${NOTEDIR} ]; then # installed package version is < 2.0, update v1 to v3 # indicated by missing directory /usr/share/saptune/notes # only change version to '1' (migration), if saptune is really used # so check, if a solution or a note is defined if (grep '^TUNE_FOR_SOLUTIONS[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1) && (grep '^TUNE_FOR_NOTES[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1); then echo "saptune NOT configured and NOT used - version will be set to '3'" else echo "ATTENTION: saptune Version 1 is currently configured and used - but this version of saptune is no longer supported. Please migrate to Version 3 after the package update is done. saptune will stop working" # to allow a migration from v1 to v3 after the installation, we need to preserve some 'old' data. touch /tmp/update_v1tov3_saptune_inst || : # preserve 'old' BOBJ and ASE note definition files for saptune # version 1 compatibility if [ -f /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.conf ]; then cp /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.conf /etc/saptune/extra/SAP_BOBJ_n2c.conf fi if [ -f /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf ]; then cp /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf /etc/saptune/extra/SAP_ASE_n2c.conf fi fi else # package version 2.0 or later # check SAPTUNE_VERSION stvers=$(grep ^SAPTUNE_VERSION= /etc/sysconfig/saptune | awk -F '"' '{ print $2 }') if [ "$stvers" == 1 ]; then # check, if saptune is really used # so check, if a solution or a note is defined if (grep '^TUNE_FOR_SOLUTIONS[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1) && (grep '^TUNE_FOR_NOTES[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1); then # saptune NOT configured and NOT used : else echo "ATTENTION: saptune currently running in Version 1 compatibility mode. Please migrate to Version 3 after the package update is done." fi fi if [ ! -d /var/lib/saptune/working/sols ]; then # installed package version is 2.x, update v2 to v3, save 'old' solution definition file cp /usr/share/saptune/solutions /var/lib/saptune/.v2_solutions fi # special fix only for 3.0.0 installations if [ -d /var/lib/saptune/working/sols ] && [ ! -f /usr/share/saptune/scripts/.updhelp ]; then touch /tmp/update_fix_300_saptune_inst || : fi fi # to prevent saptune related tuned error messages anytime after this # saptune package installation switch off tuned to remove the 'active' # saptune profile # 'tuned-adm off' is sadly the only possibility to remove an 'active' # saptune profile systemctl -q is-active tuned && [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] && (echo "found active tuned with saptune profile"; touch /run/saptune_is_active_in_tuned; tuned-adm off) || : # if the tuned profile is saptune, try to switch off tuned # if 'tuned-adm off' before had worked, the profile is empty # if not try again [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] && (echo "found saptune as tuned profile, try to switch off tuned"; touch /run/saptune_is_active_in_tuned; tuned-adm off || systemctl stop tuned.service; > /etc/tuned/active_profile) || : # if the tuned profile is still saptune, try to override the file [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] && (echo "found saptune as tuned profile, override /etc/tuned/active_profile"; touch /run/saptune_is_active_in_tuned; systemctl stop tuned.service; > /etc/tuned/active_profile) || : else # initial installation # check, if old config files from a former installation still exist if [ -f /etc/sysconfig/saptune ]; then mv /etc/sysconfig/saptune /etc/sysconfig/saptune.rpmold || : fi fi touch /run/saptune_during_pkg_inst || : PNAME=saptune SUBPNAME= SYSC_TEMPLATE=/usr/share/fillup-templates/sysconfig.$PNAME$SUBPNAME # If template not in new /usr/share/fillup-templates, fallback to old TEMPLATE_DIR if [ ! -f $SYSC_TEMPLATE ] ; then TEMPLATE_DIR=/var/adm/fillup-templates SYSC_TEMPLATE=$TEMPLATE_DIR/sysconfig.$PNAME$SUBPNAME fi SD_NAME="" if [ -x /bin/fillup ] ; then if [ -f $SYSC_TEMPLATE ] ; then echo "Updating /etc/sysconfig/$SD_NAME$PNAME ..." mkdir -p /etc/sysconfig/$SD_NAME touch /etc/sysconfig/$SD_NAME$PNAME /bin/fillup -q /etc/sysconfig/$SD_NAME$PNAME $SYSC_TEMPLATE fi else echo "ERROR: fillup not found. This should not happen. Please compare" echo "/etc/sysconfig/$PNAME and $TEMPLATE_DIR/sysconfig.$PNAME and" echo "update by hand." fi # workaround for the missing directory. mkdir -p /etc/security/limits.d # cleanup 'typo' directory (bsc#1215969) rm -rf /varlog || : # handling of working area is the same for initial install or update # initial install or update from v1 or v2 - STAGING is 'false' by default # the entire content of package area gets copied directly to the working area # which is empty at that state. # update from v3 or later - STAGING may be 'true' staging=$(grep ^STAGING= /etc/sysconfig/saptune | awk -F '"' '{ print $2 }') if [ "$staging" == "true" ]; then # handle staging area and DON'T touch the working area touch /tmp/update_saptune_staging_area || : else # staging is NOT active, same behavior as with v2 # adjust the notes of an enabled solution, if needed /usr/share/saptune/scripts/upd_helper enabledSol || : if [ -f /var/lib/saptune/.v2_solutions ]; then # remove no longer needed old solution definition file rm -f /var/lib/saptune/.v2_solutions || : fi # set up working area if [ -d /var/lib/saptune/working/notes ] || [ -d /var/lib/saptune/working/sols ]; then rm -rf /var/lib/saptune/working/* || : fi mkdir -p /var/lib/saptune/working/notes || : cp /usr/share/saptune/notes/* /var/lib/saptune/working/notes || : mkdir -p /var/lib/saptune/working/sols || : cp /usr/share/saptune/sols/* /var/lib/saptune/working/sols || : fi if [ $1 -ne 1 ]; then # package update # rewrite saptune version in /etc/sysconfig/saptune as fillup will not # change variables sed -i 's/SAPTUNE_VERSION="2"/SAPTUNE_VERSION="3"/' /etc/sysconfig/saptune if [ -f /tmp/update_v1tov3_saptune_inst ]; then # update from v1 to v3, same as v1 to v2 as nothing changed in v1 # step is needed to support migration after package update /usr/share/saptune/scripts/upd_helper v1tov2pi || : else # update from v2 to v2 or higher, call update helper script in posttrans touch /tmp/update_sle12tosel15_saptune_inst || : # clean up some leftover files from older saptune v2 versions /usr/share/saptune/scripts/upd_helper cleanup || : fi # special fix for update from 3.0.0 only if [ -f /tmp/update_fix_300_saptune_inst ]; then rm -f /tmp/update_fix_300_saptune_inst || : /usr/share/saptune/scripts/upd_helper fix_300 || : fi #else # initial install fi if [ -x /usr/bin/systemctl ]; then test -n "$FIRST_ARG" || FIRST_ARG="$1" [ -d /var/lib/systemd/migrated ] || mkdir -p /var/lib/systemd/migrated || : if [ "$YAST_IS_RUNNING" != "instsys" ]; then /usr/bin/systemctl daemon-reload || : fi for service in saptune.service ; do sysv_service=${service%.*} if [ -e /run/systemd/rpm/needs-preset/$service ]; then /usr/bin/systemctl preset $service || : rm "/run/systemd/rpm/needs-preset/$service" || : elif [ -e /run/systemd/rpm/needs-sysv-convert/$service ]; then /usr/sbin/systemd-sysv-convert --apply $sysv_service || : rm "/run/systemd/rpm/needs-sysv-convert/$service" || : touch /var/lib/systemd/migrated/$sysv_service || : fi done fi test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ "$FIRST_ARG" -eq 0 -a -x /usr/bin/systemctl ]; then # Package removal, not upgrade /usr/bin/systemctl --no-reload disable saptune.service || : ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_STOP_ON_REMOVAL" && . /etc/sysconfig/services test "$DISABLE_STOP_ON_REMOVAL" = yes -o \ "$DISABLE_STOP_ON_REMOVAL" = 1 && exit 0 /usr/bin/systemctl stop saptune.service ) || : fi test -n "$FIRST_ARG" || FIRST_ARG=$1 if [ $FIRST_ARG -eq 0 ]; then # Package removal, not upgrade stvers=$(grep ^SAPTUNE_VERSION= /etc/sysconfig/saptune | awk -F '"' '{ print $2 }') # revert settings if (grep '^TUNE_FOR_SOLUTIONS[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1) && (grep '^TUNE_FOR_NOTES[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1); then # saptune note configured and not used - nothing to do : else # saptune configured and used - revert settings to clean up the system if [ "$stvers" == 1 ]; then saptune daemon revert >/dev/null 2>&1 || : else saptune service revert >/dev/null 2>&1 || : fi fi # to suppress error messages from tuned, if the current active profile is # the removed saptune profile (systemctl -q is-active tuned && [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] ) && (tuned-adm off; /usr/sbin/saptune daemon stop >/dev/null 2>&1) || : # if the tuned profile is saptune, try to switch off tuned # if 'tuned-adm off' before had worked, the profile is empty # if not try again [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] && (> /etc/tuned/active_profile) || : # clean up saved states left over rm -rf /run/saptune/parameter/* /run/saptune/sections/* /run/saptune/saved_state/* || : # clean up working and staging area rm -rf /var/lib/saptune/staging/latest/* /var/lib/saptune/working/* /var/lib/saptune/working/.tmbackup || : # preserve 'old' BOBJ and ASE note definition files for saptune # version 1 compatibility if [ -f /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.conf ]; then echo "warning: /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.conf saved as /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.rpmsave" mv /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.conf /etc/saptune/extra/SAP_BOBJ-SAP_Business_OBJects.rpmsave || : fi if [ -f /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf ]; then echo "warning: /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf saved as /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf.rpmsave" mv /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf /etc/saptune/extra/SAP_ASE-SAP_Adaptive_Server_Enterprise.conf.rpmsave || : fi # preserve saptune configuration, if saptune was used # so check, if a solution or a note is defined if (grep '^TUNE_FOR_SOLUTIONS[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1) && (grep '^TUNE_FOR_NOTES[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1) && (grep '^NOTE_APPLY_ORDER[[:space:]]*=[[:space:]]*""' /etc/sysconfig/saptune >/dev/null 2>&1); then rm /etc/sysconfig/saptune || : else echo "warning: /etc/sysconfig/saptune saved as /etc/sysconfig/saptune.rpmsave" mv /etc/sysconfig/saptune /etc/sysconfig/saptune.rpmsave || : fi fitest -n "$FIRST_ARG" || FIRST_ARG=$1 if [ $FIRST_ARG -eq 0 ]; then # Package removal, not upgrade test -n "$FIRST_ARG" || FIRST_ARG="$1" if [ $1 -eq 0 ]; then # Package removal for service in saptune.service ; do sysv_service="${service%.*}" rm -f "/var/lib/systemd/migrated/$sysv_service" || : done fi if [ -x /usr/bin/systemctl ]; then /usr/bin/systemctl daemon-reload || : fi if [ "$FIRST_ARG" -ge 1 ]; then # Package upgrade, not uninstall if [ -x /usr/bin/systemctl ]; then ( test "$YAST_IS_RUNNING" = instsys && exit 0 test -f /etc/sysconfig/services -a \ -z "$DISABLE_RESTART_ON_UPDATE" && . /etc/sysconfig/services test "$DISABLE_RESTART_ON_UPDATE" = yes -o \ "$DISABLE_RESTART_ON_UPDATE" = 1 && exit 0 /usr/bin/systemctl try-restart saptune.service ) || : fi fi fiuk,pOY`_-q/Y'~( ego]l8u~d~{d${.8~]u.8]<e$#%AAAAA큤큤A큤AA큤AA큤A큤A큤AAAAAAAf xf xf xf xf xf xf xf xf yf yf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf xf yf yf x466dc65201abca405e412ef24821d908be59120755e0d0bb45ef5a61f740c7b7cb22b788963797df46672c1f525ed7fa8ec0ed34ab8104117359bcaf5673e227bd013f3cfd82091ff2ce7a52d947d92a275e0a6e72b0b757617ef41da378d94816f2051c1c65a2189eb26901800104f2111aa81abb9968317720ae667bd6ffca51b36adbf52cc1d4725044670fc463a3c5a33701c1682ca9630179c66d3c996969e8900a3516be4ab071e94bd2c8deafe6ef47cc7c12c65c35e76c5cb995dff3d26e3cf627fed395f2280916c8bc072953a63b157558b4487ff7acbd1e407cc2f96b63d69f4b0bc12c6b86f04ca30331ddc80a62aeca92a32774a71bad4cc84dc77e065576be9b62467dbf14ec943460e1cad5cbf77962ad81a9c9ac34c02f1ca40dd73120e9a1be175fe88ed21bab1a38af441e092ddfc4e68d3882c171395a604c1e5ae8746da0979c2ccd2216d35f3ccd854c31ec90b2eb75d2bb433a6de8a72f4fe295e749ac0b436a7f4f04fb3629555462490172abad38564707a2569c29398fc245fc6b15961b9d3c6f1fa787862444d21cda33219ec7f46734718066a02bd1235f7718565b7e616f31e5c68ccf2a23db901b753e55e24a60fef5fe70df609929a1a1d57bb5be2050e34a30bc76d9af7e87faa94037f5c847c377dd8f50e6c7c857c78dd282d182b89856258dacb81bf76efaf30c7c938d5f0469131adfc3580b12ea8298c62e6127042dd3a86dec49bca28cf12c4f2d7ca3a83eb692ed2316a5f2d67772fde16dbad28a1a80ddb685a26585d6f1f46d70cf78d394087de76f18a958892229eaecf08aad137647801d1a765f794eaa4d21ea2e93a880582bee83100eeba1ebd6824d1e188b5f7d616499cae66702ff63431f94ad8e3ad5b5c24fd7c3fdbc6300ed965808843c687ee77e4d5047400e6c51689ccb7c6017c18c9494bcd40f1449fcb70904118f44af15f4a1c46331ba30dc2b24f4693e64f81cd83881dbb93431187fd421cfd8babd399d39cd7fe8450b90fb34fbb55bf070db972d49cc503edf56c8cd88fe46d868450baef3beeb4a7a14529af5b43275e21acf9a03788a461d98ce7ac84424e9b649f4e266ee89d5778c82aa526c820c893f44615f8781b604bcb33392e00e23a7bf81aff4a15a9b7a2c7330e3b026cecc4d6477b7be44d61e48d9ae9882f13529bff6073d16eb26edaee3fa9a99d818cf3309d80ea5a24a16589479a19eafec3c42d1cc9557d9838bb481e1f4681dd0728fabf66a0c1160b773d79260bfc1001f0b621279f249ac16b41344997aece3b325339855f561c44aedfdf5d898b965a2d4d4e4ba79630e870576ba581cca5d83234df04604e094557d7b2180d932f20765c3ec68ae96f7e8a8e79485f3a643e0ee57754759be6047cc4e2ec3c4e0fdc27f18ffd4f9ab5ebb2384a250e5ae7c99f20e7b3afd9ba1ebcf19cb790e057d7a76505fac175114b8833b8c5f49cee6c5180d3db989e6ec5a91fb9c76a63d4369a1b9f9d0e95e73fe4a55a73ebf380a16f7eb370a3aeac0d112988d29adeeee865389fb54269edfd788197aa6ecdc7b509aacbbc82068be5e4f3ef09c9c2a1858a3db7a4278236ad3f5604279a753c232abf7cc01d74b879382ff4b623ac1bc6f90489f33784424e6bdf0422ac3adfa8cbbca94289b366397a93a1c1988971120ca9aacbe29a279fb12b314739bb0a776f90152cbdd7d1f5164d082eec8c40494b27c5eb51e7b5ab5c93a1ced93f866974fe470994353a99fc5a4bf4641c8a553d1bf69adb44dc1dddb08659e284ae3b23864d7e12b06a46053b99565569b0934b2c8585fceda159671e49c82539ca6fb3a7d1d3c69fe740224c8a3149a13208cb27064341583dba608422eefea1b2f5250194dee28d7ece4404a52bb6fd1053bbf6bfa06649a91d03df8cc53b67e51bb0d9393b23a13a12e5ac7cee942589c2b372b11cf587557a1b296c60320cd7ba7eca81a140c8c47defdd8e869f617ace2a385efc57e10da9e5a73ecd832a1227454d4ccf3fa479bf077a7a2f3cddb9d3b1cd2546761089d2d286eb9d1f371568e014df652b8bdd8141d7efbda4eaa4edaaf831be5204c608326c781752a7ccd2394e466d410eb51542bc7563f740ab2ee0eea934eedd26d79c6addd3d26f6434a8f30a8693dee62fdd2fdb6e012dd27bd9bc7ace73cb07d77dbbf7621f8aa162abaf511d3c89b5ca9da9693a278f4d0a140708513d5327c3ce4e7c152f5a11fe5bd3b3c40f23462e6718cb796c179349ac0db2ef00ff570db28628a584715c5488f83bdf271b560d0aaf7d6b7aa1e16977f707b1073b15abc71f2ea3ffabd4e03a4ae6a4d19c81ab89e62db0fc92b023fd81edc35d61c5cf2b991b8505003149c38e5c6cc114a11a944b698331133a226ea28afde6a06b4218fba210d6e66d645fe42d21d7f2205c871ebd248a614212f604f71aaa7e4c5f63085ec587e0b0e58c4cb7fee519eef1250fa247e8ca0c3e92b57c0bcf0d107af2d358536bdd8682f0398fad7952732ff30b180be6b7967b12f1c15e8ca0e8fcf1ce078da210028cfe69eddef7aa43f8d711913cd9e3eec02ae287fec018951dacc9664e827a21f8c394024103ded05f277c147cff87ae86a92ef13600e177bdc3cc0f033b83dc6ec08cf371738f3d8febe101085b66edad8220392f3486428a26261bc6f22487704da0b0490f026cbba3e8b6a3eb993c179797457637b669d95738e47dec0b08139ebb49b1613e8bb670c8398331db76891b32e4664b441fb8be6bfd34d031de1d5640ce938bddb2fd4cb0b4f3176c5bc599833854ab1d3779b28da6386bb76fd2ce7d047babc794d2ef5bac77c7a325d1b398950054ffd66056aff6874c5ad43e0ee57754759be6047cc4e2ec3c4e0fdc27f18ffd4f9ab5ebb2384a250e5ae27eceaf2b30e822cf885e23ffbd929266ba65137e67ee3d6cd5e544af67ea09c322639b22cdac9fc09b81a8f9b4faea692ca52c217b432f3f6eb3e788a198e2d316050bcde054202f885f0c0f7014857c8510ca3fd3d993ff1a4c0aaa2664e74f2f3ae32ba1a6627c8cf8c312248ddf2a1ab35e1b4c43619e2cc6d99e125e84e90f02e9acde06b8fe5ee3803f85df3b37358f93a4a95d0af637e92b5a7351433f871917fac9f0955b1394fea829af3abeb62afe6065ccdb0c4890c72381b24139ba817d9935f3179c13e66b6132e93ed732c01675b5bdf15227cf96eb951a77e74768067dd68daf6b1bd015da87b4e85ab3bf82e9a41d5447af3344521b448cb5a63c36a73aeb772d666f2cf918d53512bbd04f31494dc2555415674c6b425e3936e3fe84597e8c5da581f205eeaf987415df857026469248580c78537264f2ad666f7c9a1c34dbca35c1e2308076c7421edf0174c6124847f7d7aeda17ed73719f9e8ea1312c8bfd1567df3b71200b38e9aec4ba98380a4e534395511081fb72ad52b322104368243c42f51d27ec9d05510ed0043612e44f8e2768fbf01b142bb73168f28a5910795483a4664726ab05b27baff804b7882a607f8ed1abf0a90149c38e5c6cc114a11a944b698331133a226ea28afde6a06b4218fba210d6e66d82a9db46df2461c8872cd4eef2e4670611ab9e709bedab1d50a75556facd5b5d3d1040bfd8d777c887a08a25cf0b4190116929eeb841dcef3439b7583f22e909a53af82f2308ea848eecb545d69bb48dd12e40ada828701d5421fcfbbcdfbc34f4bf2daae98f1c1d41c1ae083c067d7743949dfc9b0057a1ffc0dff56bdcfd2685eb085c3fb5c4291dd84ef8e0cf50c2bbe4ac66017b342115226027ee46c39699707645af7d51706698de867190567fe2d748f4b94d568a7850772cc46a81366c9704c571ddf11993c23a1c11fcffc780afd9b60ce7d77b4e3aa037f9deb53b77435543815885d53a5b1d17604154bb3a342fd50101c35dd0fb827e8dca23943e0ee57754759be6047cc4e2ec3c4e0fdc27f18ffd4f9ab5ebb2384a250e5ae9d1dc42ad6ba5bcdd020b4595b2ab97fca7efcb435be1bde188db3530c557ee0905360921e63f419d6a111dd3216bf28402f367ab9aa69444d80e97419600d800a6af60fc7648d08bfd39ce750c7c7cc64be05a5ea9d4c5f0d20c737fa5796a9aca1ca85e1a143b67c08994a460dfc2d30d4b9429eed3dda6b875f4dd8464505c2e86cd543164f6cef8e0875da501b15eb66b2153f5b21d5463619ec5988e4590307c7c98f749a714e61eef72dd73a130ead5a3631acbf72af427af778a080acb403867c7456e434728993aceeb6048858bd09965d0fb80aa5a17e3e3e6fbdeb848ad8c81e2ca099080424895fd32f2198803148ae9527057478b6ecfeb7e5c60e886d3da5cfac25167e8649845c43e462bd7a8b8eb33b6cc351be12607302b590362ddd12131a4a472db74c9f5753c54b6122993d69d19f8497e59bdb616a274f1edcdb1fce58921ce42c9b7d9453f1422229b335e0b0635c8ec86f2e51696771a003f5d5656f9d9350a56df4237dcf33735d2e67b42034c31a33cc21d278f36c49fd25530eb0e046a764630ae7d89c679ae9e75e9c79032c3d15d21aac3cf6service@@rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootsaptune-3.1.2-150400.15.4.1.src.rpmconfig(saptune)saptunesaptune(ppc-64) @ @     /bin/bash/bin/bash/bin/sh/bin/sh/bin/sh/bin/sh/usr/bin/cpupower/usr/bin/env/usr/bin/md5sumconfig(saptune)logrotaterpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)sysctl-loggersysstatsystemdsystemdsystemdsystemdsystemduuiddvim3.1.2-150400.15.4.13.0.4-14.6.0-14.0-15.2-1234-24.424.14.3f-e̫@eB=d/@aaba?=@^U @^@^ @]N@]X]@]@]4@]1]\-@[Ѱ@Z@Z|;Z3@Z1@Z.s@ZY|Y@YRHYY@X @X)@X @W@WWzOWQq@W!@abriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comgboiko@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comhguo@suse.comabriel@suse.comabriel@suse.comabriel@suse.comabriel@suse.comhguo@suse.comhguo@suse.comhguo@suse.comhguo@suse.comhguo@suse.comhguo@suse.comhguo@suse.com- add require of package sysctl-logger for 15SP4 and 15SP5 too (jsc#PED-6220)- update package version of saptune to 3.1.2 * to support setups with saptune monitoring and heavy automation we limited the setting of our saptune lock to commands having the potential to change anything in the system. (bsc#1219500) * fix timestamp in log messages of saptune * remove redundant version information in header comment of note definition files * SAP Note 1656250 updated to Version 63 SAP Note 1771258 updated to Version 8 SAP Note 2382421 updated to Version 45 SAP Note 3024346 updated to Version 10 but without parameter value changes, only house keeping of the version section and comment updates * SAP Note 1984787 updated to Version 42 SAP Note 2578899 updated to Version 47 - add require of package sysctl-logger for 15SP6 (jsc#PED-5025)- update package version of saptune to 3.1.1 * typo in logfile directory name creates /varlog/saptune instead of /var/log/saptune (bsc#1215969) * SAP Note 2382421 fix missing handling for Azure systems regarding parameter 'net.ipv4.tcp_timestamps'. This exclude setting was left out during the last SAP Note update by mistake. * add parameter IGNORE_RELOAD to /etc/sysconfig/saptune to prevent saptune from stopping and starting the system tuning during package update Related to sapconf bug bsc#1209408. - create a flag file in preinstall and remove it in posttrans of the package installation to inform saptune that currently a package installation/update takes place so that some special situations can be handled as expected.- update package version of saptune to 3.1.0 * machine readable interfaces for saptune add json output support related json v1 schemas can be found after installation on the system at /usr/share/saptune/schemas/1.0/ (jsc#PED-2194, jsc#PED-2195, jsc#SLE-23696) * enhance the identification of the cloud service provider (jsc#SLE-23779) * add a command line syntax check * colorized and filtered output for 'saptune note verify' It is now possible to uses a 'color scheme' for the output to highlight the non-compliant parameter or to limit the verify output to show only non-compliant parameter. (jsc#SLE-23727) * add action 'saptune solution change' to switch to a new solution even that another solution was already applied. It's basically a 'revert OLDSOLUTION' && 'apply NEWSOLUTION'. This will change the Note order in case of additional applied Notes, but this is intended. The confirmation for the revert of the old solution can be suppressed by '--force' (jsc#PED-2196) * introduce a Trento naming convention for custom solutions in the saptune man page to support trento checks. (jsc#PED-4118) * deprecate action 'saptune note|solution simulate'. The action might get removed in a future saptune version (jsc#PED-2199) * deprecate support for the v1 vendor or custom specific Note definition file format (jsc#SLE-23725) * detect virtualization environment by 'systemd-detect-virt' and add the information to 'saptune status'. (jsc#SLE-23885) * enhance saptune with the new action 'check' to directly call the external check script '/usr/sbin/saptune_check'. (jsc#SLE-23726) * de-deprecate the MAXDB solution definition. It is still active supported by SAP. And add solution NETWEAVER+MAXDB (jsc#SLE-23724) * support inline comments in the Note definition files (jsc#SLE-23729) * rework Note representation in 'saptune status' output (jsc#SLE-24530) * fix problem with 'verify' output, if a sysctl parameter is empty on the system (bsc#1199527) * add hint to the manual page of saptune(8) regarding 'missing' line feed for 'saptune note applied' and 'saptune note enabled' It's intended. (bsc#1193714) * rework the version section to make it clear, which information needs to be provided (jsc#SLE-23722) * add more information to 'saptune status': differ between 'enabled' and 'applied' Solutions and add the related Notes. differ between Notes and Solutions in the staging area. rename 'system state' line to 'systemd system state' to prevent misunderstandings. add virtualisation information. * add tuning state to 'saptune status' output. The check of the tuning state (an internal 'verify' operation) can be skipped by using the flag '--non-compliance-check'. In this case the tuning state will be reported as unknown (checking disabled) 'saptune status' will exit with a return code of '4', if the saptune service is enabled, the system is tuned, but the tuning state is 'not compliant'. (jsc#SLE-24928) * add support for the IBM Power architecture to the vendor and model section tagging (jsc#SLE-23824) * add new SAP Note 1868829 to set fs.aio-max-nr and add it to the HANADB related solutions for SLE12 and SLE15. * SAP Note 3024346 updated to Version 6 SAP Note 1557506 updated to Version 16 SAP Note 1656250 updated to Version 46 SAP Note 1805750 updated to Version 9 SAP Note 2161991 updated to Version 28 SAP Note 2205917 updated to Version 63 SAP Note 2382421 updated to Version 45 SAP Note 2534844 updated to Version 15 SAP Note BOBJ updated to Version 1 but without parameter value changes, only house keeping of the version section and comment updates * SAP Note 1984787 updated to Version 40 SAP Note 2578899 updated to Version 46 SAP Note 2684254 updated to Version 23 SAP Note 1680803 updated to Version 27 includes version 3.1 of 'SAP Applications on SAP Adaptive Server Enterprise - Best Practices for Migration and Runtime' * Solution 'SAP-ASE' changed - remove SAP Note 1410736. The best practice document (version 3.1) for ASE was changed and the SAP Note 1410736 is no longer referenced. Instead the parameter 'net.ipv4.tcp_keepalive_time' is set in SAP Note 1680803 (the ASE SAP Note) directly. * introduce an additional parameter 'SKIP_SYSCTL_FILES' in the /etc/sysconfig/saptune configuration file, which contains a comma separated list of sysctl.conf files or directories containing sysctl.conf files, which should be excluded from the 'additional defined' WARNING messages. Default is SKIP_SYSCTL_FILES="/boot" to skip the WARNINGS for '/boot/sysctl.conf-' - check in preinstall and posttrans of the package installation, if the active tuned profile is still 'saptune', even that this profile no longer exists. If yes, try to remove it. (bsc#1194688)- update package version of saptune to 3.0.2 - avoid excluding LVM slaves when getting valid block devices (bsc#1194299) - fix 'not compliant' state for energy_perf_bias on Power systems and suppress misleading error message regarding missing 'mokutil' (bsc#1193435) - fix wrong behaviour of 'saptune revert all', if the saptune service was stopped between the two commands 'apply' and 'revert all' - 'saptune service enablestart|disablestop' now always perform both actions and does no longer stop working, if the service is already started|stopped. (bsc#1193241) - restrict the sys section of the AWS note 1656250 to the availability of a nvme block device to support AWS x1e instances too. sys section definition of Note 1656250 changed. (bsc#1192029) - abandon the dependency to 'mokutil' by relying on sysfs to detect a secure boot environment. Related to bsc#1193435 - support /etc/fstab entries with 4 instead of 6 fields as these are valid entries. Change error handling from 'panic' to error log messages. (bsc#1193580) - enhance man page 'saptune.8'. Add entry 'configured Note' and some more descriptions of the entries from 'saptune service status' (bsc#1192697) - as the Power systems (hardware architecture 'ppc64le') does not support files in '/sys/class/dmi' (this directory is not available on the 'ppc64le' hardware architecture) some of our section 'tags' will not work. Add some additional log messages to identify the cause and add a hint to the man page. - fix block device settings (e.g. NRREQ) for multipath devices (bsc#1193576) - 'saptune verify' will now report a non existing sysctl or sys parameter as 'not available on the system' (footnote) and this parameter will not affect the compliance state. But a warning is displayed to raise attention to may be typos in the parameter name. - 'saptune status' now reports the 'real' unit state, no mapping of not running (inactive) service to simply 'stopped' any more. (bsc#1194334)- update package version of saptune to 3.0.1 - fix the scheduler settings for multi path devices and suppress missleading warning messages regarding vendor and model information during block device detection (bsc#1192460) - fix override of custom solutions (bsc#1192062) - add missing update function for enabled solutions and add a special fix to correct the 3.0.0 behavior (bsc#1192053) - saptune_check - degraded system is no longer considered an error (bsc#1192272) - log missing model and vendor information to the saptune log file (bsc#1190509)- update package version of saptune to 3.0.0 This will be additional reflected in the saptune version found in /etc/sysconfig/saptune (SAPTUNE_VERSION) So now we will have saptune version 3 - saptune version 3 Strengthen configuration process with staging, checks of external changes and expansion of automation to new platforms (Azure, AWS) and hardware specifics (jsc#SLE-21029 and jsc#SLE-20985) - remove saptune version 1 (jsc#SLE-10823 and jsc#SLE-10842) - remove usage of tuned from saptune Add an own systemd service file for saptune to start/stop tuning of parameter values during a reboot of the system. Add a new saptune action 'service' to handle the saptune.service supporting start/stop/enable/disable/status a.s.m. The saptune action 'daemon', which handled tuned.service in the past, is now flagged as 'deprecated' and internally linked to the new action 'service' (jsc#SLE-5589, jsc#SLE-5588, jsc#SLE-6457) - add a sanity check to detect Note definition files which do not exist anymore, because they were renamed or deleted, but without reverting them before. saptune will now print an error message, remove the Note from the tracking variables in /etc/sysconfig/saptune and try to revert the related parameter settings. (bsc#1149205) - check, if json input file is empty and handle some left-over files from the migration from saptune v1 to saptune v2 (bsc#1167618) - To support system parameters only relevant for specific SLES releases, service packs and/or hardware architectures saptune now supports 'tagged' sections inside the Note definition files. (jsc#SLE-13246, jsc#SLE-13245) - new kernel requirement for Power added to SAP-Note 2205917 and 2684254 SAP Note 2205917 updated to Version 61 SAP Note 2684254 updated to Version 15 (bsc#1167416) - SAP Note 2382421 updated to Version 37 and move all 'not-well-defined' parameters from the 'reminder' section into the 'sysctl' section, but with 'empty' values. Use an override file to define the values fitting your system requirements (bsc#1170672) - support empty parameter values in the Note definition files and not only in the override file. This is needed for the support of SAP Notes like 2382421, so that the customer is able to simply use an override file to define some special parameters instead of using a customer specific Note definition file. needed for bsc#1170672 (jsc#TEAM-1702) - report an 'error' instead of 'info' and set the exit code to '1', if we reject the apply of a solution (bsc#1167213) - Skip perf bias change if secure boot is enabled When a system is in lockdown mode, i.e., Secure Boot is enabled, MSR cannot be altered in user-space. So check, if Secure Boot is enabled using the mokutil utility and skip setting the perf bias in case it is. (bsc#1176243) - rework the internal block device handling to speed up the apply of block device related tunings on systems with a high number of block devices. (bsc#1178207) - change block device handling to handle multipath devices correctly. Only the DM multipath devices will be used for the settings, but not its paths. (bsc#1179275) - fixed wrong comparison used for setting FORCE_LATENCY (bsc#1185702) - add keyword 'all' to the 'rpm' section description in the man page saptune-note(5) (bsc#1182287) - support note definition versions containing digits, upper-case and lower-case letters, dots, underscores, minus and plus signs. (bsc#1182289) - fixed issue with 'verify' operation and parameter 'VSZ_TMPFS_PERCENT'. As this parameter is only used to calculate the value of 'ShmFileSystemSizeMB' (if it is not set to a value >0 in the Note definition file) it will not be checked and compared during the saptune operation 'verify'. A footnote is pointing this out. (bsc#1182009) - SAP Note 1771258 update nofile values (bsc#1164720) - SAP Note 2684254 updated to Version 20 SAP Note 2578899 updated to Version 39 SAP Note 1680803 updated to Version 26 - enhancements for saptune version 3 All jsc#TEAM-* entries mentioned below are related to this rework (jsc#SLE-16972) - Implement a lock to avoid multiple instances of saptune running in parallel. (jsc#TEAM-1700) - Support for non-colorized output If redirecting the output from saptune to a pipe, you no longer need to deal with the 'ugly' control sequences for the colorized output. (jsc#TEAM-1679) - Add enable/disable for systemd units and support all systemd unit types in section [service] (jsc#TEAM-1701) - remove script /usr/share/doc/packages/saptune/sapconf2saptune and the associated man page (jsc#TEAM-1707) - implement staging of Note definition file and solution definitions. The idea is to freeze the saptune configuration to avoid config changes on package update when adding/removing/changing notes or solutions within the package (jsc#TEAM-1844) - support custom solutions and override files for solutions. Partners and customers will now be able to define their own solution definitions by using files in /etc/saptune/extra or to override the shipped solution definitions by using override files in /etc/saptune/override (jsc#TEAM-1706) - support for device specific configurations only supported for the [block] section, tags are 'vendor' and 'model' to support special block devices of a dedicated hardware vendor or a dedicated hardware model (jsc#TEAM-1728) - add support for AZURE cloud (SAP Note 2993054) (jsc#TEAM-2676) - add support for AWS cloud (SAP Note 1656250) (jsc#TEAM-1754 and jsc#TEAM-1755) - add NVMe support to the block device handling to support AWS (jsc#TEAM-2675) - add SAP Note 3024346 (a NetApp note) (jsc#TEAM-3454) - rework daemon and service actions (jsc#TEAM-3154) - add support for 'read_ahead_kb' and 'max_sectors_kb' to the [block] section (jsc#TEAM-1699) - add a warning to the reminder section of SAP Note 2382421 regarding iSCSI devices and setting of 'net.ipv4.tcp_syn_retries' (jsc#TEAM-1705) - for the actions 'note customise' and 'note create' check, if the customer has changed something during the editor session. If not, remove the temporary created note definition file. (jsc#TEAM-825) - add support for [sys] section and handle double configurations for parameters defined in the [sys] section (jsc#TEAM-3342) - check system sysctl config files as mentioned in the comments of /etc/sysctl.conf and in man page sysctl.conf(5) for sysctl parameters currently set by saptune notes. Print a warning and a footnote for 'verify' and 'customize'. (jsc#TEAM-1696) - add support for [filesystem] section only check filesystem mount options, not modify. Starting with filesystem type 'xfs' (jsc#TEAM-4093) - add SAP Note 900929 for SAP Netweaver workloads. It's the equivalent to the HANA Note 1980196. (jsc#TEAM-4386) - mv state files from /var/lib/saptune to /run/saptune to solve the problem of state files surviving a reboot. - add /sbin/saptune_check - add the description of the solution definitions shipped with saptune to the man page saptune(8) (jsc#TEAM-4260)- update version of saptune v2 to 2.0.3 - changes to the UserTasksMax handling in saptune In SLE15 the limit is removed from the systemd login manager and therefore the setting is no longer supported in SLE15 by saptune. On a system running SLE12 we do not restart the logind service, but try to reload the new configuration after creating or removing the drop-in file for UserTasksMax by using 'systemctl reload-or-try-restart systemd-logind' as display managers do not like a restart of the logind service. (bsc#1161791) - add commands for listing enabled Notes/Solutions to saptune (bsc#1160564) - correct typo in the year in the man page headline of man page saptune-note(5) - SAP Note 1410736 updated to Version 6 correct typo net.ipv4.tcp_probes to net.ipv4.tcp_keepalive_probes- if a parameter is not supported by the system, the note action 'verify' will no longer report this as an error even if the value is not compliant. Additionally if there is a non compliant 'grub' parameter, which has a compliant 'alternative' setting availabel (see man page saptune-note(5) for details), the note action 'verify' will no longer report this as an error (bsc#1159671)- remove no longer needed and now misleading message at the end of note action 'revert'. - check, if sapconf service is available before disabling this service during 'saptune daemon start' (bsc#1156049)- add action 'delete' to the 'note' operation to delete a customer or vendor specific Note definition file including the corresponding override file if available. A confirmation is needed to finish the action. add action 'rename' to the 'note' operation to rename a customer or vendor specific Note definition file to a new name. If a corresponding override file is available, this file will be renamed too. A confirmation is needed to finish the action. If the Note is already applied, the action will be terminated with the information, that the Note first needs to be reverted before it can be deleted or renamed. (jsc#SLE-9283)- Inform the customer that - by intention - the command 'saptune note customise ' does not apply changes immediately. It just changes the configuration in the 'override' file. These changes have to be applied in a second step. This is explained in the man page saptune_v2(8) and a message is printed in the logs and on the screen to inform the customer. (bsc#1142467)- Add warning to man page, not to rename/remove/modify active configurations (bsc#1149002)- update version of saptune v2 to 2.0.2 - support multi-queue I/O scheduler for block devices (bsc#1152598)- check, if the directory /etc/security/limits.d exists before writing the limits drop-in file. If not, create it. - add the '--no-pager' option to 'systemctl --list-unit-files' to get all services at once. - add missing search pattern to the update helper script to find all old and superfluous notes during upgrade from SLE12 to SLE15 For the daemon operations do not exit with an error, if a note definition file does not exist. Instead only log and print an error message, but continue with applying the other notes (bsc#1142526)- on 12SP1 and 12SP2 the directory /etc/security/limits.d may not exist. So create the missing directory during postinstall of the package.- update version of saptune v2 to 2.0.1 - update version of saptune v1 to 1.1.9 for migration purposes - resetting all values to clean the system during package removal - bugfixing saptune version 1: fix saptune issues with /etc/security/limits.conf (bsc#1124485) add deprecated message to the description of some notes set scheduler for note SUSE-GUIDE-01 correctly (bsc#1123808) No additional improvements or upgrades planned for saptune v1 For new features or current SAP Note settings please migrate to saptune v2. - support migration from saptune v1 to saptune v2 ship both versions of saptune in one package to support a smooth migration controlled by the customer. see man saptune-migrate(5) for more information - support note name changes and note deletion during update of saptune v2 from SLE12 to SLE15 - support different SAP Note definitions and solution definitions related to the used operation system version (distinguish between SLE12 and SLE15 at the moment) - Remove calculation of optimized values, only set the values from the configuration file irrespective of the current system value. Current system value can be increase or decrease. ATTENTION: saptune no longer respects higher system values. Use the override option to change the values of the Note definition files, if needed (bsc#1124488) - mark the Notes SUSE-GUIDE-01 and SUSE-GUIDE-02 as deprecated in saptune v1 and remove these Note definitions from saptune v2 (bsc#1116799) - add support helper script sapconf2saptune and the man page - add new man pages saptune_v1.8, saptune_v2.8, saptune-note.5 and saptune-migrate.7 rewrite man page saptune.8 - add bash-completion for saptune - add action 'show' to the 'note' operation to print content of the note definition file to stdout - add new action 'create' to support the customer/vendor while creating a vendor or customer specific file in /etc/saptune/extra using the template file /usr/share/saptune/NoteTemplate.conf - simplify file name syntax for the vendor files available in /etc/saptune/extra. Old file names still valid and supported. Add header support (version, date, description) for the vendor files available in /etc/saptune/extra as already available for the note definition files in /usr/share/saptune/notes - no longer write or remove entries from /etc/security/limits.conf. Instead add or remove drop-in files in /etc/security/limits.d The filename syntax for the drop-in files /etc/security/limits.d is saptune---.conf The limits entry syntax inside the Note definition files changed to support more than one limits settings in the definition file (bsc#1128322) - preserve comment sections of the security limits file /etc/security/limits.conf. Especially, if this is the only content of the file. (bsc#1124485) - work with the current Note definition file to define the pagecache settings and not with the default file rename PAGECACHE_LIMIT_IGNORE_DIRTY to the correct sysctl name vm.pagecache_limit_ignore_dirty (bsc#1126220) - setting of UserTaskMax is not done in the postinstall of the package. It's now done by applying the related SAP Notes. (bsc#1124489) - starting to support severities INFO, WARNING, ERROR and DEBUG for the logging and add a defined format for the log messages - remove saptune as active tuned profile during action 'saptune daemon stop' - start/stop services, if requested by SAP Notes, but do not enable/disable these services (bsc#1128325) - adapt the parameter oriented save state file handling (store and revert) to the special needs of the security limits parameter (bsc#1124485) - disable parameter settings using an override file (bsc#1124486) - store the order of the note as they are applied to get the same system tuning result after a system reboot as before - correct the revert of the vm.dirty parameters by handling their counterpart parameters in addition. (bsc#1124487) - adjust operation customize to the new configuration files and override location and enable customize option for vendor and customer specific files in /etc/saptune/extra (bsc#1124487) - Change output format of the operations list, verify and simulate (bsc#1124487) - Display footnotes during 'verify' and 'simulate' (bsc#1124487) - print current applied note order at the end of 'saptune note list' and 'saptune note verify' - remove Netweaver formula for page cache calculation. Use the HANA approach '2% system memory' for both - display a warning message, if a [block] section is found in the Note definition file because on systems with a huge number of block devices this operation may take some time - Add force_latency handling to 'cpu' section. Use the files in /sys/devices/system/cpu/cpu* instead of /dev/cpu_dma_latency. Remove the parameter from the tuned.conf file and add it to the SAP note files '1984787' and '2205917' - Add action 'saptune revert all' and add parameter based saved state files to support proper revert functionality (bsc#1124487) - Add override file handling for the solution definition using /etc/saptune/override/solution (bsc#1124486) - Read solution definition from file /usr/share/saptune/solution instead of static coding inside of saptune. (bsc#1124486) - tag deprecated solutions during list operation - allow only ONE solution to be applied - new solution definitions as discussed with SAP and Alliance team - support solution names with '+' - make sure a note, which is part of an applied solution definition, but was reverted manually later, will NOT applied again after a system reboot. - One configuration file per SAP Note (bsc#1124486) - add new SAP Notes and adapt content of SAP Notes - Handle different locations of the new configuration files (/usr/share/saptune/note, /etc/saptune/extra) (bsc#1124486) - Allow parameter override by the customer (bsc#1124486) - Expand section handling of the 'ini file' handler to handle the new configuration file entries. Supported sections: version, reminder, login, mem, vm, block, limits, sysctl, pagecache, cpu, service, rpm, grub (bsc#1124486)- remove new line from println arg list of main.go to support newer go versions. (bsc#1120741) - update version to 1.1.8- never ever stop or disable uuidd.socket in saptune (bsc#1100107) - update version to 1.1.7- correct content of /etc/systemd/logind.conf.d/sap.conf. (bsc#1089864) - improve error messages and exclude special block devices from 'number of request' settings. Improve the verify option for the block devices. (bsc#1079599)- Fix a typo in package description. (bsc#1053374) - Update from version 1.1.3 to 1.1.4- Start to support multiqueue schedulers. Writing a message to the log file, if a block device does not support the choosen scheduler. (bsc#1072562)- Check, if pagecache limit is available at the system. If yes, add SAP note 1557506 to the note list and the solution definition of saptune. If not, skip SAP note 1557506 silently (bsc#1071539, fate#323778)- Skip using tuned-adm command inside of saptune. Instead write 'saptune' profile directly to /etc/tuned/active_profile and enable and start the tuned service Remove the workaround for the tuned problem with section [cpu] (bsc#1060514)- workaround for a tuned problem with section [cpu] (bsc#1060514)- support customer entries in /etc/security/limits.conf containing values like 'unlimited' instead of an integer value. (bsc#1060469) - change error handling and redirect error messages to stderr instead of stdout. (bsc#1050521)- Fix a typo in package description. (bsc#1053374)- Amend logind's behaviour (bsc#1031355, bsc#1039309, bsc#1043844)- update man page to reflect the changes for bsc#1026172- add solution SAP ASE (Sybase) and SAP Business OBJects (BOBJ) according to fate#320359.- Support of vendor specific tune files located in /etc/saptune/extra (bsc#1026172).- Tune a PowerPC little endian system in a way similar to x86 system. Bump version to 1.0.5 to fix (bsc#1009529).- Fix processing of CLI parameter "--help" (bsc#1006114). - Fix startup failure caused by absence of sapconf package (bsc#1006187).- Avoid conflicting with sysconfig path of sapconf. (bsc#988186) Bump versin to 1.0.3.- Remove conflict against sapconf to resolve bsc#988186. Bump version to 1.0.2.- Exclusively build on X86_64 and PPC64le. Continue with fate#320360, fate#320361, fate#320362, fate#320633.- Remove ExclusiveArch. - Control uuidd as part of the tuning process. - Minor changes in the wording of CLI program output. - saptune conflicts with sapconf. - Bump version to 1.0.1. - fate#320360, fate#320361, fate#320362, fate#320633.- First revision. Implement fate#320360, fate#320361, fate#320362, fate#320633./bin/sh/bin/sh/bin/sh/bin/shxinomavro 1713244794  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz3.1.2-150400.15.4.13.1.2-150400.15.4.13.1.2-150400.15.4.1 saptunesaptuneextraoverridesupportconfigpluginssaptunesaptune.servicercsaptunesaptunesaptune_checksaptunesysconfig.saptunesaptune-note.5.gzsaptune-migrate.7.gzsaptune.8.gzsaptuneNoteTemplate.confSolutionTemplate.confdeprecatednotes14107361656250168080317712581805750186882919801962161991238242125348442578899268425429930543024346900929941735SAP_BOBJschemas1.0saptune_check.schema.jsonsaptune_daemon_start.schema.jsonsaptune_daemon_status.schema.jsonsaptune_daemon_stop.schema.jsonsaptune_help.schema.jsonsaptune_invalid.schema.jsonsaptune_lock_remove.schema.jsonsaptune_log_set.schema.jsonsaptune_log_status.schema.jsonsaptune_note_applied.schema.jsonsaptune_note_apply.schema.jsonsaptune_note_create.schema.jsonsaptune_note_customise.schema.jsonsaptune_note_customize.schema.jsonsaptune_note_delete.schema.jsonsaptune_note_edit.schema.jsonsaptune_note_enabled.schema.jsonsaptune_note_list.schema.jsonsaptune_note_rename.schema.jsonsaptune_note_revert.schema.jsonsaptune_note_revert_all.schema.jsonsaptune_note_revertall.schema.jsonsaptune_note_show.schema.jsonsaptune_note_simulate.schema.jsonsaptune_note_verify.schema.jsonsaptune_revert_all.schema.jsonsaptune_service_apply.schema.jsonsaptune_service_disable.schema.jsonsaptune_service_disablestop.schema.jsonsaptune_service_enable.schema.jsonsaptune_service_enablestart.schema.jsonsaptune_service_reload.schema.jsonsaptune_service_restart.schema.jsonsaptune_service_revert.schema.jsonsaptune_service_start.schema.jsonsaptune_service_status.schema.jsonsaptune_service_stop.schema.jsonsaptune_service_takeover.schema.jsonsaptune_solution_applied.schema.jsonsaptune_solution_apply.schema.jsonsaptune_solution_change.schema.jsonsaptune_solution_create.schema.jsonsaptune_solution_delete.schema.jsonsaptune_solution_edit.schema.jsonsaptune_solution_enabled.schema.jsonsaptune_solution_list.schema.jsonsaptune_solution_rename.schema.jsonsaptune_solution_revert.schema.jsonsaptune_solution_show.schema.jsonsaptune_solution_simulate.schema.jsonsaptune_solution_verify.schema.jsonsaptune_staging_analysis.schema.jsonsaptune_staging_diff.schema.jsonsaptune_staging_disable.schema.jsonsaptune_staging_enable.schema.jsonsaptune_staging_is-enabled.schema.jsonsaptune_staging_list.schema.jsonsaptune_staging_release.schema.jsonsaptune_staging_status.schema.jsonsaptune_status.schema.jsonsaptune_version.schema.jsonscripts.updhelpupd_helpersolsBOBJ.solHANA.solMAXDB.solNETWEAVER+HANA.solNETWEAVER+MAXDB.solNETWEAVER.solS4HANA-APP+DB.solS4HANA-APPSERVER.solS4HANA-DBSERVER.solSAP-ASE.solsaptunestaginglatestworkingnotessolssaptune/etc/logrotate.d//etc//etc/saptune//usr/lib//usr/lib/supportconfig//usr/lib/supportconfig/plugins//usr/lib/systemd/system//usr/sbin//usr/share/bash-completion/completions//usr/share/fillup-templates//usr/share/man/man5//usr/share/man/man7//usr/share/man/man8//usr/share//usr/share/saptune//usr/share/saptune/notes//usr/share/saptune/schemas//usr/share/saptune/schemas/1.0//usr/share/saptune/scripts//usr/share/saptune/sols//var/lib//var/lib/saptune//var/lib/saptune/staging//var/lib/saptune/working//var/log/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:33395/SUSE_SLE-15-SP4_Update/8152ebdf554da921531f6190127cd392-saptune.SUSE_SLE-15-SP4_Updatedrpmxz5ppc64le-suse-linux ASCII textdirectoryBourne-Again shell script, ASCII text executableELF 64-bit LSB executable, 64-bit PowerPC or cisco 7500, version 1 (SYSV), statically linked, strippedBourne-Again shell script, UTF-8 Unicode text executable, with very long linestroff or preprocessor input, ASCII text, with very long lines (gzip compressed data, max compression, from Unix)troff or preprocessor input, UTF-8 Unicode text (gzip compressed data, max compression, from Unix)UTF-8 Unicode textWindows setup INFormation, ASCII textRRRW2;(6NRg # Use a real bash script with an explicit "exit 0" at the end to be by default fail safe # an explicit "exit 1" must be use to enforce package install/upgrade/erase failure where needed # Begin refresh systemd units and clean up possibly obsolete systemd units # The following is a generic way how to refresh and/or clean up systemd units. # A systemd unit may need a refresh after updating a package when the new package # had installed a changed systemd unit file for an enabled systemd unit. # A systemd unit may become obsolete by updating a package (see bnc#904215). # A systemd unit is considered to have become obsolete when the systemd # symlink /etc/systemd/system/.../unit_name -> /path/to/unit_file is broken. # When during package update the new package does no longer provide a unit file # then the systemd symlink becomes broken after the files of the old package # had been actually removed by RPM. # According to /usr/share/doc/packages/rpm/manual/triggers and according # to https://en.opensuse.org/openSUSE:Packaging_scriptlet_snippets#Scriptlet_Ordering # and http://fedoraproject.org/wiki/Packaging:ScriptletSnippets#Scriptlet_Ordering # from the new package only "posttrans of new package" is run after "removal of old package" # so that the new package must do the clean up as RPM posttrans scriptlet. if systemctl --quiet is-enabled saptune.service 2>/dev/null; then # Refresh still valid enabled systemd units and clean up possibly obsoleted systemd units: # Enforce systemd to use the current unit file which is usually the unit file of the new package # but also in case of custom units (that use other unit files) a "reenable" won't hurt because # "reenable" does not implicitly stop a running service which is "the right thing" because # a RPM package installation must not automatically disrupt (restart) a running service. # Using "--force reenable" is essential to clean up possibly conflicting/broken symlinks. # (without "|| :" build fails with "Failed to get D-Bus connection: No connection to service manager. posttrans script ... failed"): systemctl --quiet --force reenable saptune.service 2>/dev/null || : else # Refresh still valid disabled systemd units and clean up possibly obsoleted systemd units: # First using "--force reenable" is essential to clean up possibly conflicting/broken symlinks # because there is no "--force disable" that would clean up possibly conflicting/broken symlinks # see https://bugzilla.opensuse.org/show_bug.cgi?id=904215#c34 # so that first the unit has a clean state and then it is set back to disabled (as it was before). # If a disabled systemd unit has become obsoleted, "systemctl --force reenable" will clean it up # which means the unit gets removed and the subsequent "systemctl disable" will do nothing. # (without "|| :" build fails with "Failed to get D-Bus connection: No connection to service manager. posttrans script ... failed"): systemctl --quiet --force reenable saptune.service 2>/dev/null || : systemctl --quiet disable saptune.service 2>/dev/null || : fi rm -f /run/saptune_during_pkg_inst if [ -f /tmp/update_v1tov3_saptune_inst ]; then rm -f /tmp/update_v1tov3_saptune_inst || : # get back custom note definition files for BOBJ and/or ASE # needed for migration, if customer had applied these notes /usr/share/saptune/scripts/upd_helper v1tov2pt || : else # cleanup of old saptune v1 sysconfig files # leftover from customer migration for file in saptune-note-SUSE-GUIDE-01 saptune-note-1275776 saptune-note-SUSE-GUIDE-02 saptune-note-1557506; do if [ -f /etc/sysconfig/${file} ]; then rm -f /etc/sysconfig/${file} fi done fi if [ -f /tmp/update_sle12tosel15_saptune_inst ]; then rm -f /tmp/update_sle12tosel15_saptune_inst || : # check for SAP Note name changes between SLE12 and SLE15 /usr/share/saptune/scripts/upd_helper sle12to15pt || : fi if [ -f /tmp/update_saptune_staging_area ]; then rm -f /tmp/update_saptune_staging_area || : # handle staging area and DON'T touch the working area, needs to run # after 'upd_helper sle12to15pt' /usr/share/saptune/scripts/upd_helper staging || : fi if [ -f /run/saptune_is_active_in_tuned ]; then # cleanup 'saptune with tuned is active' indicator rm -f /run/saptune_is_active_in_tuned || : # if saptune with tuned support was used/active (in v2 mode) # stop and disable tuned service # enable and start saptune service # (jsc#SLE-10987 decision) (systemctl stop tuned.service; systemctl disable tuned.service; systemctl enable saptune.service; systemctl start saptune.service) || : fi # bsc#1194688 - sometimes the tuned active profile is still 'saptune' even that # the profile no longer exists. Try to clear. [[ $(cat /etc/tuned/active_profile 2>/dev/null) == saptune ]] && (> /etc/tuned/active_profile) || : exit 0/bin/bashsystemd-sysvcompatutf-8119bf4e6edaa72066772e7dc550e84256a3654e0d9fcbb777476120cd50c6ee6?P7zXZ !t/%]"k%{dC3 #D>S ( ndQ_\0J&* U] Md)^)z&|E`~,/JlˉjO}2jS{{xw BSУa?_I.)V\S:ڌqjO%[<~wdTVE;m Div솓0$'H3ab!h_*炫{9\ H{6Q~@ U|v:?MLm)Cnge.O%L&އ'vbԭ1J\ٺ;4nT$޾o?[mKtcL2om:GHY?CuFX9v ~31%:l|żg\]dG:y*\ 1r-Xزuӌ$]@17;Dz| JK\ Y Uj*i蜆@ I !CSRc*~[YE/>`Oٔ-lvsf`7~)'m;G+x(\W GLL՜g.m^oj5Mlr; t(}SۏW'<>эCRQdac=v bҔoSxJJ#؅@Eh|W<0_/B(l?ؾkMcݚ+|LePb]YmCBZDQ9't L-E+VSƘC̼0& 竘43 5ucYL< [lD[ێ/zYsu2hr8^vo.=F7p˜(f]7a6sɜ(qw*\R|q,^Ա~1As2%oG#u_9qYh,p2JG]9J9Gw#UM*xrNY'Fn`H ;"xʓ"! KJ~kL:-:i$ {{`FN=b8F &j;AR_IيGaE3ۭYx>vn†5TֻẎ rӁԒķ_rΌ T,pݟŅH.x[RoԦU 1 ȕyKh3D0H<l =p9Q "c1$)^`Sii>0(Rz0|iYӌ- }}n+!X ۗDM kŠK|տ*\#62%|nX$p)fq8\ t{H~|Ǭ^* =~9}$P $p@dIiڪc/fZNv!;vp_YkFUO2Jm1D$\C[5~в^_86h:SOQK"WT +Q/ٓ,.7$m7c֕#OMdsJa{Mo1^ {$P>@~_E< KzcUY8tDgZ jtSheԆNOjWq+v4 >^ &]ٱu,OAA)Av-zFhވs,%/l]舮T.[[Mc_VрچxdN錫bUr<&P$5d(.rTun]C%(HL¬ObܩlsOmSVaڠ-xٍ;TQg 6%l3]!y} e&un(t 0+M-Y jF" 4ܨٗrȂ=e'px!(E"X^e^ۋK.;͝?1D%qKC3@k φp \'PQ8yX]S"M[L+%kh4t.h.IpLT,KڠhuzhNY :E $NJatڬG.,"W2yh-qZ?!C4$Z j]\2w,Im*B@`H?pg\ݳЃi%rz~4xШMJh9D聛f×Tvޚ44 8ޏ^Qf楹zٔǴaFo;:((p̿ 2S 'Hl㽁RZHC醰|t|Gmt7K# ڰ<۶(K0{60yX FCc1h{z10]5{zL4)8O,1pUw/- yGi}c97ԩFn$j͌}BfHs+K!ROK-[َ80'ڮ}*X{Va!Cj6N9~u(&/(G~ #LG Lr""b(xC";9?6^bi߯٤ Os\'mJL}~fjԠ#ISPRdP̧eo{V)̫(LHؑO^D<puJN䶻Ilu D.3.huT^3VА}/Y^sRbc#ݒ\KОDJ_m䜥[iq?^(7LhO/1`ӋU`Cnj^BgH@hoVS@id sOI@|M##Rw{Uu@MɒgK߆r-E&5 %'޾0νYG 4y*l]*F 춦jLtە.ޒ#,C%d =(3A<2T]Λ=HӖ!/Vi=qH,oCg2IG܏. :?/ -T+4t`R.:fu VDΝyRa1! Awg7!\L dgUrTZ/ywUy܀}zn,iEl/qdA@yT}*tze }IF En\1|i 5>LvՄiWȫՐ3 XDÊA2>q{}:F:*Ɉ\Ρs ̀շR&vlbk#쌆LXaՍyhc&!m$'Thk/W:C㡾 Clm RsH@Ӕ:8G:S2G0(~ &) M~<:  #(}o0r߻71bZ>1 X%r-14<5~r6'*+[y>Wop }։fIesV?fpۭ{d#'ި0)B+*DMqR-L EUYC0yrSfhX^Ja`W;#tz8 B7McE)T!iq(c(h Nm"ݿTPv S+P)HY'J٦E*cHzs+vhtpgy6zxCkEth:qfȭKƭ;H,\NV~S6@7<#G^cˡ9R줔F7jo0 FRF(<_eg1'qߴ17($Ccj)%໸9j^߯8Չ($=1~2a! AitgX[6vXnĸt؜r/BǬ􋱙d 濛GCH1.E{TL }Z<آk~\pEӓ9#Fޯ<1*"e_]h-EugW~PirTDtQ .` LΤEN߷J~;@;T#XOwSR8_ÑZ;ȕ 12iHt][kt ]4hbĺ;Wt=t? mѦ ktDEG S|a2`W4j)k3wQ3(M8ɹU[ `Hd<\c'6XNKΖ4w$ XBJO4rh1$ӟq$D5EXL$Z(2=^P\qH>3.( ݸ>&ChSo<[P4BNt[m^.E 'mؕL$&u{/>IBW'A̗oW/(d<%} 71DlGg"(k]E}.!#IDB۝IL hyd`LGSM(YPZ{8$E6CRXgꢐî\-;$Dϣ;<~i{?soj곝.K|Ύ8ٝԟ:C^EiFVJ̧. Pe%xpg5!P_otbܯHH j71Ԛ* LEקk v{h)%ZR>BG."LmjFc`m@ov }-1Wq \\`~\S\0^܋Q5RsgxOӥdR`4XҾ ^W 22*ۖG5,Wox T zgaˍ{(XIDⷤ w͗iNO"1u2,Tokon"$68ĔӍyr`c 0/?b$Z}[n@^9 A z/d N QݧŹ*aCszr*ۼgib_Qþycj*nfulĹi>÷^b]@#s&,O17"AYi}m3\ހ&\WC*w4apTЅ􀉓TSA5Cqofq‘\m,2gn}婿٦+$ug02h 5Ci t()˛B_yVI j;aH &\ ptf{. p٩=v2TDݱYNO$KjGѰJ$;å'bJqm5OWkzL\LA s \c1 q*,~HCqkQษ%$io&Q" q.BAK?Y.,mtkSqDSTnhҜ9,tJץ8 }Լ.+8%U Jߝ'ѝ`. Zh"vP*~H˳bL>dk`|GQ_Wq:co汾5B3hK}w lk?yx.$fHFеwcm V{ԾtCdkcڴ!FK$ Շ;Eߺ}GG!h@OeGxy3gga.L3+>gG AiRѶ*8oѝڬW0 Cn8'0~f#?U+k[rzBn1yK2 a@ өhכҼۧq(l>3a t^&݊?uYef!ĵJqM"BzD^RT;{=D{֕{\nM"iD}ýut LsbS:]c6`->{BޖM}>[oUV1;H6 L0kcđ5CaPhT-LħWv^XwS|~ &`K'׿lYy3\3a%N-؅̔cq*zlQاDKC|~|û3$'ý;Ɏ:GL;8sT.L _KUvbk7>|ǸnWȸ.8mXq(p{0TK o3nkw&zس0kZ)4v)"#44R-rJ{!LxI|kU?;ݩA-!VL2eMpk-: tAFpf3"{3}G4j f3eQeVCԩGHy^ɯ8I~x t2SY#߃^I@qiz@O$B!ٹ]C*H)_@@~\mʽ \PUFKU/&8IN(HPmϪ1sCZt7 ?k&8{Z9V}rѾbn#Bz ʠʈ7$,Q8(IUC`#jA૞cȒv'<fB%I!k"\";8CMyу4EHk`j2>3b_5[mn7.;o| ֐XL+AaSr/eh=ii T,ݽcTQ5_[8D eXz 2`s:k {-hnԹ:Rf\x~Nݎ”9%gV<`}9^ & hȁP:ASo++]s V2䥋&Sp9'0 6eC=%e~lCHNֳ)MXSE3WDFOeZ% <4'%C UL @UϮId"'@'qZkҵnKVGRY,a#Yqt+yɶ͟hgL r/Ư'9Dʄ쥖o5F4 p(}ל҃Fvrfu\J%%zd0IA?*-)Nx@?44b e'PB WvLf-!VjllS>Sv_i H,RU&nR@ '$rկHJ.+ 0r=SS`r*^Src:?0\B=Q;\-N,BRAS+5Ŕ˺Ra!%Eu"%zm[$~Y% OuG '/ LePJFX}`6M@^&LelWvi)OZhx Ƈ=(d+5|tn)?q7;?OMu!YpBv06A>_Q}LW*x^0 jͨoߢk?Y璑4| גjr)B"tAd۳5 +E"Cu{V=!"UCE,+REn * W|&ڢu*]`(zvZr\nQaR=OS̗pzy<:S$YŔHX F2 CoʨiXrAi cB72-v̵w7qX8^ I_ȌȠh.R\^EcH$j|h0ٰ,)^hwzSHRGcY_"xLkI6Xmta}ID|0XRj!WG!sPnb+橼!hUlS{rJД_Ͼ!o'2=zl C= rwk?3vd%zٺ{n2OKN"ҩ$MdԲ(uQ o}(2J3c.(R!^&Tp$UTE3>52 3Sm`@7Q9ȯ9 JM?0.+7 2Pw+k%>ih%&8GI?Txeݾxh8~ɏwR2|$v 42NF'rK^:JKz[P{D845Lpɱқ5\?ӑUcR'4ŗ "Vk4 0* a;0^s@dI9|Ͷl#=Ǜ$h^<GN28RowCh 'kvL? WuORYf3߸¢9^#-K/Ecj4:0Og,)N*AzGt Dhw=|O(q!u1'j-;ٳBi_.39Q)\i;Fc54P{ - RϹn[2eߍǔ.AQG#]_3g[r:]-Pt"A0Ќ`aRds/Bޥ6!c6vWg@IVJ$}-؄{sDucNI]fqÙYdx :8 ΟnimUZR=u-$(@::5{@7ӹtGM&~j!'dE睫Bo3蝹ޔ5*WԢqjSI5Pu%2zlR܀Fg*ׄף w|W9cFe`j8]e]#Mlu닱t1 <{zTm,@I3SAb ~-dfoQ1J8kgk*5Oؙi 호|FL9eQA0e q0=ҽr^~ <x/cMO=%t΋IZxs_I+GKI%K fΕʒ糰x v&aQ|gC8">z壱qQ"N089fm7җX=,goc+Dg^_?!ZNehk*' hZB 8}Oc_kE3tk0P7ib|hh>Va7µ]Zu9 iUɥPl,̿=_msf.wƥ*#ò܉[+]{q:Mqdq؂҅}?lw?=Fq,дAhu WkHB'Vd灡Cm۵Z 8ϊl3\PSؾ }r, SD<`[I0Wo}7[v%uQ ca{0 SzNGW #͍;\chGmy2Lfm_[QD:x;N1EmZ$\YZ7WEO7j7iܽpe M4lr NnϒE"s'KC)<(djwq"$_2/ |)D#b;xC6pXtը)#t;z94 ݏ bȬndȅ6(e2"GЯ=1osu5S} ;0B3÷ަ )v6[%tM?%inBR/CVf.ϨiM"{l@%u̼6|wrxT. sn5I0f4 2O }̄uxvˆp u)A_G;-~&vWғploi1`$=l@gFn[VdS#T&[+ Oabg^bN%Oi_!|=qn DJ cN邘~fccEMPuŊp!Y=#Vttc`K^%HA(fz|֘$Vԅ6Zx!?o_}-Eg ɉTi`M:/>Ʀe6"'H̵w~:]>{}<$ߓ>h^< FKS¦+ϨV1#R^$FhjX,x5~s_$D8t'·PBU}R۱.݂|'YgkJF Y5/VlEkS%pܸniE~B 9=+ܱ:kW[ \pF͟ \.{ s&Pam`23fHY[ClX]o/|r $`G/Nfu hӺeB;1]kYb:0lA7!l8p엽/K ao+}$W}aRwH^jl@]vt#R|mI] hIaHSibHrf*{[f_#~зr#9S є1;ixLpsspeY'u\ECRI!V@*CL`Rnٽ}"$w#U>}`X ] >scwϙ517V~EE]o.{7J>d?:o[S˫7jV'zѥUe;QiLS2iGln˪"FW(t"u$"leCY 3, FFʱVjy( +YhDZ^1&u*Ӭq|(Tڳ]CQ|O )Ct [^7_"DPt6:dv@fR]N Y䁓IvYLdtPHNU..+ 2x^j""‰y8ۃUM'6NEl~D{.uh$}k|mP̗j* }{vaм=;7ٛ ̦$dY#*˓YX84"p]bt6I Cjmu"H5ħekWc4ggk+6I: bcgyY/P,^w!ٌ9)gV$Ln:'p㋐sqtM0YԨTg.~xțbuӱSX:,@Sj&WؿLADUC%<$m:wC.jǝvZQ.N8"UcK·v(|捂?q:JyO-瘯[Y4w\RȌrVKDSy (&OxxƝF=<35Ύ8W#r*e` +|pLed#jdN^ceja%7Tiٟ[D߆Fo UXcA%n]>};a윟' ].q%kOEh&ms=#8um?Ʒ լ),GiD+23*oҼyRN 7U_O,gR n66Éq\:iI b-="};806Hua*-t+?л*)9Ev:-,AfPeKy bT9{9?]៹Ũʹp~,Qc`mi8X)$ ]g#2htP$_h@N\Z9&cGCv@pbn.<Qۋ[pvz$X ȫɘzv5@Bse` ,$;A"$\_  Wr'Aydm,ݷp~0t˛dֈҳyrj퓳Dǎ񃝗@_^s!{|RG{B`RVM$O}?4*$x$,)xvFhwNC(@VYF$6>?$f_qy3+]Х/jQW^gy̱!nvS])˿AIyS)+.] 9K6v$w=w0HQ ae^TN%jF {y4}3|1{הβVDz56ZܸiA|Ίجc ~#*悹Hͨ5!1{y)Yz(īˋCs{gNUżF󿟚Dr:kSxƑ !мHHZ†d۲t[t5:S|$FZ47Nx[9єQ9T+{hH x@m\Fn \K=g?G1ԙ]&{pԘYN{ mvTBSx)lEGk)j l1P`+NВWpCfM9df_Pg U+nG}PR$UuLPA>BW,eЎ2~D˷ݼ3V "I?55t- Ct.my4 (oRt`eZ)37kZ-Ȕ;Qs%Co.i9B0tWSPS08i-3IHlG%ڣ9u-N.M-+?J٫k%,W?tIױ51~5X2czs0"rvvs6g.cN V e.u"mj.~mX 1CJt ,Ȫi 5/s{}|@yxpj{+j!TG=v\J5S:othh0,Pw*2뫒|Nbbx3VF:v!wfnL?|{\qs*V_k/l]3ђ+LIw ÜYNbNw,q5'%|况j Q3BM6B1O{㿦gTCh:^ 95 f7Z] !sCYх CjJb۱b>t]{rQci@p_21{`ېZ?Erm!M ^=7bҜ};[h 5C}f %mH{./Ԅ0"{%{BTyU}\q'"Άls#*6Y/$q PxT dVyU(%H4#Z\4EK\jO[RǣH7h>-M>HJS)%XY;7 \[@3H1gp51"j ˘ǻS2{5F,d6Ը< iVt7{۵hglaS,̇@r4ÅY pQؐAHO҃]i@9.<TZ\BliIys*Ԋ9*^Y=?Avk0UtSRцszmk%-A.; 7Ul}XPHG)\䌂Oj5`NH2\k0qN>LT澍_U/?huP-/ tB~fAqD;_!DgV9'~\Mc# $a$Tݎm5悩G*z-MRna2fvh߮6<-<dhPX_.$CV︲SCޏ=aU%< py,9扉7%$E XA A؋ t-A_V,Y~3mԜy%a"r6)R .,jY d)q`쮋vzq9.?,|+,B̏Nܟ"kHI"mv6qv 3@zHy=2zsZz%:r'"&GSS|Qƪ~F'qઊa>g~^7ja@)scR+؛; MM 5%^ZC`~Gc4 2%G' 25F'e+ʝ:C|M*>>0*="aN/ Pw7ݸN!W>!huqwFbr^-7c#GY@2@=fg%/:WJqoqsoHG|ziy[ %EEDăV$|.xN  Y7.;tՅ2.Ж>ChËHC⚄-e»`]84a ݢ\ս8p26ȩucm{O3}$blxFNtȽ0*ulϛ3$;z_Qf^UjTL}5sg\~0WͪH8j=s!>ǖo5O˻,V1A[>=a  :`sMi'-2=&[rHW8-8ok [ǎ'Aةk͓zQWk5RQ,}ѯO s07 g eJLyYIiDFj׀ir1cխՈgdB~/tF!31֫9M/WG7tǕ9!hvGЁQhoZYAT\2OK#L\M/iV2*!EB֠/(秛,&of[yD_yv }IN98 v4J7ܦ1 $@|K33nTrY/pQ\a Wl6I]6Ì:#EcAH?k;Z{‹X`l7oV[@7jGڷe@&!3اH4*?OC UsXPĚ4&\S'hp -FHwM5l|vhPv0IEDw0(= 6^6A OT2ixʖ?v? Dg6 :}kKstLxKg=PsTr^A 6&5G` K Kz~:g69!s>xZEuCJ[1_|(H9F,oQ|?VzOVY_wa|Эȋvg0"H]λeļ(qe:4/zok<~8_HS _Ji#:۫W(7edp*"qnPz{mK,ݸg%] RӝmkkZO+8nw9*qT2DlϘtSf%ĖypOQ{ Mڼ% $l3顜Ki.0E*-E ߝ//KGC2iu ])6Τ@|( LU*Hc%1^F0iOiUnI1:.G=葇X˕c3sRMLyZګI+͝wPǔN>m*γH۠T8. }U:?MPm"ijÄsw n*"~FN+{! ;#FE.["ZpǂTGD$ ",{XWկ 'X,B+nSlU{@}t5;Gپo=((xC7o0rF#Z8@42 YdV6f w/g}scaurO]}]4ՌǴƏaZKؖz$>ʄ#0JZQGG)q( M󒁄dop9t~qIKg2(Bb7KS\s=e0pÌL :5ua&o\X4`m BK#yCV!B3 X~6KX%W( )9c^15?SlyR; "[(- 8QQZZmV'It1 /͎gܠT7Gpl%"rN>.3;=jobh%no&"c|k>R8"aK6t k9PA(8]n^fK06pGًW\΃^_ =p,\]uhl: q"}<ʠQև9ڱy-I sJ~װW#P&L9!N{| 'D+Վk¥8i- "CH#Hx;sVu6淣 y@}Ga%eAVM9w[9֫⸸lVwΙfPODR6BM*>߳j-'GfϩkDSv$oKrZ>c%Ej+x!@0t(f1Z$muC]eRm*c>TN;ذ/:[%XY>D+bkX,mIeK0G&s#ؘ'r6$"*Ah Κ ,Z3^ÿǯP; gJP.eH}BN,GgITۯ6Ҭ Ƀ/aeo{GkZ`J¬x3eBHx,{@g_ѽ2~iMŸ$59|-'7w006J:`6 $O6 +nЭ$˝2*JF]8d 9,hhD5eZ^0Ѡ|"ߛ^d.Gӣ2Vj]tݽ%˚ #Wƅ} dMPr0&km5еaoޣ]ᶬqOip콉3cQg3'zjomN `޲ @֧BJljbM m -L[ܦ2/HMPdalp_e1 gJ`\RM@)Oгis`~D|[=LDʃk\#|s4 'ŀ>k .Q:ͬ^S|T CSS8gzl gHbiT Jֹ`x^NPB%mҹI<_ݮUNa;8rB)> 8(pq%RIF'Ost+l>{ه˟hՖ7! p7kMCjCθ@Ӄ,]n={!~R;-IJu\Âތ}8kZ/h]d΢gnvRQctWX9ǣuQW9:WUmGWH~f ܫEc<#@X+7!#?';~f0nSLĈ[?fdRsɪ(yDyd 7~T@;ЕToeU!D.|`fY 0/rў$_>X,yp4r=|g.';d;@W[|Зfׯi.LR_ĥS#+E|R [UZA5¶m{lVu)2\?8iw=?PQkFIE,I[$޾8h(f. %.e)USIѻJt1a3&ƨ7{7G-U(%)ۅvYV"h $:e*Mp\{!BMI SA+rs)ޟ.J;4:ևWi@2IA,\B:1fQ峪~6tRң&ph2 0]:1hWs̔)8 Q@H>9} {T=͉Gր"qñje0*6 Tڗo 8n(ՈT*\ГzFWL7|&1-ҪO&D1ino. Q6@BJ (=LJH'Ak]2p<"~BX:O=;}|oiUB?%A#$loQF4+_$%`Tr5E{nca+/ ɲ?̠D̕_ x̨r1 \It\9bcRG(5Ӄ3ݼaaeyBػr̂!iU0F<, !+N*/z2&0 x{a~8Y[@shcv(l2b n% V*=ѣR{`׬EYς)[(5M"/E`["n'I>L wL~ɹ5kv徭KZ۔W^=i%4ƄÍ ] _hY0K"Wv ,m)RSk#i?lh,`;)4q]ɟZL!N7~R(7+nu/4lAcX_W/2KTORL>:zRi,%yMzu 2(CVF]#"7b3d3Gb^4hxtP^m6l.צJAKW $)FscJk!\6Q^ⲛ=;Xvk-@t c# ]OU%J/H45\\+LBJY{쌚S$Y =0 'dW9wHsjk<|;B"E[hAx/P!!AQrkh-]Io;/ssiד]Kfj>H r @"0rU[)>cZF5g;IbQlDRu^<J@C ˜mfC.{'t4"GqHd3m-K:y (s1oYoa͛"$nafIWgxfHoʊ70s}aT.IfP2~7ä;fo&,3wd!g'NE"۬O,c!"Ϊ98x8KS3͓9!s0[~b}h0PhM(I PmDu }7+6o:fpN89pXאZD=kVU/7\"JM=W[_tZ'jE \GuE:'cYa"0f.VD}ZE/4 =۝{%>2cY =>}S&@f5:O]eWvqlhbjz8zr )TP"5(k ;z:m32*~@3; .2RXiѴxM:o&:h59*Z.vi:>";L.GfZGq46zn]((B7^!{e27w·:¹SWѩ:hDϣUSus-z|-ቿjԞ\tC㘷J^ܠ?rC. soa9R T„=TۼdL>YUK%~70؊ic:w6ǨWgǶU]Ry9Nݵ^Qg%V̳kb3J3GH9ly5uE=T"-/3"g)PF08Ilye Qi:2meىާ:}cd,}O&}f+DR8tZ,ԐxqM+#(gyw߻wF= ϾE?pAZLЋeWNM}}7Ei>A>)@,`AJsG5A94?WZP.p4ZȏCK͐}# u]aB ;\"3.GOx}IzoLJ:}ڥê[G\"gNu`\ȔÑWPFeȔVj M)X7wS~  !bhZ!yfNG#F#a - в@|xnH.xZ֮K_ۨ^7T粠l PN$ʚﮄ:>]jO)U{=6UL&gxjd&ٷBI 6UġP&lG'԰+Qd4V/L85֊_=tu鴝c)ű]ō{BJ l3#qW}z6k;LFsXMzЎXo}Nr?tp櫄EOB( n\—;!JL*Vz:+&CCiK)hۨP#M'9A̰;B@FDdP?^M[kXQ1IIp^Ti*y1w` n_4{yA(Uhf++-g}n$|B:e ar, qVyz)ﺰX15S,L={PA108J=A6ruZVp_G"aյ-mZ|kƌ6FaQ8{I\^%M&YU 7CۖmPgW~o(Or- |cIhk( 9w9ңN@p<$}}f۹5`<8TN\f]?W0-ZTNu*dhaD ħ 4a2ea+7#-؎K170iCFqzJ Jn<8Iy!sf6-FSͯ(fc>0QR&N7aV @kgXCJqtI %eljlU*G0dhl|dHw@-B DW*1iܯ|Zun\?/uZRY MڿYɊ$fvmmkIiLڐ HDx!ۙPN_IYe/q?(Fped3<8Я_llF=0[ MphQxkݲogH ~'1M۳cRrp0tPvIfVƩgQG,Kwg$Cڎ4+vS [kq/ӝ$Z?lM=ťS?f{)n\r泅3O~Kr0D0#ci WSwhzQoڦ+zO#ci5ԮoRJBԍQ'N}]:Fh$%obT_.9Q:5`(A*V?XĪu2ĹK˜dXB*4&;$ͱ`&-)] ;6QM޹w9l# Ģ5Onz:^`x꣠ZQ~$`.31BD؆XQa0 t.[e,>SHEx&yyJla*MI@nOzI=ٵCPS˄wbC=&̑u Kk`~+tڤ+ ^n*F SY]a4ÆF a!dFf/!ISbUŃUڊlXdr4-wmg_}d|;HJ s TX NJ%ڑcxC3(@Ѻ/zrF27Oz';U0(0FkB2!`, @36tG`%"]vYyz|٫FH =@& ⁜I2g $esӏݖS[-Hj[ 4L >2+#^Ub$Q};T&(F*i~0߳j 5dzR;{&A%^WSjɳߣU=%8T@eX@I"#,z3'E~9q>+nZϺ 3Qu.gRAPJjG91`p">ѓGh{2o pa|qҳ3Ì!V6t}'}0.nH\ۙ[ }.?wj$e/A`ا2_! 0n;?l<>nه}QmF:ĕvF`E?93>+iJ]j)nA@ΖpzKt=,Ygut| ڧJך:Tmo+$hh.-MU Wy [ߩ[}]Aզ'oj@O2f3Z׭95I/ֹ=T'EP7pU*>9-ُO˱&yUGcxQɅ F=)>dvCIi$jS29gS7s.\KHˎ3%@-erx4E =ϵ.B6)70>l~nbe X)^Ϩt"~Ml-^h#soq=B?jq{̬#q)ȋbuw:5VGZ wEĵ^# |zdwv!c+>!޸@_GMSȺ&IO7X]"dEm?m PՅ]x"_Љ.J8CKpP.,͹yGj;bl|ܥ/Hsy*Oce2&0ѴKsN󪅼ݦ%$aqԤd+?]lPAU^C|^T?aZ Pߵ%|I$Ct/8z?q_yʕ%6ckʿˏg]0xR3NW J)3W xTk a3,e#wyDk툩Y]w壴rPx.i=v7Aɂ@T(5xhAE4os 2G&#~:f=E3xAN=VOZ*$-5':m=:q#^P [ͪRw1>YWP1Q2t$S 7wY X38%i 1}Ot$$A8e!iMtH ]Eqfu(rLQ1ULT뼏3겼zy?ۑ4 nb71VbiKWX 8Rybkg.Ur&E tV4IfПj4nRr'̱ԩC|T.!7`{m+߄\o9o48F+rև\xM`utQtY4^R 0~,B]"[>/:X9w2ǖyZ!|yc]ȼi\KL"h9a:+.}fmcif6=#<\5YѕmwFp01DSa.ߓN'{wf?'CC>6eSQ )zrYR-{L`G76j|g7o X "ݩZ5,ۚFAj@0I IɍZ*[EwwV dz!ۃW[eb9Ԓ@?IFy c`֥|xuO6۟yPD0`,Z_<=KX=W*M0qfrtZtAD 5p5+ Q鳳(.'>tp%])8ulGG6=_. z+0 }e78ޭ@ʧS~b02Q%$1ۯbU=j:VbySJq~#8ݙ]&.='oOCpc:TR[c>8ԘBDׁqĦ'hJ}jEr PU!n򇬾8ff Qo[@|67 f>E ѡ axΏдm$,kro ) /Iq2I^a:\)iՈ'xӜFnyhکٙɘhgh~ F!U# jk5/%Y3/ԏ>e)$ lI}Lu0,рo%pUcG4y. (yp@]m'> u:c;-p7UOe>O甅5k܉P93/*KI7?@D/Hb ǛԳ5+H?Wg0Z.tԽ@E/B{BxY6yu: x$kBT]J^5tA*q_\2'fVzy}ł:tnT]&yc\ vu?>1؁ {sqT6^(lvt%|v4oBJaNOv|7Y_"y1t&(|.2.[qe9s5]cFV^T^g av}uk@}4c9ÍZS iW= ~E_j Ԭ"t+ȧ6:Wt3To&>§H~>D'?y&j< ȥK`Rko"2Z4d37?AE~j ;.c,2n_$қmV37{I(E4)Yh2| MՀ4֡+LK'\h VLѫcvR&UvВzkDAF1ɪ/MOzZ+TmR7[p9Ju ::^ȵD]:QA4qvnsܴ=dz.ɟ)MnM:l&_|bf 5{5 NJ`g@G;z#pB_ip]m~fdtaJ4/3S\jK4&-r1P1y=_`j(?(!Ǒ􂼗y .-ݴ |ma-jSI)s!`UBB/fwwvΆ mιw8AdR*T`p)T9y׍? YPM%*[ljmʗ]mEjZQ$-VR,>dIE%', 7(XoK69STJ2/Idϟ7k DCmIʺrn 7B4 AKT'|)cg @:yo)|X%e=ÒҘbi&N&O&2l$;0nBR"_ c Fa@T-Q*ZjNj{bNQ{DHFN?j+ѹ8A :SGsr0rC 6ۭ<8:E X _O| 0t%zn CliZJnY 4 MHy5ys~eDMka4Pzh9SPg4wFoУ#]LѺhuDiV\+y ໩<ccn>Ed4:΂SeϚ ͊OV%3ls,p7OMbjM)[44P~E؈kg:+GǃQwzl6R} e\\. nk54<`0ԪT/2~7X\s5BୋMd`x~,,['CélK)`Q}0NG`C}7@Ct5)-xtB8y¿@j5^00R⦆> zڛvE\:JW},,"vYBZ4م7"%qn7 53{ߑ 4O]F4*5-`wzI/G0/} ?v#e-qseZ yA7# `܀SOh+fo~o6ϠpTxO/^/S)?h\-,wd w|Sϻj$ L,g1)/8g^ J䷪U[<'t n6 aXrh9) N`K<|_GQUX@-"m&3BtMv C8:;]b u2!=~52?`T/|,V(gf 80KVm "#&J- W0 57LWiKR$lȔeKT~έfpx_(ihiwR _'{oI+ uC+gB!)et'%.퇷Őp;PְS uܡpiIgQ &ċZa =QyXO1ؗQNj0xcKb(V8$ Ы ncx{]aߒRbNhdُdnzB{`@8Sm#3+ɠ"R%G|uC hC-̿ă[.(ǕyUVlZ)@8|'0찎BMPTB^I.Zq*א hZOj͢X'=2T?)G}V7Kg M2-:ųqh !~/5xx7AнVFU`9 a)m9k 1қ'M,,c`]-fz9t ™run@V~2._B. 4Wzˢnu|ƒT1hSF͙us>oa?́yגϜL]FbhBsO9|u{ljX1ov#aIx'LGC@xV9b>vFCi\7+<9'`^Z5ކ~dMd܈P$p^aG=fpW%*j<Og(EK(HZ_Y%RA89Nf.'a?zl.#jZ/C[@9֗x+ c*%7/7sMYW3,lo[(8ђ_bQI[.Ʉ `3*-j mp7&uVUS 'gjm?aݗ\0QjNu!moyzaZ / &kGѼԸoUXQ( ȹj@#߼Ғj._q1^U̍+?_ ^ NCqt ~^{y;=' f}#E`n1Ee|"TF(fKO9![LETSs%}5 ݺmEW2(t%6NI=9(GS8p\ph o9y{f/=KÆ3ɳf$_P%["Bw c)wǤh)16؜Hnm ?e6z ̷>N܆$J eGUkSrisVsl(kDN4Vj *R8$haUފ(şEfyHa*W9sC-VFc%ZE s#bs82aOܲpGkch~R~ieC6:EeVE. `be8?A hة:t !)ibۜ 1r9B># ysM-QDžQM5uB،#|(}l9}0EE; m׏ BwXg*J?;{ǾŦ1I*,l9{U R> 'a ee{j@n37g:Mr`RylS->~9x"I$_WtG€N8Y+1 #RwDD%0}>}7F)xc ISHsi" +L2~Y9"D3]k]u6ɛ*u}Fngoq}k j ! :|.u|%nË2|%$>k|]4;zNޚvO> 5[3 0o2R7(3osq0i?x2b{@ }Zpt+dJ]j8b?}M[W $Ex zn;Up.y̔-V>ݨE4㸑]NL)? rTW%c`t?rK yYvjxr"ee C:nL>Tui;&}ut?~xՂ¦|2]Hkf\o@H;O {"߾u–džH܎ Ū64(RCXKQ{^r]?ŽwR4kӥ.["!_BIDw b9 xV4 p { Yk:`v-P7!U[G7ݓm7<a 9;05չf0bk,0}+x{w!WxәC*Z9PsGqVBz;J`I-:Eb 2'v~І Gnx Zb2mc]S|QfAm>~Tg³=id2=~$i$;RWZyp>d`h7>0Zܟ`Eevvv}BAI#&:I,0p ~"sYݪ<75y)9H_D>y7Hj?C{|Oz"|qg T:03*!KhjwJPץW%LxL݁DSr`@eS|&J LGawEG*ÓGjEm>HkJ,&i5*fe18)N=WaVGT௤5f3niW*Éihi ᭙l`ġ[80O!n2۲.O8GDUSEM%@4YΡ%eDt6;U) n*9?aPl?vJj%' j{>a>5)v,tKE>~m!=8iGoZOM]fK A85N=Сl=\'D<3^ͤ*" H/J"+r= V6k<_N x,BH EB.vB2lRUhx6 sG}?/չB5FJᤃKfʌQjeot0H- hΖ6隡~="SD=t5FtT<1""~<LX3#z2q˽p؜WxUENBThQm s΃ P,I |Becg%YjE(u-Ee o_:Hr6X\Ϊ>$&kY!6ޘ&An)4B;=(; &xh19jOty2rdKY#t\쬳+.}tu^\J0RH zhmߞ/'Urf="j輱nu&oV_X>dZbPC{T3iq>p-,_~i5u2{:Q_]S.7;[hJg-U%6$w>]DH8yT6\7͆ #mEWZO|R ,wlE]21PxI5<`JT#, sZ;<(]`7mi^0^?p]5>z'+çI7wESqɤ6&v6޶>35?K\$.: Ģ`&%szixqO_Fn0w^4M|3yf6aV!_фn2辁gB\hQh=M,;>ZDq gM/`qK_YCE3]3X!~f ~co2Jx7eR8acj4 `dNQTQnVṄ2@eMpUj)Je'Rs7,';ː)"%FW)<'+basߎl,/-ۣ%ft.Iuț9.W%}GuFn58fIVg)'wx{d^8 zB!½_wh## 5apr#RCw5sŃ]E; XcL 1ZH3ʥ2{;gק@2 Un A ,'gPtm=e/T PZȎ7hyw?,),s5¦A(r-=Y=%f%4`Isn턍 uA5X#Uы`ԛf)kBtǷq~# wO$7Ƈ-O3 (wym]a!srdNsVDʸ0Bv`O:NمCM^'psC&5مڪq12͈=@ʘ$R*r!VV4e,]1!4!v`0 I6 NRɖe-qx7z"Iei N K%XJ? ~M,v~T{ȽHҭESp ^Ǭv!0h٥ Qt?*_&=QE%l@>먪ԺW^X6+ fV]s,ܤd3Tɮ:JNpuY^&6s-q:Gm z'\T|q~%Oy@"Id.gN!0RAB4pWkԡg)L2*uw/y#fuvc̠o ;YCIg >P?CY^`%o,{_#݀6uU젫ŭ%|{iݶN&vZ2aVGa\`8b H#[s- ~NM~(kv Ǚ#$=ґ:@a7lMkW'OL4epheQM<-;̉JYѿق,>D0$o V()hp%|j4}l|c埚DuPR~V]@Zי^ie0ې3k,f` h @BT_'DBkmU+W'o/c|[=)&,dcבBbXPBt86 FVbKVܺ<4]\C!J$7uɚK 4ŴFh p$H+D`)4}AaLSN Rܝ@H,PoL@E$ ~85% VŹ ؖ'ZB }#p )6#ї&Z`o<_*cK h[_m2+BL4eAN8`{ JY I--Q-5P-瀝NO,7;rKjʻmSJDg\n&XO'WEF +XoWm24l=6BHWn|EUYeNq@VA M Wۜqx|<PQDSv0c⒖}Z0]iʻ\Qn+PdirStڄưUG;2uO@A{p:[x2]ϛH{Ւa9\r?4g^w|lLDvqM/1m,{[I3^J灟4D{&k}$H h6j0L}r䯪b4~PʖӤ Z~ũs)UX41Ka~ϣ6gA Wţ  w'Za kQY1Zx`@# Py g&WeerYd4YϚ"D%6U+ISC= .A7˕U4}yvCIpE_fZҔ*QWK׊ .5ȴ.idHTXc;B-U8skˬOַD>F| tүkKJ QP79 ]h5$u1R,24/)vcȦAcm 8p`M"WEtkB# U߭CYJS,G , YDH),''9j;MkE"c`0qx 2e*5\'\ UEw6G4ǹwB2y ±F[H 8IJ\lR qو ft,u]) O[0Ol:&LiކFRQejr3+D(tE6hX= Em=v@hb" b,{+*~In|&Bfj8B!StJ(Hce :"3p2ɜr2W=|"  bi~A.Vy>(IHk\YtQA*f '_\S{V+$X5(oYƱةAjQQWX_I]Q+a˶ Nv*pɃ:dISXs'wHN1bl#0O"R8~AN^d%q!$P Y<Q0yZ>SzXV~-HXx+ljq(K*F&Ƀm5_xmU]a{1~~#]3q6f!b8V2S =uR/1+"á yʅ?+y[˱3ͳq19DNfѨ۬|ݡ yK c2\U ۖsj^Omyt*{],CƤM1}hLߙ}`:ڮ짳=#Ux1i{۾-%.ޚ:VܵUlj'[<үdI^Mnަ5ޛFH!ay:'~l ۼr`Ff҈4N i%x`vdxӍSp^+<LVנaqbc'ύ]1mӅr (e| RZq TtQp"v"b\kfR:*qI+ˀ*e4*2;s$Py;!4 I:S!,\?_ԭ5|YNRHDFfX\UZFuQؘ:pJ8~JDݯ!Co40۷v+` cg?_(lqC߀{Q + ԆLxn \Ԝ"m-m=]2 t8t:}D §ŵj5hl vr|MQ1D:G/{ךakj/`E Y1a읮]"hm'S56wc4aTyh_fTrƽ*M@1.eG_O_lN+ok)YnŃ=eY`4`&PHWM3)V3[PB߱z0 AbTҺ,l%|BUEl''9qwP_9TaX/2݀qXVWF櫛4ү(m+Eqʰ]O2м~ByE#j_ {'x* LCGOXe-"XbfU`L**._6.F m*Y=! ކ2-?s\Ca9l56 h?#Tm%RH+(T&īyI^_\6KP ddf,tvK9W c_D1'{W<3p?F(i6RO!Ge}8ѰJ+ȅj_Hp&͞!-\t>Է;O ?/DAr1\Z÷oIsy` "\zgn\",˹6?Ea0_TScᒌ}4c5<KpF0.+Shۧe9X:I1R7f6Λ'!~^WզȻi6IDf\Q4p .X)q (0?ٍ$Iģ`ddZէM@WE1.B}R)4W;@hn։>auOq1HmܥЈʮ6MF4?n#2tm0=ƙŅ-QPk3(1Ց ӱÄ:WWЁù J.khVqh3Rݘt]+ڥGsHb^r~y$H2(NG$ %ֹ9ĝ-@".W7~ k_ $N|\䜳#g] YJ'\U^5~LԀM<-BFh: KO]_X~mӱqڕ/h\ZpN2I@s@`TrV(fۯqr2= ? C9|K8DrTԁRՖE{jщ5?{cGbEM*i$d7 Ty{7MAwMnT ` sh9 !SF(t?ƤFQZ;d^]UwƺA.mR_/liŹw[x߻$M+>ai5҂+}JHXo:d2,dH툏[ {R q&`'6_,"^&3X59}JJ:ˁ m"8Gn%_…5N >a~thhT0R2+ͪ؏8iCW=SB|gPw>ׅ &Bs^%˧6ͅ Q|MW㹎4"SX0JÓ< AЦ2ReCniZ"iB6[x+V(g4RJ$Xӹ%ysō]!/:]Bԫزzc5 ]NLul[T&ky6env'?%]qVmSY~D#9>ƶ,w22helcX*AhMm $W;gh=Khf>U|a-4E _-AAydI/4y5)z;f1N%GFd%Pc㿲0YzF->[lUQۙ2Q$?MP>i ò…"8?Rwd ,Z"^ɫT/TVϠ/xüF)KXآDGe3e+ut0D>t)jߞ²M/G.xٙ=ƗޞZ9u~Kr{ taU95,e0-AZB)C>%2ԫCqC+jV+mZS4b}M(9!]ٻX޾n"Y*R4nK/yڢ3!ˣQ2)rP] TDSu \+HͫtRNDk ֫(+VGnZo )Eq