glibc-i18ndata-2.38-150600.14.17.2<>,hgN€p9||}`+h"rwSc#uN"5pű mZC.FH/8qU||k,۵]v D݃_C QdI6tPJZưJ2MiV=ݏpa%5Z%% Zב\K\B30AwR?ˋF P:NZw:Ȋcx˴݊Y^ {[⽋%===Wǖ;b(B$SdiUvԴx>ӎ+>; ?d % C $04Mn T 8T T T T lT TT˴TX|TO(k8t9:FHGHTHQTI[<TX]Y]\]T]fT^|b}c}d~Ce~Hf~Kl~Mu~`Tvz Cglibc-i18ndata2.38150600.14.17.2Database Sources for 'locale'This package contains the data needed to build the locale data files to use the internationalization features of the GNU libc. It is normally not necessary to install this packages, the data files are already created.gN€h04-ch1a"SUSE Linux Enterprise 15SUSE LLC GPL-2.0-or-later AND MIThttps://www.suse.com/System/Librarieshttps://www.gnu.org/software/libc/libc.htmllinuxnoarch@4v.T'   8 , Q I w  9 &R NHINRMQK Q4 JQf g3  5Q9  y  Th $ S i q R - p s ? MgK P [ Sa N O W Z A r h _  z 0 _   M nB 9 .|h C V  M   t A xKHV# p  ! _B b b @&= 5  ,E d D | Z6#+     0ay 6 ϟ Ld"yPtH n,m3 &_L4 a~Z1 :P i\I/w" EU)N   _ M Ab[\  u* J  ' o-4 ~  6 N  k b o f & ) q 3 1 ?k 55 g#< =  W  b  pkUQ l$sd8 ?W5: -]3  E ^  sOR0rl QyFJF R)|)/w%} !s[ @w U,  z :%- E)w  C) 8 ' {)y (L;C"& C X t Ss60 j;5|r^ rS ""Xs -I 9B2"& QBAA큤A큤gNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNgNff8119869a92ec6ab5498a4bfaeeafcf1cd3878d51b83f82baa784ebc8d5fe4432105d9280a78a221e5ce8609d0b897f2e1ba14f756e07c60515eb4ccd60ec92bc83fd0cc8e4a52919c117c8a22cf619e1b4fead46972dc9a742e7d64f1b2fd29b5503c36c3eb2f993d13af35ab731b722defbfe17e325e0b4fd7e7417b59bdaf66d414af0ab8a424fd290f749cb378d3d1ad1071a80a07a58b9033c7e22bc709ac83c26577d811d34f105f1a54b9c9ec39a4a62a6863ef0aa3ee101ecaaa471509ff8ae4237894a7d4e3b0fe049f164fa259176ca4ee75f73f68378ecac519bd250c8ccbb5182dd5b4615727eb862ad204c9de8907310cd116493620ef3a1faa0df83f538d9a18a57fcc188a9bef6e91d05336234929d0fefd10387fb51e2b2b88b9d5ca80d1f322088be3df2787c9b116997ac7df2bb5144c754056609c7f9bd0dd1128d99ae2d1ccd76a22241cbe3818a2fc2e89bbf58a5813a8925d0b7c1fa9a5b9d392e31d704ae8cdb4bce463e9b3a9690ecf60615b166cc292c04bee592532201031c10715ab5b7dd6e5c1accd5ec68b68a712dd11652a458d1990052a5d3365cbe100d2197d3a2d4be25e8bcc6e703c5677c66532f3230194b64cac33208cd58b47b3eabbf568c4647fd39d2ceb219d4d536d43b5e840beb0a9a45919f9cddea57d16ce56f03036f4ebc2385ac85cda73f925334df0c134d6a85bd811544a337234c89761154fafae3f979177111ce69020b524b4b77eea3db068d0d696b36a563f8e7d8d74d985bd3805b3564b1f8f426cdb5005122da23331ac4244d618e2a38c8278cb0b0be11c32dc86eb72a4ea0d26437164f8dd1dfe7672912c480cbb08059b5a7285d3f19057181bad10f44ca87e769ddbed2ae5029f86cdba808bf385c841e4fc31ccd95be311ec219b15cbda4a83e4ff4aa858fc59007c56703345f23613f1ec44bc97acffb90e7bf31ac810db670b2cbe40af4c1ab9e08df5d9af73a0ef9d97674f447273c3ebc2ca1f05d8f489a0114e2ccd8076707a82bce863d4ed540eb36c39602eacfffa53c4fd7f5e91aa991dd6c3ee373f7dd86e1682788439940a92ee8e4e1bcb077014f01e742e1764d5d0d676a3de1d8d881fff872f117a05a4cfb478f51a5372d1015817cc73def169caee76e620ede742b696bc4e1f59bb8864d8bc88dbc6b573c74ea738c94a33d271dc3c4f99fe9bab7db7708309e69bb1fa768d76bd06f40122410b84725ddc6d5e8b5c2a24bb24a3214f0735339685de558871b82c6a0bc268171816a387db0931ba2239288983c9497993f0dd34856a7bd40380099076c02a72d5d98f964730586d976d49309d808db9a3485846a2fd29e93077eaa40885d28807958b5d94149209dfffdeb314363682e199649abe66b569da3e4c10248b8404e5ed76b749d6c2c4d98c88b0d7eadf3fc11ad3720717b627125f59514ad3fafa81f9ff7a5ce331e134b6fef84d86454ebd4724846a610727d3cf9c0ce8b54c06f717fb5d373395536435a9cc0be059a2d0bea34d0e1f73143ded8ed1043259c4dad2be8fae0b16ed27eca1d24c3ee10e6cf2da23946d460fbd839e260c33cfa66ff00d00a3faeb3b15f450f9e0051fae263ee407cc4ae1c6173ec1b26e1447af529e5b65a9c318a60416f0734a7896c1637b3e211eec28ba30c3e9256e084671b0b98cebd663f2115b9df75d254bb7fede0d34967090939fc7fcb1d8900598f0c869e83b5ab5e131318d403be8cfce5e5a88575d90884602d41adc6598e81863263ebceb3e4c73d08119e13a95110814c148caf8d7be3ea05974fae17e536535e44e1bb1077aa44f674de22134c25d72808459f96ab3475057c94a2e5201a22429f1709245a095852dc168b53b1142d988d40729f5ebdb6724b6e3c6ecd9b2f210949a0a644bc2704a5f0e507898af54855f89a6cf48f9c0fd067c349ae1570cc9dd1380cecf2b1af0a1715f2715ac0cba09cad9cba9628488b04165367ef80dffa615d1e15798447ca5c19ff60185ef551cacff1eb877a380f06f3eb5f31c145d63261f295dc80b078a4b52e35114ec01ff52d590249c8f21e8fcc07c5edb23e7ab620255dac35223d46ee20039a01c77e5a860dad6fd510fa4a2f86eb4e28c7ad66c54c990b40d3d384b5e4a448265a5b5a1c0d24344ca07843fcac80cf0ee9165bfc1c92d6029d0963b73b6d4de7a626cbe2f5b44555791f74f86fffa8592aa16123008d919bd9a3a27486cd50d126c5762aa3c1e4e47bc2aaf4af507556e80ba1d7c340b68692f6fd8cfa1674bdbdc2db07239d1bfd8305208bc9d52f387365d0be340da8e4fbb48496b66ce00a84bbfd5ae7c89df4ceda192b8c43738fb7b2b445be6b522219108a6866b964a28d7ffe18bdfeec2e5dc1b70b18098b5b972b9bf06d2783406026b228403b7767aad7ecb2f7a17882fd4ef9e3c1b626d852570dfe8a666900ea3a0dc9d9e1dc6b987b4fab80f45b87d55233ed438073e348daf45de807ed3ff77f09a901302f09fd4dbfecbad20bef01746e80aaf00202a58e611e1cce3567ac392e6039eb4213d49b7f1b0e463d3b41901a7bd5630a5b163b167436a2667d882212261f24b2f4e00ee58d3248e0a3a64fe05d465072f2bf7f1085a41406710af27842dd46383e6b1298d911cfd593c6927c39ba8a4acd46f1a6add49bb07b33cb165d20d32efb643509b171318209b99442a87d11d44fa2e57756dbf4b0132392e61fc6aa64c14460bc7e2b2a0ab66ca5d02807357177931875f30749f57afd6cf6485d1481e488c365c30fa038cc8b0b9000000da3d4f9be17a4784526ee6e740754e8d51b099a9ee57fe295301c94890066d786fba803fead92e3e5441b9c75c12aa957e0b85617206c77948039d0c405f84dd2585280e9d1dbda751cc37c85d7d5672fcc590970f3d16576d4b569a3d39b5ec5ba6dfcae3f009ae2bb57c243789486935dc80643b37c1c1b974e9d0593549974d5c7863d4f9457f9f511cacc6ed5f2fdf878f441a0f576d12f1e542dc354cd648235443042d235c28f853ce9761e4999e3ec0c86ccde757f6dcf8c636e9e23d19c167e1e36ea8098d7ca60eefa0fc8498a3f75dc2a204598d4827b528e60204ca7eab8a91630a8c3960d4dfc0dbe71b5c1c3379df836122ce2466fc656f55a6b774b56643ddbdf865f3cb5060ddf7d4cbd90d5d63c92e6540dae786a52fcd2d9a22064755950882c007373a0bcaf962520d815050a399a118599e004b629e7f101b95bb3358449f1f1a8fb9cda04e10c347e070a3d8aca07f93cca4d36bc4214a29632e09e46c2ceaaae7b4188406b55249d28d69642ee90891cd36dc362dd9efb51e3950caeb9918753d9b9200ee7e1123aa0c2a9c8c2e8c60f9de6a02c2ba5a04ed4e4f298db60e49d2f5451c5e4c985a3f7fc412502af79c716e0032bd24e494bda6bfeefe27d693a93cea44545523f9f897a946247067b52a3d3c0a90b71c61d1c58934129f02e472043abef93c9fb874c0db52cc927a912e23146bec6942a142a1f7002d306dc7410ddea1e72ba2831a76958c492cc060325ca6083572100ef02e917b1245ffc2549eedab68396949588e23fc9f2388737216532430c9cff6311faf975f4bbb39eb3263ab037fc137f385496a2c5bac7e4000124aa17ce838a335fb6d17d35e02acd7046f327dced569538a1a85d2eb830eb1d7c230772ae7563162c99d9babd85758e5805d6a72ef1b47a32d53d7f8309f0dc1e73fca209c52c584e03353f6e965e53c89eae83b170b0509f30d3f66341296b832d84d22122f52c6aee83d30a318337f238e4770684ee324ecbbeeb4dfdeac0283bc63af8631b5a3a6a1f5a2b957f1aa338e8e2787a8ada7534be980120d6b55aa4c4f35b1810a86c9c67e1b51242902d7c18df6b3ed60b72627757689812b4dbf69c841fdadde062812216a6564f03a3526e2980e869abec20e612c4a752140f532d0acf12f2ca7ea7c4b5f682ef7ca70accfb3cf133f901493921cede7e9455943e3f9a582fb313a8d67cae01551ee363a32e7ec8b1f87c9166b0d48e7631ebacf7396c2975c1dd8a0bb4a97f608433e6983b9f60b931b3df4fa973a887c97827f9906521d67574e354af7d0dc09c7d76a814da68a6006eb4f4d1377711f857c8bd4fa3074dbcb2cc1de92df188b802f11236f65ff8988f8713a2a7481afaed7ac3e2e3639039e83a463b83e90c09b82a2611cfbd2056fc6d547f4319e0280da1485bae84a47ee05c1220e6bc7526e02c944f632ea69bd1ee1a77cb8a2eecd1ff91b0c69eea56034f1ed83c3c9cc77b5f05298b8f83c57972be626432d721feff56851bbea99cd9500181fef9d81b7108ae28276ca598177a97562f5ff41e4818728c16061db573b4db3b551991b8446cee0d181456bcf68cc2ebebd9047b92c657964f180456b59367c00dc1b44a150023307d3ee0b2650a801d0b085cf3628140cafaa33644253d226de02043945894942f655519a3488f31f7ca5bcbfb3d42294d6e438c8b04f2b83789e1586cc3b2e283d20235e1348f24ae5aa41fd411f11d9272af08a7c8460c15996872e75785e6476bf063084332b6544d3459c5c51ac37992a9d860acc40b90e3388a80ae1cfa4feab06aa9d89a288cc600cc941385c56eb9cb4aeaeaa5424b3aabdd883e78266008e1d70439ebecf33612a6637139433db90c722fb112f542112566678da1b5eb906edcc8d4d9bffefc79b694bd3d507943b3081a19e11571ba07c88cd988f08d2a54156941392e1b117c53143b05d2ae59a6aeb0fa5fe8e8fa6308acf13ae6dc3846dd6b7a6ba5d1591ae3b162eee32de8b0ebc71de58cf0bde3418f74890662f0265f5e607fa4e9b98c35f7ee66e3cfef82cda9ade00e28d979f4f5ff2b856d04bb4d5dd19b2b37450eeeef05392c959184bb71b1904a6a3c3b9486fbb5849fbc230a262fa9aec0495d420ad6a26418c042464f29da4f002d1d6d874358882f53317bf0919301e053d8edd80a5103dbec617c6484e9af779d647f9eba0837cb32e6e9d0531787128780feda8b59aae5e79be2c20948b93ce38eca0c769b86cb8ada7fba7e218048897b8ed9368e24fc15b76521f95adb0a9f1146ef5010b5ed003049ff71b055373339e711aeebd72afd3c28983da8d4e80be83986b7c18397c982807a90ff704a1051fa2d0de78f9fbed56e8c263c8d91265b831104b3794e369c0ab2d90aaba1ebe2d4f0203aa9cb3bf5e1393172c47f56ad086a25368e4bdccf4e73293493249330ba673d11fba692463afacdf62a9987027288e1acb6266ba00b2da8409fffc0e80d68c0318f0ed572e073a1333d3e8b310f9b674d88b4ab0630a9156927e0d8eaa8e7c57d4699a66d89a39b794302a58964174aadcc899914fdc4aab44419eedb4f87b95491a55e7e865c3101d5722bb3dd09c461c0bc6600b0a6ef0b89598ac5d6b51488e3ee044fb2f3b9f1bc434510675817f52933bed2298b35f28633540bfbecb597fecb9ab8e0945b4c5c2169f555b74681082b8c3cbfe690902f5bba70e58f1ba1b31be8fc4e74cbf4ea4be6d8bc483c594a32bb94eecca09c8f35a6d6fab62fb539c3bd0a22793f3698136c1f797659771d8fc2e1c1d60b97828a8e323847d9066a0265058071bfb0a35418c256076490b7eebdc4a4d30742f676fb3883c3ce1e2efebaf231d6a0bee411138b8c7be91e77fd205707e13d6342a9dd17ea9e5628c9888e3faffad0592efe0e687132c823b208bc476ad34ff1a667bd12bc77e6dd68604eebe64ffce662822bce445d459edc314d9d1809f641c4447e7f251b8ed5ceb006b62c6498eb095784bce2107a62bacc07c1858ddd1687a9f6cc80a592c6e3c392305129a777db1dec83e6096ad8c27cc083e7f87b9953bcdb5f0159269bab20044c5dbe65a6774fe52ca3203c43dd462d6a0088dc6546fe304afc931d28af5142638a6f230a78f444bcdf0c01c7fc4687fbef1c5e567f42539e1520275b83bb19003601b072eedb20142057a1c9b2554554bf50bf66855b52afcf22a9eea614b1c8517500c15e390546a5c72da77840b05ed99ec79fc59a322401546d3dc5597ce44434f7099c618fcab21ab6af93e5d7d39fb477bf9b8eafd10906a9d643e95c685d5f86692ea39717ee6147daddbab4259c5ab20ebdbfd1f898bcd413bb9bda738c9f816b65b1df8c384b8c518964c1561fee6237799c861feb5d159114a757673e12e6d2794fe074dc5271200164f23c4999b80a625891410c422fe96d2be9666aa48fc4836500fcd75d99574108572eaf5f887c8aa8b8ed13f3aeb400a1f7162e9e483b7474fce5bb43fde7a9d97ea3823773419925b3ea95707bae87d77d712103e8c78db2f7e9b32336a49af74e4955b871fafc4acc611582027f51df9185330c27a9fa6e13e21405fed0a9d644f7e85f704706575fb0f30980f7fed3b6c2ad58a90e40a6f330b8bd577baedb550675e59869755f0c613a41aec62eaeeb4288a3fb42e31c0a0af81679510515bc1763dae4f7f7900250ff66682443148d490178f9f3b6d192d041ee9e6eceec62b87c3ba402a7387916bf55a91ba5ad5a228c7e7c30159ee3e0671e291c4655bbb34de170946ae1d4500383ae12569871925d86a8dc03d2f136c33d0002120b398fe22a97b6c1d672387175420cdb6d5e8c56058a30d994a5eb6698317566dbcf2146a2145d2c095166220b786d69bf4b1494175fa7ca76b58dc69a12a7f709ba51eba1e2c2a644064c5f803ee52cf29efadbbf1242e780a840dba459a82eb621a120de671f808ade9c7755780b047e23e9be734b543c41649f6ebad339f2799c18fad959c2aa08926437acb4eb4847f363f51ca92df4a22115e81092093f3531689fdd220153e69948588f919a33938d69433f28785093672fe7478547487d208160a718ee59915fff5449e077c704c095f4fd560abc7f45183e0e5d9170f38a7d7223504cc21281425596e09f4778377ee416d134eda1b814dd4a3fd9f091148ba8055be768fc14be09b0d884de8bd720c75ec317752c66e34b631cb68c82b0df6ee9e97d55a7dfafe70ed2dc6fdf239f58c74666db78c6b514bdd04d78440fb85f41bda30bd6de587b55304de86d75b9f14780da161bdb4468b299b4e1ce2a1b8bc755ce4927eef612498bd2adf6bb3e7df285ac6505ea0585697deb4c427f0fe5f323a2043a11e02b44712b68c4c510f4efdb67caa659e4d5a09d6f0c1be37b368ae0e875758cd555bc2d37c10d38cd44aff7020b9389dc2fb36f50864d8c557857ebbd114874f5477956ae3fde0f61b65127c4188aa74281e76c5e1546568587efb7068972bc4942d4717a3c05da425cf2b71f8d45c4108b707c1ef2286d03c045abf2a8920aedc5fa6c26951c49b9becc9da9efad7a73dd25f7ffeadf8a277e007a9ce9c5e73109d7424faf904d65950398a8ce2e05d870b0ed878eb17f2721f7055c51f085efc056d502540be530fa1235d215c0348a2d10c5b19319d49579ed4a89d3735668537338c257b5e52b634269effda746423fcd1dab905ff1db1f3e88e2f59a569ba3f99605d790c8ca590a3eccdf29d5e069d97c83b6a6d7454d069ea343d41b9591432ae15b4759cae82c64e321f6fa04ae2268f0e9914771d91753cf5855ac592b5a55c3eba62c84223db9c531643cff9efa8766d82cb31d0f3bebaa884e594ace543fb936a0db41c3092e59891427e9aa67126d3885c170f904f1d351757bae5d5e0bcec1574953cfd309f863d657e5bd9aa145f2b7509d573764168ef145dc5c4be0c1705f8df281c5f340d7be29b21d09ce08c7238e5944bc07ba1793fa54594bd5c426c98842fdfa7efab0c5dd0ce885a375780aa60705e40873d4567ca5c8a370d97d6f555018ac2dcd34d4f7f51b6d253b8fb930529785a8fbe681c185ee913c60324ad1fdc6a563bb1322c4e04366acabf8fd4da6c5e857be10c84b6123aeff1efd2f34bcc7e08241c16db506429610812fc40081ab99d1b5dfaf13b1f52c07c5abd5fc390965c2381ec4d2ee504c559f03f0baab767a26abe1c62dac43e5a1373d4c3d95dd59909c968281ed622f74d048bae093100a1723fc787ec0ba09edc6660658eed9a1928aa50bb1b6ae7e8cca9d9b8e0064ce2dc7c549289a81ef07ce7c0e28cbb892bb651bdb96f4e75a6a6db0ef6fa1e7a84d0c5db0ffe402cd6f8165f771f3912c0c6b4e867cb0bf3d05ed4fd8760cdadbb203dade1ced1c4dadaeaa656d4d3283213a08e2072f5ce001bf700c16a7f05b8afec068518804ab134ce65d42eab76ec5c94bad7381c18c5b6a6f78e14bf4df38022e7652a7749d9ec284e457fc82632c330b624cc682aad5decd6a545e496e94943f1a80dd778a55eb02d2c8e97c0de3520ea5d72aed805a80dc2f0d8717621f1c3a0dc49c0065db73fd1da5082b8005143bdd8d787813121057ef0cbc92858d9512159c6268d74a4ca3f800b1ed77b507f1e36b8c991437fc31ba46c885fc3fc06a3d99b91854690fe2f2a4f0573b61d6e009877853bfed3f541fc7f8ca2473c91bf9bcf2438716d9676736662182d2f283e6569f97fb8b34c6bbef39d9d3074472b781c853dab1e72bde5b045ca8ad76052ab9425a15839867297e76f9b71511a13a2404328796f8859293b4a8e2c5d74f5ff6c1669e6d2f97b54b77b985a006d2a70e95b42e8030ed7bfdff9bcc1aa775cae56a50a8240a27c31d0f1668318f146b6868f74af30bad595b704267b4f25a3e1c839fa88348710a6931c13ec31e43b20e019a954421ab41709bb12ea3b9886de48900b07eedd6d5e3098d679a7f5c64354368216257635fd0e53c4abe146cc8a690d8ebd6c03f72e2ee25e45d04c47970d0749fae3a497f525f48611a4d456d872fee4ac629a668ebeee636bd4fd1b359eebde21141fc94e95e5d220b765d9510b21d079fa4b89d52ec86c865bd635db06b2a7da215296da334c35677a6350ef5622f84007ce7462d02bd7aab83ab76f7fdc2c93d7055cf68b4b5e8c0432b60e31fec7abbe06d3d1f0bedd0952e88a0a19ec59ec97bbe4e5fe31285d4e1ce1d30be397669431a9205cc76e4c272b748830ceac413febb77e9abf6b8f12b203ee72f7c59324878299bd0f06711da4f5da4b3ea32ae7f9af310da50cd916dbfdb85190c653ccc3288b5d2e26163b88a9983321dbfa66ba1311a213acf7ba4f002b25ac404bd9783071a2977b0af924cf5f9fa5f5eba8b3deb82834b18828d3155e20ba97286114e2525cc1707254585c07360d0b70460a0fe995bb64305780cb717c99311a2bb6ff14bb087b32c1e44adf8156d6bc529b9085a3a95aaef178961885c78779477dbe9a26d892c85b704b5c407b5e2d12dca60456318a7549adc0a1e6df34026d07e7af1f0addb8e0d6164125b971ff83827e38d938fc9eabdbdf376ed22872631ce5dc7d1c665e68eb98901acddfdc1106fc7d4662aae0cccdce41d1457e9e101fb72cede2e1b39c4dd36c4a88c971c8f6812a1dd13466b85b3ebd79319addb42820c211733def4ba5ea3f8d91a3cb7ada7b57b49740967ca3cf7f1af1a8dae7d2304b62a3ca5426217dc900902a1fcd1b2e8736407b7b7db68413eb970b37bf33eb341e63828afa31106f9e61498ce3731832bc5bf0cde5157e02fd1f39c7ce81bf73d2cf04af5191a6b4b9d57136fd78f1c1d2d48a752a0f85d7215ce7c63fe08f8df78bb1c4452b3966857d88117409999d3a6a1deed2851bd9cbf877d093750d52020d54c3a6af221baf0cce5a041c035a84f146d4ead86d4f664cd58ece7c21628e7286d583958b925ddc549d0baf6c2bee1b8c9463b2d1ea6fee2e0bc10dc19dbd6173b98bad98f99c0fe3cc4c6ff79ba4e9994213a3665e21bc9e93182d828573cab60cc73245ccd54b55c1ae3ebe25afc12d09a8f1341d97b214d0d5bd1eec1f9b49694160e63b2cb8ede1cf21dce948bb74119bface81fdfa354c722ab099f29afd89a995921f9bb5896e853cafb22c4d49c8623049f301dc1e8a73b2b26031984e4f87bb9792723ece88a8228a13cf1199fa8669f49aa56b1ae2be9c48795d6324f825761cde09ee22f1ab3fea3265355f8c6a9f8e61cbcde5c965e5221c051d960803ca565c77392458188d71ae450ea755657df031aef2da61828befde4a53e4e6bc953479d36fe88f1a9c693a25f5d64356801979f9f2425c13e2456552dd31955a1fb0185fc2f4b29143cf3daf5c45f86f3eb3064e8b428ce9f8f6837a38f499c9d0af224cc20ba1d90c90365c6332e9cb383979a500fb6394e21a7bac3709c3a2a74e2452f2f4e80b007f3bad2c766fcfbfc6a68ba96eae180fd3e949be75b8171c31362aa79a7d941f042729cff498f818a4ffa86d8629aafa643d21f8d926da575d7d52a770b77c09b971541723f9b816679f44a5a6d67b503ffbc1eebe3621c1da52c8d99a50dbb546a53dc00b138794e2e054bf4e3e032674e297c6bb259437cd28eb89287206c06fa86b5f68d48688d4d12725859d2dc2eeb249635627d55281c0954a8bdec3a1b0b8a151f20770a39b1576e9bb32f803cb5611a1800f5917cf13090786050244e24d698f68ee66d809139718a56b842e743808d17e677443249cc03d9dcc2f433863aecc5a30d86369691066bdbf58c192b1578a50dbee0365f3e6eb90d8033bbfde45caddc1e3e835116404ab85cc7b33873970a81941592400920c828f87ae940f9aab893bdd1765104158bbe7fcc1454412ccddb1113dedeaee53eae7df58afbf561704afd2a7f6566567078ea1ca432ae79ec1ef921c1a971aa59cc0d0f9f378d28dff467180eeab759dcc464f0d66365efd2c5f6f84cd088135497c7fbc168e87eb577a14ccdcb42eb27b1af2c9bfcf27ebb783be70efcb0115475783c58e9371e626becebaaedb7b6d50e3a9e9cb0c3d7ee711d566093e23c5f9240065c1a2a1406916f1cef2af807538583535db4f4ef7e60d4a494fc2661881a9ef2ea0b210f48d54fda715beaabb072ee6cf2f9491ebb1ea58825b7d0018b3d8d8693bf6aa70afd3676099d04cc50bcb07670cac966ee79c272631f35367b9c1e2d46a9cde3de5dd499c3c83e977f935ecddc21378e0fd9009f75f8b40b7933d5a0419292fcee55267ff2457f845af745635e6f3d7bfc35b2353970ac6fe974826812816b5408c2ea26dd64c8c1ca02051259e52ad15e0cc19e9fc5c7b5fc27dd56ea13eaa3e1200fcee7bec7bde0f798b5cf313206a46406942f125787202be5646eb2472e1e5a87294c67da08c6bfcaffcbefa87ad9dbb24c13ea2161e239ea143159822a959d9988ce05443d16b17944690f0670f7151892a1df312dccb4e3147bc48cf41b8115f7d7ee9708a311a60ca8b5d9af07b01d7bced5766d5b4e743fb071c86f5b2cb008df0a19d963157241ed0f582095cb5f6fd64c7b0dbaab9832a2867051bf9ee3b99bc46b9fe51b685618f824c0dcd3b6df237d24334b6b2b99f13314155bcbae25209e7f78c471a84a4460aaf2360284e46ec78c510eaabc2c4d179faa5bb3e57853ed4462df409dae60b83b55b3cce90ddbd8bb68a3ea510aa3add0667c35386dd98669f97837d2386fc04ca979a5265d67cbe866cee0b85052f2bed74c1db367fa7e9c80dda0c875850a889e2fc1741e1294b22b00f16e97387e77b4fbaf4f9a531bf172c8206c7f19925faccd20a33d039a854b5eb020882adb50a03146df568a46866fcd7332aaddbd62902f0d7c08c2e337c6b52941701ca24cc0c5e772b5fcd3c200f0ad76105b7b08c7386862bf3ebccf7f1c845d4c306f2bebd415c766a5d97f122f66061484149710d1f6f332f0587bf22c2578f197efa3c3b2f957a39c491cd913651be9924a80d5da7908aeaaa8aa0b8673bc156145fe27a90042a341f2aa46fff5c4fe7c5ef29cfcc7f29412c902b8c9b1c800a9e4667e4e7b3e503628ae1386c2c05a19177867dd06b7a96d80847ff7f3df028e0be831b2ecdadef4710d0c4f3e4099a09f270ee95e1d0bf06c59fe93c81fc744b878c6f9326637f580ad1d375c9b4aeba852353487111dd11d5618a3d5b0c75626160feb6139f99e0ab76b6378cf84b124af52e10c5a19a352c6a11b6f9d71bae83eab078d195fde711708ecbd6fb74ebd4661166f2dbd24e9b68db1abf2a65c01d65d55ffa1f6c943eebed55d0dc4b22b1bcc4d6c8885fa1a1a5bf48e77744d081b1490b12d887bdb4229f2211f736297b807b478035631014451d4a0262bb20ba147014177dfba16c016a97c60fdd0565dd33d73e32d756349f6d40b1e4d9b3947725b1ea80a4438f4719e396d7e5fdad0fabf3c533e054a8746a44349496cee5728ba7fbb205c7117340c77eefb017e351757d8e3f15ba558213213f76a7200cf9ef0e35c05cbf21a14671720629354cc40aa2460b5e495e1587da48516de9b0ee6ed786729876c530608a2c5c5100f110d97677bd0627b3d9c93fd3b2a54ef04ad4cf986d31c79c03596c8972778c20e31ffaaea598b7031c7d2c45fd974d56e473d8dc446fd4903c6940fe9c4e98207bb5e5f7cb5a032346b306f379085361ed73171b100664ba2f6420438588bbdc22398e0a49d88c151eeb744023f164b2b755116aefdf52eca1c09df56aea2bd8946e6dbcdf15446c9bcaf1b66748f4cce8db2625ed0520a4f6cad50987125fb3ef37b82dfa8acba172a2d2264abff6fc1f50e8986f53c45ae424c680f7c93c83fd4710466397ab633c9a295302e02f56629fbcbbdd75a2d659daa24beec59d78b932bb598cde7e84c6908fafabca5cedcd522d1ca7b7e426a547f47693641ce48caa1074a3a14c16ec62274eca0db52613a50f074f0fe2164712140f98365a135e9b819c2808328eab2888156f485b1a80a74c79fecdf08f6c0d303e53d504f16dc83493c12fb10095536188e22bbacce2877aeeef9f150941bfd1238ea738c2ba09397cde6b7d0a81b2cf876a87e26398cfde8bf004b960c44730b1f1741abd65b1c00c7a20564988e237b4dc8fe33b5b3c11c283a47a7012cc3fb4ef5ab08b69480f121664c8b53a142d4743da95fd1b96222e7085e17ffa0a754a89875bc7b9dad9a626d582d56ba60c1cd7101c0f667ff5293cc8c8c265a77432a432f3ebbe20838f7a8c409f3f8f4750fadb11eace940b09de9d3940b16ae8a339dfc45b8e3c741825c9695b56fbb4804bc9c1141c470f4e204ce646f4c1f9706195e1dc222087b6eff47bf6eeff33dfed4f9676d0ccb245224dfbed53d84fbef68fc39b5c043fb61f784f9158a4732dca3c6c29c3b1c3c6646b46f9b925a325abb049bd210106e3db70dc24d231798b32e2876ece9537e051809a88b2fc24604306aba5a695f58c6ccca4396f35f49e19db7500bc047e266abbf442e58dbc41710ac844e2717537e7259c20c1a65410a1c3d6e5f02774fed986d63b662e147e625378862b35c7be14633856b450d70c4eb215aaecd8f54d2925b721e45d808e17319be6f1c9b26dd2b51bd702cfbedcfa1801f57f4744752ea5059e01421ae240e316d278383cc38d34df8e3daf76d1524d87f00f71c566d074b9f1e42b35f734ec7f8b6b59207c1108fa1e787508acc841aad94efcb87051a0784b76d82be3970e801bdcf2715ae501d6143a7e9ae2e3ee3c121000196a344ace90eeaf2120cb93731339645cd50416b269a766febd1393cec5b66e0266cc7e84c514d26e391582cee68b401571fbe388d86abca06e8aedbbf4fc9364dee6c0baa9b098acde432798e59851f2a9d1e9ebdcfaeee8e83a39ade6e5a1229155b7a4936cc0cba12b5639d0f418c51293af6f0ebe9e5d36a77f5f1c988daa2998d90e6cfd2f289e8d9e13d05fce0118d4e12d7bb248baa9527b82e8b64173387127e933e6931a3578a8c2d6a5c192dc65761d9ea40a90084638124e4fa3e0ed107a48fa30de09189291d44fbe0eb1088984e4fed062a31bee95084398d4805f25f14990d1ae952bd2513f3634eba5d54de838fc1d812d6720cdfd5135da713b7865404a0305dc26f03c6a4bd0e4f054bc480b824355ca44e89cd4b7bacad2767f7c2534139c6d506b61990c98d5d7c8c28af996a3ce2aa05d2fe2d015ed8d77da5d193f47847489d0d63c967a008a8402c63496788b4c9936a09d5f6af34e03a288a659c019e8bc6fb4f14325c2eca383ded8023ba2291585611e3a4be8f2d92b7b8f76d649682ab69ca1e61ac4d392b4c693b15f3e63e1a3ea23fa36c5a6510a0fa0a195b6591957d4a4a03d833ac58f91d0f59619e9eb3240880d93dfdd8639ea7eac1cfae06b0193320a691466b2f4609ab040a8039dab333db6ff220b52d98eb63d37f9711d7f436c5c1f775234b62bcbbd05c051dc2b2936a55716553270e33c28802a117cd59ab149aaa0948b6602c92d5bcdd70a012221793936523ab8ace82e0fc48c24d7ec905c1fcdee640c13ec5c214ac54ebf6b220fe88f7c89d84b8d39c49eb77fff07bd8b76df692808a044860895cad7b52a21b6ff4a22b5147774e1ca1e9ce995a171613392391d2eb0b404b59be79ae2739b3d57496eb8785467490fbe3b8e059ac551dc360ed75442b933c07da648adf0bacb4c79b1ce4fd5cc4f1945fc9817a58e8fd09933f9054784ab5d17582b7538a1507ad8b4a879afa50bc5be7899bd3d3cf7147f9f31ad905192b1af15df1d71cd4030a36d69714acec9dc05fb2da2170e6e4d2f9abff022bb35ec36b1ca292c63446fb5a080c78d4a6cd528e8e6609cbf47c943ee4a2da898b3c870c7ca9a4c9699e63f5d3b6dc67d28badcd6126a6133863990976af9362d6de529a5aae0145713283f16163f3a8d684c6357f398dcc30f4343eaba589c4acdc6baeafb6db8ef126cd38b9b56db33626f89791f44f60f07a1ec6e86b13b4478483c4ab39071bcc3e98bd21490a0d4fdbb6bcf615bf4204f893a8be6b7f3f85416083b55bf003f1c6d4d3259fd1f1aa8403ccc35c50648afad7b1f906f89641fb992fa4557a2d53eb9dc647de0582fc3648ebf691a2de5eadfd6743b1cdca78d263ec276aa4215055d7b51a2a7157f5684b810be1a2db5b25cb4bc35e0ec3304d9786fdb7e61ba49f3035547f3c938d19863f8f889ce04fd3bffc4946bf26c29666b434d68e8ec01e1623345a65747d20fdfe1ab1a47f4a3c11675e4a14bdbe6d9a2f1b957c859566e0debbb533397e7911a15a7748ce442a27b43018baa1f761ed746f8be3692393696b290b3858ff968c6bade680a4da8f135bfa5cf1982eaefc7014a6bf0f9800eeee1abb4d3d18f82c7c5096e8ea742938e3102344829f4ef998db66d064c0082b4bd1c8cf95e35ac3de12bb9f1d62f50c4d4f67ebad88dead20fbf297a2282a1e000a9c8993c04108898d8779ccd7202d7047ff21cedbd29d66a3a2ca6d144f758e08bc83565dae981b3e77fd34fac117968035d238c3cb97f58303347e92adb3b6ad510e4030edcd0a36a416a0f3697b1408aaac07cd04e9860965f970ec40d0a5577c3ef5fee8ab2d445ff4214a36920b91f0ffed94bbac2420575ba3a00df366b8ac40709f77dc76303613dd03405aeb3effe636ffed130a8fb4d04e97db2299bf16d47498e788a9ff1164d111b9192973991d04bef0d42b361eed4aa997f8f7b5710b6267b9ef38a4c029c523e20bb98f6aaffe9dbbcbbd1e3a3c029a1c2d618b5ed1e0b04be70ff78224b3b8810a72bef8e69e58972a345cfa3e448d94a69145c13eaa135399d37e9eae12915b8e2ef4e088b18cac24d1ff19800f81bc9c2087e296644d91ccb405029250ce4272c8ebd4d331d90d20f8f785bedd64faadc0ef5eaf09201a702cd1889e099a1303cb5ad0c18e63940b6b22e2828f761fd75d99d1769fe27b15d4417bcf3cbf79c760f83ad49d7a352ad32de3e1810ab9528da4d46bcab94f657ea249358e098765b2ae505f85423cbdcd1f1875820596bfe1a3e61f89d86686d3dcb341dfbdcf3df439ddbb0b2f1996bd7aa4d88a5abb9cd2a6fdf41bf7668d632fe73ddffbaf949fd8c2783bc55c6b0cf99488b09b6d7adc4170be295fee7eb1e1ab9e67c5d334401286cd7868359639c3f573a04bc1e2053d6d39440fc197514c0cab0f9c14505787e362397c948a8d608ec2d9d1ed8d871e268e29edd16aa9f43054babcff0037736ee33500cff014a3423deaffa3abb3d999b9b1afcd4ae23fb18974769d2b73fd7009323d0e952acd056238e62e45ee5bc71eabd192cce76e513c0edd9a9322007e78e55e27de9cd869921042100a1cf5a43f8366d1d9a89c62132ed0869c046f7d89b14d0d772396f387d6cc5eb8e6262a88926a836a717e4e5d468ff302cd7f93557b89d63405b4fb2f79ff42551287c368ba9e36da7605bb359588be1b4d8f51a6909f3817cdf219cb56a7dd5943490e011d8db609084805d6d1adb55472d024fab178af2c4b46a36b7bf482d4c1a83cbbceb344c3fa3ea744693b47a8dca649f44013375c1eacb2168982deb957320b9da11a8b106c5b72f6d4f6f3cbbd322c368ec69aa4e5593aee492a58745219487203e166d1abe4560c7482456771879faa47cacdffa8d7d610307d3c0118489c11797c3243f4844b7ab88b796b6c8409c75f1804df9446ccedc185df4b78f10b457cec981db612c8ea7e5062be5c7f7d15d66680e2263967c99d4f13ab6db7098c9797594780d25197bd2c580cb6b63c0289a6df127c6192fe67df87cae9d1d79cd1e8c2ded48a47f09c108b26bb222632a89b4c31ba087b391de008b3cda16a0c58a89e0f980574b6d94af3fe60b30d76d1fdf108886ae48ebfac9b28d66b12de07d42bbeae92829ab899dedf5ca2d0dd8ed956c3ad094406774a70b11e13f8cb63619514d225e356aa971fc196b3d81ec5b5085ace49392c203be1f306f2ccaba986accabdcbe2d1c56f08044a6bb6c4b187dbeacd365bbebd7ac0104478ffccfb6eb6c0e6575eb80555a756aa3030189b712bd81c7cb6d131a683cd064556af4c4b52cf30355662ab028eb61a1f850ab267bc29aea4e56d66cdc3c8c9de5f4bbf0ba75212fa7bc48d55857c43114c81ea717b302fddbd2158fb407b5eee14e2c44638128280636b930051d2c04ecf368821f208af7f1072732d7c9cbe5eba71aa071dc1130e1e95d32e04bfcc7dc15e0009069a7ad3ace459298a144022690d85b12902cce63cb2d87d5ee8150975c8f0abe401c2b9cf1bc7ee5f0409954de6072df323e93253d08db1fdfc1c7ce1d9ed57db7cc0b67e1dd7c08837937ccd368863ab05028f8ad2c6273f30df19000fe4183f77c65e0f8be5328b02e38da1dd3adbabafd5f3329103a15897a6cd017ccc9b4acce30c023f5db1400430c49677c054bb49fbb5f38721f30abdc45ddc049dbf6f7f66af13e8e48443849e20dd0f274dac03ba00773c990556485ec4296b893d05ab69cc8428af42cabd8abefaa6173584e01a5ea47e4f93cd1179fb8388d6ff1eecdeb758a678e48d786740ee84559a2609b8f05a649a7427b553191200d8813a30da372d0857c5c41c9cf202864c9fd93f2cf149db0ecbb30447141651d8d80865902aca1b16a2435f1e65bcbb3690a02536e96d34688f88d5dbd616c1967ab85e011d50b2b6e1d8115fdc6cf8680f4914fcaa284afa381d8930ad1b97597150a3206ab8c297204fd6d9e33b9dd107cc666d73c2dec13770c1b15b070c0677d015145eac961e86761e7f8f9bcd4b50c2d41d05844be3bb794017ee522c0c022102dd359a5deeb7a7be9afc3f9854cef47d5d6c46e85ed042e2624fd10c8bed191dc4faf337bc6b8838d2a595667f2af6235e795efaec7958d9dc5a7a4db391aa6fada78fdbc1bdf19860023c9b5b1210216e0f6ec0dd6801e23d4415f9aaec74b60e3288060d8627617c3946eb7322e76333451d92f2679a8d9f51321523ffdc8b1dc3ddced3af0d40e29e91996ccc39650f510dd352ddf2a0327cd306e8669e33428f0741a51404dd63c491c0547e971c3d4cf3552aee64d4d4fc28ec007ddf4a51ef8e6acbb6931b78d11fa1333dd6cfdc9649df1c307100337f5300c1f854c7e0fd1127582cc253a8c49278f923dd3e77c256192ec11b58d52d94bdde7d439012801be6ebac40402c928e3c7d057e24f04a0028c20f9c3ba7d04e7fccecd0ac3d33a0cbd30858136c9efbd267980de8faba43b5e880c3147f31f3764442456a84b7fe350687c6eb190778a6e6c4a91601c6ef70a8a2ebd6d1419eb7be46d2f5ae577f1425e43a0eecaac9ff55d6364f24636070da49b355fee1e69ff50c3af5922acc3bf6688bc6fd86f07b68a9f069e4528aed8e27802de829d7a102f59a4b30ca95b11cc30ea4140cabe6a1301a966306ed814fd8070c94cd43507597e2c94f483173f23781998adef0a690dd8cce442b19751b3c3231be32b94ad308109cc9de918005dc51b006d1bdf4c27d37e791f05bde643fefb740c09bf589cfffeed5d530d977a9ce8ff8f2519a6a63bef847a2da8163017049043cca741e6fd9cf43a18fd4ac79f6b6df91efb689403f7f72717c12d1d834ba1464229d4c23405a10bd7ca5e233c2d4503eaa348b08ed1c6333e3a7e14842e003e0b56e2e2a68ee29502af64b5a67958cd5571432b8d94103b5db8b1e66813e9ae8dae76fab8d225c8fd667e1e0e6117aa30681433a475d4b74426553f7f4a33c6cc55dd60ea7fad8817ab5b290742515c568d13c9abe423a53bb1228a025368b462ba34ace172f685f7a4cdeefb95a093432e504a686912d5784a3bc85f3e1941ce316bb5b1a987553e67728089475453a5225c24f8a88e8df2c1dccbfc54585feb729213815861540fc89e65332b6b53e6b3f9e0715307e8421a16972212da253968b14d4a265dede6870c8a8300db6af4f8b477a290212eb3bfb512c8bb16493628739bbc879b18e2bf5c20d67379e2fe8fd0f67ee5def4a383161c025a60a529bd0e446e8f36700cb1142cdfd6519d9d1e7e86a03872b104db74269ef6fd6e31d34e99699d6e09566817a109a8d018657e320a79ebb81ae73196b400f48efa346adfb8a2f57eddf87e5674fac177ed85dd69039a03808f4503c88b49e0a710f84ce6f179b90ad903620eeb1f67d8a803c859ddef997a6c1b37fdb8e8165c18a59e46480676a7ab85af5f092540398ad56545cb1f4d62e2c41a2b525b5785bbf4a74930d9eb2cd45d99b245e25b6a2f44c694d6a0e6c78736851dd684af60168ba9c875036fc62c3c7e1e002bb13b190628e5f20ba33901fc418096d63b4fa724beb4eb7f58f7d1d595b77c05f6859f426e1e352d8d40de83e1b25dd037fda2ec0ceb91542843ef66cefdb7f491393ca9d1f41f7c642a04cb0b159c2784f6e005d4186838ca3bacef98a4fead870f0404e9b5776417b3a8db4deb20f8e445c6b9dbc9667d911d5d0a75333d3196ca6bec16d1c3dc9b13576a3795a483150648d168a93e0c48f36cad02ee9ab4e0eb9d0cb8154a9900a35cb2f34e5f6af9ce2fcb01e083a800bc33d1c60964f8cc90a3bc7d1fc01fa937af42d2e91cb63813fb1b3c88f4ab6d7592b08f0abbcdba9c012cafc701887c8017c91f5a859b39a63d1192d86878c2026df7c4ff427c139de2266ed07380887f7689b0ffb0282a988545377e9cd308ac2b02023f12d0bddfd9813fccc6bef276f1cd2fc0ac8be17b34a2e7e1a89cc633e6c1da978d29de5c826dd72099c4c4ff9d924acdfe5ea0b8ad5c8dadb1616219ec67705643975a35b2ef537bec9612f7a2a4d6affd82ad88da3ba979b609b95465c2be9fb84ef51d797e72b57722d7fb16ecc1323631f1797476d2c5e675f87ccdeb8c2737eba999a2954a2b4c474d0bcb1fb936a789dd02c8c2e4d07a5d481e18e69dae73f38e940ae1955148d01e3a9816e27e645d7b6a3141ae81695a65314fad92c927cb41cbc0456f675015a63c37d8c23b15cb1450ae8122e3bc7cafb66332e8d0d1884f9acd6a872c9c6e6a0b1ab216ee36d45d62b0997d836d8788c6e58de16297827c403f652c6bdd09105c1f72873cc7b8df76f0997f865f9f0929775974fcd309d89db232acbae7298682a491f9b4118d67014bb3a59064f75c67c72fa340e5ea5a467df82461ad8a3040f7fdbc3adaa7001fe3f3a4c13ee1355d4299a91b4649c14ce6d06bb0a40ef1b4a78fa793c1ca510831fa7a726b0d602535ee56ec9ace5487968405e621783422e9ba3a50f1ed7333adb8a176e0851e4abd88fa7be2c2e7f4365ab43ec5f6f2c9b1087b3733b57dfec3b98af3a20454279fa285295e47f983f334f32ada6303cae1c79e9208d9c4bfa839738de42c303cab4600ca45ebc4df8265a7b01f1c57c7b2c8f69980f6f48c9cc1845454a7be7ab9ef155732d0c12cd5344f673d738b6be7bf991bb062451120510af699fc707cfd38806b5034ef04ed05cddf39e512746f86828e0ae2734028ad576fe59e16a6ba5bd8991601ebad8e3f2a7c6b2ceb5af7bca7a94ac7d3c94d76e630d2cf9fd70fccb377b501890d1fc848d7331654c247fcae744f42ca5727b003416a898d544f0a529755d759b637a968c68a882694a32e9ac0bc88b90cce8936b48548611e7b719abff1f76bdca388bdc2e5061e705a01633ade2e688f58ee523fab6508ac873db70fd3a78fbf2fd128f865dc89cefba34420319d8fa8a8cd280a35a6953367b8bdaf965f72e760060c3c952e1b106a9c37f21b0690f01385dcd91a62b7fbe19c8595694f22f70c0a33a7edc2ba4551f29a944f5c8c427b3cf57c4751abb353c55478867291614524cc2584128e729f34b2b4d2b518869d5141b212166d82d20065d017b7b3411723b19f6ba39d62b36fab8f848c4357a5199f040968fc4f0029cbadcc32b9ddf6ade695848284805082f93bf54fe9b5a513edb0b94799bdc1a0071be6e1f6812ff000caeaf2c1ebf85edde8cf641e43a7ba7bc004d1fb486b509f76bb5e570a59cb90a4a1ff5095f77a00a8a62aeb64c23b4f2ddb0d52fc02f4dcc6b37b889c085e49d74d83edb0506c26a001ad5dac75c6f40fd7fb9439fbcaed8dbe6913527fac749b82c53e92d3b9321a09627d975ebc2168af9ebd22b591c8c8d059313dee2a211cb20813d1b44b06dbf575d07a30d88ccfed97ad490cf9f212740ed77fad33312f55215eb9f70cec8a22afa7e49ce4f4da4d072693455916752408ea216f7fcf3314759c99ed67e8c78cacd04b88899ea50efb31ef6e9f3c37a49887f8a159505cd9bce6d24f08931160a6def7095adc7db6a9f7d3142681945d3ab8d04aaa9d227b74ac8b4af15a06b299ad64a8625d07ddaaf455cd15fe56be14e02b52e1ee25152e4ece7ae5f4a87046b2d17a4db1f172ca13fe77bbf0f33bead45abbe6e8fb93bdad06da5309044166b1ed906f3df5d8d09c9b87e775e07eef6ac1e103f8e08feb2a42fa3ff56eb8533644bca0d9937ee5365d7df6b4a6ae3e1ef88681a39fc245748c0c346cd954b91e2d135e9bbe26796f8010a4293efcc44ca9c01dfd287171a718da753ea94c5a49dc2e32ee77d446e268018f95bd023d1f40cc34c7f90a9a686bb8aede542caef7bb4b61d57e99c4cbc0822f771faf8e144ece2dc296f2b61608ca0c9d1151401268d269a3b85ab14a8d37ab17ee3f4b431dfb9b5fe8ac229ca947425087d35fb6df71e8fd5bac4eb099fe829f65ca6d9b7a85caf2a1a10e6ac6b950d15e74b381c4f47a055dfd3851d895000e1751bbe9ab1cbb96a96260cd0f3d2d0acc5c9f26d8e0adb6015cd01e788d46777050f2e5885ee86b7784d76c71de760c7dd7791676c9acb0f3dc0f3a54875533a83fdfde14995fd6cc9d760bb70bf3269bd7be933b3735c824125e88695e3f14ecced1563f6c30bfa177c0bd81902ab827ffabcd404ba9239f76558e811be162af8ecd057ea58ead302e14c9d0ea2dbc32869f39ca8b895b9571ef5cca2bec799f41b2a95ca0138568c16761e529283d329485ded809518024d7fef8ab7c280e39a162cf0d45f536449da86751e341098ac6969a56c0640bb9e905641fd357c946f832bfdbc6efdad2e5ed141324bfd251efbdc06f9f0ddb4f26a625855d2126bcedd3fa00a8075abc067911948e78656239b1107411652360cccc4d4e0184e128e3951cab9139aebbfdd21fe5491eb02de95b9be188c0fca42aa7ee271600244cc3971eb914197b7e5e5e36fdf1868fb659a06107a44903ad07acde64ec659841f51be950d882045f05d1a53d710086360722ad6c0ed824362c93bd5c07e3127808293bc23ddf6d51da85456952f2fe39e79ae3d2eba5737efeff7fb11dd8ba0a22035c8540f4295fb97a4bf64a9bd4926c4ad598d6199a87dd444b2685e587d5c10171ba9c086f52d3832609b1ef85d7ecf2532fd131926b7a56c052cd111fc2c85e1f32f003564364518c945e1cd80427594dcfbafbd4bf556d238189fd496db73ffb9374f6c340a9c087fa3d72f5d8e771419959a63290cdc7c02a8004dac9454a0f7209c745e270ac261736d270bf0b2837ccc003fe7c74cccae9f3bfe7fa9f2b89bfb33b781b103e84ed99a8ab969de28c30214d728f94bdd668210ff26c99473f198d476d24f802f2c9fdb52a2f6a6da56cbfd77612eb6caf1e8a4a93f60c7de8541d6aecbf18d77730e1b1e9f48b893d5c9282efa45166dfa8944d0665455df6f3319573aa54998ef611d6dddfc6ce030beb7553546b9a4df3fb6eaacaa6004ad93df0f4603ddec69954ca9bb39b38bfe3c9b0a6df9b28037bebd0cb813068d6c8a69c0cad3601ca7a4fc25fde4bbd47c914efe691c3b1dde0b7d08537fe1b312d4904745a2b9ec2bf8440db3a866d454f17587450826b7a2844d08055d08e9a92d5ef3b27b182c7f10f115f8cfad569268176f85649a75421964d0a88e40fc85ed7d5da8a986f0ee8be10c18e947db113f04d3c71e6d33a87db40a73cddd8be7b6f7dd9dfd1a39e5e4e7bcb53be022b47b56ee3c44d205a99185fb6dfb4ce5c9caafc34b176b56ba69cac2f19f8695e110dda825840e53e4bef1e901beb9da0bc825b6a9d5d3173a00ee1a00cad3d76e1991cfde8e62c8c7ffc0371e9a7ff54dd57ac0adc46e2f8df1422dce0c88ae91be109c84a1021db4a81edfd2f7d53320cf76508bac00b233bbd95bd7090f323883b96c0bc1d74c5442db812107e5965ee58a8757993e646b2ffaeade0b640ca17e2a57c64f38345147fcfaeb02d7539061c144d0c9ebc578d6967b2ff5208f5af07c3c7289db3bd3f73112a1ddb177a83d19ff15af277e0967017c87718d9132eec2437f81de311a11de0638efa84db3e0ff896aba845449550e5fe390217c6a98b612796fadde3a6627deda891e5327f6e438fabbea0c70975eeb0dff593834feec511fda1d39af3678a38d746c7efb88b50fee6e3616e8973e04a3c444422615ff98dd270fa4fd5ec2583e70a989701662b75c9bee4bb0d6649539f52742367d27267741f364901c41154d3345625a766c7fa0443241d3cf133735f99f774a98307505f165c18a1b0ae41a9db7ae8e57451c0bc787de4cd9cbd852704060c0d907296f25b8032d5fba33da58a62b6c3e27283f39c06206de7499114e6218a31710165f8163c974b17b3aef06720d92c1f67d4705e54ed7a5add5c785b2e23e4f0847562a144e4605ab8aa749aed364cd9b4d1981c57293287d9781d86404db3a21d386c3f0c9d1e93670de48901258cf71670d9ef48fd9522b0829c82e3d4906f80c2c490f70e82c5c1437f7b1e6d1762cac9c93e0031f79eaec5cea530510d0754dbf41d3c8ce1c9d5e85a4bce80073e188c38910a4deb65234cf2b75330dddc1d1e00f64533fd2e74fa6f0f1e54d2e104e8b1984f76a485adfe948532b57397bcef0905e9f8ba6f8287e1f8fe177f2e3eba256d0ec7d9d7b34563b3400128e62bfe5e923a542f13e29601194a64f110dd3509bfdc20d94897894346500c60c9bc8ab57633cf5c91f98a2871f700c49ff244166e92ef08191291b9ac3cb75fa9023ace08c3bf7d43e8f52455164368aa9d56241b97a0696de1e02b7ded34eff3c71845cc62d7b16d56590f2f9734e063da4e2faa522afbf78458af876faeb31abb0929af27dc064692b3ffc62064525a8f451440f0375249f5f35c8fc0999cfce644d1b06ebdf453317d4adc518eae0648c4256b7662004b30097c0c787ab42cf8748b9b5ea9243844c66a5392c631cc86d455f6d07f6ac0ee578062698b03204a5e04b0e4e02df94ccc480537048571bdd7cd6eb13831b678e3aabc5ba66f9d81748187feb7d14abe755821a2c91ae0118c9ffe6381019756df4874c67e7d50c8bbb5d8175cedd5ab82adfa720e16c5ff64d4af8e8bff5d8c5ed6709d990b60c1b62c32157eab243d0e49af161a6eae671a2b6485ec84ec9bef6b8da09dfc7cc4d0f9b45b82a5aea0d40ae727f84e91d5399808c1bcffa8dae7222bbb3d7ec07a132edd806dbb5a8a56dfa4ce130c72863a318b2b074c96c28076f614ba00dfc4a32b3a4c1e6aa9675b9c56f9dacb4a58c0d6b02df2e696426536e26f86e7985db1e0efdecc6e8a3b58f4b5767b878dce1f5be3adf979ab7a90e907595b6cd6e69b12796bfa01c4bfc66f47a828488f90285349f4d98e28e2c9b8eafc18ddbe825e7f00644c2e16e47939359e2901c940b2ca05eef427736ecdbd23642f980f0bdae1ed6a58bc225d26486c394bdbde215c08027ef33e54c631dc9a12c87bdc0e2cd391de0863ee4500f65a60e9f6b3d4a7bba0c5eb96b7dd9ed5c2440bdbd887a2368d4dbf6b0b9c3bef0d7d1ba5441d56667c30837c8f414270de8be7a8416bc5eec3d27dd478566d979a01746dbbd311c1ca6374d5562a1a5e39c0cebee372ca929254c4edd3b14dd0ca5a815a16cfa200dab1017264226f87da32c8426e3fd504575020cfcff1c305861c8a775a5279f4c0933f34210902b33fc434e9b21d592f13ee454a36b25a3c47757f50ce3873452f4e361ea10a0b250150e6414566ac7287645d3fbb2dc2d386f4a0e4c6abac3b759f5741f1e8697aa5ae0568fa85028e371cc1244c7e09523b218989056816f1b940af9670042ccc18c712c248bccdeedd226808633cf1c07264722dae5c6fe1ef387f24a4ba8cc89f772786b26ce9b308130a83912002835bd8e6496091b2ac457ea4ed91ee96b2fd6e1b600085d51af4b90460d1ec867f8644ef024c6cd5d05847f9feea24fd9961671e1a9759db68aeecb323c2fa06af088b0821f2fa156aa7fea53972b47d7d8dcfe13cec6a6bf7bef45d4995922766ae329710f7115b52630c41e07483fc6f83cc5184b98b706b7c10b9d4888e445d3a9aca065d76c2c085de2616d8cf09943e327f65eae11713e3ba282c734ee5ebdb02a722c61bad58456f407628038b0291ed6cb1a339c7d70ed8e3f147fb5391c3953c9f7710396f91faf472e4d8158be796098b36082ed8aed818a43a708e80829525d445f6ab3f794e9133c3cfc367b1e876e5b09e4fb391bd871d75b9be902511a3d2cb3d51e935937a229bbc6c1ea8a2475300e4d4f90512867af6e2c554af08997641b8340c5423bf0abb19ebcc6524dfeab2ee1b45a434ce95356f2759b13472792987d6dbdb0155be599bb44dead2e8eec2908e314a3dc26c90da512eebbd08af45129c2345ae91d7b22cba9ae5b754d09805a3055c6f0aec4a6ca7e158ce9547d1d3dab6bce866d0b3287915d930f1cdb7e73fd120386a47e143a9c272e2b6c9388798c424e5c943024ae3bfd4f6cb2c6602638741442a6e7859e3ca2b7e6fccb3fa38077b19280093034b9efe3dc73183c31ab541dee95905e7ea54c2efeb1b1b5521264dc8cadade60b4b5b43164ed2ab0c75a878ee7a2f8e04751d0ed3ca9b583a7bb5d6cd7f6b97e07c1f06288380a6e0e0e71e5d62bf756fcb3f34f55a48fa9d9c3a60a32387f0a941e6f8ca8f8de65232357cdcf24386e05bdd8ccec61e6d1ab915cfd4d2bf479283638c00547a99072f00e76991c330a64d7f709b377146e1c1125890246531fc2b6e4b3ad37107683540d3da8088a1939bc7114e5c7e52b7e77239316d19eacfb3d21ca35783b95de68099c96a13dcde325169a9acc891b379960d4b18c03035d19d6565531081d174a895f0df084cee20df28066e4b3e1c81b28f06280a89d2cc6275bd094ca750f2dd599d096b42b3f5a92a0db4ed175c697e2e6397cfb751d551259729c05bbc11092203f61adb48ec650dad4fcd9adf749c8b58efeb7cbab2afa44d560f87e00c84617a697245ec2d6f26b6a977ae71434bbe96dd131ec4bf1920c26a74e34f8c70c8e39af8828f83e056bf37838c92c69f7d4186c3a36bb22daa4cf4cff6f1b0748a8e88cef2c038091e52f5fa439d3f952c8deb1f5f783f81e1b6b94fa8fcaf2a074c56ccdf8a1bd2627990ab554fbf703aeabdee619352f806fd4f0dcd56916395d1e2a32d5c8996eff449eb2e087775e07bc0f42b3e4575f9740f62e42d66f154f6b1a9546381e69bb707e66c012af96262186d305992042f9ea030493cf0c9c7be7c523f6a0641e871ad8638883d428326ccda4f6dec93ba3564b7e87a7694f024d6fa7a8694f055db64d85a9b273f1e7419fe3284575b87bd03de2390ee47ff03201f568a412b9c7db91644c6c3e548658cc4b32bc692e065da0be545d004964a82bab518ed86f028616c286e8993d28f337b113a26703525rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootglibc-2.38-150600.14.17.2.src.rpmglibc-i18ndata    rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.0.4-14.6.0-14.0-15.2-14.14.3gM@gp@fffWfO/f;i@f:f2.f! @f De!@e@e}@epe6@e@e@eeoem@e6`@e/e.w@e#@eSe@ev@e;e@eRd@d@d@d@d@d@dE@dd@dr@dK@d%ydcT@c@c @clcY!@c=qc*c@c6@cb5@bb@bUbb@b@b|bk@b@aa@a@a@a\>@aaaj@a@`P@```8@`7@`u`Y@`F`>(`<@`.V`+`>`_إ@__@_Wr@_+^^x^^j$@^K^E:@^8 @^&]7@]]c@]@]]]@]Z@]Z@]D%]/ ]^@] ] u@]@\@\@\\~d\n\j@\T4\5@[@[[[t[[t[b@[(@["X[)[WZJ@Z@Z2@ZZ@ZZ$Z@ZxG@Zp^@Zp^@Ze@ZKt@Z1@Z/Z@Y@Y@YYܶ@YdY@Y@YY@Y@Y@YW@Y@YJYYw2Yp@YJ_YA%@Y.@Y, @Y, @Y$$@Y"XۡX@XWw@W@W@Ws@Wk@Wj}WYZ@WL+@W3W0{WW V@V@V޾Vm@VIV@VŲ@V`VVV@VLh@V.V$@VVZV VUYU|@UAUȒ@UU@UU4@UUv@U%@U/@U:T@TPTgTܕTء@TO@schwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.degiuliano.belinassi@suse.comschwab@suse.degiuliano.belinassi@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.derguenther@suse.comschwab@suse.derguenther@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.degiuliano.belinassi@suse.comschwab@suse.deschwab@suse.deschwab@suse.delnussel@suse.comschwab@suse.degmbr3@opensuse.orgschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.defvogt@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.dedimstar@opensuse.orgmeissner@suse.comschwab@suse.deschwab@suse.dematz@suse.comgiuliano.belinassi@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.dematz@suse.comschwab@suse.delnussel@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deguillaume.gardet@opensuse.orgschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.derguenther@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.dekukuk@suse.deschwab@suse.deschwab@suse.deschwab@suse.delnussel@suse.deschwab@suse.deschwab@suse.dekukuk@suse.deschwab@suse.deschwab@suse.deschwab@suse.demliska@suse.czmliska@suse.czschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.demliska@suse.czschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.dejengelh@inai.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.defvogt@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.dejslaby@suse.comschwab@suse.deschwab@suse.deschwab@suse.deidonmez@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.denormand@linux.vnet.ibm.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.demeissner@suse.comschwab@suse.deschwab@suse.demgorman@suse.comschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.deschwab@suse.de- Remove nss-systemd from default nsswitch.conf (bsc#1233699)- Apply libc_nonshared.a workaround also on s390x and ppc64le (bsc#1231051)- Use nss-systemd by default also in SLE (bsc#1230638)- s390x-wcsncmp.patch: s390x: Fix segfault in wcsncmp (bsc#1228042, BZ [#31934])- Fix typo in last change- Also include stat64 in the 32-bit libc_nonshared.a workaround (bsc#1221482)- ulp-prologue-into-asm-functions.patch: Avoid creating ULP prologue for _start routine (bsc#1221940)- nscd-netgroup-cache-timeout.patch: Use time_t for return type of addgetnetgrentX (CVE-2024-33602, bsc#1223425) - Also add libc_nonshared.a workaround to 32-bit x86 compat package (bsc#1221482)- glibc-CVE-2024-33599-nscd-Stack-based-buffer-overflow-in-n.patch: nscd: Stack-based buffer overflow in netgroup cache (CVE-2024-33599, bsc#1223423, BZ #31677) - glibc-CVE-2024-33600-nscd-Avoid-null-pointer-crashes-after.patch: nscd: Avoid null pointer crashes after notfound response (CVE-2024-33600, bsc#1223424, BZ #31678) - glibc-CVE-2024-33600-nscd-Do-not-send-missing-not-found-re.patch: nscd: Do not send missing not-found response in addgetnetgrentX (CVE-2024-33600, bsc#1223424, BZ #31678) - glibc-CVE-2024-33601-CVE-2024-33602-nscd-netgroup-Use-two.patch: netgroup: Use two buffers in addgetnetgrentX (CVE-2024-33601, CVE-2024-33602, bsc#1223425, BZ #31680)- iconv-iso-2022-cn-ext.patch: iconv: ISO-2022-CN-EXT: fix out-of-bound writes when writing escape sequence (CVE-2024-2961, bsc#1222992)- Add workaround for invalid use of libc_nonshared.a with non-SUSE libc (bsc#1221482)- malloc-arena-get2.patch: malloc: Use __get_nprocs on arena_get2 (BZ [#30945]) - sched-getcpu-rseq-area.patch: linux: Use rseq area unconditionally in sched_getcpu (BZ #31479)- duplocale-global-locale.patch: duplocale: protect use of global locale (bsc#1220441, BZ #23970)- s390-clone-error-clobber-r7.patch: S390: Do not clobber r7 in clone (BZ [#31402])- Add libnsl1 to baselibs.conf (bsc#1219640)- syslog-buffer-overflow.patch: syslog: Fix heap buffer overflow in __vsyslog_internal (CVE-2023-6246, CVE-2023-6779, CVE-2023-6780, bsc#1218863, bsc#1218867, bsc#1218868) - qsort-invalid-cmp.patch: qsort: handle degenerated compare function (bsc#1218866)- Change minimum GCC to 13- Split off libnsl.so.1 into a separate package- sem-open-o-creat.patch: sem_open: Clear O_CREAT when semaphore file is expected to exist (BZ #30789) - ldconfig-process-elf-file.patch: elf: Fix wrong break removal from 8ee878592c - tls-modid-reuse.patch: elf: Fix TLS modid reuse generation assignment (BZ #29039) - getaddrinfo-eai-memory.patch: getaddrinfo: translate ENOMEM to EAI_MEMORY (bsc#1217589, BZ #31163) - libio-wdo-write.patch: libio: Check remaining buffer size in _IO_wdo_write (BZ #31183)- aarch64-rawmemchr-unwind.patch: aarch64: correct CFI in rawmemchr (bsc#1217445, BZ #31113)- Remove systemd from shadow and gshadow lookups (bsc#1217220)- gb18030-2022.patch: add GB18030-2022 charmap (jsc#PED-4908, BZ #30243)- dtors-reverse-ctor-order.patch: Remove, has been reverted- Avoid use of SSE in i586 build- Add systemd also to gshadow lookups (jsc#PED-5188) - For SLE continue to use nsswitch.conf without systemd- setxid-propagate-glibc-tunables.patch: Propagate GLIBC_TUNABLES in setxid binaries - tunables-string-parsing.patch: tunables: Terminate if end of input is reached (CVE-2023-4911, bsc#1215501)- fstat-implementation.patch: io: Do not implement fstat with fstatat- getaddrinfo-memory-leak.patch: Fix leak in getaddrinfo introduced by the fix for CVE-2023-4806 (CVE-2023-5156, bsc#1215714, BZ #30884)- getcanonname-use-after-free.patch: getaddrinfo: Fix use after free in getcanonname (CVE-2023-4806, bsc#1215281, BZ #30843) - Do not build any cross packages in SLES- no-aaaa-read-overflow.patch: Stack read overflow with large TCP responses in no-aaaa mode (CVE-2023-4527, bsc#1215280, BZ #30842)- Add systemd to passwd, group and shadow lookups (jsc#PED-5188)- ppc64-flock-fob64.patch: io: Fix record locking contants for powerpc64 with __USE_FILE_OFFSET64 (BZ #30804) - libio-io-vtables.patch: libio: Fix oversized __io_vtables - call-init-proxy-objects.patch: elf: Do not run constructors for proxy objects - dtors-reverse-ctor-order.patch: elf: Always call destructors in reverse constructor order (BZ #30785)- intl-c-utf-8-like-c-locale.patch: intl: Treat C.UTF-8 locale like C locale (BZ #16621) - glibc-disable-gettext-for-c-utf8.patch: Removed- Add cross-ppc64le package- posix-memalign-fragmentation.patch: malloc: Enable merging of remainders in memalign, remove bin scanning from memalign (BZ #30723) - Limit build counter sync to i686 flavor, to reduce needs for rebuilds- Add cross-s390x package (bsc#1214460)- Require that elf/check-localplt does not fail - glibc-2.3.90-langpackdir.diff: add hidden alias for __strcpy_chk - cache-amd-legacy.patch: x86: Fix for cache computation on AMD legacy cpus - cache-intel-shared.patch: x86: Fix incorrect scope of setting `shared_per_thread` (BZ# 30745)- Update to glibc 2.38 * When C2X features are enabled and the base argument is 0 or 2, the following functions support binary integers prefixed by 0b or 0B as input * PRIb*, PRIB* and SCNb* macros from C2X have been added to . * printf-family functions now support the wN format length modifiers for arguments of type intN_t, int_leastN_t, uintN_t or uint_leastN_t and the wfN format length modifiers for arguments of type int_fastN_t or uint_fastN_t, as specified in draft ISO C2X * A new tunable, glibc.pthread.stack_hugetlb, can be used to disable Transparent Huge Pages (THP) in stack allocation at pthread_create * Vector math library libmvec support has been added to AArch64 * The strlcpy and strlcat functions have been added * CVE-2023-25139: When the printf family of functions is called with a format specifier that uses an (enable grouping) and a minimum width specifier, the resulting output could be larger than reasonably expected by a caller that computed a tight bound on the buffer size - Enable build with _FORTIFY_SOURCE - glibc-2.3.90-langpackdir.diff: avoid reference to __strcpy_chk - iconv-error-verbosity.patch: iconv: restore verbosity with unrecognized encoding names (BZ #30694) - printf-grouping.patch, strftime-time64.patch, getlogin-no-loginuid.patch, fix-locking-in-_IO_cleanup.patch, gshadow-erange-rhandling.patch, system-sigchld-block.patch, gmon-buffer-alloc.patch, check-pf-cancel-handler.patch, powerpc64-fcntl-lock.patch, realloc-limit-chunk-reuse.patch, dl-find-object-return.patch; Removed - bsc#1211828 - bsc#1212819- gshadow-erange-rhandling.patch: gshadow: Matching sgetsgent, sgetsgent_r ERANGE handling (BZ #30151) - system-sigchld-block.patch: posix: Fix system blocks SIGCHLD erroneously (BZ #30163) - gmon-buffer-alloc.patch: gmon: Fix allocated buffer overflow (CVE-2023-0687, bsc#1207975, BZ #29444) - check-pf-cancel-handler.patch: __check_pf: Add a cancellation cleanup handler (BZ #20975) - powerpc64-fcntl-lock.patch: io: Fix F_GETLK, F_SETLK, and F_SETLKW for powerpc64 - realloc-limit-chunk-reuse.patch: realloc: Limit chunk reuse to only growing requests (BZ #30579) - dl-find-object-return.patch: elf: _dl_find_object may return 1 during early startup (BZ #30515)- Need to build with GCC 12 as minimum- fix-locking-in-_IO_cleanup.patch: Update to final version- ulp-prologue-into-asm-functions.patch: Add support for livepatches in ASM written functions (bsc#1210777, bsc#1211726)- getlogin-no-loginuid.patch: getlogin_r: fix missing fallback if loginuid is unset (bsc#1209229, BZ #30235)- Exclude static archives from preparation for live patching (bnc#1208721)- Update to glibc 2.37 * The getent tool now supports the --no-addrconfig option * The dynamic linker no longer loads shared objects from the "tls" subdirectories on the library search path or the subdirectory that corresponds to the AT_PLATFORM system name, or employs the legacy AT_HWCAP search mechanism, which was deprecated in version 2.33 - printf-grouping.patch: Account for grouping in printf width (BZ #30068) - strftime-time64.patch: Use 64-bit time_t interfaces in strftime and strptime (BZ #30053) - glibcextract-compile-c-snippet.patch, sys-mount-kernel-definition.patch, sys-mount-usage.patch, nscd-netlink-cache-invalidation.patch, syslog-large-messages.patch, dlmopen-libc-early-init.patch, ldd-vdso-dependency.patch, syslog-extra-whitespace.patch, errlist-edeadlock.patch, makeflags.patch, get-nscd-addresses.patch, x86-64-avx2-string-functions.patch, nscd-aicache.patch, dl-debug-bindings.patch, floatn.patch: Removed - bsc#1207957 - bsc#1208358 - bsc#1212910- Remove reference to obsolete %usrmerged macro (boo#1206798)- floatn.patch: Update _FloatN header support for C++ in GCC 13- nscd: Convert to systemd-sysusers- dl-debug-bindings.patch: elf: Reinstate on DL_DEBUG_BINDINGS _dl_lookup_symbol_x (bsc#1204710)- get-nscd-addresses.patch: get_nscd_addresses: Fix subscript typos (BZ [#29605]) - x86-64-avx2-string-functions.patch: check for required cpu features in AVX2 string functions (BZ #29611) - nscd-aicache.patch: nscd: Drop local address tuple variable (BZ #29607)- makeflags.patch: Makerules: fix MAKEFLAGS assignment for upcoming make-4.4 (BZ# 29564)- errlist-edeadlock.patch: errlist: add missing entry for EDEADLOCK (BZ [#29545])- syslog-large-messages.patch: syslog: Fix large messages (CVE-2022-39046, bsc#1203011, BZ #29536) - dlmopen-libc-early-init.patch: elf: Call __libc_early_init for reused namespaces (BZ #29528) - ldd-vdso-dependency.patch: elf: Restore how vDSO dependency is printed with LD_TRACE_LOADED_OBJECTS (BZ #29539) - syslog-extra-whitespace.patch: syslog: Remove extra whitespace between timestamp and message (BZ #29544)- nscd-netlink-cache-invalidation.patch: nscd: Fix netlink cache invalidation if epoll is used (boo#1199964, BZ #29415)- glibcextract-compile-c-snippet.patch: glibcextract.py: Add compile_c_snippet - sys-mount-kernel-definition.patch: linux: Mimic kernel definition for BLOCK_SIZE - sys-mount-usage.patch: linux: Fix sys/mount.h usage with kernel headers- Update to glibc 2.36 Major new features: * Support for DT_RELR relative relocation format has been added to glibc * On Linux, the pidfd_open, pidfd_getfd, and pidfd_send_signal functions have been added * On Linux, the process_madvise function has been added * On Linux, the process_mrelease function has been added * The “no-aaaa” DNS stub resolver option has been added * On Linux, the fsopen, fsmount, move_mount, fsconfig, fspick, open_tree, and mount_setattr have been added * localedef now accepts locale definition files encoded in UTF-8 * Support for the mbrtoc8 and c8rtomb multibyte/UTF-8 character conversion functions has been added per the ISO C2X N2653 and C++20 P0482R6 proposals * The functions arc4random, arc4random_buf, and arc4random_uniform have been added Deprecated and removed features, and other changes affecting compatibility: * Support for prelink will be removed in the next release * The Linux kernel version check has been removed along with the LD_ASSUME_KERNEL environment variable * On Linux, The LD_LIBRARY_VERSION environment variable has been removed - get-nprocs-sched-uninit-read.patch, get-nprocs-inaccurate.patch, strcmp-rtm-fallback.path, pt-load-invalid-hole.patch, localedef-ld-monetary.patch, nptl-spurious-eintr.patch, strncpy-power9-vsx.patch, nptl-cleanup-async-restore.patch, read-chk-cancel.patch, wcrtomb-fortify.patch, nptl-cleanup-async-restore-2.patch: Removed - CVE-2023-4813, bsc#1215286 - bsc#1198751 - bsc#1200334- nptl-cleanup-async-restore-2.patch: nptl: Fix ___pthread_unregister_cancel_restore asynchronous restore (bsc#1200093, BZ #29214)- read-chk-cancel.patch: debug: make __read_chk a cancellation point (bsc#1200682, BZ #29274) - wcrtomb-fortify.patch: wcrtomb: Make behavior POSIX compliant (bsc#1200688)- Set SUSE_ZNOW=0- strncpy-power9-vsx.patch: powerpc: Fix VSX register number on __strncpy_power9 (BZ #29197) - nptl-cleanup-async-restore.patch: nptl: Fix __libc_cleanup_pop_restore asynchronous restore (bsc#1200093, BZ #29214)- nptl-spurious-eintr.patch: nptl: Handle spurious EINTR when thread cancellation is disabled (BZ #29029)- Follow the distro default gcc version to build the cross bootstrap packages.- switched to https urls- get-nprocs-sched-uninit-read.patch: linux: __get_nprocs_sched: do not feed CPU_COUNT_S with garbage (BZ #28850) - get-nprocs-inaccurate.patch: linux: fix accuracy of get_nprocs and get_nprocs_conf (BZ #28865) - strcmp-rtm-fallback.path: x86: Fallback {str|wcs}cmp RTM in the ncmp overflow case (BZ #28896) - pt-load-invalid-hole.patch: elf: Check invalid hole in PT_LOAD segments (BZ #28838) - localedef-ld-monetary.patch: localedef: Update LC_MONETARY handling (BZ [#28845])- Update to glibc 2.35 Major new features: * Unicode 14.0.0 Support * Bump r_version in the debugger interface to 2 * Support for the C.UTF-8 locale has been added to glibc * functions that round their results to a narrower type, and corresponding macros, are added from TS 18661-1:2014, TS 18661-3:2015 and draft ISO C2X * functions for floating-point maximum and minimum, corresponding to new operations in IEEE 754-2019, and corresponding macros, are added from draft ISO C2X * macros for single-precision float constants are added as a GNU extension * The __STDC_IEC_60559_BFP__ and __STDC_IEC_60559_COMPLEX__ macros are predefined as specified in TS 18661-1:2014 * The exp10 functions in now have a corresponding type-generic macro in * The ISO C2X macro _PRINTF_NAN_LEN_MAX has been added to * printf-family functions now support the %b format for output of integers in binary, as specified in draft ISO C2X, and the %B variant of that format recommended by draft ISO C2X * A new DSO sorting algorithm has been added in the dynamic linker that uses topological sorting by depth-first search (DFS), solving performance issues of the existing sorting algorithm when encountering particular circular object dependency cases * A new tunable, glibc.rtld.dynamic_sort, can be used to select between the two DSO sorting algorithms * ABI support for a new function '__memcmpeq'. '__memcmpeq' is meant to be used by compilers for optimizing usage of 'memcmp' when its return value is only used for its boolean status * Support for automatically registering threads with the Linux rseq system call has been added * A symbolic link to the dynamic linker is now installed under /usr/bin/ld.so (or more precisely, '${bindir}/ld.so') * All programs and the testsuite in glibc are now built as position independent executables (PIE) by default on toolchains and architectures that support it * On Linux, a new tunable, glibc.malloc.hugetlb, can be used to either make malloc issue madvise plus MADV_HUGEPAGE on mmap and sbrk or to use huge pages directly with mmap calls with the MAP_HUGETLB flags) * The printf family of functions now handles the flagged %#m conversion specifier, printing errno as an error constant (similar to strerrorname_np) * The function _dl_find_object has been added * On Linux, the epoll_pwait2 function has been added * The function posix_spawn_file_actions_addtcsetpgrp_np has been added, enabling posix_spawn and posix_spawnp to set the controlling terminal in the new process in a race free manner * Source fortification (_FORTIFY_SOURCE) level 3 is now available for applications compiling with glibc and gcc 12 and later Deprecated and removed features, and other changes affecting compatibility: * On x86-64, the LD_PREFER_MAP_32BIT_EXEC environment variable support has been removed since the first PT_LOAD segment is no longer executable due to defaulting to -z separate-code * The r_version update in the debugger interface makes the glibc binary incompatible with GDB * Intel MPX support (lazy PLT, ld.so profile, and LD_AUDIT) has been removed * The catchsegv script and associated libSegFault.so shared object have been removed * Support for prelink will be removed in the next release; this includes removal of the LD_TRACE_PRELINKING, and LD_USE_LOAD_BIAS, environment variables and their functionality in the dynamic loader Changes to build and runtime requirements: * The audit module interface version LAV_CURRENT is increased to enable proper bind-now support * The audit interface on aarch64 is extended to support both the indirect result location register (x8) and NEON Q register Security related changes: * CVE-2022-23219: Passing an overlong file name to the clnt_create legacy function could result in a stack-based buffer overflow when using the "unix" protocol * CVE-2022-23218: Passing an overlong file name to the svcunix_create legacy function could result in a stack-based buffer overflow * CVE-2021-3998: Passing a path longer than PATH_MAX to the realpath function could result in a memory leak and potential access of uninitialized memory * CVE-2021-3999: Passing a buffer of size exactly 1 byte to the getcwd function may result in an off-by-one buffer underflow and overflow when the current working directory is longer than PATH_MAX and also corresponds to the / directory through an unprivileged mount namespace - copy-and-spawn-sgid-double-close.patch, fcntl-time-bits-64-redirect.patch, gaiconf-init-double-free.patch, gconv-parseconfdir-memory-leak.patch, getcwd-attribute-access.patch, glibc-c-utf8-locale.patch, iconv-charmap-close-output.patch, ld-show-auxv-colon.patch, ldconfig-leak-empty-paths.patch, librt-null-pointer.patch, pthread-kill-fail-after-exit.patch, pthread-kill-race-thread-exit.patch, pthread-kill-return-esrch.patch, pthread-kill-send-specific-thread.patch, pthread-mutexattr-getrobust-np-type.patch, setxid-deadlock-blocked-signals.patch, sysconf-nprocessors-affinity.patch, x86-string-control-test.patch: Removed. - bsc#1194640 - bsc#1194768 - bsc#1194770 - bsc#1197718 - bsc#1211829 - bsc#1215891- Enable building the cross packages in rings.- Add ExtraBuildFlags for build flags that cannot be passed to configure. - Add support for livepatches (jsc#SLE-20049). - Generate ipa-clones tarball artifact when livepatching is enabled.- glibc.rpmlintrc: Update for rpmlint2- ld-show-auxv-colon.patch: elf: Fix missing colon in LD_SHOW_AUXV output (BZ #282539 - x86-string-control-test.patch: x86-64: Use testl to check __x86_string_control - pthread-kill-fail-after-exit.patch: nptl: pthread_kill, pthread_cancel should not fail after exit (BZ #19193) - pthread-kill-race-thread-exit.patch: nptl: Fix race between pthread_kill and thread exit (BZ #12889) - getcwd-attribute-access.patch: posix: Fix attribute access mode on getcwd (BZ #27476) - pthread-kill-return-esrch.patch: nptl: pthread_kill needs to return ESRCH for old programs (BZ #19193) - pthread-mutexattr-getrobust-np-type.patch: nptl: Fix type of pthread_mutexattr_getrobust_np, pthread_mutexattr_setrobust_np (BZ [#28036]) - setxid-deadlock-blocked-signals.patch: nptl: Avoid setxid deadlock with blocked signals in thread exit (BZ #28361) - pthread-kill-send-specific-thread.patch: nptl: pthread_kill must send signals to a specific thread (BZ #28407) - sysconf-nprocessors-affinity.patch: linux: Revert the use of sched_getaffinity on get_nproc (BZ #28310) - iconv-charmap-close-output.patch: renamed from icon-charmap-close-output.patch- Don't create separate debuginfo packages for cross packages- ldconfig-leak-empty-paths.patch: ldconfig: avoid leak on empty paths in config file - gconv-parseconfdir-memory-leak.patch: gconv_parseconfdir: Fix memory leak - gaiconf-init-double-free.patch: gaiconf_init: Avoid double-free in label and precedence lists - copy-and-spawn-sgid-double-close.patch: copy_and_spawn_sgid: Avoid double calls to close() - icon-charmap-close-output.patch: iconv_charmap: Close output file when done - fcntl-time-bits-64-redirect.patch: Linux: Fix fcntl, ioctl, prctl redirects for _TIME_BITS=64 (BZ #28182) - librt-null-pointer.patch: librt: fix NULL pointer dereference (BZ [#28213])- Add cross development packages for aarch64 and riscv64.- Update to glibc 2.34 Major new features: * When _DYNAMIC_STACK_SIZE_SOURCE or _GNU_SOURCE are defined, PTHREAD_STACK_MIN is no longer constant and is redefined to sysconf(_SC_THREAD_STACK_MIN) * Add _SC_MINSIGSTKSZ and _SC_SIGSTKSZ * The dynamic linker implements the --list-diagnostics option, printing a dump of information related to IFUNC resolver operation and glibc-hwcaps subdirectory selection * On Linux, the function execveat has been added * The ISO C2X function timespec_getres has been added * The feature test macro __STDC_WANT_IEC_60559_EXT__, from draft ISO C2X, is supported to enable declarations of functions defined in Annex F of C2X * Add support for 64-bit time_t on configurations like x86 where time_t is traditionally 32-bit * The main gconv-modules file in glibc now contains only a small set of essential converter modules and the rest have been moved into a supplementary configuration file gconv-modules-extra.conf in the gconv-modules.d directory in the same GCONV_PATH * On Linux, a new tunable, glibc.pthread.stack_cache_size, can be used to configure the size of the thread stack cache * The function _Fork has been added as an async-signal-safe fork replacement since Austin Group issue 62 droped the async-signal-safe requirement for fork (and it will be included in the future POSIX standard) * On Linux, the close_range function has been added * The function closefrom has been added * The posix_spawn_file_actions_closefrom_np function has been added, enabling posix_spawn and posix_spawnp to close all file descriptors great than or equal to a giver integer Deprecated and removed features, and other changes affecting compatibility: * The function pthread_mutex_consistent_np has been deprecated * The function pthread_mutexattr_getrobust_np has been deprecated * The function pthread_mutexattr_setrobust_np has been deprecated * The function pthread_yield has been deprecated * The function inet_neta declared in has been deprecated * Various rarely-used functions declared in and have been deprecated * The pthread cancellation handler is now installed with SA_RESTART and pthread_cancel will always send the internal SIGCANCEL on a cancellation request * The symbols mallwatch and tr_break are now deprecated and no longer used in mtrace * The __morecore and __after_morecore_hook malloc hooks and the default implementation __default_morecore have been removed from the API * Debugging features in malloc such as the MALLOC_CHECK_ environment variable (or the glibc.malloc.check tunable), mtrace() and mcheck() have now been disabled by default in the main C library * The deprecated functions malloc_get_state and malloc_set_state have been moved from the core C library into libc_malloc_debug.so * The deprecated memory allocation hooks __malloc_hook, __realloc_hook, __memalign_hook and __free_hook are now removed from the API Changes to build and runtime requirements: * On Linux, the shm_open, sem_open, and related functions now expect the file shared memory file system to be mounted at /dev/shm Security related changes: CVE-2021-27645: The nameserver caching daemon (nscd), when processing a request for netgroup lookup, may crash due to a double-free, potentially resulting in degraded service or Denial of Service on the local system CVE-2021-33574: The mq_notify function has a potential use-after-free issue when using a notification type of SIGEV_THREAD and a thread attribute with a non-default affinity mask CVE-2021-35942: The wordexp function may overflow the positional parameter number when processing the expansion resulting in a crash - nss-database-check-reload.patch, nss-load-chroot.patch, x86-isa-level.patch, nscd-netgroupcache.patch, nss-database-lookup.patch, select-modify-timeout.patch, nptl-db-libpthread-load-order.patch, rawmemchr-warning.patch, tst-cpu-features-amx.patch, mq-notify-use-after-free.patch: Removed - bsc#1181403 - bsc#1184035 - bsc#1187911 - jsc#PED-987- Enable usrmerge in Factory always as it's default there - Add conflict with pre-usrmerge filesystem package- mq-notify-use-after-free.patch: Use __pthread_attr_copy in mq_notify (CVE-2021-33574, bsc#1186489, BZ #27896) - Drop glibc-usrmerge-bootstrap-helper package- tst-cpu-features-amx.patch: x86: tst-cpu-features-supports.c: Update AMX check- rawmemchr-warning.patch: string: Work around GCC PR 98512 in rawmemchr- nptl-db-libpthread-load-order.patch: nptl_db: Support different libpthread/ld.so load orders (bsc#1184214, BZ #27744)- Enable support for static PIE (bsc#1184646) - select-modify-timeout.patch: linux: always update select timeout (bsc#1184339, BZ #27706)- Don't remove -f[asynchronous-]unwind-tables during configure run, no longer needed- nss-database-check-reload.patch: nsswitch: return result when nss database is locked (BZ #27343) - nss-load-chroot.patch: nss: Re-enable NSS module loading after chroot (bsc#1182323, BZ #27389) - x86-isa-level.patch: x86: Set minimum x86-64 level marker (bsc#1182522, BZ #27318) - nss-database-lookup.patch: nss: fix nss_database_lookup2's alternate handling (bsc#1182247, BZ #27416) - nss-revert-api.patch: remove - nscd-netgroupcache.patch: nscd: Fix double free in netgroupcache (CVE-2021-27645, bsc#1182733, BZ #27462)- Disable x86 ISA level for now (bsc#1182522, BZ #27318) - nss-revert-api.patch: Workaround for nss-compat brokeness (bsc#1182247, BZ #27416)- Fix build of utils flavor for usrmerge- Prepare for usrmerge (bsc#1029961)- Add --enable-memory-tagging for aarch64- Update to glibc 2.33 * The dynamic linker accepts the --list-tunables argument which prints all the supported tunables. * The dynamic linker accepts the --argv0 argument and provides opportunity to change argv[0] string. * The dynamic linker loads optimized implementations of shared objects from subdirectories under the glibc-hwcaps directory on the library search path if the system's capabilities meet the requirements for that subdirectory. * The new --help option of the dynamic linker provides usage and information and library search path diagnostics. * The mallinfo2 function is added to report statistics as per mallinfo, but with larger field widths to accurately report values that are larger than fit in an integer. * Add to provide query macros for x86 CPU features. * A new fortification level _FORTIFY_SOURCE=3 is available. * The mallinfo function is marked deprecated. * When dlopen is used in statically linked programs, alternative library implementations from HWCAP subdirectories are no longer loaded. * The deprecated header and the function vtimes have been removed. * On s390(x), the type float_t is now derived from the macro __FLT_EVAL_METHOD__ that is defined by the compiler, instead of being hardcoded to double. * A future version of glibc will stop loading shared objects from the "tls" subdirectories on the library search path, the subdirectory that corresponds to the AT_PLATFORM system name, and also stop employing the legacy AT_HWCAP search mechanism. * CVE-2021-3326: An assertion failure during conversion from the ISO-20220-JP-3 character set using the iconv function has been fixed. - Remove obsolete, unused /etc/default/nss - aarch64-static-pie.patch, euc-kr-overrun.patch, get-nprocs-cpu-online-parsing.patch, iconv-redundant-shift.patch, iconv-ucs4-loop-bounds.patch, ifunc-fma4.patch, intl-codeset-suffixes.patch, nscd-gc-cycle.patch, printf-long-double-non-normal.patch, strerrorname-np.patch, syslog-locking.patch, sysvipc.patch: Removed - bsc#1180557 - bsc#1181505 - bsc#1191592 - bsc#1201942- Remove support for %optimize_power - Move to power4 baseline on ppc- aarch64-static-pie.patch: fix static PIE start code for BTI (bsc#1179450, BZ #27068) - iconv-redundant-shift.patch: iconv: Accept redundant shift sequences in IBM1364 (CVE-2020-27618, bsc#1178386, BZ #26224) - iconv-ucs4-loop-bounds.patch: iconv: Fix incorrect UCS4 inner loop bounds (CVE-2020-29562, bsc#1179694, BZ #26923) - printf-long-double-non-normal.patch: x86: Harden printf against non-normal long double values (CVE-2020-29573, bsc#1179721, BZ #26649) - get-nprocs-cpu-online-parsing.patch: Fix parsing of /sys/devices/system/cpu/online (bsc#1180038, BZ #25859)- intl-codeset-suffixes.patch: intl: Handle translation output codesets with suffixes (BZ #26383) - strerrorname-np.patch: string: Fix strerrorname_np return value (BZ [#26555]) - sysvipc.patch: sysvipc: Fix SEM_STAT_ANY kernel argument pass (BZ [#26637], BZ #26639, BZ #26636)- Use --enable-cet on x86_64 to instrument glibc for indirect branch tracking and shadow stack use. Enable indirect branch tracking and shadow stack in the dynamic loader (jsc#PM-2110, bsc#1175154)- Keep nsswitch.conf in /etc for SLES15 - syslog-locking.patch: Correct locking and cancellation cleanup in syslog functions (bsc#1172085, BZ #26100) - ifunc-fma4.patch: x86-64: Fix FMA4 detection in ifunc (BZ #26534)- Update to glibc 2.32 * Unicode 13.0.0 Support * New locale added: ckb_IQ * The GNU C Library now loads audit modules listed in the DT_AUDIT and DT_DEPAUDIT dynamic section entries of the main executable * powerpc64le supports IEEE128 long double libm/libc redirects when using the -mabi=ieeelongdouble to compile C code on supported GCC toolchains * To help detect buffer overflows and other out-of-bounds accesses several APIs have been annotated with GCC 'access' attribute * On Linux, functions the pthread_attr_setsigmask_np and pthread_attr_getsigmask_np have been added * The GNU C Library now provides the header file which declares the variable __libc_single_threaded * The functions sigabbrev_np and sigdescr_np have been added * The functions strerrorname_np and strerrordesc_np have been added * AArch64 now supports standard branch protection security hardening in glibc when it is built with a GCC that is configured with - -enable-standard-branch-protection (or if -mbranch-protection=standard flag is passed when building both GCC target libraries and glibc, in either case a custom GCC is needed) * The deprecated header and the sysctl function have been removed * The sstk function is no longer available to newly linked binaries * The legacy signal handling functions siginterrupt, sigpause, sighold, sigrelse, sigignore and sigset, and the sigmask macro have been deprecated * ldconfig now defaults to the new format for ld.so.cache * The deprecated arrays sys_siglist, _sys_siglist, and sys_sigabbrev are no longer available to newly linked binaries, and their declarations have been removed from * The deprecated symbols sys_errlist, _sys_errlist, sys_nerr, and _sys_nerr are no longer available to newly linked binaries, and their declarations have been removed from from * Both strerror and strerror_l now share the same internal buffer in the calling thread, meaning that the returned string pointer may be invalided or contents might be overwritten on subsequent calls in the same thread or if the thread is terminated * Using weak references to libpthread functions such as pthread_create or pthread_key_create to detect the singled-threaded nature of a program is an obsolescent feature * The "files" NSS module no longer supports the "key" database (used for secure RPC) * The __morecore and __after_morecore_hook malloc hooks and the default implementation __default_morecore have been deprecated * The hesiod NSS module has been deprecated and will be removed in a future version of glibc * CVE-2016-10228: An infinite loop has been fixed in the iconv program when invoked with the -c option and when processing invalid multi-byte input sequences * CVE-2020-10029: Trigonometric functions on x86 targets suffered from stack corruption when they were passed a pseudo-zero argument * CVE-2020-1752: A use-after-free vulnerability in the glob function when expanding ~user has been fixed. * CVE-2020-6096: A signed comparison vulnerability in the ARMv7 memcpy and memmove functions has been fixed - riscv-syscall-clobber.patch, ldbl-96-rem-pio2l.patch, long-double-alias.patch: Removed - bsc#1027496 - bsc#1162930 - bsc#1166106 - bsc#1167631 - bsc#1167939 - bsc#1194785, jsc#SLE-18195 - bsc#1200855 - bsc#1201560 - bsc#1201640 - bsc#1207571 - jsc#SLE-13520- long-double-alias.patch: Fix build with GCC 10 when long double = double - nscd-gc-cycle.patch: nscd: bump GC cycle during cache pruning (bsc#1171878, BZ #26130)- glibc-nsswitch-usr.diff: read /usr/etc/nsswitch.conf if /etc/nsswitch.conf does not exist - Install default nsswitch.conf in /usr/etc - Don't install gai.conf in /etc- Split off %lang_package- riscv-syscall-clobber.patch: riscv: Avoid clobbering register parameters in syscall - ldbl-96-rem-pio2l.patch: Avoid ldbl-96 stack corruption from range reduction of pseudo-zero (CVE-2020-10029, bsc#1165784, BZ #25487)- nsswitch.conf: comment out initgroups setting, so that it defaults to the group setting (bsc#1164075)- fix-locking-in-_IO_cleanup.patch: update to latest version- Update to glibc 2.31 * The GNU C Library now supports a feature test macro _ISOC2X_SOURCE to enable features from the draft ISO C2X standard * The functions that round their results to a narrower type now have corresponding type-generic macros in * The function pthread_clockjoin_np has been added, enabling join with a terminated thread with a specific clock * New locale added: mnw_MM (Mon language spoken in Myanmar). * The DNS stub resolver will optionally send the AD (authenticated data) bit in queries if the trust-ad option is set via the options directive in /etc/resolv.conf (or if RES_TRUSTAD is set in _res.options) * The totalorder and totalordermag functions, and the corresponding functions for other floating-point types, now take pointer arguments to avoid signaling NaNs possibly being converted to quiet NaNs in argument passing * The obsolete function stime is no longer available to newly linked binaries, and its declaration has been removed from * The gettimeofday function no longer reports information about a system-wide time zone * If a lazy binding failure happens during dlopen, during the execution of an ELF constructor, the process is now terminated - malloc-info-whitespace.patch, riscv-vfork.patch, prefer-map-32bit-exec.patch, backtrace-powerpc.patch, ldconfig-dynstr.patch: Removed. - bsc#1157893 - bsc#1163184 - fate#325815, fate#325879, fate#325880, fate#325881, fate#325882 - fate#325962- backtrace-powerpc.patch: Fix array overflow in backtrace on PowerPC (CVE-2020-1751, bsc#1158996, BZ #25423) - Drop support for pluggable gconv modules (bsc#1159851)- prefer-map-32bit-exec.patch: rtld: Check __libc_enable_secure before honoring LD_PREFER_MAP_32BIT_EXEC (CVE-2019-19126, bsc#1157292, BZ [#25204])- nsswitch.conf: add usrfiles for services, protocols, rpc, ethers and aliases for /usr/etc move- euc-kr-overrun.patch: Fix buffer overrun in EUC-KR conversion module (CVE-2019-25013, BZ #24973)- ldconfig-dynstr.patch: ldconfig: handle .dynstr located in separate segment (bsc#1153149, BZ #25087)- Package gconv-modules.cache as %ghost - Regenerate it also in the %post of glibc-local-base-- move mo files to glibc-locale as that's where all the other informations for those locales are. glibc-locale-base only has English anyways.- riscv-vfork.patch: Fix RISC-V vfork build with Linux 5.3 kernel headers- Remove NoSource tags (bsc#994835)- pwdutils is long gone and replaced by shadow- Update to glibc 2.30 * Unicode 12.1.0 Support * The dynamic linker accepts the --preload argument to preload shared objects * The twalk_r function has been added * On Linux, the getdents64, gettid, and tgkill functions have been added * Minguo (Republic of China) calendar support has been added * The entry for the new Japanese era has been added * Memory allocation functions malloc, calloc, realloc, reallocarray, valloc, pvalloc, memalign, and posix_memalign fail now with total object size larger than PTRDIFF_MAX * The dynamic linker no longer refuses to load objects which reference versioned symbols whose implementation has moved to a different soname since the object has been linked * Add new POSIX-proposed pthread_cond_clockwait, pthread_mutex_clocklock, pthread_rwlock_clockrdlock, pthread_rwlock_clockwrlock and sem_clockwait functions * On AArch64 the GNU IFUNC resolver call ABI changed * The copy_file_range function fails with ENOSYS if the kernel does not support the system call of the same name * The functions clock_gettime, clock_getres, clock_settime, clock_getcpuclockid, clock_nanosleep were removed from the librt library for new applications (on architectures which had them) * The obsolete and never-implemented XSI STREAMS header files and have been removed * Support for the "inet6" option in /etc/resolv.conf and the RES_USE_INET6 resolver flag (deprecated in glibc 2.25) have been removed * The obsolete RES_INSECURE1 and RES_INSECURE2 option flags for the DNS stub resolver have been removed from * With --enable-bind-now, installed programs are now linked with the BIND_NOW flag. * On 32-bit Arm, support for the port-based I/O emulation and the header have been removed * The Linux-specific header and the sysctl function have been deprecated and will be removed from a future version of glibc * CVE-2019-7309: x86-64 memcmp used signed Jcc instructions to check size * CVE-2019-9169: Attempted case-insensitive regular-expression match via proceed_next_node in posix/regexec.c leads to heap-based buffer over-read - pthread-rwlock-trylock-stalls.patch, arm-systemtap-probe-constraint.patch, pthread-mutex-barrier.patch, fork-handler-lock.patch, pthread-join-probe.patch, riscv-clone-unwind.patch, add-new-Fortran-vector-math-header-file.patch, regex-read-overrun.patch, japanese-era-name-may-2019.patch, dl-show-auxv.patch, s390-vx-vxe-hwcap.patch, taisho-era-string.patch, malloc-tracing-hooks.patch, pldd-inf-loop.patch, malloc-large-bin-corruption-check.patch, wfile-sync-crash.patch, malloc-tests-warnings.patch, fnmatch-collating-elements.patch, iconv-reset-input-buffer.patch: Removed - malloc-info-whitespace.patch: Remove unwanted leading whitespace in malloc_info (BZ #24867) - bsc#1100396 - bsc#1130045- Move /var/lib/misc/Makefile to /usr/share/misc/Makefile.makedb (bsc#1138726)- malloc-tests-warnings.patch: Fix warnings in malloc tests with GCC 9- Set optflags for i686 after _lto_cflags is set (boo#1138807).- Disable LTO due to a usage of top-level assembler that causes LTO issues (boo#1138807).- nss-files-long-lines-2.patch: Remove obsolete patch- dl-show-auxv.patch: Fix output of LD_SHOW_AUXV=1 - s390-vx-vxe-hwcap.patch: S390: Mark vx and vxe as important hwcap - taisho-era-string.patch: ja_JP: Change the offset for Taisho gan-nen from 2 to 1 (BZ #24162) - malloc-tracing-hooks.patch: malloc: Set and reset all hooks for tracing (BZ #16573) - pldd-inf-loop.patch: elf: Fix pldd (BZ#18035) - malloc-large-bin-corruption-check.patch: malloc: Check for large bin list corruption when inserting unsorted chunk (BZ #24216) - wfile-sync-crash.patch: Fix crash in _IO_wfile_sync (BZ #20568)- japanese-era-name-may-2019.patch: ja_JP locale: Add entry for the new Japanese era (BZ #22964) - Replace glibc_post_upgrade with lua script- add-new-Fortran-vector-math-header-file.patch: Update from upstream- regex-read-overrun.patch: fix read overrun (CVE-2019-9169, bsc#1127308, BZ #24114) - ldconfig-concurrency.patch: Avoid concurrency problem in ldconfig (bsc#1117993, BZ #23973)- Add add-new-Fortran-vector-math-header-file.patch.- pthread-rwlock-trylock-stalls.patch: nptl: Fix pthread_rwlock_try*lock stalls (BZ #23844) - arm-systemtap-probe-constraint.patch: arm: Use "nr" constraint for Systemtap probes (BZ #24164) - pthread-mutex-barrier.patch: Add compiler barriers around modifications of the robust mutex list for pthread_mutex_trylock (BZ #24180) - fork-handler-lock.patch: nptl: Avoid fork handler lock for async-signal-safe fork (BZ #24161) - pthread-join-probe.patch: nptl: Fix invalid Systemtap probe in pthread_join (BZ #24211) - riscv-clone-unwind.patch: RISC-V: Fix elfutils testsuite unwind failures (BZ #24040)- Update to glibc 2.29 * The getcpu wrapper function has been added, which returns the currently used CPU and NUMA node * Optimized generic exp, exp2, log, log2, pow, sinf, cosf, sincosf and tanf * The reallocarray function is now declared under _DEFAULT_SOURCE, not just for _GNU_SOURCE, to match BSD environments * For powercp64le ABI, Transactional Lock Elision is now enabled iff kernel indicates that it will abort the transaction prior to entering the kernel (PPC_FEATURE2_HTM_NOSC on hwcap2) * The functions posix_spawn_file_actions_addchdir_np and posix_spawn_file_actions_addfchdir_np have been added, enabling posix_spawn and posix_spawnp to run the new process in a different directory * The popen and system do not run atfork handlers anymore (BZ#17490) * strftime's default formatting of a locale's alternative year (%Ey) has been changed to zero-pad the year to a minimum of two digits, like "%y" * As a GNU extension, the '_' and '-' flags can now be applied to "%EY" to control how the year number is formatted * The glibc.tune tunable namespace has been renamed to glibc.cpu and the tunable glibc.tune.cpu has been renamed to glibc.cpu.name * The type of the pr_uid and pr_gid members of struct elf_prpsinfo, defined in , has been corrected to match the type actually used by the Linux kernel * An archaic GNU extension to scanf, under which '%as', '%aS', and '%a[...]' meant to scan a string and allocate space for it with malloc, is now restricted to programs compiled in C89 or C++98 mode with _GNU_SOURCE defined - unwind-ctor.patch, old-getdents64.patch, nss-files-leak.patch, riscv-feholdexcept-setround.patch, pthread-cond-broadcast-waiters-after-spinning.patch, regex-uninit-memory-access.patch, spawni-maybe-script-execute.patch, gethostid-gethostbyname-failure.patch, strstr-huge-needle.patch, pthread-mutex-lock-elision-race.patch, x86-haswell-string-flags.patch, if-nametoindex-descr-leak.patch, riscv-flush-icache.patch: Removed - CVE-2016-10739 - bsc#1114984 - bsc#1114993 - bsc#1122729 - bsc#1131330 - bsc#1149332 - bsc#1151582 - bsc#1164505- fnmatch-collating-elements.patch: update - riscv-flush-icache.patch: fix for compiling against 4.20 headers- if-nametoindex-descr-leak.patch: if_nametoindex: Fix descriptor leak for overlong name (CVE-2018-19591, BZ #23927, bsc#1117603)- Fix typography for glibc-locale-base.- pthread-mutex-lock-elision-race.patch: Fix race in pthread_mutex_lock while promoting to PTHREAD_MUTEX_ELISION_NP (BZ #23275) - x86-haswell-string-flags.patch: x86: Fix Haswell CPU string flags (BZ [#23709])- unwind-ctor.patch: Add missing unwind information to ld.so on powerpc32 (BZ #23707) - old-getdents64.patch: Rewrite __old_getdents64 (BZ #23497) - nss-files-leak.patch: Fix file stream leak in aliases lookup (BZ #23521) - riscv-feholdexcept-setround.patch: Fix rounding save/restore bug - pthread-cond-broadcast-waiters-after-spinning.patch: Fix waiters-after-spinning case (BZ #23538) - regex-uninit-memory-access.patch: fix uninitialized memory access (BZ [#23578]) - spawni-maybe-script-execute.patch: Fix segfault in maybe_script_execute - gethostid-gethostbyname-failure.patch: Check for NULL value from gethostbyname_r (BZ #23679) - strstr-huge-needle.patch: Fix strstr bug with huge needles (BZ #23637)- Add libpng-devel and zlib-devel for utils build- Add glibc-locale-base subpackage containing only C, C.UTF-8 and en_US.UTF-8 locales (fate#326551)- Update to glibc 2.28 * The localization data for ISO 14651 is updated to match the 2016 Edition 4 release of the standard, this matches data provided by Unicode 9.0.0 * Unicode 11.0.0 Support: Character encoding, character type info, and transliteration tables are all updated to Unicode 11.0.0, using generator scripts contributed by Mike FABIAN (Red Hat) * functions that round their results to a narrower type are added from TS 18661-1:2014 and TS 18661-3:2015 * Two grammatical forms of month names are now supported * The renameat2 function has been added, a variant of the renameat function which has a flags argument * The statx function has been added, a variant of the fstatat64 function with an additional flags argument * IDN domain names in getaddrinfo and getnameinfo now use the system libidn2 library if installed * Parsing of dynamic string tokens in DT_RPATH, DT_RUNPATH, DT_NEEDED, DT_AUXILIARY, and DT_FILTER has been expanded to support the full range of ELF gABI expressions including such constructs as '$ORIGIN$ORIGIN' (if valid) * Support for ISO C threads (ISO/IEC 9899:2011) has been added. * The nonstandard header files and <_G_config.h> are no longer installed * The stdio functions 'getc' and 'putc' are no longer defined as macros * All stdio functions now treat end-of-file as a sticky condition * The macros 'major', 'minor', and 'makedev' are now only available from the header * The obsolete function ustat is no longer available to newly linked binaries; the headers and have been removed * The obsolete function nfsservctl is no longer available to newly linked binaries * The obsolete function name llseek is no longer available to newly linked binaries * The AI_IDN_ALLOW_UNASSIGNED and NI_IDN_ALLOW_UNASSIGNED flags for the getaddrinfo and getnameinfo functions have been deprecated * The AI_IDN_USE_STD3_ASCII_RULES and NI_IDN_USE_STD3_ASCII_RULES flags for the getaddrinfo and getnameinfo functions have been deprecated * The fcntl function now have a Long File Support variant named fcntl64 * CVE-2016-6261, CVE-2016-6263, CVE-2017-14062: Various vulnerabilities have been fixed by removing the glibc-internal IDNA implementation and using the system-provided libidn2 library instead - Split off all libcrypt related functions into package libxcrypt - fix-locking-in-_IO_cleanup.patch, fnmatch-collating-elements.patch: Rediff - aarch64-sys-ptrace-update.patch, crypt_blowfish-1.2-hack_around_arm.diff, crypt_blowfish-1.2-sha.diff, crypt_blowfish-const.patch, crypt_blowfish-gensalt.patch, glibc-2.14-crypt.diff, i386-memmove-sse2-unaligned.patch, i386-sigaction-sa-restorer.patch, mempcpy-avx512.patch, netgroup-cache-keys.patch, nss-database-multiple-dfn.patch, pkey-get-reserved-name.patch, powerpc-sys-ptrace-undefine-macros.patch, powerpc-sys-ptrace-update.patch, realpath-ssize-max-overflow.patch, res-send-enomem.patch, riscv-fmax-fmin-nan.patch, riscv-kernel-sigaction.patch, riscv-readelflib.patch, riscv-tls-init.patch: Removed - glibc_post_upgrade.c: Don't reload init (bsc#1103124) - CVE-2009-5155, CVE-2015-8985 - bsc#1092877 - bsc#1102526 - bsc#1112570 - bsc#1126590 - bsc#1127223- Use python3-pexpect instead of python-pexpect- riscv-kernel-sigaction.patch: fix struct kernel_sigaction to match the kernel version (BZ #23069)- glibc-2.3.90-langpackdir.diff: No longer search in /usr/share/locale-bundle- mempcpy-avx512.patch: Don't write beyond destination in __mempcpy_avx512_no_vzeroupper (CVE-2018-11237, bsc#1094154) - realpath-ssize-max-overflow.patch: Fix overflow in path length computation (CVE-2018-11236, bsc#1094161, BZ #22786) - Use %license also for COPYING, COPYING.LIB- Readd nis to netgroup and automount nss config (bsc#1088860)- i386-memmove-sse2-unaligned.patch: Fix SSE2 memmove issue when crossing 2GB boundary (CVE-2017-18269, bnc#1094150, BZ #22644)- res-send-enomem.patch: Fix crash in resolver on memory allocation failure (bsc#1086690, BZ #23005)- pkey-get-reserved-name.patch: Linux: use reserved name __key in pkey_get (BZ #22797) - aarch64-sys-ptrace-update.patch: linux/aarch64: sync sys/ptrace.h with Linux 4.15 (BZ #22433) - powerpc-sys-ptrace-undefine-macros.patch: powerpc: Undefine Linux ptrace macros that conflict with __ptrace_request - powerpc-sys-ptrace-update.patch: linux/powerpc: sync sys/ptrace.h with Linux 4.15 (BZ #22433, BZ #22807) - netgroup-cache-keys.patch: Fix netgroup cache keys (BZ #22342) - i386-sigaction-sa-restorer.patch: i386: Fix i386 sigaction sa_restorer initialization (BZ #21269) - riscv-tls-init.patch: RISC-V: Do not initialize $gp in TLS macros - riscv-fmax-fmin-nan.patch: RISC-V: fmax/fmin: Handle signalling NaNs correctly (BZ #22884)- nss-database-multiple-dfn.patch: Fix multiple definitions of __nss_*_database (BZ #22918)- Use %license (boo#1082318)- Add systemtap-headers to BuildRequires - Add --enable-systemtap to configure arguments (fate#324969, bsc#1073636)- riscv-readelflib.patch: Fix parsing flags in ELF64 files on riscv- Update to glibc 2.27 * Optimized x86-64 asin, atan2, exp, expf, log, pow, atan, sin, cosf, sinf, sincosf and tan with FMA * Optimized x86-64 trunc and truncf for processors with SSE4.1 * Optimized generic expf, exp2f, logf, log2f, powf, sinf, cosf and sincosf * In order to support faster and safer process termination the malloc API family of functions will no longer print a failure address and stack backtrace after detecting heap corruption * The abort function terminates the process immediately, without flushing stdio streams * On platforms where long double has the IEEE binary128 format (aarch64, alpha, mips64, riscv, s390 and sparc), the math library now implements _Float128 interfaces for that type, as defined by ISO/IEC TS 18661-3:2015 These are the same interfaces added in version 2.26 for some platforms where this format is supported but is not the format of long double * On platforms with support for _Float64x (aarch64, alpha, i386, ia64, mips64, powerpc64le, riscv, s390, sparc and x86_64), the math library now implements interfaces for that type, as defined by ISO/IEC TS 18661-3:2015 * The math library now implements interfaces for the _Float32, _Float64 and _Float32x types, as defined by ISO/IEC TS 18661-3:2015 * glibc now implements the memfd_create and mlock2 functions on Linux * Support for memory protection keys was added * The copy_file_range function was added * The ldconfig utility now processes `include' directives using the C/POSIX collation ordering * Support for two grammatical forms of month names has been added * Support for the RISC-V ISA running on Linux has been added * Statically compiled applications attempting to load locales compiled for the GNU C Library version 2.27 will fail and fall back to the builtin C/POSIX locale * Support for statically linked applications which call dlopen is deprecated and will be removed in a future version of glibc * Support for old programs which use internal stdio data structures and functions is deprecated * On GNU/Linux, the obsolete Linux constant PTRACE_SEIZE_DEVEL is no longer defined by * libm no longer supports SVID error handling (calling a user-provided matherr function on error) or the _LIB_VERSION variable to control error handling * The libm functions pow10, pow10f and pow10l are no longer supported for new programs * The mcontext_t type is no longer the same as struct sigcontext * The add-ons mechanism for building additional packages at the same time as glibc has been removed * The res_hnok, res_dnok, res_mailok and res_ownok functions now check that the specified string can be parsed as a domain name * In the malloc_info output, the element may contain another element, "subheaps", which contains the number of sub-heaps * In the malloc_info output, the element may contain another element, "subheaps", which contains the number of sub-heaps * The nonstandard header files and <_G_config.h> are deprecated and will be removed in a future release * CVE-2018-6485, CVE-2018-6551: The posix_memalign and memalign functions, when called with an object size near the value of SIZE_MAX, would return a pointer to a buffer which is too small, instead of NULL (bsc#1079036) - Support for Sun RPC is no longer available, use libtirpc instead - glibc-nodate.patch, powerpc-elision-enable-envvar.patch, s390-elision-enable-envvar.patch, resolv-context-leak.patch, dl-runtime-resolve-opt-avx512f.patch, libpthread-compat-wrappers.patch, math-c++-compat.patch, remove-nss-nis-compat.patch, eh-frame-zero-terminator.patch, ld-so-hwcap-x86-64.patch, assert-pedantic.patch, getaddrinfo-errno.patch, resolv-conf-oom.patch, dynarray-allocation.patch, nearbyint-inexact.patch, nss-compat.patch, nscd-libnsl.patch, malloc-tcache-leak.patch, falkor-memcpy-memmove.patch, aarch64-cpu-features.patch, nss-files-large-buffers.patch. sysconf-uio-maxiov.patch, glob-tilde-overflow.patch, dl-runtime-resolve-xsave.patch, spawni-assert.patch, x86-64-dl-platform.patch, glob64-s390.patch, tst-tlsopt-powerpc.patch, powerpc-hwcap-bits.patch, malloc-tcache-check-overflow.patch, dl-init-paths-overflow.patch, fillin-rpath-empty-tokens.patch, getcwd-absolute.patch, ldd-system-interp.patchabort-no-flush.patch: Removed - All patches refreshed - bsc#1063675- fix-locking-in-_IO_cleanup.patch: Skip locked files during exit (bsc#1070491, BZ #15142)- Avoid duplicate source rpm- getcwd-absolute.patch: make getcwd(3) fail if it cannot obtain an absolute path (CVE-2018-1000001, bsc#1074293, BZ #22679)- dl-init-paths-overflow.patch: Count components of the expanded path in _dl_init_path (CVE-2017-1000408, CVE-2017-1000409, bsc#1071319, BZ [#22607], BZ #22627) - fillin-rpath-empty-tokens.patch: Check for empty tokens before dynamic string token expansion (CVE-2017-16997, bsc#1073231, BZ #22625)- tst-tlsopt-powerpc.patch: fix tst-tlsopt-powerpc (bcn#1070419) - powerpc-hwcap-bits.patch: Update HWCAP for powerpc (bnc#1070420) - malloc-tcache-check-overflow.patch: Fix integer overflow in malloc when tcache is enabled (CVE-2017-17426, bnc#1071479, BZ #22375)- Add _multibuild- glob64-s390.patch: no compat glob64 on s390 - noversion.tar.bz2: remove unused source- x86-64-dl-platform.patch: Don't set GLRO(dl_platform) to NULL (BZ #22299)- spawni-assert.patch: Fix improper assert in Linux posix_spawn (BZ [#22273])- math-c++-compat.patch: Add more C++ compatibility (BZ #22296) - malloc-tcache-leak.patch: Fix tcache leak after thread destruction (BZ [#22111]) - falkor-memcpy-memmove.patch: Optimized implementation of memcpy/memmove for Qualcomm Falkor - aarch64-cpu-features.patch: Fix glibc.tune.cpu tunable handling - nss-files-large-buffers.patch: Avoid large buffers with many host addresses (BZ #22078) - sysconf-uio-maxiov.patch: Fix missing definition of UIO_MAXIOV (BZ [#22321]) - glob-tilde-overflow.patch: Fix buffer overflows with GLOB_TILDE (CVE-2017-15670, CVE-2017-15671, CVE-2017-15804, bsc#1064569. bsc#1064580, bsc#1064583, BZ #22320, BZ #22325, BZ #22332) - dl-runtime-resolve-xsave.patch: Use fxsave/xsave/xsavec in _dl_runtime_resolve (BZ #21265)- nscd-libnsl.patch: Remove reference to libnsl from nscd (bsc#1062244)- Drop glibc-obsolete - glibc-2.3.90-noversion.diff: remove - reinitialize-dl_load_write_lock.patch: remove- nss-compat.patch: Move nss_compat from nis to nss subdir and install it unconditionally - nsswitch.conf: switch back to compat for passwd, group, shadow- assert-pedantic.patch: Suppress pedantic warning caused by statement expression (BZ #21242, BZ #21972) - math-c++-compat.patch: Add more C++ compatibility (BZ #22235) - getaddrinfo-errno.patch: Fix errno and h_errno handling in getaddrinfo (BZ #21915, BZ #21922) - resolv-conf-oom.patch: Fix memory handling in OOM situation during resolv.conf parsing (BZ #22095, BZ #22096) - dynarray-allocation.patch: Fix initial size of dynarray allocation and set errno on overflow error - nearbyint-inexact.patch: Avoid spurious inexact in nearbyint (BZ #22225)- math-c++-compat.patch: add more C++ compatibility (BZ #22146)- Remove rpcsvc/yppasswd.* from glibc-devel - ld-so-hwcap-x86-64.patch: add x86_64 to hwcap (bsc#1056606, BZ #22093)- eh-frame-zero-terminator.patch: Properly terminate .eh_frame (BZ #22051)- Disable obsolete libnsl and NIS support - remove-nss-nis-compat.patch: remove nis and compat from default NSS configs - nsswitch.conf: Likewise- math-c++-compat.patch: Do not use __builtin_types_compatible_p in C++ mode (BZ #21930)- Add iconvconfig to baselibs.conf (bsc#1051042)- resolv-context-leak.patch: Fix leaks of resolver contexts - dl-runtime-resolve-opt-avx512f.patch: Use _dl_runtime_resolve_opt only with AVX512F (BZ #21871) - libpthread-compat-wrappers.patch: Don't use IFUNC resolver for longjmp or system in libpthread (BZ #21041)- Update to glibc 2.26 * A per-thread cache has been added to malloc * Unicode 10.0.0 Support * Improvements to the DNS stub resolver * New function reallocarray, which resizes an allocated block (like realloc) to the product of two sizes, with a guaranteed clean failure upon integer overflow in the multiplication * New wrappers for the Linux-specific system calls preadv2 and pwritev2 * posix_spawnattr_setflags now supports the flag POSIX_SPAWN_SETSID, to create a new session ID for the spawned process * errno.h is now safe to use from C-preprocessed assembly language on all supported operating systems * On ia64, powerpc64le, x86-32, and x86-64, the math library now implements 128-bit floating point as defined by ISO/IEC/IEEE 60559:2011 (IEEE 754-2008) and ISO/IEC TS 18661-3:2015 * The synchronization that pthread_spin_unlock performs has been changed to now be equivalent to a C11 atomic store with release memory order to the spin lock's memory location * The DNS stub resolver no longer performs EDNS fallback * res_mkquery and res_nmkquery no longer support the IQUERY opcode * The _res_opcodes variable has been removed from libresolv * no longer includes inline versions of any string functions, as this kind of optimization is better done by the compiler * The nonstandard header has been removed * The obsolete header has been removed * The obsolete signal constant SIGUNUSED is no longer defined by * The obsolete function cfree has been removed * The stack_t type no longer has the name struct sigaltstack * The ucontext_t type no longer has the name struct ucontext * On S/390 GNU/Linux, the constants defined by have been synced with the kernel * Linux kernel 3.2 or later is required at runtime, on all architectures supported by that kernel * The DNS stub resolver limits the advertised UDP buffer size to 1200 bytes, to avoid fragmentation-based spoofing attacks (CVE-2017-12132) * LD_LIBRARY_PATH is now ignored in binaries running in privileged AT_SECURE mode to guard against local privilege escalation attacks (CVE-2017-1000366) * Avoid printing a backtrace from the __stack_chk_fail function since it is called on a corrupt stack and a backtrace is unreliable on a corrupt stack (CVE-2010-3192) * A use-after-free vulnerability in clntudp_call in the Sun RPC system has been fixed (CVE-2017-12133) * fate#322258, fate#321513, fate#322453 - fts-symbol-redirect.patch, glibc-resolv-reload.diff, glibc-2.2-sunrpc.diff, i686-memchr-sse.patch, ld-hwcap-mask-suid.patch, ld-library-path-suid.patch, sunrpc-use-after-free.patch, test-math-vector-sincos-aliasing.patch, tunables-bigendian.patch: Removed - bsc#1074208- Fix RPM group- s390-elision-enable-envvar.patch: enable TLE only if GLIBC_ELISION_ENABLE=yes is defined (fate#322271)- ld-hwcap-mask-suid.patch: Ignore and remove LD_HWCAP_MASK for AT_SECURE programs (BZ #21209) - ld-library-path-suid.patch: Completely ignore LD_LIBRARY_PATH for AT_SECURE=1 programs (CVE-2017-1000366, bsc#1039357, BZ #21624)- Remove glibc-cpusetsize.diff, no longer useful- fts-symbol-redirect.patch: Fix symbol redirect for fts_set (bsc#1041123, BZ #21289)- test-math-vector-sincos-aliasing.patch: Fix test-math-vector-sincos.h aliasing- add-locales.patch: renamed from glibc-2.3.locales.diff.bz2, drop en_BE locales (bsc#1039502)- Remove glibc-testsuite.patch, no longer relevant- Use multibuild feature - Remove obsolete check-build.sh - glibc.rpmlintrc: remove obsolete entries - Use %tmpfiles_create in nscd postin- i686-memchr-sse.patch: Fix i686 memchr overflow calculation (bsc#1031021, BZ #21182) - sunrpc-use-after-free.patch: Avoid use-after-free read access in clntudp_call (BZ #21115) - Build testsuite with gdb and python-pexpect to enable more tests- tunables-bigendian.patch: Fix getting tunable values on big-endian (BZ [#21109])- Update to glibc 2.25 * The feature test macro __STDC_WANT_LIB_EXT2__, from ISO/IEC TR 24731-2:2010, is supported to enable declarations of functions from that TR. * The feature test macro __STDC_WANT_IEC_60559_BFP_EXT__, from ISO/IEC TS 18661-1:2014, is supported to enable declarations of functions and macros from that TS. * The feature test macro __STDC_WANT_IEC_60559_FUNCS_EXT__, from ISO/IEC TS 18661-4:2015, is supported to enable declarations of functions and macros from that TS. * The nonstandard feature selection macros _REENTRANT and _THREAD_SAFE are now treated as compatibility synonyms for _POSIX_C_SOURCE=199506L. * The inclusion of by is deprecated. * New features from TS 18661-1:2014 are added to libm: the fesetexcept, fetestexceptflag, fegetmode and fesetmode functions, the femode_t type and the FE_DFL_MODE and FE_SNANS_ALWAYS_SIGNAL macros. * Integer width macros from TS 18661-1:2014 are added to : CHAR_WIDTH, SCHAR_WIDTH, UCHAR_WIDTH, SHRT_WIDTH, USHRT_WIDTH, INT_WIDTH, UINT_WIDTH, LONG_WIDTH, ULONG_WIDTH, LLONG_WIDTH, ULLONG_WIDTH; and to : INT8_WIDTH, UINT8_WIDTH, INT16_WIDTH, UINT16_WIDTH, INT32_WIDTH, UINT32_WIDTH, INT64_WIDTH, UINT64_WIDTH, INT_LEAST8_WIDTH, UINT_LEAST8_WIDTH, INT_LEAST16_WIDTH, UINT_LEAST16_WIDTH, INT_LEAST32_WIDTH, UINT_LEAST32_WIDTH, INT_LEAST64_WIDTH, UINT_LEAST64_WIDTH, INT_FAST8_WIDTH, UINT_FAST8_WIDTH, INT_FAST16_WIDTH, UINT_FAST16_WIDTH, INT_FAST32_WIDTH, UINT_FAST32_WIDTH, INT_FAST64_WIDTH, UINT_FAST64_WIDTH, INTPTR_WIDTH, UINTPTR_WIDTH, INTMAX_WIDTH, UINTMAX_WIDTH, PTRDIFF_WIDTH, SIG_ATOMIC_WIDTH, SIZE_WIDTH, WCHAR_WIDTH, WINT_WIDTH. * New features are added from TS 18661-1:2014: - Signaling NaN macros: SNANF, SNAN, SNANL. - Nearest integer functions: roundeven, roundevenf, roundevenl, fromfp, fromfpf, fromfpl, ufromfp, ufromfpf, ufromfpl, fromfpx, fromfpxf, fromfpxl, ufromfpx, ufromfpxf, ufromfpxl. - llogb functions: the llogb, llogbf and llogbl functions, and the FP_LLOGB0 and FP_LLOGBNAN macros. - Max-min magnitude functions: fmaxmag, fmaxmagf, fmaxmagl, fminmag, fminmagf, fminmagl. - Comparison macros: iseqsig. - Classification macros: iscanonical, issubnormal, iszero. - Total order functions: totalorder, totalorderf, totalorderl, totalordermag, totalordermagf, totalordermagl. - Canonicalize functions: canonicalize, canonicalizef, canonicalizel. - NaN functions: getpayload, getpayloadf, getpayloadl, setpayload, setpayloadf, setpayloadl, setpayloadsig, setpayloadsigf, setpayloadsigl. * The functions strfromd, strfromf, and strfroml, from ISO/IEC TS 18661-1:2014, are added to libc. * Most of glibc can now be built with the stack smashing protector enabled. * The function explicit_bzero, from OpenBSD, has been added to libc. * On ColdFire, MicroBlaze, Nios II and SH3, the float_t type is now defined to float instead of double. * On x86_64, when compiling with -mfpmath=387 or -mfpmath=sse+387, the float_t and double_t types are now defined to long double instead of float and double. * The getentropy and getrandom functions, and the header file have been added. * The buffer size for byte-oriented stdio streams is now limited to 8192 bytes by default. * The header now includes the header. * The malloc_get_state and malloc_set_state functions have been removed. * The “ip6-dotint” and “no-ip6-dotint” resolver options, and the corresponding RES_NOIP6DOTINT flag from have been removed. * The "ip6-bytestring" resolver option and the corresponding RES_USEBSTRING flag from have been removed. * The flags RES_AAONLY, RES_PRIMARY, RES_NOCHECKNAME, RES_KEEPTSIG, RES_BLAST defined in the header file have been deprecated. * The "inet6" option in /etc/resolv.conf and the RES_USE_INET6 flag for _res.flags are deprecated. * DNSSEC-related declarations and definitions have been removed from the header file, and libresolv will no longer attempt to decode the data part of DNSSEC record types. * The resource record type classification macros ns_t_qt_p, ns_t_mrr_p, ns_t_rr_p, ns_t_udp_p, ns_t_xfr_p have been removed from the header file because the distinction between RR types and meta-RR types is not officially standardized, subject to revision, and thus not suitable for encoding in a macro. * The types res_sendhookact, res_send_qhook, re_send_rhook, and the qhook and rhook members of the res_state type in have been removed. * For multi-arch support it is recommended to use a GCC which has been built with support for GNU indirect functions. * GDB pretty printers have been added for mutex and condition variable structures in POSIX Threads. * Tunables feature added to allow tweaking of the runtime for an application program. * A new version of condition variables functions have been implemented in the NPTL implementation of POSIX Threads to provide stronger ordering guarantees. * A new version of pthread_rwlock functions have been implemented to use a more scalable algorithm primarily through not using a critical section anymore to make state changes. * On ARM EABI (32-bit), generating a backtrace for execution contexts which have been created with makecontext could fail to terminate due to a missing .cantunwind annotation. (CVE-2016-6323) * The DNS stub resolver functions would crash due to a NULL pointer dereference when processing a query with a valid DNS question type which was used internally in the implementation. (CVE-2015-5180) - Enable stack protector if part of %optflags - startcontext-cantunwind.patch: Removed - cpuid-assertion.patch: Removed- cpuid-assertion.patch: Don't assert on older Intel CPUs (BZ #20647)- glibc-2.3.3-nscd-db-path.diff: Move persistent nscd databases to /var/lib/nscd - glibc-2.3.90-langpackdir.diff: simplify- Update to glibc 2.24 * The minimum Linux kernel version that this version of the GNU C Library can be used with is 3.2 * The pap_AN locale has been deleted * The readdir_r and readdir64_r functions have been deprecated * The type `union wait' has been removed * A new NSS action is added to facilitate large distributed system administration * The deprecated __malloc_initialize_hook variable has been removed from the API * The long unused localedef --old-style option has been removed * nextupl, nextup, nextupf, nextdownl, nextdown and nextdownf are added to libm * An unnecessary stack copy in _nss_dns_getnetbyname_r was removed (CVE-2016-3075) * Previously, getaddrinfo copied large amounts of address data to the stack, even after the fix for CVE-2013-4458 has been applied, potentially resulting in a stack overflow. getaddrinfo now uses a heap allocation instead (CVE-2016-3706) * The glob function suffered from a stack-based buffer overflow when it was called with the GLOB_ALTDIRFUNC flag and encountered a long file name (CVE-2016-1234) * The Sun RPC UDP client could exhaust all available stack space when flooded with crafted ICMP and UDP messages (CVE-2016-4429) * The IPv6 name server management code in libresolv could result in a memory leak for each thread which is created, performs a failing naming lookup, and exits (CVE-2016-5417) - startcontext-cantunwind.patch: mark __startcontext as .cantunwind (bsc#974800, BZ #20435) - Removed patches: * 0001-Updated-translations-for-2.23.patch * 0002-Regenerate-libc.pot-for-2.23.patch * 0003-Regenerated-configure-scripts.patch * 0004-x86_64-Set-DL_RUNTIME_UNALIGNED_VEC_SIZE-to-8.patch * 0005-Add-fts64_-to-sysdeps-arm-nacl-libc.abilist.patch * 0006-Don-t-use-long-double-math-functions-if-NO_LONG_DOUB.patch * 0007-NEWS-2.23-Fix-typo-in-bug-19048-text.patch * 0008-Update-NEWS.patch * 0009-sln-use-stat64.patch * 0010-Add-sys-auxv.h-wrapper-to-include-sys.patch * 0011-mips-terminate-the-FDE-before-the-return-trampoline-.patch * 0012-Use-HAS_ARCH_FEATURE-with-Fast_Rep_String.patch * 0013-Mention-BZ-19762-in-NEWS.patch * 0014-Define-_HAVE_STRING_ARCH_mempcpy-to-1-for-x86.patch * 0015-Or-bit_Prefer_MAP_32BIT_EXEC-in-EXTRA_LD_ENVVARS.patch * 0016-Fix-resource-leak-in-resolver-bug-19257.patch * 0017-math-don-t-clobber-old-libm.so-on-install-BZ-19822.patch * 0018-resolv-Always-set-resplen2-out-parameter-in-send_dg-.patch * 0019-S390-Save-and-restore-fprs-vrs-while-resolving-symbo.patch * 0020-S390-Extend-structs-La_s390_regs-La_s390_retval-with.patch * 0021-CVE-2016-3075-Stack-overflow-in-_nss_dns_getnetbynam.patch * 0022-configure-fix-test-usage.patch * 0023-Suppress-GCC-6-warning-about-ambiguous-else-with-Wpa.patch * 0024-nss_db-Propagate-ERANGE-error-if-parse_line-fails-BZ.patch * 0025-getnameinfo-Do-not-preserve-errno.patch * 0026-getnameinfo-Refactor-and-fix-memory-leak-BZ-19642.patch * 0027-getnameinfo-Reduce-line-length-and-add-missing-comme.patch * 0028-getnameinfo-Avoid-calling-strnlen-on-uninitialized-b.patch * 0029-getnameinfo-Return-EAI_OVERFLOW-in-more-cases-BZ-197.patch * 0030-hesiod-Remove-RCS-keywords.patch * 0031-hesiod-Always-use-thread-local-resolver-state-BZ-195.patch * 0032-hesiod-Avoid-heap-overflow-in-get_txt_records-BZ-200.patch * 0033-malloc-Remove-NO_THREADS.patch * 0034-Fix-malloc-threaded-tests-link-on-non-Linux.patch * 0035-malloc-Run-fork-handler-as-late-as-possible-BZ-19431.patch * 0036-malloc-Remove-malloc-hooks-from-fork-handler.patch * 0037-malloc-Add-missing-internal_function-attributes-on-f.patch * 0038-nss_dns-Fix-assertion-failure-in-_nss_dns_getcanonna.patch * 0039-nss_dns-Validate-RDATA-length-against-packet-length-.patch * 0040-resolv-nss_dns-Remove-remaining-syslog-logging-BZ-19.patch * 0041-nss_dns-Check-address-length-before-creating-addrinf.patch * 0042-nss_dns-Skip-over-non-PTR-records-in-the-netent-code.patch * 0043-resolv-Always-set-resplen2-out-parameter-in-send_vc-.patch * 0044-tst-audit4-tst-audit10-Compile-AVX-AVX-512-code-sepa.patch * 0045-Fix-tst-audit10-build-when-mavx512f-is-not-supported.patch * 0046-tst-audit10-Fix-compilation-on-compilers-without-bit.patch * 0047-strfmon_l-Use-specified-locale-for-number-formatting.patch * 0048-glob-Simplify-the-interface-for-the-GLOB_ALTDIRFUNC-.patch * 0049-CVE-2016-1234-glob-Do-not-copy-d_name-field-of-struc.patch * 0050-ldconfig-Do-not-remove-stale-symbolic-links-with-X-B.patch * 0051-Report-dlsym-dlvsym-lookup-errors-using-dlerror-BZ-1.patch * 0052-Fix-tst-dlsym-error-build.patch * 0053-Remove-trailing-newline-from-date_fmt-in-Serbian-loc.patch * 0054-Revert-Report-dlsym-dlvsym-lookup-errors-using-dlerr.patch * 0055-CVE-2016-3706-getaddrinfo-stack-overflow-in-hostent-.patch * 0056-Fix-strfmon_l-Use-specified-locale-for-number-format.patch * clntudp-call-alloca.patch * glibc-memset-nontemporal.diff * nis-initgroups-status.patch * nscd-gc-crash.patch * robust-mutex-deadlock.patch * strncat-avoid-array-bounds-warning.patch- strncat-avoid-array-bounds-warning.patch: Avoid array-bounds warning for stncat on i586 (BZ #20260) - Update glibc.keyring - Unset MALLOC_CHECK_ during testsuite run- nsswitch.conf: Add fallback to files for passwd and group to prepare for libnsl removal.- nis-initgroups-status.patch: Return proper status from _nss_nis_initgroups_dyn (bsc#984269, BZ #20262) - robust-mutex-deadlock.patch: Fix generic __lll_robust_timedlock_wait to check for timeout (bsc#985170, BZ #20263)- nscd-gc-crash.patch: Fix nscd assertion failure in gc (bsc#965699, BZ [#19755])- clntudp-call-alloca.patch: do not use alloca in clntudp_call (CVE-2016-4429, bsc#980854, BZ #20112)- Import patches from 2.23 branch 0001-Updated-translations-for-2.23.patch 0002-Regenerate-libc.pot-for-2.23.patch 0003-Regenerated-configure-scripts.patch 0004-x86_64-Set-DL_RUNTIME_UNALIGNED_VEC_SIZE-to-8.patch 0005-Add-fts64_-to-sysdeps-arm-nacl-libc.abilist.patch 0006-Don-t-use-long-double-math-functions-if-NO_LONG_DOUB.patch 0007-NEWS-2.23-Fix-typo-in-bug-19048-text.patch 0008-Update-NEWS.patch 0009-sln-use-stat64.patch 0010-Add-sys-auxv.h-wrapper-to-include-sys.patch 0011-mips-terminate-the-FDE-before-the-return-trampoline-.patch 0012-Use-HAS_ARCH_FEATURE-with-Fast_Rep_String.patch 0013-Mention-BZ-19762-in-NEWS.patch 0014-Define-_HAVE_STRING_ARCH_mempcpy-to-1-for-x86.patch 0015-Or-bit_Prefer_MAP_32BIT_EXEC-in-EXTRA_LD_ENVVARS.patch 0016-Fix-resource-leak-in-resolver-bug-19257.patch 0017-math-don-t-clobber-old-libm.so-on-install-BZ-19822.patch 0018-resolv-Always-set-resplen2-out-parameter-in-send_dg-.patch 0019-S390-Save-and-restore-fprs-vrs-while-resolving-symbo.patch 0020-S390-Extend-structs-La_s390_regs-La_s390_retval-with.patch 0021-CVE-2016-3075-Stack-overflow-in-_nss_dns_getnetbynam.patch 0022-configure-fix-test-usage.patch 0023-Suppress-GCC-6-warning-about-ambiguous-else-with-Wpa.patch 0024-nss_db-Propagate-ERANGE-error-if-parse_line-fails-BZ.patch 0025-getnameinfo-Do-not-preserve-errno.patch 0026-getnameinfo-Refactor-and-fix-memory-leak-BZ-19642.patch 0027-getnameinfo-Reduce-line-length-and-add-missing-comme.patch 0028-getnameinfo-Avoid-calling-strnlen-on-uninitialized-b.patch 0029-getnameinfo-Return-EAI_OVERFLOW-in-more-cases-BZ-197.patch 0030-hesiod-Remove-RCS-keywords.patch 0031-hesiod-Always-use-thread-local-resolver-state-BZ-195.patch 0032-hesiod-Avoid-heap-overflow-in-get_txt_records-BZ-200.patch 0033-malloc-Remove-NO_THREADS.patch 0034-Fix-malloc-threaded-tests-link-on-non-Linux.patch 0035-malloc-Run-fork-handler-as-late-as-possible-BZ-19431.patch 0036-malloc-Remove-malloc-hooks-from-fork-handler.patch 0037-malloc-Add-missing-internal_function-attributes-on-f.patch 0038-nss_dns-Fix-assertion-failure-in-_nss_dns_getcanonna.patch 0039-nss_dns-Validate-RDATA-length-against-packet-length-.patch 0040-resolv-nss_dns-Remove-remaining-syslog-logging-BZ-19.patch 0041-nss_dns-Check-address-length-before-creating-addrinf.patch 0042-nss_dns-Skip-over-non-PTR-records-in-the-netent-code.patch 0043-resolv-Always-set-resplen2-out-parameter-in-send_vc-.patch 0044-tst-audit4-tst-audit10-Compile-AVX-AVX-512-code-sepa.patch 0045-Fix-tst-audit10-build-when-mavx512f-is-not-supported.patch 0046-tst-audit10-Fix-compilation-on-compilers-without-bit.patch 0047-strfmon_l-Use-specified-locale-for-number-formatting.patch 0048-glob-Simplify-the-interface-for-the-GLOB_ALTDIRFUNC-.patch 0049-CVE-2016-1234-glob-Do-not-copy-d_name-field-of-struc.patch 0050-ldconfig-Do-not-remove-stale-symbolic-links-with-X-B.patch 0051-Report-dlsym-dlvsym-lookup-errors-using-dlerror-BZ-1.patch 0052-Fix-tst-dlsym-error-build.patch 0053-Remove-trailing-newline-from-date_fmt-in-Serbian-loc.patch 0054-Revert-Report-dlsym-dlvsym-lookup-errors-using-dlerr.patch 0055-CVE-2016-3706-getaddrinfo-stack-overflow-in-hostent-.patch 0056-Fix-strfmon_l-Use-specified-locale-for-number-format.patch - CVE-2016-3075 CVE-2016-1234 CVE-2016-3706 bsc#973164 bsc#969727 - resolv-mem-leak.patch: renamed to 0016-Fix-resource-leak-in-resolver-bug-19257.patch - no-long-double.patch: renamed to 0006-Don-t-use-long-double-math-functions-if-NO_LONG_DOUB.patch - glibc-gcc6.patch: renamed to 0023-Suppress-GCC-6-warning-about-ambiguous-else-with-Wpa.patch- glibc-c-utf8-locale.patch: fix bad standard in LC_IDENTIFICATION categories - glibc-2.3.locales.diff.bz2: likewise- glibc-gcc6.patch: Suppress GCC 6 warning about ambiguous 'else' with - Wparentheses- Add compatibility symlinks for LSB 3.0 (fate#318933)- powerpc-elision-enable-envvar.patch: enable TLE only if GLIBC_ELISION_ENABLE=yes is defined (bsc#967594, fate#318236)- ldd-system-interp.patch: Restore warning about execution permission, it is still needed for noexec mounts (bsc#915985)- Add C.UTF-8 locale (see https://sourceware.org/glibc/wiki/Proposals/C.UTF-8) and rh#902094 . Added with glibc-c-utf8-locale.patch. - Add glibc-disable-gettext-for-c-utf8.patch to disable gettext for C.UTF-8 same as C locale.- Move %install_info_delete to %preun - crypt_blowfish-1.3.tar.gz.sign: Remove, the sign key is no longer acceptable- no-long-double.patch: Don't use long double functions if NO_LONG_DOUBLE- Update to glibc 2.23 release. * Unicode 8.0.0 Support * sched_setaffinity, pthread_setaffinity_np no longer attempt to guess the kernel-internal CPU set size * The fts.h header can now be used with -D_FILE_OFFSET_BITS=64 * getaddrinfo now detects certain invalid responses on an internal netlink socket * A defect in the malloc implementation, present since glibc 2.15 (2012) or glibc 2.10 via --enable-experimental-malloc (2009), could result in the unnecessary serialization of memory allocation requests across threads * The obsolete header has been removed * The obsolete functions bdflush, create_module, get_kernel_syms, query_module and uselib are no longer available to newly linked binaries * Optimized string, wcsmbs and memory functions for IBM z13. * Newly linked programs that define a variable called signgam will no longer have it set by the lgamma, lgammaf and lgammal functions - Removed patches: * dont-remove-nodelete-flag.patch * openat64-readd-o-largefile.patch * mntent-blank-line.patch * opendir-o-directory-check.patch * strcoll-remove-strdiff-opt.patch * ld-pointer-guard.patch * tls-dtor-list-mangling.patch * powerpc-lock-elision-race.patch * prelink-elf-rtype-class.patch * vector-finite-math-aliases.patch * powerpc-elision-adapt-param.patch * catopen-unbound-alloca.patch * strftime-range-check.patch * hcreate-overflow-check.patch * errorcheck-mutex-no-elision.patch * refactor-nan-parsing.patch * send-dg-buffer-overflow.patch * isinf-cxx11-conflict.patch * ibm93x-redundant-shift-si.patch * iconv-reset-input-buffer.patch * tzset-tzname.patch * static-dlopen.patch- isinf-cxx11-conflict.patch: Fix isinf/isnan declaration conflict with C++11 (bsc#963700, BZ #19439)- tls-dtor-list-mangling.patch: Harden tls_dtor_list with pointer mangling (BZ #19018) - prelink-elf-rtype-class.patch: Keep only ELF_RTYPE_CLASS_{PLT|COPY} bits for prelink (BZ #19178) - vector-finite-math-aliases.patch: Better workaround for aliases of * _finite symbols in vector math library (BZ# 19058) - powerpc-elision-adapt-param.patch: powerpc: Fix usage of elision transient failure adapt param (BZ #19174) - catopen-unbound-alloca.patch: Fix unbound alloca in catopen (CVE-2015-8779, bsc#962739, BZ #17905) - strftime-range-check.patch: Add range check on time fields (CVE-2015-8776, bsc#962736, BZ #18985) - hcreate-overflow-check.patch: Handle overflow in hcreate (CVE-2015-8778, bsc#962737, BZ #18240) - errorcheck-mutex-no-elision.patch: Don't do lock elision on an error checking mutex (bsc#956716, BZ #17514) - refactor-nan-parsing.patch: Refactor strtod parsing of NaN payloads (CVE-2014-9761, bsc#962738, BZ #16962) - send-dg-buffer-overflow.patch: Fix getaddrinfo stack-based buffer overflow (CVE-2015-7547, bsc#961721, BZ #18665) - powerpc-lock-elision-race.patch: renamed from 0001-powerpc-Fix-a-race-condition-when-eliding-a-lock-20150730.patch- Add audit-devel and libcap-devel to BuildRequires, for use by nscd- reinitialize-dl_load_write_lock.patch: Reinitialize dl_load_write_lock on fork (bsc#958315, BZ #19282)- resolv-mem-leak.patch: Fix resource leak in resolver (bsc#955647, BZ #19257) - tzset-tzname.patch: Force rereading TZDEFRULES after it was used to set DST rules only (BZ #19253)- glibc-2.3.90-noversion.diff: use stat64- ld-pointer-guard.patch: Always enable pointer guard (CVE-2015-8777, bsc#950944, BZ #18928)- strcoll-remove-strdiff-opt.patch: Remove incorrect STRDIFF-based optimization (BZ #18589)- iconv-reset-input-buffer.patch: Fix iconv buffer handling with IGNORE error handler (BZ #18830)- new patch [BZ #18743] PowerPC: Fix a race condition when eliding a lock 0001-powerpc-Fix-a-race-condition-when-eliding-a-lock-20150730.patch- nss-files-long-lines-2.patch: Properly reread entry after failure in nss_files getent function (bsc#945779, BZ #18991)- fnmatch-collating-elements.patch: Fix fnmatch handling of collating elements (BZ #17396, BZ #16976)- opendir-o-directory-check.patch: Fix opendir inverted o_directory_works test - static-dlopen.patch: Static dlopen default library search path fix (bsc#937853)- mntent-blank-line.patch: Fix memory corruption w/blank lines- dont-remove-nodelete-flag.patch: Don't remove DF_1_NODELETE flag from all loaded objects on failed dlopen - openat64-readd-o-largefile.patch: Readd O_LARGEFILE flag for openat64- Update to glibc 2.22 release. * Cache information can be queried via sysconf() function on s390 * A buffer overflow in gethostbyname_r and related functions performing DNS requests has been fixed. (CVE-2015-1781) * The time zone file parser has been made more robust against crafted time zone files * A powerpc and powerpc64 optimization for TLS, similar to TLS descriptors for LD and GD on x86 and x86-64, has been implemented. * Character encoding and ctype tables were updated to Unicode 7.0.0 * Added vector math library named libmvec * A new fmemopen implementation has been added with the goal of POSIX compliance. * The header is deprecated, and will be removed in a future release. * bsc#905313 bsc#920338 bsc#927080 bsc#928723 bsc#931480 bsc#939211 bsc#940195 bsc#940332 bsc#944494 bsc#968787 - Patches from upstream removed * htm-tabort.patch * o-tmpfile.patch * memcpy-chk-non-SSE2.patch * pthread-mutexattr-gettype-kind.patch * powerpc-software-sqrt.patch * static-tls-dtv-limit.patch * threaded-trim-threshold.patch * resolv-nameserver-handling.patch * nss-separate-state-getXXent.patch * aarch64-sigstksz.patch * heap-top-corruption.patch * pthread-join-deadlock.patch- pthread-join-deadlock.patch: Use IE model for static variables in libc.so, libpthread.so and rtld (bsc#930015, BZ #18457)- glibc-nodate.patch: fix verification of timestamp- also filter out -fstack-protector-strong- getaddrinfo-ipv6-sanity.diff: Remove. It breaks services that start before IPv6 is up (bsc#931399) - glibc-2.3.locales.diff.bz2: Remove sh_YU locales, fix currency for en_BE.- Add /usr/include/gnu/lib-names-.*.h to baselibs - pthread-join-deadlock.patch: Don't require rtld lock to store static TLS offset in the DTV (bsc#930015, BZ #18457) - heap-top-corruption.patch: Do not corrupt the top of a threaded heap if top chunk is MINSIZE (BZ #18502)- threaded-trim-threshold.patch: Fix regression in threaded application malloc performance (bsc#915955, BZ #17195)- aarch64-sigstksz.patch: Increase MINSIGSTKSZ and SIGSTKSZ (BZ #16850)- powerpc-software-sqrt.patch: Fix powerpc software sqrt (BZ #17964, BZ [#17967]) - nss-separate-state-getXXent.patch: Separate internal state between getXXent and getXXbyYY NSS calls (CVE-2014-8121, bsc#918187, BZ #18007) - static-tls-dtv-limit.patch: Fix DTV race, assert, DTV_SURPLUS Static TLS limit, and nptl_db garbage (bsc#919678, BZ #17090, BZ #17620, BZ #17621, BZ #17628)- resolv-nameserver-handling.patch: Replace with simpler version with more compatibility- memcpy-chk-non-SSE2.patch: Fix __memcpy_chk on non-SSE2 CPUs (bsc#920084)- resolv-nameserver-handling.patch: Rewrite handling of nameserver configuration in resolver- htm-tabort.patch: Fix TABORT encoding for little endian- Update to glibc 2.21 release. * A new semaphore algorithm has been implemented in generic C code for all machines * Added support for TSX lock elision of pthread mutexes on powerpc32, powerpc64 and powerpc64le * Optimized strcpy, stpcpy, strchrnul and strrchr implementations for AArch64 * i386 memcpy functions optimized with SSE2 unaligned load/store * New locales: tu_IN, bh_IN, raj_IN, ce_RU * The obsolete sigvec function has been removed * CVE-2015-1472 CVE-2015-1473 CVE-2012-3406 CVE-2014-9402 CVE-2014-7817 bsc#864081 bsc#906371 bsc#909053 bsc#910599 bsc#916222 - Patches from upstream removed * ifunc-x86-slow-sse4.patch * pthread-mutex-trylock-elision.patch - o-tmpfile.patch: Fix value of O_TMPFILE for architectures with non-default O_DIRECTORY (BZ #17912)- Update to crypt_blowfish 1.3. * Add support for the $2b$ prefix. - ifunc-x86-slow-sse4.patch: Fix misdetected Slow_SSE4_2 cpu feature bit (BZ #17501)h04-ch1a 1733214848  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRST2.38-150600.14.17.2i18ncharmapsANSI_X3.110-1983.gzANSI_X3.4-1968.gzARMSCII-8.gzASMO_449.gzBIG5-HKSCS.gzBIG5.gzBRF.gzBS_4730.gzBS_VIEWDATA.gzCP10007.gzCP1125.gzCP1250.gzCP1251.gzCP1252.gzCP1253.gzCP1254.gzCP1255.gzCP1256.gzCP1257.gzCP1258.gzCP737.gzCP770.gzCP771.gzCP772.gzCP773.gzCP774.gzCP775.gzCP949.gzCSA_Z243.4-1985-1.gzCSA_Z243.4-1985-2.gzCSA_Z243.4-1985-GR.gzCSN_369103.gzCWI.gzDEC-MCS.gzDIN_66003.gzDS_2089.gzEBCDIC-AT-DE-A.gzEBCDIC-AT-DE.gzEBCDIC-CA-FR.gzEBCDIC-DK-NO-A.gzEBCDIC-DK-NO.gzEBCDIC-ES-A.gzEBCDIC-ES-S.gzEBCDIC-ES.gzEBCDIC-FI-SE-A.gzEBCDIC-FI-SE.gzEBCDIC-FR.gzEBCDIC-IS-FRISS.gzEBCDIC-IT.gzEBCDIC-PT.gzEBCDIC-UK.gzEBCDIC-US.gzECMA-CYRILLIC.gzES.gzES2.gzEUC-JISX0213.gzEUC-JP-MS.gzEUC-JP.gzEUC-KR.gzEUC-TW.gzGB18030.gzGB2312.gzGBK.gzGB_1988-80.gzGEORGIAN-ACADEMY.gzGEORGIAN-PS.gzGOST_19768-74.gzGREEK-CCITT.gzGREEK7-OLD.gzGREEK7.gzHP-GREEK8.gzHP-ROMAN8.gzHP-ROMAN9.gzHP-THAI8.gzHP-TURKISH8.gzIBM037.gzIBM038.gzIBM1004.gzIBM1026.gzIBM1047.gzIBM1124.gzIBM1129.gzIBM1132.gzIBM1133.gzIBM1160.gzIBM1161.gzIBM1162.gzIBM1163.gzIBM1164.gzIBM256.gzIBM273.gzIBM274.gzIBM275.gzIBM277.gzIBM278.gzIBM280.gzIBM281.gzIBM284.gzIBM285.gzIBM290.gzIBM297.gzIBM420.gzIBM423.gzIBM424.gzIBM437.gzIBM500.gzIBM850.gzIBM851.gzIBM852.gzIBM855.gzIBM856.gzIBM857.gzIBM858.gzIBM860.gzIBM861.gzIBM862.gzIBM863.gzIBM864.gzIBM865.gzIBM866.gzIBM866NAV.gzIBM868.gzIBM869.gzIBM870.gzIBM871.gzIBM874.gzIBM875.gzIBM880.gzIBM891.gzIBM903.gzIBM904.gzIBM905.gzIBM918.gzIBM922.gzIEC_P27-1.gzINIS-8.gzINIS-CYRILLIC.gzINIS.gzINVARIANT.gzISIRI-3342.gzISO-8859-1.gzISO-8859-10.gzISO-8859-11.gzISO-8859-13.gzISO-8859-14.gzISO-8859-15.gzISO-8859-16.gzISO-8859-2.gzISO-8859-3.gzISO-8859-4.gzISO-8859-5.gzISO-8859-6.gzISO-8859-7.gzISO-8859-8.gzISO-8859-9.gzISO-8859-9E.gzISO-IR-197.gzISO-IR-209.gzISO-IR-90.gzISO_10367-BOX.gzISO_10646.gzISO_11548-1.gzISO_2033-1983.gzISO_5427-EXT.gzISO_5427.gzISO_5428.gzISO_646.BASIC.gzISO_646.IRV.gzISO_6937-2-25.gzISO_6937-2-ADD.gzISO_6937.gzISO_8859-1,GL.gzISO_8859-SUPP.gzIT.gzJIS_C6220-1969-JP.gzJIS_C6220-1969-RO.gzJIS_C6229-1984-A.gzJIS_C6229-1984-B-ADD.gzJIS_C6229-1984-B.gzJIS_C6229-1984-HAND-ADD.gzJIS_C6229-1984-HAND.gzJIS_C6229-1984-KANA.gzJIS_X0201.gzJOHAB.gzJUS_I.B1.002.gzJUS_I.B1.003-MAC.gzJUS_I.B1.003-SERB.gzKOI-8.gzKOI8-R.gzKOI8-RU.gzKOI8-T.gzKOI8-U.gzKSC5636.gzLATIN-GREEK-1.gzLATIN-GREEK.gzMAC-CENTRALEUROPE.gzMAC-CYRILLIC.gzMAC-IS.gzMAC-SAMI.gzMAC-UK.gzMACINTOSH.gzMIK.gzMSZ_7795.3.gzNATS-DANO-ADD.gzNATS-DANO.gzNATS-SEFI-ADD.gzNATS-SEFI.gzNC_NC00-10.gzNEXTSTEP.gzNF_Z_62-010.gzNF_Z_62-010_1973.gzNS_4551-1.gzNS_4551-2.gzPT.gzPT154.gzPT2.gzRK1048.gzSAMI-WS2.gzSAMI.gzSEN_850200_B.gzSEN_850200_C.gzSHIFT_JIS.gzSHIFT_JISX0213.gzT.101-G2.gzT.61-7BIT.gzT.61-8BIT.gzTCVN5712-1.gzTIS-620.gzTSCII.gzUTF-8.gzVIDEOTEX-SUPPL.gzVISCII.gzWINDOWS-31J.gzlocalesCPOSIXaa_DJaa_ERaa_ER@saahoaa_ETab_GEaf_ZAagr_PEak_GHam_ETan_ESanp_INar_AEar_BHar_DZar_EGar_INar_IQar_JOar_KWar_LBar_LYar_MAar_OMar_QAar_SAar_SDar_SSar_SYar_TNar_YEas_INast_ESayc_PEaz_AZaz_IRbe_BYbe_BY@latinbem_ZMber_DZber_MAbg_BGbhb_INbho_INbho_NPbi_VUbn_BDbn_INbo_CNbo_INbr_FRbr_FR@eurobrx_INbs_BAbyn_ERca_ADca_ESca_ES@euroca_ES@valenciaca_FRca_ITce_RUchr_USckb_IQcmn_TWcns11643_strokecrh_UAcs_CZcsb_PLcv_RUcy_GBda_DKde_ATde_AT@eurode_BEde_BE@eurode_CHde_DEde_DE@eurode_ITde_LIde_LUde_LU@eurodoi_INdsb_DEdv_MVdz_BTel_CYel_GRel_GR@euroen_AGen_AUen_BWen_CAen_DKen_GBen_HKen_IEen_IE@euroen_ILen_INen_NGen_NZen_PHen_SCen_SGen_USen_ZAen_ZMen_ZWeoes_ARes_BOes_CLes_COes_CRes_CUes_DOes_ECes_ESes_ES@euroes_GTes_HNes_MXes_NIes_PAes_PEes_PRes_PYes_SVes_USes_UYes_VEet_EEeu_ESeu_ES@eurofa_IRff_SNfi_FIfi_FI@eurofil_PHfo_FOfr_BEfr_BE@eurofr_CAfr_CHfr_FRfr_FR@eurofr_LUfr_LU@eurofur_ITfy_DEfy_NLga_IEga_IE@eurogd_GBgez_ERgez_ER@abegedegez_ETgez_ET@abegedegl_ESgl_ES@eurogu_INgv_GBha_NGhak_TWhe_ILhi_INhif_FJhne_INhr_HRhsb_DEht_HThu_HUhy_AMi18ni18n_ctypeia_FRid_IDig_NGik_CAis_ISiso14651_t1iso14651_t1_commoniso14651_t1_pinyinit_CHit_ITit_IT@euroiu_CAja_JPka_GEkab_DZkk_KZkl_GLkm_KHkn_INko_KRkok_INks_INks_IN@devanagariku_TRkw_GBky_KGlb_LUlg_UGli_BEli_NLlij_ITln_CDlo_LAlt_LTlv_LVlzh_TWmag_INmai_INmai_NPmfe_MUmg_MGmhr_RUmi_NZmiq_NImjw_INmk_MKml_INmn_MNmni_INmnw_MMmr_INms_MYmt_MTmy_MMnan_TWnan_TW@latinnb_NOnds_DEnds_NLne_NPnhn_MXniu_NUniu_NZnl_AWnl_BEnl_BE@euronl_NLnl_NL@euronn_NOno_NOnr_ZAnso_ZAoc_FRom_ETom_KEor_INos_RUpa_INpa_PKpap_AWpap_CWpl_PLps_AFpt_BRpt_PTpt_PT@euroquz_PEraj_INrif_MAro_ROru_RUru_UArw_RWsa_INsah_RUsat_INsc_ITsd_INsd_IN@devanagarise_NOsgs_LTshn_MMshs_CAsi_LKsid_ETsk_SKsl_SIsm_WSso_DJso_ETso_KEso_SOsq_ALsq_MKsr_MEsr_RSsr_RS@latinss_ZAst_ZAsv_FIsv_FI@eurosv_SEsw_KEsw_TZsyrszl_PLta_INta_LKtcy_INte_INtg_TJth_THthe_NPti_ERti_ETtig_ERtk_TMtl_PHtn_ZAto_TOtpi_PGtr_CYtr_TRtranslit_circletranslit_cjk_compattranslit_cjk_variantstranslit_combiningtranslit_compattranslit_fonttranslit_fractiontranslit_hangultranslit_narrowtranslit_neutraltranslit_smalltranslit_widets_ZAtt_RUtt_RU@iqtelifug_CNuk_UAunm_USur_INur_PKuz_UZuz_UZ@cyrillicve_ZAvi_VNwa_BEwa_BE@eurowae_CHwal_ETwo_SNxh_ZAyi_USyo_NGyue_HKyuw_PGzh_CNzh_HKzh_SGzh_TWzu_ZA/usr/share//usr/share/i18n//usr/share/i18n/charmaps//usr/share/i18n/locales/-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:36653/SUSE_SLE-15-SP6_Update/06c69cbeb239b2ae9c58e2fab735e12e-glibc.SUSE_SLE-15-SP6_Updatedrpmxz5x86_64-suse-linuxdirectoryASCII text (gzip compressed data, max compression, from Unix)UTF-8 Unicode text (gzip compressed data, max compression, from Unix)ASCII textUTF-8 Unicode textexported SGML document, UTF-8 Unicode textUTF-8 Unicode text, with very long liness Гu"utf-86101bb8ce60cdf38870b4ddef5207f8da17d26f471ce97c5c0cfd341d92fb43d?P7zXZ !t/0]"k%*76K]O,t'Eu}GJS~0s+70R\:"s:`TxGuacFR x+nUq(lB7YTV.]@ζ[Rv< B9tu[mFeit"mk[|{Rh}8ygG&rl7 aDiWDbT]zs {{nV 7fhLGÉ5wX)(Ou(r|;0 v!y3a`x` &7Ta85~ =αVb3v( b0]6`ԛа[(ą[A )%8[Pa@f-TjOi?.֙3WUNq~OB 4DrYtq-ryftݻ;+|2O7Zwy+wA ತ>M mec9Xn \:K;8jR~?᛫[kki&Δ(`#57OA uTOD&*K-ԛrK[h' )?U!aYMso?WʊqeP56c5»Ҭ.>.)@1'2䐼5zǸӄx`u)4b!Shs~AJ9Gtڈ}&L3K@0O~C-Qyr1[ "3#U7g@C+ƹM"ZBNm[5rA'Q2>i66ŇNWCcZ^tGH?턵o 7BjĒ9jFGCy]G42yR'{=?w\߄Wumi+Aoeъw{~MR1t'2%x1q p%CCqDuTS٬bAGXRXᵚ̶2ET E?*!jOU O8<J/i-S~V|:-sv/wU)[+E$< ,E|uyM;cVM~F<*FtM:>eWJC Ѣ=}}bx{ w96JΌj'@Gl U1[M "c!"-EB%zw!o(g=y,NFFhG%|zY|˿ <3˔L:)1" 9{nYk|N2Bj@@ %׀`:/1jcfNBWwG6fxё17]6dk ]& O!$\sg9NT |T;z5lgS_hkb]R_Ǹ+*[\ӭÑD:)Ӎ`_4X[kRUH_ {, ~E^<4Y7ԙe03V oLM|5kƻ%ٺGS j[_M# XrIIg] o%3RcOI1]~z<6}%͙WͽmƳ@zM5\2ީ;hd2;À묡};n@v> Ҏx)hvzg(e>5~~1}d:M`W$ӭ {D+_ĉ!#de_KYQ.et6=F4a۬zq'Dnk!|r^U0QgfceIxTكz׺ U>C|D3) ޝ7Y~ň: I۠qhPnj50W6?>ܚ',$snonV3VY,rߟGggw{I^}σx9o ׸ I)hk%$́iֵ4 5F""ؓ\q:BFvC\P#7Ua ؆cMW\0R!yl&i$e.y@]* 2sSח ¡Lذm[Q(qr*F3zHߜ; 4m4E稳}SߴiS422=TiEla)皏7!W+ע5f{:gwboQձrBoXɄ=sRh6G"]5RWt_ca}oNho,Fvȴz}2k 8Ham ueC⹤<8&K|RG@@M ߣFu6VD9<&kOrhڮ@Q5jV8`!N2L.NJy# +6{*)BC2Bpd+4b $knox=[^a 'I+CwG"X"QWE1Xa2>L  ҏChLdrYbOp/zL?zC"IHI2π ];!3PiuS_7&0+"Ez|mt>*W}[ "LU/L#uxnr˗UViq@0n(NdL!yԘ>)qaA q,uعzfԀLL[lo\s:S铑?zm;2-`-rL|6A.Ypf ! _u.{a}c=`2iTzїf~m~*0ot0 Y\l]=ThM#CRGա6( t%R1JPF䁋. fFC:_rh 9|^G}$:5&*F'j`-*#{{kqII7fg@_ʿ)X;ϽCp9ܪÂ?;F6x@N! GIS[v]~='^vQe|y)ݎ="OMے&HF6Wx!ơ]:Ӟk9sM YZ