openvswitch2.13-devel-2.13.0-153.el8s >  H a: !F^(*v` ҴR3|/ϯ8 -ٲ[7 `<h:{p)z$W,|gy̼Hc5Xf́yvmR89FEܞ*1}_ϳ1sK^X7u*htrv %ձB|%1aMk4S~"[uL(Œ%_tXM{Kq|էQ _&XDP[qxxSw(#^cQELP}b0943c1ae9c11a2ac19779f7d6668af56ec3395c0e922fb4277f332ef10c9c90a367dea7d80398a15a1efdb39bfb8ba9a39cfa7bw@a: !F^(*v)zOMlpv+ͲY,,.sw8B|?SZ[iq"w1Di:bw=EW:9`^= W qև}_R)SA]iס}ڞE[pD-OJ獃'jnV_#v h4p~CrRv]iZJ*8<3* zRzT#dwxyf0Y5K}!^!(n򙞤ǹ`6,) \>p<?d ( e  /dFF 4F F F ^F F4FFF0   (88@9:System Environment/Daemons daemon/database/utilitieshttp://www.openvswitch.org/linuxaarch64# P3NIn)5@9<&K+* *.;)7 n*< . U yy'#BnL8([ T . n.)=42 azazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazazaz azaz azazazazaz904813c8078bc01f8a36974f95f21affdbfbda4d71846ef37ccbbe234a6110324271784cc979835a9f97532052f74db6306ce4f94b13d0c5b1d7ba7d6352df39de10c0c5bfd1ae16c4e9ab7a5f33608db6fba46aa295bbd1d7c132f0bce2eade8f882eca6713b1bd6786dbc4baccc499becf40ace89a10a5e5cbe56e718f8924179f04b61148324280e960fba3abb9661c3697971672ad768ba82e316a43a55167bca656cc1abf0b76dd3e3e002f04098a849e00ce3f1249b2bfbc4df29ea414da215fa66e48fc2a5c253f392ffd6d959b6621ad6a8621fefe6bf842d6da4dab193f7885404a8feff36ecb09bf496282b809adaec929bf16b59b7152378aff9601d1d77ac382501247ad59c07406ca7b84fe05329e2b04d6959d21e78390f37a357ab39008ce3a063da4a09050235cffb3c09a20bffdd43bf43389ffd27f3da7fd9f783ff0481fc679e7d305d02a48fbb5b8554ac62b3b7330678bc51f494c00dfec2338087062b2773b0a760ed03937afb3a262a522f15461634fc794d459c2a44e32644d49d00b3c8e4d090e7d8e4ca8d067a2807089a841b565a0445526504493d59959377662f3e80b262fd6aceefb2665f97d840a5964d9e0540c28a185f856ef10590a46d3fb75da32f84f4a0072b8fe4e18a1750bc95a7888dfca0e6594b076ce69ea410e23b4deded62835928b58b4d8721d89c328bfb0a8cd94aca899e00590f8fc4bd8dea6f0af9c95f143747f268a0db95631702ccdc4abf6c9ffdd2ddafe659eb67af1b78b695e7416bb746660a87527f29fec1e79d087d79faafaa51bc84582de143a7cd324aec3605a403d1f2e22f8d584051d168d4389ad79341d35008b7589f02fc2d94de1ca8c3d3eb470e090bc01726e959ff343078501086774c716d7dbcb245e8b3249242e41739172409baa33a07f277d5615a2043aa0428fde81904727986f5b9e202f0c658aae4276c9e786cb4f1e36a8c74803ad0d9a1f68a6fae6d2b8ff510d6ea002b10f9bd415448cfdf60fcd0f61ec4f04b34fae4ef7e0ebbefb56eb200685cf66bbf11341182216b6c35089cc555f794a76613c00b0d4bc262bce871391f4b99673e6a6b7a8a90cd2f8c54f261ed0a2219127e0fc28952a684c2798fc62f150a93b60463026af9e41d178e6d1e10a012fba42441e6c6b7edf788b11c8818042bb99bf68ecbb539512fec4c08512039e294f4a289517f607b8e8aa15a61c67f1abf40ec411c3633b714a68f2e0171b2cd62b122cd32f8e6c36ec9f07aaf08d8a1fb504d9c222aebe8f301ec2a68984fdf11cfae3a0545efa120a3daac4c1c0724066ecb6f9fe53b90a97fcac95e96f86a17f4190a6d95322edbcb9951e4c5205c63c796e9c63d70d0d47af51341f4a5b4f8654c02456ddaeb31027a539031efd673cb11848405f6f7d7ff78ea87dbff9980839ca3dda40415a80e5e5c31bc1133e9b190a18fc728ac8c368d2fe203cea1b11f8990df4084c2650c2a69c930b5baf93436c335d372669e1cd2a4befe1b1240e249556f2afa09043e3b9b0ae13cb16aa60d1ca83bb40ac6d6ee1884c26ec8332291e8d2e5c293ce0cab4b38b3223da8416e040b5d7e5eb3174a1533784e3eaf41eba0cd83f9f307c60c164a1387129a2d1c42b864551639c947986763c8161aacf8afe6dfbd3c02915479f9da13b27ed716229c6b0d87ff4858e84728c75c118684326319628951ca55c282c1cc462f6f005edde258d5324c68b096913a01ce6c9b93d707e7cae5c3c1440708d1f26c6bfa45d456f6ef8bad03b5f5fee6013571ef3735d5bddf51430cc1bfdc4881411d850788fb55c03ce740a429c607d0ded1aef169b0778a8925e28e70cdda4e40d6fd3c8e7028992cca3aee9c9e0f66022e260322fa76c447c32aa3af013d0c0e8cd0d10577b7c52f331e4edffb7b22a06c509eed3a8b38df67402a0684e7acfbcfb21a19789312202a633baf6a1b3ab5696336ea2a2a434d481a6254216e406a968215933e61ac41bb50c3a81c322fdb05a09c9947f1ecdafe2dc08c990de95679cbb792f2d3432325a54d48ab5db9a8304a437d546e734e0c4c29f0a2318135554fddb988c8fef4a229b1417f483f63f8aa710d029c10a632f3741affa49a1004b5cdf40260ede39d223b74f429e20e266c9412939375231d20ef8fa2c9d4c49d5a5ca997121aa54840a5af24cec4e7619c3bb7e6532ecbed68097f4cd7c14a50e5e02bece360a6001b10ab4c154ca0cd11d21a66a02472be2cd83949e4589a96a592638a3d8fff0c6c8db00f0c133486b474d2bf06c8b2cf5035f8061a825f62f852b98b45b484bb553c62eca889aca72c32ef5c737560502031af3cb363a5749efeffdb39a8382441317f2365851642b41f61297000368cdfa8fdff267aecf2547775233bf127334cf9b42988082025a38b942d02f32049601d0b9a17ec245b8e7c1338849e2a7223e373f479e2a95183282319b28f1fcfe57849311b937db18378dc066ea68bc3efd401f1431a97e0f7e8e269d30159939310f472b64569b4e966e8c6bff9082e1250e0f4d163188f37bd160db3412ef6d5d665cd2afd43195c5a6506cb622f6f9a503d8d0009b4fa1d51b96dd993ef8b9281037a954bcf266ab1e9fb486b40a02ed19ee122cf2be768d7c77a625f38cd94f0f71b743b79a64ac99537a293de05f9d6e73de68a6f03259307254db747798e0f1444ba5878ef1435883e041e62a3dc47e83a20d827982af371a2e18a2da8ab97b60c4953926dc5ee4b9fae385820282207ba15850af3660231b4d0d16618e95c5934e71f6e9fc9c1c588a7a2b9e96a99412965fe1f026ffc98b6c8dd2b79e7c148e048c85fe61aca63e8901e34f6d923497f2caaaae93ee778b7cc3c80680a068e521cff8bed5eccffa2f329796b8dd941ee380d09blibofproto-2.13.so.0.0.7libopenvswitch-2.13.so.0.0.7libovsdb-2.13.so.0.0.7libsflow-2.13.so.0.0.7libvtep-2.13.so.0.0.7rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootopenvswitch2.13-2.13.0-153.el8s.src.rpmopenvswitch2.13-developenvswitch2.13-devel(aarch-64)pkgconfig(libofproto)pkgconfig(libopenvswitch)pkgconfig(libovsdb)pkgconfig(libsflow)@@@@@@    /usr/bin/pkg-configlibofproto-2.13.so.0()(64bit)libopenvswitch-2.13.so.0()(64bit)libovsdb-2.13.so.0()(64bit)libsflow-2.13.so.0()(64bit)libvtep-2.13.so.0()(64bit)openvswitch2.13rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)2.13.0-153.el8s3.0.4-14.6.0-14.0-15.2-14.14.3a7a@a@a@a@a@a@a@aNaaZ@a@aa@a@@aKazay?@ay?@araqV@an@ahaf@aexaUaQ@aLl@aC1a8aaS@aS@a@`` @`@`\`````f@`@`q` @``~@`v@`pA`lM@`lM@`g@`e`c`X`T@`P`*b@`#`3@``@`>`>`>`@``@`@`@`@`@`2@_@_1@_$_$_@_ǁ_^@_@_i_@_@_/@_@__ _@_"_"_P_a@_Z@_G@_FN_;_;_5+@_16_16_._._"@_A@_A@_A@_A@____ @_@^^3^3^3^?@^?@^^^^^^@^@^@^@^@^@^@^@^1^^H^H^H^^k@^^^}^y@^x^x^x^h^W@^U @Open vSwitch CI - 2.13.0-153Eelco Chaudron - 2.13.0-152Eelco Chaudron - 2.13.0-151Eelco Chaudron - 2.13.0-150Eelco Chaudron - 2.13.0-149Eelco Chaudron - 2.13.0-148Eelco Chaudron - 2.13.0-147Open vSwitch CI - 2.13.0-146Open vSwitch CI - 2.13.0-145Open vSwitch CI - 2.13.0-144Open vSwitch CI - 2.13.0-143Open vSwitch CI - 2.13.0-142Open vSwitch CI - 2.13.0-141Open vSwitch CI - 2.13.0-140Open vSwitch CI - 2.13.0-139Open vSwitch CI - 2.13.0-138Open vSwitch CI - 2.13.0-137Open vSwitch CI - 2.13.0-136Open vSwitch CI - 2.13.0-135Open vSwitch CI - 2.13.0-134Open vSwitch CI - 2.13.0-133Open vSwitch CI - 2.13.0-132Open vSwitch CI - 2.13.0-131Open vSwitch CI - 2.13.0-130Open vSwitch CI - 2.13.0-129Open vSwitch CI - 2.13.0-128Open vSwitch CI - 2.13.0-127Timothy Redaelli - 2.13.0-126Open vSwitch CI - 2.13.0-125Open vSwitch CI - 2.13.0-124Michael Santana - 2.13.0-123Open vSwitch CI - 2.13.0-122Michael Santana - 2.13.0-121Open vSwitch CI - 2.13.0-120Open vSwitch CI - 2.13.0-119Open vSwitch CI - 2.13.0-118Open vSwitch CI - 2.13.0-117Timothy Redaelli - 2.13.0-116Open vSwitch CI - 2.13.0-115Open vSwitch CI - 2.13.0-114Open vSwitch CI - 2.13.0-113Open vSwitch CI - 2.13.0-112Open vSwitch CI - 2.13.0-111Open vSwitch CI - 2.13.0-110Open vSwitch CI - 2.13.0-109Open vSwitch CI - 2.13.0-108Open vSwitch CI - 2.13.0-107Timothy Redaelli - 2.13.0-106Open vSwitch CI - 2.13.0-105Open vSwitch CI - 2.13.0-104Timothy Redaelli - 2.13.0-103Timothy Redaelli - 2.13.0-102Open vSwitch CI - 2.13.0-101Open vSwitch CI - 2.13.0-100Open vSwitch CI - 2.13.0-99Kevin Traynor - 2.13.0-98Kevin Traynor - 2.13.0-97Open vSwitch CI - 2.13.0-96Eelco Chaudron - 2.13.0-95Open vSwitch CI - 2.13.0-94Open vSwitch CI - 2.13.0-93Open vSwitch CI - 2.13.0-92Open vSwitch CI - 2.13.0-91Timothy Redaelli - 2.13.0-90Timothy Redaelli - 2.13.0-89Timothy Redaelli - 2.13.0-88Open vSwitch CI - 2.13.0-87Open vSwitch CI - 2.13.0-86Open vSwitch CI - 2.13.0-85Timothy Redaelli - 2.13.0-84Flavio Leitner - 2.13.0-83Flavio Leitner - 2.13.0-82Timothy Redaelli - 2.13.0-81Open vSwitch CI - 2.13.0-80Open vSwitch CI - 2.13.0-79Open vSwitch CI - 2.13.0-78Open vSwitch CI - 2.13.0-77Open vSwitch CI - 2.13.0-76Open vSwitch CI - 2.13.0-75Open vSwitch CI - 2.13.0-74Timothy Redaelli - 2.13.0-73Timothy Redaelli - 2.13.0-72Open vSwitch CI - 2.13.0-71Flavio Leitner - 2.13.0-70Flavio Leitner - 2.13.0-69Flavio Leitner - 2.13.0-68Ilya Maximets - 2.13.0-67Ilya Maximets - 2.13.0-66Open vSwitch CI - 2.13.0-65Open vSwitch CI - 2.13.0-64Open vSwitch CI - 2.13.0-63Timothy Redaelli - 2.13.0-62Open vSwitch CI - 2.13.0-61Open vSwitch CI - 2.13.0-60Open vSwitch CI - 2.13.0-59Open vSwitch CI - 2.13.0-58Open vSwitch CI - 2.13.0-57Flavio Leitner - 2.13.0-56Flavio Leitner - 2.13.0-55Open vSwitch CI - 2.13.0-54Open vSwitch CI - 2.13.0-53Dumitru Ceara - 2.13.0-52Flavio Leitner - 2.13.0-51Flavio Leitner - 2.13.0-50Timothy Redaelli - 2.13.0-49Flavio Leitner - 2.13.0-48Flavio Leitner - 2.13.0-47Flavio Leitner - 2.13.0-46Flavio Leitner - 2.13.0-45Flavio Leitner - 2.13.0-44Flavio Leitner - 2.13.0-43Flavio Leitner - 2.13.0-42Flavio Leitner - 2.13.0-41Timothy Redaelli - 2.13.0-40Timothy Redaelli - 2.13.0-39Ilya Maximets - 2.13.0-38Ilya Maximets - 2.13.0-37Ilya Maximets - 2.13.0-36Aaron Conole - 2.13.0-35Aaron Conole - 2.13.0-34Timothy Redaelli - 2.13.0-33Timothy Redaelli - 2.13.0-32Timothy Redaelli - 2.13.0-31Timothy Redaelli - 2.13.0-30Timothy Redaelli - 2.13.0-29Dumitru Ceara - 2.13.0-28Dumitru Ceara - 2.13.0-27Dumitru Ceara - 2.13.0-26Dumitru Ceara - 2.13.0-25Dumitru Ceara - 2.13.0-24Dumitru Ceara - 2.13.0-23Dumitru Ceara - 2.13.0-22Dumitru Ceara - 2.13.0-21Timothy Redaelli - 2.13.0-20Timothy Redaelli - 2.13.0-19Timothy Redaelli - 2.13.0-18Timothy Redaelli - 2.13.0-17Timothy Redaelli - 2.13.0-16Timothy Redaelli - 2.13.0-15Flavio Leitner - 2.13.0-14Flavio Leitner - 2.13.0-13Flavio Leitner - 2.13.0-12Flavio Leitner - 2.13.0-11Flavio Leitner - 2.13.0-10Timothy Redaelli - 2.13.0-9Timothy Redaelli - 2.13.0-8Numan Siddique - 2.13.0-7Timothy Redaelli - 2.13.0-6Timothy Redaelli - 2.13.0-5Timothy Redaelli - 2.13.0-4- Merging upstream branch-2.13 [RH git: 607e493104] Commit list: 348cdae4b4 ofproto-dpif: Fix issue with non-reversible actions on a patch ports.- downstream: Enable usdt probes in build [RH git: 30f6bfcfca] Fixes: BZ1840877- utilities: Add netlink flow operation USDT probes and upcall_cost script. [RH git: bb307de169] This patch adds a series of NetLink flow operation USDT probes. These probes are in turn used in the upcall_cost Python script, which in addition of some kernel tracepoints, give an insight into the time spent on processing upcall. Signed-off-by: Eelco Chaudron Acked-by: Paolo Valerio Signed-off-by: Ilya Maximets - utilities: Add upcall USDT probe and associated script. [RH git: 2c68e0b4c2] Added the dpif_recv:recv_upcall USDT probe, which is used by the included upcall_monitor.py script. This script receives all upcall packets sent by the kernel to ovs-vswitchd. By default, it will show all upcall events, which looks something like this: TIME CPU COMM PID DPIF_NAME TYPE PKT_LEN FLOW_KEY_LEN 5952147.003848809 2 handler4 1381158 system@ovs-system 0 98 132 5952147.003879643 2 handler4 1381158 system@ovs-system 0 70 160 5952147.003914924 2 handler4 1381158 system@ovs-system 0 98 152 It can also dump the packet and NetLink content, and if required, the packets can also be written to a pcap file. Signed-off-by: Eelco Chaudron Acked-by: Paolo Valerio Signed-off-by: Ilya Maximets - Documentation: Add USDT documentation and bpftrace example. [RH git: 714f513833] Add the USDT documentation and a bpftrace example using the bridge run USDT probes. Signed-off-by: Eelco Chaudron Acked-by: Paolo Valerio Signed-off-by: Ilya Maximets - openvswitch: Define the OVS_STATIC_TRACE() macro. [RH git: c47c990c6b] This patch defines the OVS_STATIC_TRACE() macro, and as an example, adds two of them in the bridge run loop. Signed-off-by: Eelco Chaudron Acked-by: Paolo Valerio Signed-off-by: Ilya Maximets - configure: Add --enable-usdt-probes option to enable USDT probes. [RH git: 6bad1cd13d] Allow inclusion of User Statically Defined Trace (USDT) probes in the OVS binaries using the --enable-usdt-probes option to the ./configure script. Signed-off-by: Eelco Chaudron Acked-by: Paolo Valerio Signed-off-by: Ilya Maximets - Merging upstream branch-2.13 [RH git: 0b2dac74a2] Commit list: 0df41e29b2 ovs-monitor-ipsec: Fix generated strongSwan ipsec.conf for IPv6.- Merging upstream branch-2.13 [RH git: 035f2095f9] Commit list: 9572c60bfc datapath-windows: Pickup Ct tuple as CT lookup key in function OvsCtSetupLookupCtx- Merging upstream branch-2.13 [RH git: df42b314bc] Commit list: 77750b1b19 Documentation: Fix Rx/Tx queue configuration section.- Merging upstream branch-2.13 [RH git: 52b03eee18] Commit list: d30d561bd9 ofproto-dpif: Fix memory leak in dpif/show-dp-features appctl.- Merging upstream branch-2.13 [RH git: e2ae994435] Commit list: 025ec93bc5 Prepare for 2.13.7. 723e0727f3 Set release date for 2.13.6. d6d2dead72 ofproto-dpif-xlate: Snoop ingress packets and update neigh cache if needed. dc8b79ccf1 tnl-neigh-cache: Do not refresh the entry while revalidating. 7e1c6034b5 tnl-neigh-cache: Include expected array sizes in prototypes. 9c98116ac7 tnl-neigh-cache: Read/write expires atomically.- Merging upstream branch-2.13 [RH git: 035911bcc8] Commit list: 0263845fde compat: handle NF_REPEAT error on nf_conntrack_in.- Merging upstream branch-2.13 [RH git: 6a59db52e8] Commit list: 9fa66631c2 flow: Consider dataofs when parsing TCP packets. cabeb5d056 tests/flowgen: Fix packet data endianness. 0b8586fbeb ofproto: Fix resource usage explosion due to removal of large number of flows. 34801d50e2 ofproto: Fix resource usage explosion while processing bundled FLOW_MOD. 1910814e5e tests/flowgen: Fix length field of 802.2 data link header. 6aac7758c0 ovs-lib: Backup and remove existing DB when joining cluster. a5e1af7b99 docs/dpdk: Fix install doc. 6fb9d7ab08 ovs-save: Save igmp flows in ofp_parse syntax. 0c93c71f8c dpdk: Use DPDK 19.11.10 release.- Merging upstream branch-2.13 [RH git: 37c2767bbd] Commit list: 057a5b0708 ofproto-dpif-xlate: Fix check_pkt_larger incomplete translation.- Merging upstream branch-2.13 [RH git: 424b25f9ca] Commit list: 85358e0a9f datapath-windows: Reset flow key after Ipv4 fragments are reassembled- Merging upstream branch-2.13 [RH git: f86ccc67c2] Commit list: da5b115580 datapath-windows:Reset PseudoChecksum value only for TX direction offload case- Merging upstream branch-2.13 [RH git: 25cc09c60a] Commit list: 2c1369aa6d netdev-offload-tc: Verify the flower rule installed.- Merging upstream branch-2.13 [RH git: 1b6734e549] Commit list: b73ad3bcf7 ci: Make linux-prepare trust system installs.- Merging upstream branch-2.13 [RH git: c72ff28f03] Commit list: 4d5470a450 Prepare for 2.13.6. 6771b9c9d7 Set release date for 2.13.5.- Merging upstream branch-2.13 [RH git: d37b008459] Commit list: 70f6efa41c python: idl: Avoid sending transactions when the DB is not synced up.- Merging upstream branch-2.13 [RH git: 60a72ee3f6] Commit list: 5c33e4db80 datapath-windows: add layers when adding the deferred actions- Merging upstream branch-2.13 [RH git: 31c65d3e94] Commit list: 6e2e180851 ofproto-dpif-xlate: Fix zone set from non-frozen-metadata fields.- Merging upstream branch-2.13 [RH git: beb8cdaec6] Commit list: ceb395773d dpif-netdev: Fix use-after-free on PACKET_OUT of IP fragments. fed4df9bb7 tunnel-push-pop.at: Mask source port in tunnel header.- Merging upstream branch-2.13 [RH git: fc819dabd3] Commit list: ec44c50cf0 ipf: release unhandled packets from the batch- Merging upstream branch-2.13 [RH git: 9d83aff7e3] Commit list: 695d25f507 datapath-windows:adjust Offset when processing packet in POP_VLAN action- Merging upstream branch-2.13 [RH git: a117849d24] Commit list: e33aaf8bda cirrus: Reduce memory requirements for FreeBSD VMs.- redhat: use hugetlbfs group for /var/log/openvswitch when dpdk is enabled [RH git: a32eb508f7] (#2007292) Resolves: #2007292- Merging upstream branch-2.13 [RH git: 215f08bbd8] Commit list: a56a8008eb netdev-linux: Fix a null pointer dereference in netdev_linux_notify_sock(). 186ff2a5b2 pcap-file: Fix memory leak in ovs_pcap_open(). b9b144b8d8 odp-util: Fix a null pointer dereference in odp_flow_format(). fea883d3bd odp-util: Fix a null pointer dereference in odp_nsh_key_from_attr__(). ef6d151b04 ipf: Fix only nat the first fragment in the reass process.- Merging upstream branch-2.13 [RH git: b3c7c50935] Commit list: 38efd803dd dpif-netdev: Fix crash when PACKET_OUT is metered.- Migrate openvswitch to gitlab [RH git: 081bad43fc] Signed-off-by: Michael Santana - Merging upstream branch-2.13 [RH git: 775922244f] Commit list: f61f810fb3 tc: Set action flags for tunnel_key release. 0dc609a260 netlink-socket: Replace error with txn->error when logging nacked transactions. d3776e354c dynamic-string: Fix a crash in ds_clone().- pkgtool: Make changelog in spec file more informative [RH git: 42174a9bc1] This is done by adding the body of the commit message to the changelong. The body is indented and has extra spacing separating each entry in the changelog to make each one more discernible since now they could be longer. Also, make sure the bugzilla ID is at the end of the line Signed-off-by: Michael Santana - Merging upstream branch-2.13 [RH git: eda2f50cf9] Commit list: f7e3b47e09 dpif-netdev: Fix offloads of modified flows. 350507b163 dpif-netdev: Fix flow modification after failure.- Merging upstream branch-2.13 [RH git: c2e53c3150] Commit list: f92ce92e53 daemon-unix: Fix leak of a fork error message.- Merging upstream branch-2.13 [RH git: d613ce404a] Commit list: d794934d01 datapath-windows:Correct checksum for DNAT action- Merging upstream branch-2.13 [RH git: 1dbd295283] Commit list: 9b1c0df6ad dpif-netlink: Fix report_loss() message. 17e98772cb conntrack: Document all-zero IP SNAT behavior and add a test case. 305b944a2e ovsdb-server: Fix memleak when failing to read storage. 1aa1f59142 netdev-linux: Ignore TSO packets when TSO is not enabled for userspace. d127fa6d2b conntrack: Handle already natted packets. c8ebe4434c python: Fix Idl.run change_seqno update. 2762bf6895 Prepare for 2.13.5. d72ccdfbda Set release date for 2.13.4. 76fdda2b34 netlink: removed incorrect optimization 9c386761f9 ovs-actions.xml: Add missing bracket. be8c4af1ce netdev-offload-tc: Use nl_msg_put_flag for OVS_TUNNEL_KEY_ATTR_CSUM.- Merging 15251f0e1d datapath-windows: Specify external include .. [RH git: f9d10a495b] Commit list: 15251f0e1d datapath-windows: Specify external include paths 9f05167b21 Remove Python 2 leftovers. 64c3133c01 ipf: Fix a use-after-free error, and remove the 'do_not_steal' flag. fe7bd42d6c ofproto: Fix potential NULL dereference in ofproto_ct_*_zone_timeout_policy(). fc23134227 ofproto: Fix potential NULL dereference in ofproto_get_datapath_cap().- Merging upstream branch-2.13 [RH git: 190762bf5c] Commit list: 8be19f789b dpif-netlink: Fix send of uninitialized memory in ct limit requests. 25dd08492d ofproto-dpif: Fix use of uninitialized attributes of timeout policy. 95570b23c8 netdev-linux: Fix use of uninitialized LAG master name.- Merging upstream branch-2.13 [RH git: 63656e47fb] Commit list: 160bb80a32 ofp_actions: Fix set_mpls_tc formatting.- Merging upstream branch-2.13 [RH git: 43b0d45790] Commit list: 32a197f845 dpif-netdev: Remove meter rate from the bucket size calculation. 1b4d8fe1d9 ovsdb-idl: Consider all tables when computing expected cond seqno.- Merging upstream branch-2.13 [RH git: 3f4fc768f0] Commit list: 9acbf2cff7 ovs-ofctl: Fix coredump when using "add-groups" command.- Merging upstream branch-2.13 [RH git: 5eca61ee5e] Commit list: 058702e3dc raft: Transfer leadership before creating snapshots.- Merging upstream branch-2.13 [RH git: 6022570f3f] Commit list: 3bc41e2b6a dpdk: Use DPDK 19.11.8 release.- Merging upstream branch-2.13 [RH git: 132c26ba20] Commit list: fbebe7377d github: Fix up malformed /etc/hosts. 2a3d1f4971 doc: automake: Add support for sphinx 4.0. 4ab5524dbb cirrus: Look up existing versions of python dependencies.- Merging upstream branch-2.13 [RH git: d2edacdddd] Commit list: ea98fe0743 ofp-group: Use big-enough buffer in ofputil_format_group().- Merging upstream branch-2.13 [RH git: 9a8a649301] Commit list: 798a40ffb6 ofproto/ofproto-dpif-sflow: Check sflow agent in case of race 9984d61124 dpif: Fix use of uninitialized execute hash. 43c2a10922 odp-util: Fix use of uninitialized erspan metadata. 4f68040a5c dpif-netlink: Fix using uninitialized info.tc_modify_flow_deleted in out label. 1c2a5f170f netdev-offload-tc: Probe for support for any of the ct_state flags. a4730043a4 compat: Add ct_state flags definitions. bbd62d7a44 tc: Use skip_hw flag when probing tc features.- Fix typo in rh-mock-srpm [RH git: 5641bf9d72] Thanks fbl for reporting- Merging upstream branch-2.13 [RH git: 0aaf7c02b7] Commit list: 759da53f07 Add test cases for ingress_policing parameters c901a563f4 netdev-linux: correct unit of burst parameter- Merging upstream branch-2.13 [RH git: 1334a398c9] Commit list: d47800bd66 ovsdb-idl: Mark arc sources as updated when destination is deleted. 6cf6f9d0d3 ovsdb-idl: Preserve references for deleted rows. e7d451ab8a ovsdb-idl.at: Make test outputs more predictable. 7fca8a3c94 test-ovsdb: Log steps in idl test. 4ca9dd87f6 test-stream: Silence memory leak report.- Align DPDK config to 19.11.7 [RH git: 62cff1abf5]- Merge tag 'c765f42e31c1baa8f4e7a9e01080f5474596ea98' into fast-datapath-rhel-8 [RH git: 4ef8ee2e1a] dpdk-19.11.7- Merging upstream branch-2.13 [RH git: 02b662f992] Commit list: 68086371c8 ipsec: Fix IPv6 default route support for Libreswan.- Merging upstream branch-2.13 [RH git: 7323d4b8e4] Commit list: 2cb952326e ovs-ofctl: Fix segfault due to bad meter n_bands.- Merging upstream branch-2.13 [RH git: 8e7dc3319c] Commit list: a112239ff5 dpif-netdev: Refactor and fix the buckets calculation. d9d8ebfa00 dpif-netdev: Fix the meter buckets overflow.- dpif-netdev: Allow PMD auto load balance with cross-numa. [RH git: edeaca020b] (#1938162) commit ec68a877db5bbfba49ddeb9929479c033420ea6b Author: Kevin Traynor Date: Thu Mar 18 11:34:04 2021 +0000 dpif-netdev: Allow PMD auto load balance with cross-numa. Previously auto load balance did not trigger a reassignment when there was any cross-numa polling as an rxq could be polled from a different numa after reassign and it could impact estimates. In the case where there is only one numa with pmds available, the same numa will always poll before and after reassignment, so estimates are valid. Allow PMD auto load balance to trigger a reassignment in this case. Acked-by: Eelco Chaudron Acked-by: David Marchand Tested-by: Sunil Pai G Acked-by: Flavio Leitner Signed-off-by: Kevin Traynor Signed-off-by: Ilya Maximets Reported-at: https://bugzilla.redhat.com/show_bug.cgi?id=1938162 Conflicts: Commit backported from upstream master branch. Commit not present on upstream branch-2.13. Removed NEWS file update as could cause future merge conflicts.- redhat: Update docs for test builds [RH git: 0322f225d3]- Merging upstream branch-2.13 [RH git: bb107a7f7f] Commit list: fc8444fb1d python: Send notifications after the transaction ends. 712193ff1c ovs-ctl: Allow recording hostname separately. 3665d7f805 dpif-netdev: Fix crash when add dp flow without in_port field. 732e17d6b6 Documentation: Fix DPDK qos example. 1dee0a67e5 raft: Report disconnected in cluster/status if candidate retries election. e78d6ffba7 raft: Reintroduce jsonrpc inactivity probes. aea5fefdac connmgr: Check nullptr inside ofmonitor_report(). 26fa38c332 ovsdb-client: Fix needs-conversion when SERVER is explicitly specified. 65582c0bad dpdk: Use DPDK 19.11.6 release. 967d4055e7 windows, tests: Modify service test. ccdfc67b74 netdev-linux: Fix indentation. 81e759618c ci: Use parallel build for distcheck. 6d67310f4d ofp-actions: Fix use-after-free while decoding RAW_ENCAP.- conntrack: add generic IP protocol support [RH git: 6b3ca4b028] Currently, userspace conntrack only tracks TCP, UDP, and ICMP, and all other IP protocols are discarded, and the +inv state is returned. This is not in line with the kernel conntrack. Where if no L4 information can be extracted it's treated as generic L3. The change below mimics the behavior of the kernel. Resolves: BZ1876459 Signed-off-by: Eelco Chaudron Acked-by: Flavio Leitner Signed-off-by: Ilya Maximets (cherry picked from commit a27d70a8984879bc0a66afc2d7c35149659be24d)- Merging upstream branch-2.13 [RH git: 8655a639ac] Commit list: 2be25e3b00 Prepare for 2.13.4. f25820bf55 Set release date for 2.13.3. 9a5e78b5c7 cirrus: Use FreeBSD 12.2. 3512fb512c flow: Support extra padding length.- Merging upstream branch-2.13 [RH git: 2100324b58] Commit list: a6efca9628 netdev-offload-tc: Reject rules with unsupported ct_state flags.- Merging upstream branch-2.13 [RH git: 92b77d1489] Commit list: 9985c46501 dist-docs: Include manpages generated from rST.- Merging upstream branch-2.13 [RH git: ea87c21ff2] Commit list: fcae3177d4 tc: Fix mpls bottom of stack bit mask reporting.- dpif-netdev: Add PMD auto load balance status log. [RH git: 4fd540d8ef] When any PMD auto load balance parameters change, it is useful to also log if the feature is enabled or disabled. |dpif_netdev|INFO|PMD auto load balance load threshold changed to 70% |dpif_netdev|INFO|PMD auto load balance is disabled Signed-off-by: Kevin Traynor Acked-by: David Marchand Acked-by: Ian Stokes Signed-off-by: Ilya Maximets (cherry picked from commit 30de75520277a39ac775d15d4fa1c9cc886ad5d2)- dpif-netdev: Add parameters to configure PMD auto load balance. [RH git: 5935f7a9d8] Two important parts of how PMD auto load balance operates are how loaded a core needs to be and how much improvement is estimated before a PMD auto load balance can trigger. Previously they were hardcoded to 95% loaded and 25% variance improvement. These default values may not be suitable for all use cases and we may want to use a more (or less) aggressive rebalance, either on the pmd load threshold or on the minimum variance improvement threshold. The defaults are not changed, but "pmd-auto-lb-load-threshold" and "pmd-auto-lb-improvement-threshold" parameters are added to override the defaults. $ ovs-vsctl set open_vswitch . other_config:pmd-auto-lb-load-threshold="70" $ ovs-vsctl set open_vswitch . other_config:pmd-auto-lb-improvement-threshold="20" Signed-off-by: Christophe Fontaine Co-Authored-by: Kevin Traynor Signed-off-by: Kevin Traynor Acked-by: David Marchand Acked-by: Ian Stokes Signed-off-by: Ilya Maximets (cherry picked from commit 62ab5594c20cc815592562af69abb5b8ebe85d55)- dpif-netdev: Add log for PMD auto load balance interval parameter. [RH git: a8f4696c20] Previously if the parameter for the PMD auto load balance minimum interval was changed at runtime, it was not logged unless the PMD auto load balance feature was also changed to enabled. Log the parameter anytime it changes, and use minutes when it is logged as that is the user input format. Fixes: 5bf84282482a ("Adding support for PMD auto load balancing") Signed-off-by: Kevin Traynor Acked-by: David Marchand Acked-by: Ian Stokes Signed-off-by: Ilya Maximets (cherry picked from commit e4db0b69e2d81d8d5ca1265fbfbd08a9b30a1a02)- Merging upstream branch-2.13 [RH git: d303f53850] Commit list: a5e068f24b netdev-dpdk: Fix incorrect shinfo initialization. 522d828ae6 github: Don't fail the job if 'apt update' failed. 81026f0bad vswitchd.xml: Fix supported IPsec tunnels.- Merging upstream branch-2.13 [RH git: 2986e0866e] Commit list: 98723e351f ovsdb-doc: Add build dependency on dirs.py.- Merging upstream branch-2.13 [RH git: f2f6b58dd9] Commit list: 484068b741 dpctl: Fix dpctl process command parameter error.- redhat: Use a mock config based on the buildsystem target [RH git: b820a7b894]- Merging b37528cef7 conntrack: Fix the icmp conntrack new state. [RH git: dc913c7d4c] Commit list: b37528cef7 conntrack: Fix the icmp conntrack new state. c06328ae57 conntrack: Fix icmp conntrack state. 8e0a1527d7 odp-util: Fix abort while formatting nsh actions.- Merging f383000ca6 acinclude: Strip out -mno-avx512f provided .. [RH git: 304ba372e4] Commit list: f383000ca6 acinclude: Strip out -mno-avx512f provided by DPDK. 63f2aa2b7d acinclude: Strip out -march provided by DPDK.- Enable AVX512 support on binutils >= 2.30-79.el8 [RH git: 8b3f992902]- Merging upstream branch-2.13 [RH git: b7a6e48410] Commit list: 66fc41bfb2 Prepare for 2.13.3. e8ca014102 Set release date for 2.13.2. 9b00c9c047 lldp: do not leak memory on multiple instances of TLVs 02e48ecf29 ipf: Avoid accessing to a freed rp. 999bec82e1 rhel: Fix libunwind dev package.- Merging upstream branch-2.13 [RH git: 86c9f9af77] Commit list: 6c3d1c9f6f ovs-monitor-ipsec: Add option to not restart IKE daemon. d9edf71d17 ovs-monitor-ipsec: Allow exit of ipsec daemon maintaining state. 7286dc4412 ovs-ctl: Use 'stop_daemon' to stop ovs-monitor-ipsec. 60c6013b7b ovs-monitor-ipsec: Fix active connection regex. d59ec5359d ovs-monitor-ipsec: set correct 'leftcert' and 'rightcert' name 6e1f4ade25 ovs-monitor-ipsec: Add support for tunnel 'local_ip'. 03ee7466ca ovs-monitor-ipsec: Suppress "unknown %d argument" warning. d371c42bbb ovs-monitor-ipsec: Fix _nss_clear_database() parse error. ff48c43a59 ovs-ctl: Don't overwrite external-id hostname.- Merging upstream branch-2.13 [RH git: 2cfb47639f] Commit list: 7312222306 odp-util: Fix netlink message overflow with userdata. b3c09431ad NEWS: Move '--offload-stats' entry to correct release. 7c24762d3e ovsdb-tool: Fix datum leak in the show-log command. a47647c6ec ofproto-dpif-xlate: Stop forwarding MLD reports to group ports. 82093f97c5 github: Fix Ubuntu package installation. 56b81e3ee7 jsonrpc: Avoid disconnecting prematurely due to long poll intervals.- Merging upstream branch-2.13 [RH git: 350e017b66] Commit list: aacf05c5b8 ovsdb-idl: Fix expected condition seqno when changes are pending. db74cd6f4b ovsdb-cluster.at: Fix infinite loop in torture tests.- Merging upstream branch-2.13 [RH git: ece49fb665] Commit list: cdf4cf4966 lib/tc: fix parse act pedit for tos rewrite- Merging upstream branch-2.13 [RH git: 3e10785905] Commit list: ac5c067937 ovsdb-idl: Fix use-after-free when deleting orphaned rows. 60607ba779 ovsdb-idl: Fix memleak when deleting orphan rows. 08c8a29bf4 ovsdb-idl: Fix memleak when reinserting tracked orphan rows.- Merging upstream branch-2.13 [RH git: 773fc1e75b] Commit list: d853716dcb python: Update build system to ensure dirs.py is created. 9ada310291 python: set ovs.dirs variables with build system values 9342d27a26 datapath: ovs_ct_exit to be done under ovs_lock d93d9181f5 compat: rcu: Add support for consolidated-RCU reader checking 505b916b03 ovsdb-idl: Fix iteration over tracked rows with no actual data. 1eb6abd6fc Handle refTable values with setkey() feec8e6888 tests: Add overflow test for the sha1 library. b5a39a7d7f travis: Remove support for Travis CI. db5e2bdd3b github: Add GitHub Actions workflow. 3ff5e400bd ci: Don't use 'native' machine for DPDK cache.- Fix building OVS on ppc64le and armv7hl with Python 3.9 [RH git: a6928f88b2] Python 3.9 changed the architecture naming in suffix used for binary extensions. Use python3-config --extension-suffix in order to figure out the correct extension suffix used for binary extensions. This is not, currently, an issue on RHEL8, but it'll be an issue on RHEL9 and it's an issue on Fedora Rawhide.- redhat: Enable ipsec support [RH git: 2c7306b51f] (#1782141) Resolves: #1782141- Merging upstream branch-2.13 [RH git: 2aae181525] Commit list: abe7fe4486 ovsdb-idl: Return correct seqno from ovsdb_idl_db_set_condition(). 03c12fe076 ovsdb-idl: Fix *_is_new() IDL functions. 1b73731eef ovsdb-idl.at: Return stream open_block python tests. b876447179 compat: Fix compile warning. cb874fa2f2 compat: Remove stale code. 6c5cd45051 tests: Add parse-flow tests for MPLS fields. fa59781826 ofp-actions: Fix userspace support for mpls_ttl. cdf2cf98e3 python: Don't raise an Exception on failure to connect via SSL. 032fd056fe lldp: correctly increase discarded count f051229561 lldp: increase statsTLVsUnrecognizedTotal on unknown TLV 12ffc6118e lldp: fix a buffer overflow when handling management address TLV 46b5101de0 lldp: Fix size of PEEK_DISCARD_UINT32() 364d371c58 lldp: validate a bit more received LLDP frames 3a3c52b8a2 sha1: Fix algorithm for data bigger than 512 megabytes. 8ea7e55eb6 odp-util: Fix overflow of nested netlink attributes.- redhat: Fix conf.db permissions in the spec. [RH git: 46d3617298] Upstream has removed the read permission from the db file because it may incur security concerns, for example, IPsec Pre-shared keys are stored in the db. Fixes: 3e581f43a9 ("ovsdb: Remove read permission of *.db from others.") Signed-off-by: Flavio Leitner - Merging d43d10e10c netdev-offload-dpdk: Preserve HW statistics.. [RH git: a779495d03] Commit list: d43d10e10c netdev-offload-dpdk: Preserve HW statistics for modified flows. 3e581f43a9 ovsdb: Remove read permission of *.db from others. 1440833435 raft: Make backlog thresholds configurable. efc59be2ea raft: Set threshold on backlog for raft connections.- Merging dc5b4e8f69 ovs-bugtool: Fix crash when enable --ovs. [RH git: de7f5508d7] Commit list: dc5b4e8f69 ovs-bugtool: Fix crash when enable --ovs.- Merging upstream branch-2.13 [RH git: 03753de14f] Commit list: 07049d5b66 bugtool: Fix for Python3. 625a6f0f0e raft: Avoid having more than one snapshot in-flight. fc7a644a73 ovsdb-server: Reclaim heap memory after compaction. 49453540d9 raft: Add log length to the memory report.- Merging upstream branch-2.13 [RH git: 373b7e9f51] Commit list: fd29479f04 raft: Report jsonrpc backlog in kilobytes. 7865bc49d3 ovsdb: Add raft memory usage to memory report.- Merging upstream branch-2.13 [RH git: f9a054c1b5] Commit list: 7a69ccf7e4 raft: Avoid annoying debug logs if raft is connected. 3a8897322f raft: Fix error leak on failure while saving snapshot.- Merging upstream branch-2.13 [RH git: 73eb33dcf1] Commit list: 9bd5bf4c3a netdev-tc-offloads: Don't delete ufid mapping if fail to delete filter- Merging upstream branch-2.13 [RH git: 6f80f8c230] Commit list: df3ecbbb6b travis: Fix kernel download retry. 1c9e73f922 Revert "travis: Disable check for array of flexible structures in sparse." 1557ce2673 ofp-ed-props: Fix using uninitialized padding for NSH encap actions.- redhat: Add conflicts for older versioned packages [RH git: b1f563c738] (#1886836) Resolves: #1886836- Merging upstream branch-2.13 [RH git: fa57a21817] Commit list: 75fbada49b travis: Disable check for array of flexible structures in sparse. 12c43c2e64 ovsdb-idl.at: Queue for termination all OVSDB IDL pids. 61e6f03cc3 system-userspace-packet-type-aware.at: Wait for ip address updates. 6d30b86168 dpif-netdev: Fix typo in copyright header. 9400845f88 docs: Add flow control on i40e issue- Merging upstream branch-2.13 [RH git: 38d21cf4eb] Commit list: 3c2b1915d2 ipsec: Fix Strongswan configuration syntax. 610dfdc63d cirrus: Use FreeBSD 11.4. 0cb432954a selinux: Add missing permissions for ovs-kmod-ctl. 9a6d26ea30 netdev-dpdk: Don't set rx mq mode for net_virtio. 183be08223 rhel: Fix reload of OVS_USER_ID on startup. 90443bc5c6 classifier: Fix use of uninitialized value. c38ebe8164 userspace-tso: Document the minimum kernel version. faf6651357 rhel: Fix logrotate group when dpdk is enabled.- Merging upstream branch-2.13 [RH git: 4fbcdeb187] Commit list: 4d6846d4d8 ovsdb-idl.at: Wait all servers to join the cluster.- Merging upstream branch-2.13 [RH git: d5817ddabf] Commit list: ace73aa122 travis: Merge matrix entries. 9eedff62fe ovs-dpctl-top: Skip "eth()" element. 9903c42973 meta-flow: fix a typo in "MPLS Bottom of Stack Field" paragraph. 7f1b52086b python: Fixup python shebangs to python3. 5d1e1c161a test-conntrack: Fix conntrack benchmark by clearing conntrack metadata.- Merging upstream branch-2.13 [RH git: 2fe3a06bff] Commit list: 14c5912a7b travis: Test build of debian packages. 823bea7797 debian: Fix broken build after some man pages became generated from RST 895fc18393 debian: Add python3-sphinx to ovs build dependencies b0e8532d01 debian: Fix package dependencies 0427918d89 connmgr: Support changing openflow versions without restarting. d02892966c ovs-monitor-ipsec: Convert Python2 code to Python3. 8b3fcc65a0 netdev-offload-dpdk: Fix for broken ethernet matching HWOL for XL710NIC.- dpdk: Updated configs to 19.11.3 [RH git: 4e4acaf40a]- Merging 798524b5e3 version: 19.11.3 [RH git: 64c883ec66] (#1868709) Commit list: 798524b5e3 version: 19.11.3 1e5167d97f mem: mark pages as not accessed when freeing memory 4153891ad2 net/mlx5: fix packet length assert in MPRQ 8bec239cff buildtools: get static mlx dependencies for meson 3196e264f7 net/mlx5: fix build with separate glue lib for dlopen f9fde3f8a9 doc: fix reference in ABI guide d455442cac Revert "common/qat: fix GEN3 marketing name" d764b2cd1f test/crypto: fix statistics case b965554c17 eal/ppc: fix bool type after altivec include 9f090f7c97 net/hns3: replace memory barrier with data dependency order 05f23c1a24 net/hns3: add free threshold in Rx 22ae47b85b net/hns3: remove one IO barrier in Rx 7669265b7f net/hns3: reduce judgements of free Tx ring space 4341cd6f0c net/hns3: remove unnecessary assignments in Tx 008d6625ed net/mlx5: fix RSS key copy to TIR context 987ef3cd66 net/ena/base: fix testing for supported hash function 5072ef83e7 net/hns3: fix MSI-X interrupt during initialization 6fdabde3d9 net/hns3: fix Rx interrupt after reset eb23edc7c2 net/hns3: fix Tx interrupt when enabling Rx interrupt 3db4e6aabb net/hns3: fix RSS indirection table configuration 7cfc979bc9 net/hns3: support different numbers of Rx and Tx queues f16148907b net/hns3: support Rx interrupt a4f8b13c12 doc: add NASM installation steps 43e4f20638 doc: fix API index 106dddaf87 doc: prefer https when pointing to dpdk.org 130830b165 doc: fix typo in contributors guide e9aeb99c93 doc: fix typo in contributors guide 029c527ef4 examples/ip_pipeline: remove check of null response 1b2d70662c examples/kni: fix crash during MTU set d9da460ee3 net/ixgbe: check driver type in MACsec API 33189eecd0 net/i40e: fix flow director enabling a6c3bc7236 net/ice: fix setting L2TAG a46186d063 net/iavf: fix setting L2TAG b7a08ea7cd net/i40e: fix setting L2TAG 696a40bd94 net/sfc/base: fix manual filter delete in EF10 bea8e15b59 net/hinic: fix TSO c4d7293707 net/octeontx2: fix buffer size assignment 586faf5a4f net/bnxt: fix Rx ring producer index 1df20ac457 cryptodev: fix SHA-1 digest enum comment 86809db310 doc: fix build with doxygen 1.8.18 121f752786 examples/vm_power: drop Unix path limit redefinition ba5df75ed5 examples/vm_power: fix build with -fno-common 4d1fd43b3a net/mvpp2: fix build with gcc 10 1c2eaf9a98 vhost: fix zero-copy server mode 3ddb8f1d07 net/i40e: fix queue related exception handling 69516f9e3f net/ice: fix RSS for GTPU f956486556 net/i40e: fix wild pointer 3af3834731 examples/kni: fix MTU change to setup Tx queue 4b369799c7 fix same typo in multiple places c85044909a mempool/dpaa2: install missing header with meson fd2cc33835 kvargs: fix strcmp helper documentation 0b45ef6e39 doc: fix typos in ABI policy a7413810b9 pci: reject negative values in PCI id c4d58cd40c pci: accept 32-bit domain numbers 7b732e25df net/ice/base: update copyright 0491724e4a common/iavf: update copyright 75f2750b43 net/i40e/base: update copyright 3c6d1a0269 net/ixgbe/base: update copyright 7c36f2ea8b app/testpmd: fix DCB set 070a7b832d common/mlx5: fix netlink buffer allocation from stack 8fecf8ad1d net/mlx5: fix doorbell bitmap management offsets fc047c800b net/i40e: fix queue region in RSS flow 099b9e280c net/bnxt: fix storing MAC address twice ba15f6288e net/bnxt: fix using RSS config struct 2109b14aa9 net/bnxt: fix error log for command timeout bbcbd194d8 net/qede: fix port reconfiguration f9630f56a4 net/virtio: fix unexpected event after reconnect c651ee6999 vhost: handle mbuf allocation failure 1e2a3beb12 net/hinic: fix Tx mbuf length while copying b191e32975 net/hinic: fix queues resource free 733bc3f639 net/vmxnet3: handle bad host framing a15ee3e4a7 net/mlx5: fix VLAN flow action with wildcard VLAN item 4de7d8bc21 net/qede: fix link state configuration f98d3de913 net/ixgbe: fix statistics in flow control mode 22f701a5d4 common/mlx5: fix umem buffer alignment 348a2c5a9a doc: fix multicast filter feature announcement fc962b01c7 net/e1000: fix port hotplug for multi-process 2e33e6b144 doc: fix build issue in ABI guide da5586fcbe eal: fix C++17 compilation 2d2ba1fb00 doc: fix default symbol binding in ABI guide ef254d821e doc: fix LTO config option f40d9a3cbb build: disable gcc 10 zero-length-bounds warning b02c7838a0 crypto/caam_jr: fix IRQ functions return type 199d2c49a6 crypto/caam_jr: fix check of file descriptors 053c7ff9b5 app/eventdev: check Tx adapter service ID a23ef1c188 event/dsw: fix enqueue burst return value 32b5e80df1 crypto/qat: support plain SHA1..SHA512 hashes 507cda6e23 examples: remove extra new line after link duplex 83e7cafc27 app: remove extra new line after link duplex 40a2233e78 net/mlx5: fix Tx queue release debug log timing ead66a3fb9 net/mlx4: fix drop queue error handling 46cd8f27b1 net/mlx5: fix meter color register consideration 77ca941f9d net/mlx5: fix matching for UDP tunnels with Verbs 23e2c36fa1 net/mlx5: fix match on empty VLAN item in DV mode 425b3ccd2d net/ring: fix device pointer on allocation 39abdde91a net/ice: fix variable initialization 8ec53ab745 Revert "net/bnxt: fix number of TQM ring" ee4518a2de Revert "net/bnxt: fix TQM ring context memory size" 53038c4760 net/ixgbe: fix link state timing on fiber ports 61706cf3f2 bus/fslmc: fix size of qman fq descriptor eeaa4c42b3 net/dpaa2: fix congestion ID for multiple traffic classes a71e30e6b0 net/dpaa2: fix 10G port negotiation ef6d112d7d bus/fslmc: fix dereferencing null pointer f83c2ba6ea app/testpmd: fix memory failure handling for i40e DDP e428b51c18 net/bnxt: fix FW version query dafdf58799 net/virtio: fix crash when device reconnecting abe65fce86 net/bnxt: fix TQM ring context memory size 426e8b5253 net/bnxt: fix number of TQM ring 2befb2f470 net/tap: fix crash in flow destroy 82e2269d01 net/ice: fix crash in switch filter 2e1e12f6a8 net/ice: support mark only action for flow director f05c433b44 net/ixgbe: fix link status synchronization on BSD b639786c5f net/iavf: fix link speed 6c8f2aef2f net/bnxt: fix possible stack smashing 1a476dbabd net/netvsc: do not configure RSS if disabled f815b93c27 net/netvsc: do RSS across Rx queue only bb0fd68c99 bus/vmbus: fix comment spelling 4fe11771a2 net/netvsc: fix comment spelling 024a568578 app/testpmd: fix statistics after reset 556ae6bd83 net/failsafe: fix fd leak 47bd1f0ad2 ipsec: check SAD lookup error 7b842acdfa drivers/crypto: disable gcc 10 no-common errors b64337ffa3 examples/fips_validation: fix parsing of algorithms b168483089 crypto/kasumi: fix extern declaration 0665fb6e09 crypto/qat: fix cipher descriptor for ZUC and SNOW de299dec14 app/crypto-perf: fix display of sample test vector 9b91b991b6 crypto/ccp: fix fd leak on probe failure 6e0bdc2ba1 bbdev: fix doxygen comments abc111ae3d test/flow_classify: enable multi-sockets system a009c7667f event/octeontx2: fix build for O1 optimization 6fc3588de0 net/ena: fix build for O1 optimization c6f6f3d8e1 mempool/octeontx2: fix build for gcc O1 optimization 2cb0536157 examples/eventdev: fix crash on exit fd554a1f8f mem: fix overflow on allocation f0ac3aa2d2 examples/l2fwd-keepalive: fix mbuf pool size deb055888f remove references to private PCI probe function d8aeeb8cfb service: remove rte prefix from static functions 99303c675d service: fix identification of service running on other lcore c4bcf57075 service: fix race condition for MT unsafe service c4c9531648 mk: fix static linkage of mlx dependency d104eb2c03 common/octeontx: fix gcc 9.1 ABI break 9022ffe003 event/dsw: avoid reusing previously recorded events 85c1aae896 eventdev: fix probe and remove for secondary process a309eafc89 event/octeontx2: fix queue removal from Rx adapter 46b7943fda net/mlx5: fix gcc 10 enum-conversion warning 7e01ad84bf net/mlx5: fix VLAN ID check 4fdea813e5 net/mlx5: fix assert in modify converting 831152d0d9 net/mlx5: fix RSS enablement ea6b087b9b net/octeontx: fix dangling pointer on init failure ee263a1371 net/hns3: fix return value when clearing statistics 827eb6ca97 net/hns3: fix VLAN PVID when configuring device 6686131671 net/softnic: fix resource leak for pipeline 60dfeffc23 net/softnic: fix memory leak for thread e399ff6427 net/sfc/base: fix build when EVB is enabled 5862e3fe62 net/sfc/base: use simpler EF10 family run-time checks 68409f9a6c net/sfc/base: use simpler EF10 family conditional check ecd69bfb76 net/mlx5: fix actions validation on root table 58ca518c24 net/mlx5: fix assert in dynamic metadata handling a6ae060e39 vhost: prevent zero-copy with incompatible client mode 5099fb8d59 vhost: fix peer close check fd7ba64cb4 net/mlx5: fix assert in doorbell lookup d6db84d0b1 net/i40e: fix flush of flow director filter a42e979217 doc: add i40e limitation for flow director 74095b0ca6 net/i40e: fix flow director for ARP packets fe42bb4b74 net/bnxt: fix max ring count a131ab7d0f eal/ppc: fix build with gcc 9.3 2acc78a0a1 kvargs: fix invalid token parsing on FreeBSD df17bcb43b eal/x86: ignore gcc 10 stringop-overflow warnings 274dec7548 examples/ipsec-gw: fix gcc 10 maybe-uninitialized warning ea0fb3e5a5 net/avp: fix gcc 10 maybe-uninitialized warning daa2cd115f eal: fix typo in endian conversion macros 9ef2246962 doc: fix log level example in Linux guide aecc7782a6 app/testpmd: add parsing for QinQ VLAN headers 26467e800b net/bnxt: fix VNIC Rx queue count on VNIC free 61c8f03fd4 net/bnxt: fix memory leak during queue restart e09bf2672d bus/pci: fix UIO resource access from secondary process 35348ca71e usertools: check for pci.ids in /usr/share/misc a8e6e27b00 app: fix usage help of options separated by dashes 0d7e4fbf2d fix various typos found by Lintian ccc676944f timer: protect initialization with lock 6be8fba616 eal: fix comments spelling 32688549a0 lpm6: fix comments spelling eee7a4f089 lpm6: fix size of tbl8 group 8426cebb49 mempool: remove inline functions from export list 632fec749f security: fix crash at accessing non-implemented ops 0407d17dae net/bnxt: fix VLAN add when port is stopped a62880c4d4 net/bnxt: fix port start failure handling 6cc939165f net/bnxt: use true/false for bool types 886085974e net/bnxt: fix HWRM command during FW reset c1b7cb6792 net/iavf: fix stats query error code ca2ecc15f2 net/ixgbe: fix link status after port reset 9a673fc544 net/ixgbe: fix resource leak after thread exits normally 4c84ef15a7 net/mlx5: improve logging of MPRQ selection f0a019c950 net/mlx5: set dynamic flow metadata in Rx queues bf10f18c64 net/mlx5: fix header modify action validation da5c4ff51b net/mlx5: fix crash when releasing meter table a9018074d1 common/mlx5: fix build with rdma-core 21 461a2ba67a net/i40e: fix flow director initialisation ac051be918 net/tap: fix queues fd check before close 4c587687f7 net/virtio-user: fix devargs parsing 74a51ef091 vhost: fix shadowed descriptors not flushed 2f48b05305 vhost: fix shadow update d28299df0a net/tap: fix unexpected link handler 8e90f78a02 net/tap: fix fd leak on creation failure 2523e877dc net/tap: fix file close on remove 2b74a885aa net/tap: fix check for mbuf number of segment 2fe4af64f9 net/tap: fix mbuf and mem leak during queue release 908866e6fc net/tap: fix mbuf double free when writev fails ab9701159d net/mlx5: fix validation of push VLAN without full mask d2f4d1ae3d net/mlx5: fix push VLAN action to use item info 1603ade39c net/enic: fix flow action reordering d3c99e41b1 net/mlx5: fix jump table leak 652a21028a net/mlx5: fix meter suffix table leak afca8bc661 net/mlx5: add multi-segment packets in MPRQ mode bbdd1a9c79 net/mlx5: enable MPRQ multi-stride operations a1b3dc84bc net/mlx5: add device parameter for MPRQ stride size 31d1b373d5 net/i40e: relax barrier in Tx for NEON 85897fd567 net/octeontx2: disable unnecessary error interrupts 6075a1ee65 net/octeontx2: enable error and RAS interrupt in configure fd2f1973f4 net/mlx5: use open/read/close for ib stats query 624db5a0ab net/mlx4: fix build with -fno-common b3e01cd3e4 common/mlx5: fix build with -fno-common be0d36b087 net/hns3: fix VLAN filter when setting promisucous mode c6f7d75949 net/hns3: fix default VLAN filter configuration for PF 0bd1d3b49c net/hns3: fix RSS key length c4e9d7e10c net/hns3: add RSS hash offload to capabilities 50daf2acc9 net/hns3: clear residual flow rules on init 1ff55a18be vhost: make IOTLB cache name unique among processes c0c67a2dac vhost: remove unused variable 871773f3ac net/virtio: fix outdated comment 4f5f084c7f net/vhost: fix potential memory leak on close b35cbd50b9 vhost: fix packed ring zero-copy e624761604 vhost/crypto: add missing user protocol flag 11d9847039 net/hinic/base: fix PF firmware hot-active problem f662af80b1 net/null: remove redundant check bfc5290bc8 net/null: fix secondary burst function selection 670758fe8b net/pfe: fix double free of MAC address 175f707d92 app/testpmd: fix PPPoE flow command 03527bd393 net/mlx5: fix counter container usage 2c0c0e4820 net/ena: set IO ring size to valid value 59acd7de4c net/ena/base: fix indentation of multiple defines 3c4bf79460 net/ena/base: fix indentation in CQ polling 3c6ec30057 net/ena/base: fix documentation of functions c6730185e0 net/ena/base: prevent allocation of zero sized memory d5cfa58c05 net/ena/base: make allocation macros thread-safe af84a4f278 net/ice/base: remove unused code in switch rule 5cfef294de net/ice: fix RSS advanced rule 46825a9e59 net/nfp: fix dangling pointer on probe failure d027444df5 net/nfp: fix log format specifiers 61347b53bb examples/vmdq: fix RSS configuration 267e255ef4 ethdev: fix build when vtune profiling is on c6f822199a net/memif: fix resource leak 4f880a2089 net/netvsc: avoid possible live lock 9f54fa3e2b net/netvsc: handle Tx completions based on burst size 62ec946eec net/netvsc: remove process event optimization 81441b4e4f net/netvsc: fix memory free on device close 42916635b3 net/netvsc: split send buffers from Tx descriptors 244193073d net/netvsc: handle Rx packets during multi-channel setup cc1f006253 net/netvsc: propagate descriptor limits from VF 39e690ab3b net/ice: fix input set of VLAN item 175dc210ad net/ice: add action number check for switch 1b23b24565 net/ice: change default tunnel type 8e8fdd68f7 net/octeontx2: fix device configuration sequence 272fcab063 net/octeontx: fix meson build for disabled drivers d50174f38a net/tap: remove unused assert f50974db04 net/ice/base: check memory pointer before copying 3e51abed66 net/ice/base: fix binary order for GTPU filter 7ba59c1fd4 net/mlx5: fix imissed counter overflow e7c5383a09 net/thunderx: use dynamic log type 3e0d3b1204 net/dpaa: use dynamic log type 516f5f9136 net/bnxt: do not use PMD log type 45284045c5 net/pfe: do not use PMD log type 64ca12ff65 net/tap: do not use PMD log type 0bf29e36c3 net/virtio: do not use PMD log type 80e04ea6ae net/mvneta: do not use PMD log type 1b70d8acd0 examples/vmdq: fix output of pools/queues d9a7bf74e1 net/mlx5: fix zero value validation for metadata 5e3859176e net/mlx5: fix call to modify action without init item 24f6ab6d31 net/mlx5: update VLAN and encap actions validation 2491443dce net/mlx5: fix metadata for compressed Rx CQEs c469619b7a net/mlx5: fix validation of VXLAN/VXLAN-GPE specs 4493efb719 net/ixgbe: fix link status inconsistencies 117ecae920 net/ice/base: fix MAC write command d57cbe48b2 net/ice/base: minor fixes b97902938a net/ice/base: read PSM clock frequency from register d1cd22be97 net/ice/base: fix uninitialized stack variables 8081044a6f net/hns3: fix return value of setting VLAN offload 2717e6ab25 net/hns3: fix mailbox opcode data type 70b22c9ed2 net/hns3: fix configuring RSS hash when rules are flushed 7953227c19 net/ipn3ke: use control thread to check link status d57282791c net/hinic/base: fix port start during FW hot update 4710da6ef5 net/hinic: fix LRO 7caa43cc22 net/hns3: fix status after repeated resets 3f9c9bdcb5 net/hns3: fix configuring illegal VLAN PVID b6c05b0781 net/hns3: fix crash when flushing RSS flow rules with FLR 1cd4ab6cf4 net/hns3: fix default error code of command interface e9248b23b3 net/hns3: fix packets offload features flags in Rx ebad6ac59a test: remove redundant macro b54822ff2f security: fix session counter 477f8e08d3 security: fix return types in documentation 4fa404e280 security: fix verification of parameters 48bb740ce1 crypto/openssl: fix out-of-place encryption 8d5349e781 test/crypto: fix flag check 9aa6caeb5a drivers/crypto: fix log type variables for -fno-common 46a37b23ba cryptodev: add asymmetric session-less feature name efd0dea9c8 drivers: fix log type variables for -fno-common 2ef9870118 vfio: fix use after free with multiprocess 5732151922 vfio: fix race condition with sysfs 952892aa67 eal: fix PRNG init with HPET enabled 8eefb8787a doc: fix matrix CSS for recent sphinx da57576513 log: fix level picked with globbing on type register bd5e2ef80a ipsec: fix build dependency on hash lib c4d52beff8 doc: fix sphinx compatibility b0843e5671 event/dsw: remove unnecessary read barrier 09a714399a event/dsw: remove redundant control ring poll b9b72b8815 crypto/nitrox: fix oversized device name b878b432b7 crypto/nitrox: fix CSR register address generation 3b841d16dc baseband/turbo_sw: fix exposed LLR decimals assumption 2193048d87 test/ipsec: fix crash in session destroy 152fadd540 common/qat: fix GEN3 marketing name 196993b705 cryptodev: fix missing device id range checking ca31f0aee2 fib: fix headers for C++ support 1c51807a35 ci: fix telemetry dependency in Travis 39adba3b55 bus/pci: fix devargs on probing again c285902e7b kvargs: fix buffer overflow when parsing list bbf0c2d983 test/kvargs: fix invalid cases check bcdd4476cd test/kvargs: fix to consider empty elements as valid 9aebba7e3d mem: preallocate VA space in no-huge mode 46cd0c98bb eal/freebsd: fix queuing duplicate alarm callbacks 7ad8cd364e test: skip some subtests in no-huge mode 796af72c2d test: load drivers when required 7c8ab0ae70 devtools: fix symbol map change check 4710904861 contigmem: cleanup properly when load fails 6e0c764098 net/mlx5: reduce Tx completion index memory loads 307876a747 net/mlx5: fix CVLAN tag set in IP item translation 7ad364893c net/hinic: allocate IO memory with socket id 75457cff3f net/mlx5: fix zero metadata action 8ea2ea8fe4 net/sfc/base: handle manual and auto filter clashes in EF10 c6ae74f068 net/sfc/base: refactor filter lookup loop in EF10 9e496b76ab net/sfc/base: reject automatic filter creation by users 0e4497208a net/sfc/base: reduce filter priorities to implemented only c239286b98 net/sfc: set priority of created filters to manual 8771074d95 net/sfc: fix promiscuous and allmulticast toggles errors 6c1634ec93 ethdev: fix spelling 7aa0060a2a net/hns3: fix promiscuous mode for PF 32f349234b net/hinic: fix repeating cable log and length check d16cceef30 net/hinic: fix snprintf length of cable info d40bcdfb59 net/memif: fix init when already connected ba2322fb9a build: support MinGW-w64 with Meson 5cdff30419 net/mlx5: fix mask used for IPv6 item validation 7ce629f7f2 net/ice: remove bulk alloc option a42ef6f777 net/sfc: fix Rx queue start failure path 251cb7e722 net/sfc: fix initialization error path 5f0378bb2e net/vmxnet3: fix RSS setting on v4 556cdccab2 net/sfc: fix reported promiscuous/multicast mode 194ca60cde doc: fix number of failsafe sub-devices adf15e37f2 net/ice: remove unnecessary variable 2847184082 net/enetc: fix Rx lock-up aec781c6b1 net/ice: fix hash flow crash 2ce2096092 net/i40e: fix X722 performance 64a38788d1 net/mlx5: fix VLAN PCP item calculation 3e387d591e net/i40e: relax barrier in Tx 2550666028 net/octeontx2: fix link information for loopback port c2e90f337d build: fix linker warnings with clang on Windows 3262e4181c pci: fix build on ppc 5a99c0d994 pci: fix build on FreeBSD 027e022a18 pci: remove unneeded includes in public header file 9ca664d8be telemetry: fix port stats retrieval c20055f471 service: fix crash on exit d0e456e9b1 mem: mark pages as not accessed when reserving VA bcf4069ff2 eal/arm64: fix precise TSC 40a7c85881 eal: fix log message print for regex 2a46dc5951 drivers/crypto: fix build with make 4.3 3425ff8896 drivers: add crypto as dependency for event drivers 25fe1c8b05 examples/qos_sched: fix build with gcc 10 4de659fdc0 examples/eventdev: fix build with gcc 10 84119ecce2 examples/vhost_blk: fix build with gcc 10 5fb297ba3d app/pipeline: fix build with gcc 10 ef348e22a0 test: fix build with gcc 10 295ba7d0c3 crypto/octeontx2: fix build with gcc 10 Resolves: #1868709- Merging upstream branch-2.13 [RH git: 5dddb2d4f8] Commit list: 0047ca3a02 acinclude: Fix build with kernels with prandom* moved to prandom.h. 8a72db60ad faq: Mention Linux kernel versions supported by 2.13.x. 114ff63e3d Documentation: Fix kernel support matrix- Merging upstream branch-2.13 [RH git: bb436c2999] Commit list: 184a58e8b8 ovsdb-server: Replace in-memory DB contents at raft install_snapshot. 727bb3440d Prepare for 2.13.2. 714caaf571 Set release date for 2.13.1. ac51dcac87 odp-util: Clear padding in the nd_extension. eeef00da2f datapath-windows: Update flow key in SET action 37606fb5ca odp-util: Fix clearing match mask if set action is partially unnecessary. 5ad46c9a4d debian: Fixed openvswitch-test package dependency. b3a9dc6e5e dpctl: Fix memory leak in dpctl_dump_flows() cce57c5e0e ovs-router: Fix flushing of local routes. 8d0b409fcc acinclude: Remove libmnl for MLX5 PMD. 217ac490ac dpif-netdev: Avoid deadlock with offloading during PMD thread deletion.- ovsdb-server: Replace in-memory DB contents at raft install_snapshot. [RH git: 9f646ec051] (#1867185) Every time a follower has to install a snapshot received from the leader, it should also replace the data in memory. Right now this only happens when snapshots are installed that also change the schema. This can lead to inconsistent DB data on follower nodes and the snapshot may fail to get applied. Fixes: bda1f6b60588 ("ovsdb-server: Don't disconnect clients after raft install_snapshot.") Acked-by: Han Zhou Signed-off-by: Dumitru Ceara Signed-off-by: Ilya Maximets (cherry picked from commit 184a58e8b892231b44479b612bdfe2529bb04363) Resolves: #1867185- redhat: Add support to custom RPM releases. [RH git: 7eb5b56344] This commit allows the developer to specify a custom release string to be appended to package NVR. If the custom release is 'bz123456', the final release would look like -Y.bz123456.X where Y is the number of changes until the branch was created, and X is the number of changes after that.- pkgtool: Use OVS static version in package NVR. [RH git: a0b572aaa1] The package NVR must coincide with the tarball version.- odp-util: Fix clearing match mask if set action is partially unnecessary. [RH git: 6d85fea8b4] (#1862153) While committing set() actions, commit() could wildcard all the fields that are same in match key and in the set action. This leads to situation where mask after commit could actually contain less bits than it was before. And if set action was partially committed, all the fields that were the same will be cleared out from the matching key resulting in the incorrect (too wide) flow. For example, for the flow that matches on both src and dst mac addresses, if the dst mac is the same and only src should be changed by the set() action, destination address will be wildcarded in the match key and will never be matched, i.e. flows with any destination mac will match, which is not correct. Setting OF rule: in_port=1,dl_src=50:54:00:00:00:09 actions=mod_dl_dst(50:54:00:00:00:0a),output(2) Sending following packets on port 1: 1. eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),eth_type(0x0800) 2. eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0c),eth_type(0x0800) 3. eth(src=50:54:00:00:00:0b,dst=50:54:00:00:00:0c),eth_type(0x0800) Resulted datapath flows: eth(dst=50:54:00:00:00:0c),<...>, actions:set(eth(dst=50:54:00:00:00:0a)),2 eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),<...>, actions:2 The first flow doesn't have any match on source MAC address and the third packet successfully matched on it while it must be dropped. Fix that by updating the match mask with only the new bits set by commit(), but keeping those that were cleared (OR operation). With fix applied, resulted correct flows are: eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0a),<...>, actions:2 eth(src=50:54:00:00:00:09,dst=50:54:00:00:00:0c),<...>, actions:set(eth(dst=50:54:00:00:00:0a)),2 eth(src=50:54:00:00:00:0b),<...>, actions:drop The code before commit dbf4a92800d0 was not able to reduce the mask, it was only possible to expand it to exact match, so it was OK to update original matching mask with the new value in all cases. Fixes: dbf4a92800d0 ("odp-util: Do not rewrite fields with the same values as matched") Reported-at: https://bugzilla.redhat.com/show_bug.cgi?id=1854376 Acked-by: Eli Britstein Tested-by: Adrián Moreno Signed-off-by: Ilya Maximets (cherry picked from commit 37606fb5ca76aef478a51d407aaa06caf7fb9376) Resolves: #1862153- redhat: Clean old changelog entries. [RH git: 6cf8d909e8] Fix the changelog shift caused by use of static references and remove the old entries not relevant to the new tarball. Fixes: 90ac9bd6aa ("redhat: Use static references.")- redhat: Update the documentation. [RH git: c9571d2dad]- redhat: Add merge script. [RH git: 752c59ba74] This script helps to provide a standard commit log.- redhat: Use static references. [RH git: f1025c1515] Add static references because there could be patches after SHA_REF not available in newer tarballs. Therefore, it is only possible to update the references if all previous patches are applied in the new references.- Update DPDK configs to v19.11.2. [RH git: 98e6e9823b]- Merge DPDK tag 'v19.11.2' into fast-datapath-rhel-8 [RH git: 755e86c61a]- Merging upstream branch-2.13 to fast-datapath-rhel-8 [RH git: 735b3f94c2] Commit list: bef407fa7f dpdk: Use DPDK 19.11.2 release. 53e0568753 dpif-netdev: Return error code when no mark available. 99a4564348 dpif-netdev: Add check mark to avoid ovs-vswitchd crash. 22c6148a9a netdev-offload-dpdk: Fix Ethernet matching for type only. 9747d5649b dpif-netdev: Don't use zero flow mark. 39cc59dc91 netdev-linux: Fix broken build on Ubuntu 14.04 ac92cdbc4d odp-execute: Fix length checking while executing check_pkt_len action. 08ad9f6483 odp-util.c: Fix dp_hash execution with slowpath actions. 5351651d37 ctags: Include new annotations to ctags ignore list. d5484cf697 lib/tc: only update the stats for non-empty counter 998475d79f datapath-windows, conntrack: Fix conntrack new state 6dbbf0771e bridge: Fix null dereference on ct_timeout_policy record 3e5991a75e rhel: Fix syntax error when matching version. 59cedd3b35 rhel: Support RHEL 7.8 kernel module rpm build. 78ac2896d1 dpif-netlink: Fix Windows incompatibility when setting new feature 51e9479da6 ovsdb-idl: Avoid inconsistent IDL state with OVSDB_MONITOR_V3. 8ba057d345 ovs-rcu: Avoid flushing callbacks during postponing. b24ff56441 raft: Avoid sending equal snapshots. a33880c6e9 ovsdb: Fix timeout type for wait operation. 7077328846 classifier: Prevent tries vs n_tries race leading to NULL dereference. a29fe0d482 ovsdb-server: Fix schema leak while reading db. 1bb5be5138 compat: Backport ipv6_stub change 71acf83c33 netdev-offload-tc: Re-fetch block ID after probing. 23e3ae7158 netdev-linux: Update LAG in all cases. 85fe081852 ofproto: Fix statistics of removed flow. 6bd9ddc829 metaflow: Fix maskable conntrack orig tuple fields 1600e0040c raft: Disable RAFT jsonrpc inactivity probe. 168beb87ca raft: Fix leak of the incomplete command. da9dc791de compat: Fix ipv6_dst_lookup build error a09e22dbdd system-traffic: Check frozen state handling with TLV map change b267889057 tun_metadata: Fix coredump caused by use-after-free bug d323c5398f cirrus: Force pkg update on FreeBSD. 62cede43ee Revert "ovsdb-idl: Avoid sending redundant conditional monitoring updates" b52877a483 dpif-netdev: Force port reconfiguration to change dynamic_txqs. dc389fd319 netdev-offload-tc: Flush rules on ingress block when init tc flow api e2f6393592 conntrack: Reset ct_state when entering a new zone. 314bd235c1 ofp-actions: Fix memory leak. 1f12a91cf9 ofproto-dpif-xlate: Fix recirculation when in_port is OFPP_CONTROLLER. 8315f3cc98 conntrack: Fix NULL pointer dereference. 89c85b997c dpif-netlink: avoid netlink modify flow put op failed after tc modify flow put op failed. 49db27d213 dpif-netdev: Enter quiescent state after each offloading operation. bf2dcbfe5c pvector: Use acquire-release semantics for size. 443f8e2575 tc: Fix nat port range when offloading ct action d69d4c0537 travis: Disable sindex build in sparse. 25a7e5547f raft: Fix the problem of stuck in candidate role forever. 877618fc83 raft: Fix next_index in install_snapshot reply handling. 3ae90e1899 raft: Avoid busy loop during leader election. adc64ab057 raft: Fix raft_is_connected() when there is no leader yet. f0c8b44c58 ovsdb-server: Don't disconnect clients after raft install_snapshot. 78c8011f58 raft-rpc: Fix message format. f0de491257 ovs-dpctl-top: python3 compatibility 00dd014519 dpif-netdev.at: Fix partial offloading test cases failure. 6f86b10549 userspace TSO: SCTP checksum offload optional. b837d1fdc4 userspace TSO: Include UDP checksum offload. ad550ebc36 netdev-dpdk: vhost: disable unsupported offload features. 3f83220418 docs: Update conntrack established state description dd0293c8b5 conntrack: Fix TCP conntrack state 0aefc0eb8e docs: Update DPDK version table d33cc044f3 Prepare for 2.13.1.- redhat: Rename OVSCI job name. [RH git: a61f1d1095] The OVSCI job's name has been renamed to follow a standard.- redhat: pkgtool: use diff instead of format-patch [RH git: da2129ac82]- bus/pci: fix VF memory access [RH git: 2b22bcd9ad] (#1851169) To fix CVE-2020-12888, the linux vfio-pci module will invalidate mmaps and block MMIO access on disabled memory, it will send a SIGBUS to the application: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=abafbc551fdd When the application opens the vfio PCI device, the vfio-pci module will enable the bus memory space through PCI read/write access. According to the PCIe specification, the 'Memory Space Enable' is always zero for VF: Table 9-13 Command Register Changes Bit Location | PF and VF Register Differences | PF | VF | From Base | Attributes | Attributes -------------+--------------------------------+------------+----------- | Memory Space Enable - Does not | | | apply to VFs. Must be hardwired| Base | 0b 1 | to 0b for VFs. VF Memory Space | | | is controlled by the VF MSE bit| | | in the VF Control register. | | -------------+--------------------------------+------------+----------- Afterwards the vfio-pci will initialize its own virtual PCI config space data ('vconfig') by reading the VF's physical PCI config space, then the 'Memory Space Enable' bit in vconfig will always be 0b value. This will make the vfio-pci treat the BAR memory space as disabled, and the SIGBUS will be triggered if access these BARs. By investigation, the VF PCI device *passthrough* into the Guest OS by QEMU has the 'Memory Space Enable' with 1b value. That's because every PCI driver will start to enable the memory space, and this action will be hooked by vfio-pci virtual PCI read/write to set the 'Memory Space Enable' in vconfig space to 1b. So VF runs in guest OS has 'Mem+', but VF runs in host OS has 'Mem-'. Align with PCI working mode in Guest/QEMU/Host, in DPDK, enable the PCI bus memory space explicitly to avoid access on disabled memory. Fixes: 33604c31354a ("vfio: refactor PCI BAR mapping") Cc: stable@dpdk.org Signed-off-by: Haiyue Wang Acked-by: Anatoly Burakov Tested-by: Harman Kalra Tested-by: David Marchand Tested-by: Thierry Martin (cherry picked from commit 54f3fb127d9c265a5724d193e5c7c6db29fb4150) Resolves: #1851169- raft: Avoid sending equal snapshots. [RH git: 3168eba559] (#1834838) [ upstream commit 8c2c503bdb0da1ce6044a53d462f905fd4f8acf5 ] Snapshots are huge. In some cases we could receive several outdated append replies from the remote server. This could happen in high scale cases if the remote server is overloaded and not able to process all the raft requests in time. As an action to each outdated append reply we're sending full database snapshot. While remote server is already overloaded those snapshots will stuck in jsonrpc backlog for a long time making it grow up to few GB. Since remote server wasn't able to timely process incoming messages it will likely not able to process snapshots leading to the same situation with low chances to recover. Remote server will likely stuck in 'candidate' state, other servers will grow their memory consumption due to growing jsonrpc backlogs: jsonrpc|INFO|excessive sending backlog, jsonrpc: ssl:192.16.0.3:6644, num of msgs: 3795, backlog: 8838994624. This patch is trying to avoid that situation by avoiding sending of equal snapshot install requests. This helps maintain reasonable memory consumption and allows the cluster to recover on a larger scale. Acked-by: Han Zhou Signed-off-by: Ilya Maximets Related: #1834838 Signed-off-by: Ilya Maximets - ovsdb-server: Fix schema leak while reading db. [RH git: 92a1e56c8a] (#1834838) [ upstream commit 16e3a80cf646f6c53d22ef98599d5aecb8310414 ] parse_txn() function doesn't always take ownership of the 'schema' passed. So, if the schema of the clustered db has same version as the one that already in use, parse_txn() will not use it, resulting with a memory leak: 7,827 (56 direct, 7,771 indirect) bytes in 1 blocks are definitely lost at 0x483BB1A: calloc (vg_replace_malloc.c:762) by 0x44AD02: xcalloc (util.c:121) by 0x40E70E: ovsdb_schema_create (ovsdb.c:41) by 0x40EA6D: ovsdb_schema_from_json (ovsdb.c:217) by 0x415EDD: ovsdb_storage_read (storage.c:280) by 0x408968: read_db (ovsdb-server.c:607) by 0x40733D: main_loop (ovsdb-server.c:227) by 0x40733D: main (ovsdb-server.c:469) While we could put ovsdb_schema_destroy() in a few places inside 'parse_txn()', from the users' point of view it seems better to have a constant argument and just clone the 'schema' if needed. The caller will be responsible for destroying the 'schema' it owns. Fixes: 1b1d2e6daa56 ("ovsdb: Introduce experimental support for clustered databases.") Acked-by: Han Zhou Signed-off-by: Ilya Maximets Related: #1834838 Signed-off-by: Ilya Maximets - ovsdb: Add raft memory usage to memory report. [RH git: fb32a78921] (#1834838) [ upstream commit 3423cd97f88fe6a8de8b649d79fe6ac83bce94d1 ] Memory reports could be found in logs or by calling 'memory/show' appctl command. For ovsdb-server it includes information about db cells, monitor connections with their backlog size, etc. But it doesn't contain any information about memory consumed by raft. Backlogs of raft connections could be insanely large because of snapshot installation requests that simply contains the whole database. In not that healthy clusters where one of ovsdb servers is not able to timely handle all the incoming raft traffic, backlog on a sender's side could cause significant memory consumption issues. Adding new 'raft-connections' and 'raft-backlog' counters to the memory report to better track such conditions. Acked-by: Han Zhou Signed-off-by: Ilya Maximets Related: #1834838 Signed-off-by: Ilya Maximets - netdev-offload-tc: Re-fetch block ID after probing. [RH git: d14e39f81b] It's possible that block_id could changes after the probe for block support. Therefore, fetch the block_id again after the probe. Fixes: edc2055a2bf7 ("netdev-offload-tc: Flush rules on ingress block when init tc flow api") Cc: Dmytro Linkin Acked-by: Roi Dayan Co-authored-by: Marcelo Leitner Signed-off-by: Marcelo Leitner Signed-off-by: Aaron Conole Signed-off-by: Ilya Maximets - netdev-linux: Update LAG in all cases. [RH git: 8b15547574] In some cases, when processing a netlink change event, it's possible for an alternate part of OvS (like the IPv6 endpoint processing) to hold an active netdev interface. This creates a race-condition, where sometimes the OvS change processing will take the normal path. This doesn't work because the netdev device object won't actually be enslaved to the ovs-system (for instance, a linux bond) and ingress qdisc entries will be missing. To address this, we update the LAG information in ALL cases where LAG information could come in. Fixes: d22f8927c3c9 ("netdev-linux: monitor and offload LAG slaves to TC") Cc: Marcelo Leitner Cc: John Hurley Acked-by: Roi Dayan Signed-off-by: Aaron Conole Signed-off-by: Ilya Maximets - vhost: fix potential fd leak [RH git: a9e6e35814] Vhost will create temporary file when receiving VHOST_USER_GET_INFLIGHT_FD message. Malicious guest can send endless this message to drain out the resource of host. When receiving VHOST_USER_GET_INFLIGHT_FD message repeatedly, closing the file created during the last handling of this message. Fixes: d87f1a1cb7b666550 ("vhost: support inflight info sharing") Cc: stable@dpdk.org This issue has been assigned CVE-2020-10726 Signed-off-by: Xuan Ding Signed-off-by: Xiaolong Ye Reviewed-by: Maxime Coquelin - vhost: fix potential memory space leak [RH git: b39bac1377] A malicious container which has direct access to the vhost-user socket can keep sending VHOST_USER_GET_INFLIGHT_FD messages which may cause leaking resources until resulting a DOS. Fix it by unmapping the dev->inflight_info->addr before assigning new mapped addr to it. Fixes: d87f1a1cb7b6 ("vhost: support inflight info sharing") Cc: stable@dpdk.org This issue has been assigned CVE-2020-10726 Signed-off-by: Xiaolong Ye Reviewed-by: Maxime Coquelin - vhost: fix translated address not checked [RH git: 7da9061642] Malicious guest can construct desc with invalid address and zero buffer length. That will request vhost to check both translated address and translated data length. This patch will add missed address check. Fixes: 75ed51697820 ("vhost: add packed ring batch dequeue") Fixes: ef861692c398 ("vhost: add packed ring batch enqueue") Cc: stable@dpdk.org This issue has been assigned CVE-2020-10725 Signed-off-by: Marvin Liu Reviewed-by: Maxime Coquelin - vhost: fix vring index check [RH git: 7c4cfd12e3] vhost_user_check_and_alloc_queue_pair() is used to extract a vring index from a payload. This function validates the index and is called early on in when performing message handling. Most message handlers depend on it correctly validating the vring index. Depending on the message type the vring index is in different parts of the payload. The function contains a switch/case for each type and copies the index. This is stored in a uint16. This index is then validated. Depending on the message, the source index is an unsigned int. If integer truncation occurs (uint->uint16) the top 16 bits of the index are never validated. When they are used later on (e.g. in vhost_user_set_vring_num() or vhost_user_set_vring_addr()) it can lead to out of bound indexing. The out of bound indexed data gets written to, and hence this can cause memory corruption. This patch fixes this vulnerability by declaring vring index as an unsigned int in vhost_user_check_and_alloc_queue_pair(). Fixes: 160cbc815b41 ("vhost: remove a hack on queue allocation") Cc: stable@dpdk.org This issue has been assigned CVE-2020-10723 Reported-by: Ilja Van Sprundel Signed-off-by: Maxime Coquelin Reviewed-by: Xiaolong Ye Reviewed-by: Ilja Van Sprundel - vhost: check log mmap offset and size overflow [RH git: 517d8488dc] vhost_user_set_log_base() is a message handler that is called to handle the VHOST_USER_SET_LOG_BASE message. Its payload contains a 64 bit size and offset. Both are added up and used as a size when calling mmap(). There is no integer overflow check. If an integer overflow occurs a smaller memory map would be created than requested. Since the returned mapping is mapped as writable and used for logging, a memory corruption could occur. Fixes: fbc4d248b198 ("vhost: fix offset while mmaping log base address") Cc: stable@dpdk.org This issue has been assigned CVE-2020-10722 Reported-by: Ilja Van Sprundel Signed-off-by: Maxime Coquelin Reviewed-by: Xiaolong Ye Reviewed-by: Ilja Van Sprundel - raft: Disable RAFT jsonrpc inactivity probe. [RH git: 3d9b529afb] (#1836308) [ upstream commit 1600e0040caded7eaa9b1f41926f9619d8e0ec8d ] With the scale test of 640 nodes k8s cluster, raft DB nodes' jsonrpc session got closed due to the timeout of default 5 seconds probe. It will cause disturbance of the raft cluster. Since we already have the heartbeat for RAFT, just disable the probe between the servers to avoid the unnecessary jsonrpc inactivity probe. Acked-by: Han Zhou Signed-off-by: Zhen Wang Signed-off-by: Ilya Maximets Resolves: #1836308 Signed-off-by: Dumitru Ceara - raft: Fix leak of the incomplete command. [RH git: 5c38ccd52f] (#1836307) [ upstream commit 168beb87ca63056e8896b09a60031565b7b60728 ] Function raft_command_initiate() returns correctly referenced command instance. 'n_ref' equals 1 for complete commands and 2 for incomplete commands because one more reference is in raft->commands list. raft_handle_execute_command_request__() leaks the reference by not returning pointer anywhere and not unreferencing incomplete commands. 792 bytes in 11 blocks are definitely lost in loss record 258 of 262 at 0x483BB1A: calloc (vg_replace_malloc.c:762) by 0x44BA32: xcalloc (util.c:121) by 0x422E5F: raft_command_create_incomplete (raft.c:2038) by 0x422E5F: raft_command_initiate (raft.c:2061) by 0x428651: raft_handle_execute_command_request__ (raft.c:4161) by 0x428651: raft_handle_execute_command_request (raft.c:4177) by 0x428651: raft_handle_rpc (raft.c:4230) by 0x428651: raft_conn_run (raft.c:1445) by 0x428DEA: raft_run (raft.c:1803) by 0x407392: main_loop (ovsdb-server.c:226) by 0x407392: main (ovsdb-server.c:469) Fixes: 1b1d2e6daa56 ("ovsdb: Introduce experimental support for clustered databases.") Signed-off-by: Ilya Maximets Acked-by: Han Zhou Signed-off-by: William Tu Resolves: #1836307 Signed-off-by: Dumitru Ceara - raft: Fix the problem of stuck in candidate role forever. [RH git: 9c76350e27] (#1836305) [ upstream commit 25a7e5547f1e107db0f032ad269f447c57401531 ] Sometimes a server can stay in candidate role forever, even if the server already see the new leader and handles append-requests normally. However, because of the wrong role, it appears as disconnected from cluster and so the clients are disconnected. This problem happens when 2 servers become candidates in the same term, and one of them is elected as leader in that term. It can be reproduced by the test cases added in this patch. The root cause is that the current implementation only changes role to follower when a bigger term is observed (in raft_receive_term__()). According to the RAFT paper, if another candidate becomes leader with the same term, the candidate should change to follower. This patch fixes it by changing the role to follower when leader is being updated in raft_update_leader(). Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - raft: Fix next_index in install_snapshot reply handling. [RH git: cc3d026992] (#1836305) [ upstream commit 877618fc833273d1e29e012b5e925d51cba80ff5 ] When a leader handles install_snapshot reply, the next_index for the follower should be log_start instead of log_end, because there can be new entries added in leader's log after initiating the install_snapshot procedure. Also, it should send all the accumulated entries to follower in the following append-request message, instead of sending 0 entries, to speed up the converge. Without this fix, there is no functional problem, but it takes uncessary extra rounds of append-requests responsed with "inconsistency" by follower, although finally will be converged. Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - raft: Avoid busy loop during leader election. [RH git: 053b78c8d6] (#1836305) [ upstream commit 3ae90e1899c5a05148ea1870d9bb4ac3c05e3a19 ] When a server doesn't see a leader yet, e.g. during leader re-election, if a transaction comes from a client, it will cause 100% CPU busy loop. With debug log enabled it is like: 2020-02-28T04:04:35.631Z|00059|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00062|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00065|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00068|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00071|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00074|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 2020-02-28T04:04:35.631Z|00077|poll_loop|DBG|wakeup due to 0-ms timeout at ../ovsdb/trigger.c:164 ... The problem is that in ovsdb_trigger_try(), all cluster errors are treated as temporary error and retry immediately. This patch fixes it by introducing 'run_triggers_now', which tells if a retry is needed immediately. When the cluster error is with detail 'not leader', we don't immediately retry, but will wait for the next poll event to trigger the retry. When 'not leader' status changes, there must be a event, i.e. raft RPC that changes the status, so the trigger is guaranteed to be triggered, without busy loop. Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - raft: Fix raft_is_connected() when there is no leader yet. [RH git: e732012d7b] (#1836305) [ upstream commit adc64ab057345f7004c44bf92363b9adda862134 ] If there is never a leader known by the current server, it's status should be "disconnected" to the cluster. Without this patch, when a server in cluster is restarted, before it successfully connecting back to the cluster it will appear as connected, which is wrong. Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - ovsdb-server: Don't disconnect clients after raft install_snapshot. [RH git: 8ff30dfee6] (#1836305) [ upstream commit f0c8b44c5832c36989fad78927407fc14e64ce46 ] When "schema" field is found in read_db(), there can be two cases: 1. There is a schema change in clustered DB and the "schema" is the new one. 2. There is a install_snapshot RPC happened, which caused log compaction on the server and the next log is just the snapshot, which always constains "schema" field, even though the schema hasn't been changed. The current implementation doesn't handle case 2), and always assume the schema is changed hence disconnect all clients of the server. It can cause stability problem when there are big number of clients connected when this happens in a large scale environment. Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - raft-rpc: Fix message format. [RH git: 914d885061] (#1836305) [ upstream commit 78c8011f58daec41ec97440f2e42795699322742 ] Signed-off-by: Han Zhou Signed-off-by: Ben Pfaff Resolves: #1836305 Signed-off-by: Dumitru Ceara - redhat: pkgtool: Use the oldest sha1 [RH git: 4c657a79de] Doing git merge from a branch to another branch the tag:C0FF3E commit is repeated, but the correct one is the oldest one.- Fix building locally on Fedora 32+ [RH git: d1c89e4d99]- Set -fcommon in DPDK CFLAGS [RH git: f8a379e95e] This is needed to build on Fedora 32+- Update DPDK config files for 19.11.1 [RH git: d771330907]- Merge tag 'v19.11.1' into fast-datapath-rhel-8 [RH git: 0b3abfb0e6] dpdk-19.11.1- bugtool: Fix for Python3. [RH git: 71f25b7920] (#1809241) Currently ovs-bugtool tool doesn't start on Python 3. This commit fixes ovs-bugtool to make it works on Python 3. Replaced StringIO.StringIO with io.BytesIO since the script is processing binary data. Reported-at: https://bugzilla.redhat.com/1809241 Reported-by: Flavio Leitner Signed-off-by: Timothy Redaelli Co-authored-by: William Tu Signed-off-by: William Tu (cherry picked from commit 9e6c00bca9af29031d0e160d33174b7ae99b9244)- redhat: Skip NVR check only if building rhel-8 on rhel-7. [RH git: 2b9f32bef2]- redhat: rh-dgit-brew: Skip NVR check in RHEL-7. [RH git: 6280d8d29f] The RPM in RHEL-7 can't parse Supplements tag in the SPEC to get the package NVR. The NVR is used to check if brew is already done. error: line 241: Unknown tag: Supplements: (openvswitch2.13 and network-scripts) error: query of specfile openvswitch2.13.spec failed, can't parse Use --skip-nvr-check to work around the issue.- redhat: pkgtool: Use BZ id from reported-at tag. [RH git: 3ee7ec51b6] Some upstream commits might contain the Reported-at tag pointing to Red Hat bugzilla. In that case, use the BZ id in the package's changelog. Signed-off-by: Flavio Leitner - redhat: ovsci: Schedule the CI job while brew is building. [RH git: 1551e1e70e] The CI will wait for the brew build to complete and this helps to have a single place to monitor and also to record in the CI log the brew build.- redhat: ovsci: Use the correct job name and params. [RH git: 220f32afb2] Jenkins needs to support different use-cases so fix the parameters to be uniform and the job name to allow multiple triggers (formal and non-formal releases processes). Signed-off-by: Flavio Leitner - Add compatibility with RHEL7 git [RH git: 3492995783]- Use the date in UTC [RH git: b53bdb16b8] In order to avoid changing date in changelog cast the date in UTC- ofproto-dpif-xlate: Fix recirculation when in_port is OFPP_CONTROLLER. [RH git: 4ee0f6af9e] (#1775160) [ upstream commit c5a910dd92ecbad24f86b4c59b4ff8105b5149fd ] Recirculation usually requires finding the pre-recirculation input port. Packets sent by the controller, with in_port of OFPP_CONTROLLER or OFPP_NONE, do not have a real input port data structure, only a port number. The code in xlate_lookup_ofproto_() mishandled this case, failing to return the ofproto data structure. This commit fixes the problem and adds a test to guard against regression. Reported-by: Numan Siddique Reported-at: https://mail.openvswitch.org/pipermail/ovs-dev/2020-March/368642.html Tested-by: Numan Siddique Acked-by: Numan Siddique Signed-off-by: Ben Pfaff Resolves: #1775160 Signed-off-by: Numan Siddique - vhost: fix packed virtqueue ready condition [RH git: 0b4e7827b8] (#1812620) [ upstream commit c5a910dd92ecbad24f86b4c59b4ff8105b5149fd ] Consider a virtqueue ready when, apart from the descriptor area, both event suppression areas have been mapped. Fixes: 2d1541e2b6b3 ("vhost: add vring address setup for packed queues") Signed-off-by: Adrian Moreno Reviewed-by: Tiwei Bie Resolves: #1812620- redhat: permit make to fail when pkgtool --gen{spec,patches} exist badly [RH git: 61807f941e]- vhost: protect log address translation in IOTLB update [RH git: 0d4370404f] (#1806599) [ upstream commit 4f37df14c405b754b5e971c75f4f67f4bb5bfdde ] Currently, the log address translation only happens in the vhost-user's translate_ring_addresses(). However, the IOTLB update handler is not checking if it was mapped to re-trigger that translation. Since the log address mapping could fail, check it on iotlb updates. Also, check it on vring_translate() so we do not dirty pages if the logging address is not yet ready. Additionally, properly protect the accesses to the iotlb structures. Fixes: fbda9f145927 ("vhost: translate incoming log address to GPA") Signed-off-by: Adrian Moreno Reviewed-by: Maxime Coquelin Resolves: #1806599 Signed-off-by: Maxime Coquelin   !"#$%&'()*+,-./0123456789:;<=@CFILMNOP2.13.0-153.el8s2.13.0-153.el8s2.13.72.13.72.13.72.13.7intel-ext.hnetronome-ext.hnicira-ext.hopenflow-1.0.hopenflow-1.1.hopenflow-1.2.hopenflow-1.3.hopenflow-1.4.hopenflow-1.5.hopenflow-common.hopenflow.hcompiler.hdynamic-string.hflow.hgeneve.hhmap.hjson.hlist.hmatch.hmeta-flow.hnamemap.hnetdev.hnsh.hofp-actions.hofp-bundle.hofp-connection.hofp-ed-props.hofp-errors.hofp-flow.hofp-group.hofp-ipfix.hofp-match.hofp-meter.hofp-monitor.hofp-msgs.hofp-packet.hofp-parse.hofp-port.hofp-print.hofp-prop.hofp-protocol.hofp-queue.hofp-switch.hofp-table.hofp-util.hofpbuf.hpackets.hpoll-loop.hrconn.hshash.hthread.htoken-bucket.htun-metadata.htype-props.htypes.husdt-probes.hutil.huuid.hvconn.hversion.hvlog.hlibofproto.solibopenvswitch.solibovsdb.solibsflow.solibvtep.solibofproto.pclibopenvswitch.pclibovsdb.pclibsflow.pc/usr/include/openflow//usr/include/openvswitch//usr/lib64//usr/lib64/pkgconfig/-O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions -fstack-protector-strong -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -fasynchronous-unwind-tables -fstack-clash-protectioncpioxz2aarch64-redhat-linux-gnuC source, ASCII textpkgconfig file RRRRRPRPRPRPRutf-86f6dbbb51a03f4ea3e5ae33d77a13d4ae6554342550c12be62ced4d44936d11e?@7zXZ !#,] b2u Q{LRL/5&eZ,=eXuʹ"߆okM103 LxKl4/[ݲ-BE쒀-yһ myMg2~Bl b%3˛y-6)N4VR|1^nw@k(J[=^NxS-WEPWPT&<í,U1a.a+Yo%!1|W>Q31^x.nXh&+kٛ [(F}bѦVo,`h=1̌5Dӗݢy.LO&i}@@Dֻ0 ru79R5Y0m5y1JΉ% 617]"Y>ݨD.C9zT颥—Y\lK^αNM\"Xqz[j nrl&ODH"؄θ*I#W\0sF+3ʛ% bG}0CٱV3ar棖8\NkRҠi:6ƨ`~ Ff hO* g!W̃h[""oz:QcO3蛄r4UkaJKʁOJB]زC8bߪS ]&.xn*t(!BWl: `ـЏ̐%ďerրfgCH=da?#hyԂe(3o5( 28Q&M.Sd`bt y^ S`9|R:O}t]I ;5Л"$[pUN1Ur]eb^C^1 sžFԋcه .'NP`,DWMi[ . 2E@821t:~fwO#uuZP[G snl=gz~COe3!^%HoVK!{=j5s%T ̃Bu!AZ{5ҳChj,:_* HJ&:dSӡ'|P ZۜnSZvShKQh|ձt c}x̨'0(볡.gOܤ~e^wB:$ElnRjlyy0WȈsq[mEdB%b?ϫb3/syHg*QdCsbD);}y%2ǚ!Yj|tZ? {,}<|nl=Q y 7}=7j6|H{qHpx 9t-nXx,wL~%s~Ž=uV vElJ3JA8& tg8dk~#62zɄhXvșꖡ1h_caz?T*I^26&a R{t)̸6m ʶr{r4xi\H SK)Se3$=xGTv2G5KA˖&L菑׻U=51f8&3E`T]ʳ-e8po6VvDeM_U (^u#jQduϩ a>?0;ٛqno!/"kr<坬!b"\ߨ20lPQB=974'ugI XLjG异ճ=vό(m72=[X\\G9/헑Јg%0S \v>ENe YE'Q>Œrpz˸?xBo`4'ھQD*_V6EC[w1󁹵e\ɗ FF]3*Vڏ.d? ΠSc^t9r$˴wgnO_h!q{Z}p %JʤX}K`3B>!Vb6)֨s1$A!j|*M~-Ffbb)_͜f*qH@׼ߢoBABD/B_ CYZn-wj#9ƾEȓQ'ӷҾv:A2bUex|V۾]\ڥRLQuTl^ʤD6GJж ɇ%5xnF~7Β۱r@ V<7{-@>RaTk@!j3Džinxʊ0S/:@?s` L6ģPG( Vj3|Sޓq 8ID[CZ /Op" .J}TAhۣA!sֻ`m5jpTxm]AasBuf:_A᳄gT1{V^%fmǯ=n"JQ0 ٕrz~%~5Fx-Oaq" (%sE"PM_A{X,L.?q߽$me1`ûI@@zHg9.zƆA8Fe6cɥbFnY5-!gFJ9 D }'T,MmP2gT}y$<%dIFOH VYȺG4ձ\ f*L#{J v'8sZ- *1-RX _KDw_&U&;M|`{< 񱥩<:&aY]5vh6,9J\97=EBbg:G3_xHI;f'( g9 Çcrd TfѠ6KE aD9s^!,d.ބy8.xE-.ͭ>=Ej)7Ԛɸ|mӉ>@;"獏/FyIyVuI I 8> b heK[cm :fGrhmtZ{R[ ڰ ޡ;OU kЉ[^ n"gn }>!iʬkg^TbT_x';OI#N/2΢.'-<9+%xp~r>jx)VX zOosoI=ɮhxczW80U9?=CY~Vc,lUXÆ,Nlll&53G%o WKУvl F#X8@εrzL nlT(ˎ0;}詖Ca>_l)wM m=AfD^vy`'4}P g;VmcakI3ԍ LnH Bu7 _ A9SlޮigFJG&xRf,#}Ѽ Qk.N`;f1mceV5ޝ)Eo&)yCd͊Lml./0nC~T4x\ʹqhX~S-j̑5apjq/vpH\1~Q9rQs-'OP9^z!a2q!|k4FwW.0?=NB᠗Ednoc.M_]\/H4ߙEa#% [ \wn>kG&Z65o&&+!R<&GiR_Hl=@X0U@k0_YO_hѡy -mT+#8>tMp'2E5zT9/Ry Y2m$3_!)V:9C7+)œ?~-tx,uVuABQZNedggZDdwT)1Ϯy(P7 yVRD.L_B Sqq2=c -%&a˶$];0 oKZ:c;dW{A8jlS=>N2dɧi8UA5fr+ϙ ~Z$ >aKewpl'/5ۊq:#6ytF,% P˶L.vK<۰ֳ/暗)驴tO؊w'ec3in*|f5Rnfj塹k|K }B-f\]t`3O䌽18?T3 qVS`Ō~bYi=|"4d䔩?5S iZ3z | {j%NMtO<BOnM)z5j֛OW+&v()NXX.k/NxXs8uF w2_CebAqOB^)=8p=? [3/;w Cg]>YVK9W5MWRgY%fY FYWVqf|IpޖL0x.2c! pgr͖b5-`L%aP#51LHiУCj^Ww,vF2%ᨓG!|`47|2>,N"ZjYq8WO(Mh O(sc+ W -w~CPcDhZ{F|ᚐȜQ?*TqAU4 I\.]#dN"lSt |mHUˈ{l6N%13rw|k1,ʓ`(.t2 XaF'qOqumWZ!)9븶B~`64=[hG_D;ږVp͍9y=Akb8tz?Vo)߾_,iD+ϣo<K1amv:ҞfY<ɼ Z+/3k<,12vgnmlm#<:N5m) b$S zxj%xĨ]1#f/Tȍ/7ș&&8spćAꚃUY$^1 |#/Us)>/.I|0b1HIבKtRQCr 0#͞WK;'X-G/~ : 1>OS"G3z riYHWFڒU+BjuGs-wmP;J>iW7+Xffҫqg,syZfǮ4?I`Tǂ})~Va@Z t(۱Zxx~*,">Brˏj}"&1 4 Z7B[Ⱥvu,4#:(i}{fؼۑ CmD Lβgsڑ *fqy1}[-lN7E~d6wvNLf9fGS{`8<,K8< *+$ 40"}23f -R%Hǵ+H=„p AvKPo=Hy~XyMD^MZ?X{:ysY(мf\ O~y P:թ@x[D^$:ܛ]ID/ȃod9q+<.K5kIjL?qʟJڈ-K $&vf̕!6P؜=c \ŚUvJzHU l[\ _XM-OΣ4j^_YmbSlbA2~ cIㄧ!0~4Lgjʰ"kY+ V&s9Q8|b1A$ԇ118IhPe8I@PEhU^\Y`g T` @yT4UPX5dpȡe|Q"+ѻml]]uΓG;F U'꡼ڌc1:.0ڿHȀ{z:qrw&y?>TrۏZ" ?ri4%ŕs9LؼOVE߅ R:ẅ́InS ֔{Qpvtf ]]~lmnpZڬ<,RMx;U2ƫ vR^g}jrHB;9 E +]獣xln_QP{ QLcfS_h͕|K,ac3| qM9z1D)pfK$ezvBy@QŊ6JűYAAge7|&n'P'*Xdne.}NM74O;"Ѥ!iM,uN /p3w!WPv\ }|*]7vع$;"u8+6Da? oY ji5nd83G#lEDb?P3 A=򺰤!Ւ R?FJM}?u* ʋ|2JG<05"_ YF7KN &Lh@h|m*#݂5̟祅?(ِD ;sD4 C+^(>(Lw~ôD0>64n=`AǶaWgI)`t sR:9n|yE^vlja ։Y:6ٱ~#ڪ4\O55@nbуDM$aaٷb,8Zcm>0t5A·ĈsDP6C"JEmnG8+C1~n1t{r͡ы4q$Uglj%%cv%]J .d=f9cg>$C펜Be&$vYZ̥o*?)b7-,gv=lQ[J%mTT[^vG S\S04ȯDED!ir"tÃ"^6BhJB &ތ9x%p쳑z_3l_-w=nCX.&)y7Vʦ}+}ADؐQD?ls„jVaTD>G+hı5P]fJnضy2]LP9i32i>b|HoUE;`Wa'. $;m#yӓ+:$ʣ,wM3e?u10 B#"E97ydUKR4vUcvIs* ĂH9S BA4]`Y /_(Io PPn9thرN%"\7/C93hHW-KV]}DUvKyӭ]'IˎlQZBG}!oV$ tp+-qHȀNPr ZXպQ1r|UtQmQ _zU]m&Rq@NΧ$mq^rfj(cz5\u]ʭUģYPRЛzѽ lkO%?pxDlX6%e Sq%`BEd+U9VܭKqR61//9z֣u'+X<SjI mMFIlVZtzlы9tʌB২dEiOBknR*p6wS>{Gּ5f(|h}uvrpnr+{fa`/dSՂv߇mujrXjFg$_OHTL,^C,4Vv1 P۪~yCQ}i@`/ ~a^}{,[F t%1綘%U,OMz=jq<) 1 m IPˍceӮe]*/`BCD}D<zw_2t(^4FŎA=?]!MB|`Nwj.Ȏy:LoI fzGdAT Y `mןQ#b,x"l2ipϲ<]a{ !hO /{G/Ufrp{k.Ʌ(4 Ad$&#AGSy9(4N-ᆱd*U&h47j]~Vtϰ<)nkynw6y$"[DmB~0sHjUg^G3O(0ήeET#ԋN(,_ݴ z.x6W/9%EʽR7"! FH57ڑ7 s|Mfws5+cس1c|Pi܅(wQ?xDCR@. 7?.1{\R#r;p̴ڴ5gsk">QJ78(ߒ>hč0xͦbZx ئWFΡ3D-.6b?Ǚ1z~Ug-dϜ s$.2( WDD_LӴ~G .->h諨џpU@= 0 Z_%lHZfADΠ]6]n۞sE+'*Y=o6! ձVj%g D9ȝ?G6Rɟc  yIG2TtϜcm8 H8TJ3[әF!B).bH[=v k[*hbdH ;PɨM) esbxbd5CU5C%GG;&{z~㉵{7B%\".b!aHitUQK~:O$/]ߑ S?X+O]éuҀ[B0Clj&֚Z4RwWΡ9lH4,x#/_(Nr[ :yɫ S\B e'i߷ .Ƙvm z$#̉-CJ&CIR3x; =.!\a#C2?*L ʾ#wsB󣑽W0(~ϟ|yB bJ1/[`7J=!M=S"=n8!jI)QA |^K0] "5Am]X+.(Z-c8k-"4*ι`e˥7_[єqw$iKDk8ج2GP;cpEBn_߳s|{pBtw) H08*+tynȕ1g9ѿ4k4?+HE՗.P.2wF0|hcpO,`!ܮ$SWׁܑAb c2+KXr4di_"~T'0OegpVF.FFLP\R$1N\0 EۈLnv+*k$ǂJH2HIe=ew`IX^^/_Q8jEz_sﶦkm:~fKq[]8ȭ 4*?l:e[ïhڒܙ%GagNy-0>эm:^)_W\2Pi㖢ӣwLKlu> 論Yдg‹P Ŗ5lǐFJ|ӝsCq1׿,6?%V2 UtWg΋pZTK#RĞo"lxQӹ5Q>'O8# G񩶘/Bkaz_rI8ޡFSs][o:8H-17xY 'HB .3^c9̧nY(,?=4;РLݹh/\avqxrIs2Ɉ"p^RNS"9hg-2 (j^)]ɏ>i8C *FztIJ7U:V X-,d4.Q1YLMn3r]2dϦ~ xZiXg8JM%?7V0Ni$u‡TUl6fdEeM ;I Pn Ӷ8(b|)#s-61Ħ *Yk$#ǹ^ꡅn#AjH#|)}a;زm>AFs|6ȺigyU+__ɢ^tlr^Epo_ t+czыLS#6n$=Iy(:#^nz8i+9 \)!di\`Lv0UAPJYI׋3%? bNq<$I`R􎿀gOTǘl3.?AC FĨ,0m*p> I9RX,r+\/cXS=["V1Fto|>B\1\SV1#$6gR*2 zS%3^ӯ bw {//[I r۴?sό#hUH&<}e~gw47ezy\,ǺjMY{z 1ϴl:3~ߒڙ`:@_|xw6Y6/ֆ53Y`GEs YGUL@f&k8A &wp,PyPe]iidL vAnʽûyc>i12u/: #Nrу^u7IbGRPı p3n[$RX?헼~WiD S#lg:Ua1-^ fżOK!Q҃AJv q(Q3_bQA6tBM]X'#9J.!d}|ԣ8FY;yYăPw P$a*ɻz5Owx2L|U{,A-1]!hjjW:޶#]u底2zBjLqS%GdH(F%].eB)U+4lw1kBJڠa2-׉wlwM)7dӳ>ʄHb""g#O%W R5ݭ^5Y7 3B΋FyR&.1ށճ9Ljk,4Ƞ^c{!eYOs5(8XQBO‘(ȕyH. 3DžC&>х m.U%ҳ)Y$R~BdAYn,2n珢hGܩ`5XSbj¬CdI+:8ZtUT<3ZU) 0p}!|K}|.zB,\M[NcDlhER@ҵAex;7I޽O cn6uOĽOʅ"VbsTrIDZ+F]=}gvux3:~Պ#81R/*3g3]kALm-嶆ŗg4D#a$Q4Jƛ&N_=2w=9Vm+Λ}eR)2"3vx+bBAwmZ-ptL ڀ(ͽ0 JPZ0@V.T)>?f^iUTsw*|hHL+|τx<ħ0fpT>*V*epRڕ9 ?gyx}ľgN;(N 9"[48)X+h;5GxNH~E'դ[JV&Pwp< x|*J;;krJ8Z] ߏŝ*0Ā Ey;!ےUaIQW.'u(i0{V!=P}ZRݓmTr36k?M"Şxg4uKlRyĄSM =r4^x- EEP2/M.SbYGRscKR1\ b!JSG2oE5px=_@pJElz 9Vm囸tT("pc=ח\ t2#bSD!WџYB}N ;pPgTՏ*nNplpsZ?8F`20J i H ^/vpCSBeѤ@&eQZ #I\~oN/N c6&>RY=@USx|ԕ_W[f{h(yN|ĂfgLEhdyk%tzB@M捎 934~Pg(M~"D.ֈh, ?k|^TL^[нVqO"xʰ#3MIMhdfk '|r )1~Xd1;dom l5(F@#Bp>}qnK5whZB3]~զ;H6%wToW!w]|[;37k&ܷ0[?4Tze;PVRNR^xwt~M"/k1 xN/;U{`kPEqVX(Rd<].~Vk5\Ȫu̟41R:@6cyhq#lSV];RXcE"$.DB*,Ń3H v7|\jƀ 7ԍҚ_`a\'FO]7BH{ߩmo=f$ʬ)ɘ)AJN ^_@HN〦J=?ilZhQ֢A2Mv}U^!M:& >̒ϙImW'I4$QPX6.%43)Ÿi‡Xue K5vWKyͯɾVuUAN̼<+}F},ۛG"cs!Db$L=14/~MᕧO 8 6OS֪NO͆W$Rcnj|e.=b[0C-R,Βpf4E c:1b*IvaO8~jّa>-8+ '%>( h'z5(Ր^&*sFЂQԏV)xPӾjGI`0Ѱ `&ʬ'5lr:KV8TU=oňgy׷9d,*Z+\ !x1}W1uRy AGڸIxoֹ>NEJDEٷnUHU OdzT=>4շ3VCKxh=x><E5:ك&qR]=t&-,hGx!1b7 _('FVXKv󞫘{uV-hwVp'605MkihSV 9bGLXiksdBz3 q&qnHj/Q:0Yu=L._pMZ&Wu0cԣ98Ƴϭx`W]\zGiI@V&iv\~LW="M֛1 gm^Be)n"ה*n<+ I2w!.pxl.HҠ!v\ PV$} nK^hŝc:-SEJx Q,*Rx2^?@p e;!]ڵHnb#nA‚d}Ă!ƪ!nbe Eksy~Zha,-o/E6nH#Z(aeu~?y9= ]y+!i"~0̻&m/4n6esާ+uGu3>g}dvۗ7?mvgȦ+Z.Sa 8`v&?=opR>~ҌM8R6c^ mCcDḯ6HߪR ".m{L3 2SV}i~q?E/}`ІZvI#`,Jvlj-Tص9ouV%??6-Vk, 2ѓm*[8zc<tq }=ϕ0|g[f` TgdOkߋIHSf8h$cw˃%#4. k2ZU)6~`.]%Dʄ$Fr>am\p.xyMboFN' ,GȜ'鎽+2ˋ¼U Z,J1-J#e5QX !TȳyfpIp ocGGkdMH;72 o`-$y빧Vd_%G)U ljz,%ڗ70A 3[e׍`ʆ{[96>| p:~GqKN05N>~My5#'J! ԫ|8q [+ڟ\%s zCՆkxjQz/-x$3M_FO+ ~uhONx*W6dnEq,=79Xg G`y-հ]_A}$ڄ${8֐r>(DVW>nZ (Ĥ5|3e(b<=o^(m 0\ycl6┹WgTŏe]W)w BGi4}fuuҙpgΚRl" C lDQ*c KJ>TH LfUr\sO' ῖ69Di\l $TENLܿ6ij4T^7j;B|j-Bǽ`M؜x\]\;jzR>Gy/#Qb>3oZAkr(Y!L螈y.1;aL!=ƎoTn531˫W Q S*w w%YÛILql5 *OEu"KYJ@71Y;O @D: K{Q!O+J4|Z"ACa)# ZP> EO51`S޸QA\^DӴMOnorzfłt ټ!ݵ'9̒&aj9fA|9BɇMAːd )3/pAG?̙)\ Xz8܂)gOa7(ҡwJOs0A X$]ax8{}p@ u~.]bƲyh)B&y&&8Kp]Io5<" ;,[nUIru%/Eաi :NڇҔBД׃ S9qye"|>*bLRK/)5zvP_{5oE@OW(%JptwрٔuB5X U=Bhm }Rے񐿣?9F  \WyFr% Ӯ\{̓ۥB,xD@xr$`.Z@ NЧÎLLa ?Ju Yhu9NaC= 6 ːJ;NZ4xO֚ I=L((Phw'AÏyz٥Fa !H&Uw"zvdh)6XE7|~\:3zW +:{\y354~sաe zc!,d&/H{Ź69.UFUDp&Dm+ƠXntlѨ2!.&5 UUkTjR|?̻:@HG][q wcO W ҥ%d6Ďf uXL= :5[/ɪ ձ`@R1SGhSYx (=UNOjZxWٮڣ;LJm~! >>55#N HmҶm4o5vyJ:t<u Q=ȩƼ jAEO?|u O\pQNA MM?s-+) pn҉M-vp0o&ŠǮqK'x?48% (9C}ƫRb{s|@7ZJd6rfdJmWjУ<bjҗ7RfGg85{5:uK-+~b lHS_4 #. ;0t@ {(U ePEO-J0̒b@)W m5QeLr 5CrL{XଦGgta[׷@FYy$?r$mĭOF옧)Yysw1x7zmS"JjX d¿' Sv @5TQ|#.ASMk0}=K44"kx¹/IxN \UlŒ{ oRf[ 7Ꝗі; #9&fNP=;Lޤ t7 TM<)0cC+jՅ-o!t{b\pv TIᖭPvA)/Zg8Ew*5ooK~[yлש,+K[i$,<✽N^+-QdAըߒ͚M2l4xF<@ ̕JlSd#zD>(?Z^q:,[9X}m2RK4\.l/8RclP1}!hq6{84Rɦ-Ct–֠( HY3|LT(3r*lnA(;VԨmEcxݚi˟GKpY@kWxU(F\wՀ$IF`)B@|QB]P$f} `sR-/^_(<%Gǻ8WwE޿XE" cP:Ͳa*5lpҵe5y?ӥpt$]i.AU {Q  kp FF**iӻlr ck , (![%ۤ0jKԦ q斓ˮD]0@(,ֹ|ZKZM"id5Hg0Gj8Y\[9DUS”dh\Æo:9gDėEeنʇ~E{.PQlL-tUƆJd FFA_vf 0C"CtI(u7.4 Er/rȜ 5c5'CIk0(z@aH@@Ehi4Eaj3uSQrdE⊤Y!Gs/[B m:CC|Ҥ5":% 1%-G(iZH+l҈@`F̦Ce5y6Cd`(Zs"3hJ/v5R@;9J<w~t+QIeBlc8 ur`8Z:gOW֎vгÝZ _Cz(5rF#*J#):an^jL'm^ij$uOC*|1#h%HCG;ɴ{jVܕsޔ;lX(V9MBж}U>OLx$-oXՄAf4GAo&yL0N|J˂3zONy 8l|W>jş-:S .iQMm.VNio$=M*JLܦj'O:IJ3j R2&'^g~;qBOԦ%.~/9{L "_ֶ͵Tguw"Όٺ_ҨiĎBCݶKz~ ĉٍ2(=S`c%JS>ռUavwM|NDSQ `y3δqHKi&/AX\>t>[[Km4>Hxr oBk7y%Cm;+ ʖ}y.& GQzISޅ|B6SK U~ldO~@␎rEpY#Œ i:Sbtձt Ѓa|&Kwj]A %B~Eu/bl73-ґD, EUOv'G;ퟁ(&F0GfDB=B6ؿ#s 5@<;|ZweuR+w9ħ(f~xL@ V4ȧE1U:c'[xIV!]Wg g]5XЬBDmG ܨ"-!A$i},<=\/%d|%^5H^h zKoAG>wZu/uZ-8 ^s$8X%Xv'%q豘{ VlJ,:6cQ˄}P{atʐީpJ<\> ZH4q%s^ ΈN[:&]m5#wMvGnޅxGdZVw}]Oޜ$ar'Ԟ' rK u꼨%2'h<}k;rW {{ ks/ί5ꕔ o\f!&uJ3v5bi1 1qGxIG'!߳`k16WmKD.C=\ڲ F޺p<Ӏ<3o]F;-`w0 )AtW0)V9j~HЭ:.%?:t$!7D,l?%{Ŏț Hp*%YtjA9a`K(E 9OW NQHeӪWO;uT-Q6`H=88Pvj#`Z(֞ZUQY.sHw ѓGwYG>pRcOh; "z'pԹ Li}FɊ1 5 rQHZ-95X;g ()G$֕pViɢ\l%quAYubsNѻ7)í'-(zkWjiK:1AIC'$bV-n0*((` )l-rIt$5UjW:-ᾀ.pj)dGųPD!`z* L*I*:*ҕIj0Sl!eΖL)˞3Skz .nIPxN 6”ӻ2ﮩl̿7G2X-Aul?\d4 jc+4k̸-S9NinaVH=aă<7R_$MG۴܉L{G,,-ȈB) F-XdC 6?pgEzG8VZP&z0#!@q6IbfP;-Ǩm x% 4v%t>.]=u-h>V\N؎Fm{z;i2$ry/ qȠBl?WwtZ1k62/o3 ,k?-T;[~ӠN=$_ ;/> {g 3qBRTsng̺h^Z7Up8%m nΡ^Ik?f6o]BQ~Jӭ} ܵv=MEliXWkNNk:K$8(W*#>\e=(r _FLvPgO *419V.qvx4D<!6+205gж@O~h sgm]^<3("N)w K;$D=G1ƒM3,N]\\܇n1XǶ#s_ϢRre2V" }x] ẕ_4;#oRǟsťo[pbg`$;쀫~THNL~|kJ]G]gLxӅ 6|1s~&3k]]fcG9 t.:~3MwcwPLBw0j1G6Z~hpdrAmhs^Ϩr?}pWYdrnO%n* M-m L=Ch LLw_0[]VlHmkw;8S^iD9{$RlOf8Q\, ?L`6Gj a9sO;3!HH!vӆ71cǭd== ^cxȼN/їP zyJ9fku1ľu!ޏv̜ˁIYGۺd P2T]XFh|qpDF` i "v*a0 #)VUMSESpqn~ B&6:J#ׅ?LuqÏHcSr6;eJW<>@K#Nz+[_3;uJf?pY9L: zh0~{g\RY|xT_{KIxsӀ(qN9ҹ SZ׻Jpt>+X ŖzJ$0'RT^yi]TW#$9ill\_GC9Y `e ˠ JWbfk 4Ő,IGpu098[:֜)v嚼O +ou\b"dÆ|rMk>R?8ɒ4SbiUc%ci>|ݓh{*y`0sveqYQ C wSQItE>''؏i}DrAlIT*(m\VjYOY k`Զ]M4Af/:A=򻃢|Oم IۂVYٰTʳY- <{. xyLt8mf^2R-=AY`]1k˿"m f(0ka=iC`)m3PlrJ Ҕu?琵@'{\i`pzA:'q`?h_Hep/g CTCa߰MON)E]WhLZTYi5 Da4q wߐ_Bz#cCbce3•?\]wv,9&N&Q;ȭ^v:Cw_T֧moV09'N#)jL -D.|e`sЎ.>bp}RG 8S7d;>e~n]`XbOADIj!gyS*9^UEz #j͡î〴q^vwGeM6lY0h8J#h^LZU'|*{4ܡL3`~j5lᖪb4 u">:u ,G{[>0v.zH˱@Ѩfu_0=r lZ{2WO|\r۝!Zw=F.GTHW_%C%{V!+/X/6ǐ(XG_|tڅV{MKb \4UF]:!<%`D* =:aD@E-x~ qwkTx_ߊe>A$~YC#_ cëMr5[{n缈D`CZpDBMPyI:Hq\x,ι$N^O4V7ǽPRG jugv=uU ol )DS`O6|NSj!O- [CZטiǰbJáq,6xZ:}pub0ytd n6XW~ߛ8"`]\(Qlv /vgθ|6S'xZܽ$SItq-꿌zF= j y?Q $,C:)H\-MPxQ6IcxWbY8o/xxua3&/Gecy?{xWb|׈B"y[6,Y,<_h;?K! *?]%>H+A? !Q\m­ Y%9Kh8P A毀2gKR2-=U>??Jd5X_9ŭ6~݄ec_Օ*; Cȿ?4r񤭋C1d:Ѡ mzlh;2T<V4uR66s~Fš<]|_|ȚLt*GcjGGg\2Ù0+.t ttdSSe}xP@UYg>+*ݫr}z)tR5 :a/z}m1o}qeXn'`A'C0G!"A_|tacšx )u0xg%8C +Ea3b숣ꢯ[ ^^-A fH5Q:/6?_ު`xMy%Z'Sf6+%;*Yn.S`-lZrYnѝPx~ CzK4v""df;V`'@P~8CQAb۽ Czߠ9\ܨjmtj~%n5:SQ\5!.!b6Tg*uvk&'jv9;&[/sz8L@1jC^xFjrc#dV {KY34tK*NƷ#O.U ,|:2o[m쾞pnM>х]-L- +͠XF"VӊFv 'R7ΔCN-qpEXOHwoԝ=ϩgtش9r03,0Jf>vhHe rc[XD<c oBl:1'@Km4'<,^ ۛxI" )" T"[E5ޠ,__}I_+:%nTd^iْJ-ৼKݶlȡaBX ^L"Q)`&V}8@9I$/Udx"c{1K?fظZnb+SW +Tnr=h f݊$Ȅ[Tֶ N ygW]%j;y+lQO}$.hŒ`U_`hه `mdB,nbzEm, ?b*+Vm} Wǣ]u^x/ r>B]f9`c-vjbiۉnyEU}\ 7^ųŜ$(35<6kw $'k'`)TʃP&;Կ.hf)1{f_O[<%nN+ O?0Cs[LFfV92f?=2&Rx=6P#cAvo^; ?E ~Cchď# |ws2^_|V U>zHjli(>L'Irb*If5(&qs&8j2%Hgw\d9۲A΋{4I` 1e.f|3a{L$rn9%Mw'ت$fġ %Zxv.^ԪenB+&g{z~6#,P[煜={G"h&%|?h6P O}P]@C+倌+qcOY_\F<}vފH37ۗ0WHZQC<0Il>oj8j8b/JG*wS%LÈ@S y$*7/ҕv/-ËcV-)'saɣ#砧gy2̷ ,`OӉ57Cl8p,jdW BpBQ?5FJ48#\XM eWm[7( 6TmPiͿT*.kmnøW+"J $n!1t^Lr-J"ŝ[ 7tj,m V-XKvyS)Zn@k&vGyΜ94߹ޢvHDz1S[pDgD*Yd%3^$JxC?Ȝ|0]\ (WxItRpCNug!2r6z}t0_hwR/Ñ$ɏ?Y'BEc-i ͮjķZ 6E~j'lZھsiR >)㶔>ԕ 9$ ~k`K bX-6[[TG<}GR\UϟSU$)|^ȃ`3}xuagNfw1líH'Eң -Ɵ %]oR'TGfؒ8V%C9(a[w荚$~e_?Q m+8/ls3lIoy"YhtF! ޽o>s9*o3^yRNv;Viexֻͻ۸ʫN~EnF z8!.٤p|~_sq!8T+w?<)WIZt%FofըUM<߼T:~jn֬13`zgYQ}N31?#3+>.ﺗ m*™f. g.go-*Cg[[ !z6HzTRP?wΓA3숽FjnEȹZbl9\b S2x |q5/U3jTJ><Ysk&іRLC y?ekwJRlOk ;"&&/i &?vO>5,èwYK nId1"ndQE@R 룇,9E%)N""d_%vr=z+K壇VA uap(;RV-!HEqPXqs㩁[EIWkS%[KxArqP'/\fc?T#(Aͨ9=Gn@[]l5 DA[VF$ڨ&9} We9_͐ca K!N !fu|lVK ƭ}ag?n . CSBU4Wc\¯~{{_Fgi"v ^5<*r.LO /ߊ1Pw&[7jޒ_x܈Mmtئ\| ǀ)= '!StÅj|M'a/ 8!G²uHJ*~N\rj,[?$B^*_H}?})A~8-g0 -3b7qՁ0WdK=Q5P#U_zїk ޓpQStjQ\M'#QZ: #hPKH/TD_u耔dfea|`VBCEABKџ׹uay ^E *4Wx2FvO'k*P4+eY3 }Ϛ. UG \Տ"oY]-@bf}L #Nb?)_X#};/t)ƁHMOꓖ i|-3 @h؄J*F9W@1'.?Pd*y8,y1 H?R/ zX|@ER7 I绢Wu,\aY:7oR(}>^qLfIO*-;k "oJ[滏s%g~Ɂ,mZhwDxIS]T( "@FOՑ_oOߏ܄ ~DJP͢srUX FneT/)$MH9Β~`&fyVT٫~kس˞wk̥ T49O#_1,.3BNi)[c=n=5O-u?Df]}miW'X"7:hu#p>+Tpޤ(聨M*1VI3ЫhOl# \귯Ļ|~p+,M !:־tkb>il30oSw\c*#8!| f~(ܩ ipIaOH5+[+P,No0xB)v8We+8okdžd4 { {/8CmF, U=nv}2 F>w5WHqل +Z)OgDZiȵGql:u >/+b<\}s]Las;oyW%upﴌ,jP2d2؁c#\vû ܩÒHk}Q%qp3v- {B_bu9خ%DT\EzgsCpj>RYypʔ /x&cnNGa_Hqq~!ctU(̀5Y>VkW2 z^H4֪*X8ϳl +aYjSo_~WTtFCC؂;QT(e-d9}v߭Vu/liV]"WWV.]0NG~jV-=@J)|ᡮUB3VU'Ddφ[ &l\FY ޿x]νy5u4B!uheE#@ D{ h8;PSR'rZo1&ak*؊ԂŸ yYwRZ; #zY1d{HqJ ɱV59[Muo^"ӒNXI&'R7PO4ǞGfqh-T- YZ6F 7)X.@< Rx_#*";a0ەt;@+w^a[d n65.1l{~QJ$ &BB~w {l-!<:pDo0]FF*= 3yMَuA\&㤦$ʪd=9+ jH_"X0:GɚczmcY!}:kyx^ZHoV6۔ѾMѲNM4zj /D k"+ F,dvd>xS3 tҢBTYg*0ădQVc-v5m&V I#51݊]F |χjO8B qf5' qG~UR v28wV@ц΋KNv]?Si#O`JejLo)Vi)O_kQ;mhvMX[\#cO3~ekΤYɀ#2APi;Ro#:`DYAz nKb y(:b/~*8#=FjYfF)3 žEgH듔paEc1~Ay =]a5Ґ|mȋE#^<䂥vJymWBch3U8R#/ZKClS-_(vuj;_bo*.'eJ%@<ʾ 0mkr2f!(G{o}caor6YP8M7=3>[<] -5ȿCxG]Hh(sB 3<(EjZfxFF8䳠$4^ 2rE_Z$e]*=9s\YjyO,bI 9P  3Մ,`LBSlE\~94 F^vXYH\%lJw;{U!FpDB+3xz2L3`@6O JRIR<2ٔaAT{ҕu}$Jn4щw0n~=A6V3Rw4%NfF 0w#:H?4Yd܈(730S~Bѷ6*"}#$P)߯x\mPQ}$d>iFkrX\) LZVA7PdeW dCkHXXPyR%Ig&!(XX0Nd`V\բE1t٪o'J:1Xƍ%5oxЁ4wb j ơM3W"#_q|pZ\_MX1 o*_x\?`4mfi!2~^Y9o)&[V1q)&5\T3W~y`X$ydOP~hN'~p#4>amX#mDwy\"qih9ej?0dj F'dgc"*\oѻK&eȞx5 JP|MmP'4m0C8sۅ<~D7q3J'Fwh!@ 1pz*Rz4 Xt4[cEFe?֘Z* 9h=ǘJW|Vu }$4~ȏ)W@F\r%JsT1M^w * Һ-5bCg$QK*2΁%TGS"_>9(Ψn@? *:7F85ԊuR]|9:r;(Bڑ(8f=}RɝUm8@DM<96uN_$stNM^RF,(Icj޲#R}&mf"l-+笜=o+i\vp!׉V,|~!6$} $![E o u4qݸroǵ __5$rHvwut3VtT_AS[|8V|Hxqւ.Pֶ|X^]M81`&݀ !n<|%ȷ zGNkPkF1:X. >I~q6ӅjidNH#1+48ZF#=z{.rp |T) -5wuH#׈߈)K>E0H`j7߹`@rٺjTdγRH~zw0Q ϽݬCZi+5Q򈘶2=;6|b%Glxֽ`zMG$}Z =fHb3!dn ϡjl[`N*(;OtdeZU) |P_le^ N!|e1;du"(6qEkʕFݵ oLfLf%_o0G.L MUnieb $" O3R,%)G7kg5ɼ!o՝{U *[dM?3o!q,9#%[*w6j.~Sp? $!-{l`xxüƙ$:M\>u 4 <xsI;7ݲW 'aWG-s%%[ZHK=sDNՎU&z}K Ey=A,3+}8#[dʥsp΂ru׸;j6^da6'6Jf pvȯe(R-|wL4I>(؟}ĮhUcޠo U1?uvk+Ջ-k͖'2Yg-T1wzyqϗ2K@!du߇_]`p-ȅZ&6L4Mڗ03 (&b ~.@Sf MaY-bL7*!?lq#G.oqJ+կJx&Qi"R?`sɻEN$Ե5yɖC%^JI@ &A'-+ղڨA։_!XvrHB? Xn聗,,ӟC?0FS>*&&9N M8mfx>:_3?٘k1۱r}j=zNT"=E;mN`j0I`9*xY[R6F,f<Y[!3Qr2+" :UL3uo?3 ]v eZ|A'eՌ%0 ˉYEeM,܏Djsa͌ObS$4 %c0޽-Ը>Kϛ{mF3t`"#~5ĸeYg/ bŶ8|*DB}!N΢X=f[l8}r&`[uN\ڄyC,0`Nd?(jcM)Al!{'=ju,_Or&;U!$b}%9+&MU ޔaJ-3t*^}*AֳWCҠ3̴hH `^̖kzn'H) н08Fߩ}{D]SM+] /LgUm7@r՞Th{)W;/ח<CmCc9s} a|,e+u9ږc#ߦ7T >[o_*='\$nl s]uIїG0ꔼ%h|ӄCh'5 W脋vXl>V5Y:t ބt(z'Vz؞h: 엯xhrw]K]8=ƗqW.] O}E &9S{urAN 3eN!PDMQDR|P<2 _3` 啬2VʗBV^j)w/|o6Ɨ'@K;,̹_Q#8e 'YqL`1X9z ]V(q&h;yDrغaջКSY`t _\v OϙtװEYJ3)U|U<+BJ};cQ>0!|w*L vWEjw՜;}gQIBG7Uh+uhR|,|-"Q9[.cn̻h|!!8.O[+ >h?II:he|FX,6Z >!LҸ;MTmkڦpC? c+e CF?aCn 7a;o"qL(11U؂aJFLkLM~1"tfik`Fum;\Ot&A#w Λ*.{?n2Jf(Ϳxf@Ac4g `TǎJ8x]' foKE(yrNʦci6vuOkj?h xixO~0\QϊݺH!+2Q 2A`uw;4 )SZItkW6C73r_?*An1!g# ;jML7*$қ.P.p,|Hq؆@DY7]E b&.̝&*f֭ߴSt0\b_={ LUtw_m@14vQ]ݏ qs떐|#p\uD{pګ>3W6u{U;loFBwSQmg8-QD<“P sJ  7{ ?ܟz&Nl+Xd1]cqQ41#j!nn:PɽW6u3"?;ZmseveÙ7Y~(>.irbLs oPX9`M1јFqIpWNO烔I }8*shc=9O[8]>cf̈[KbJ0!1wf0_݊1LCF@x+>JʓV,o$Ht7X.K_W<:glG:Ht8ӕSQUo|Y 87-;Y'7=@}oP#L'8ŵl"O2Ud$JK/OWT^ YS+}C)I+y!ɰ(fBxm`gCHJjg8545B&!VI&{LB~S· a+דkle{|&{Z<~$K.)i4Yx8rzu=16)VUqlS H֥G%%nU>뾎>ډ96_m&oa4I \'C?c"eZ[%6?X&j(,d >]?()N% XunM`q".$QZyTnWql&SoKW=OIE[h\pAnsf{#D3x&7}xl ӺTt6Xt*4}D(}}tLj6^ +q8շ8;3S)iZH8s1iIA\;ٚ,еc2`ꪈg \ӗ!>L5 mPk G.p~}=t2T]oY!$ JE*J/0EnI{>s3׬ , aPǽ&g@rAL)WHxS2έ eP]R3u@s/{ϣJćI>,bGTa>LVqhW7J65'y;J抈-^ޯj /Tm<:6fA85uDư{ Qnmp?)A—٦\ !Ug7(CyrWwLġ@A6k2bm>!A좸$B GI*@YdF*󢏼Awnz)`hx>/e]Jnn_XɃރH;|F_at: 'v>hf0%`ۊeRԨ/etGk)Qi6aRsEfU!)==T=~43 MpIlm((Yg$K{{FI؁7*!nzn,3G& I?CZ嗮[IlBtZ"ygXF@e(M9nO(a<%>uľ@jaXH$Ag0/i?1;Nf1v3JB8ݘ*Y/yu_AT,gjVWL RPt"[IYbɒ8"݃L3 [?ǑSVVbC;16e4Hx- n"we,m82\ NO]HX@WbpfgK|KVwSHO=e{E.P g? & X{Ypcǯ8#o>Pu 2%:L~CXքԖ録c~'%l)f7Gdss m 櫕2VpGȏD&_, ymb }$& *z]39\QrM'ʳD4~x [Mh ~g-a'_*Q>#ȸ:s*kg{ ͝bJTz COoʶ߽I3NEhaǶ7^}N-\y]E^<\_03gn~~gxyԏ/C4M5SV"$iN:UinT/$|G4?3 {%m=ѯjgM`ۻ4OXe!A2ablͷKTإE3YiMf$qf1ٺYI՚ֱgK{O_a %1$y%A}$ŀE0R^Г1c|%uces'zD?ȓkJ$q:ѯVw{C3XM?h3>U4l}(M!guv=&*ơ~+SuW)a߸Ÿe}L s$mG`#E? uKcjc9U$OGqD 8cEr=92kϥ (U7>ϑyų%?iI?È\-d<YXQQDIta;-ֱZ҃b#Q <Үܒ-vc*ʞ B'< O%3<*%)ȒJzN|˟/4e8Z\:eA|TrDTNJ/ݒ' hZi:"YOv)"LVwj([\ߌ{[h鸵# '\kBeøY+4|?rX!dЏKV(+/qBU;e4bƫ1-~֨\Y̸ îɈ9*,vVwԍ3%5JzQLHs*60DJ^@aDy|0A'FKOx[qk GtV]5fdMHO6r\%0Gz̆⢵6 3yB/ [*]}GQҦF#R6(|={\MJfҷLLZ])^v& ĕkoFׂ1nƙӅ#M߳!PO iQ2&~j}A1> ۰0)Ʈ?ɏ5)+%0 KpQF/zjKQNj!L:Fq$TgK0N͏)8^ Fy):VtzFmU-ڦ4ԁd+ gT[Uo@[b߿2Ynr/Vr} IUhNm&oC{$?/h}qO <_[[L@^]Ŀ.*}+Y~@M">jG/HY;~/ٔYm+gn5E&1uV[}=OcvZlR)ԙ/##31Y3MXP0'#v7 f1p\:FU\o3Z4:R{0Պl˗21uۇP'q_DZ &$C~s#e¥<~jv=#Z3 4["_0[`AV<fkynH- q#ܚbɨX`D(subQGR)FSo_F*GA= ryBbg(4~q!û3CK_oQDyAAgzfg̡V)-GM3ЕQ3S c|Z+R<]8aۡXLMfXЙ?{"+>]z." j[%U{ˮ8[(' `S7RH[@i\25S5Tr3+rE"֞a5hI(˩/QkDҥ jk&'+V1˶]PiUC8jC8#v.[X]4-gzj0QMV9Lu3眉nccdz'a6)Ҁ`G !߇{ XŌ p s}(b?*2A[zg0r ( oE%eѼ\ڋ<HwMsd/"aei.l{gzeDqWO5:|*G I,ƤZۉr #QR)8vR'f2}(h/8:+aùZ!XÉa4 1ҷæK3RwāƝ}]bx!ΧSjlnՎr8#I=(BVxKE1%9W`*R1arݻ,47iE :nPXDrN"Bϻ%0Ӊu8z9y0?' |, Mdt=ub:#m𻷪Uanp)a *[!z $yWN%4p{ 9 >0]>fauH=G v""9, HM-075a݁J X@5|ojF|/2i}?ZhTb_I%Fc7 ZZiGoɓ!юkJyڐ',VA[})R֌. kc"eOw,?B1mEPqd} ^AKolk]T/٧nOڹ0_v,H˗WFXZ|Щ&sw7srU%@;[yx5q/w+ Ӄ͉:y{ f)uT% xĄuI}k7{f_:?6T`6S0s*,+qT?">J'kկ F[,ٯ+sځ*m̵"XŁx+8A8pTuHOn;ȲWctג"nrFC%bbX,NAy Jۙ› qp)uݤ"Z,8/w!YBdˈ̯ϒ$W f1:{ kE酨$)}TJ-NWۯfd# _H#CMtqmRNZ>~ 4Qu=7K"Ҁ6kq;H^I܇l_O:u/[gC*X@hyˎUCnCCjj! />cȲʘsЏ?%ϭ2O#cxXѢ7nF)8[^Ib>-?7Dlb<ӤF|{p1< H) dV/ØROUHr͙G]TP{chLW=Ҽ}țKQKڍQ bT-uze;dnH5V}v`MBQ vꛇq> X:<-!~yt7u{|G@SyV<$Kb>Zz#Jexz&cQIc[2^hÿ'eJ)G 7@v Nƶ'dP+_;(M1mB$WȌ Yܴ!h1lٌz'7E珩uH_ϣ8!%L#mR,m?3jn4f]iP'nha7o-3ibN|;2l8|@ЋoIim}ň;^ObX7v!-GœI"d^CpJvCiGc'_-wө d>y[󲬇zMVK~pR'c v ʗB]?r(wP+64{:≪|؎A\'DF'6i ԗ?[&.M,PWx1wƚ[p7+O\_9+ Vqb '吆Pz`?ث9/F)l7:+UngiEM2և@#a)G^1faM^8{& ؃wGZ]:/=k͎pqL ܻ s3QebpK]9`-)4v~BޑbI1A/L]Nv6L M\aV cR{Zϫ#e&5mzSvc8q^_}ŋ[r'-~mqȾᡳayfbbAIj"NGkVeBq]wk.Tz}M5}{RAA4cWKb`JkAG2J7Bcu}s jFKuDOk|j1&шs!iR,X=\ŴaigAJh鎭C7B,=w.Jy0"k m;6"ϑ`ϒFvS%Su}6)!ESܚl \~>A뙒J=&>*g4鞉np>4jM ׵wX:_o ̓t8)0^x5LxeJ`=߾Ebf1O=A٧; 4 I"-r|z{+Stf  MTP)0FfMum`{F)PvQ_Ko/cb2])OՌX\xޫ`a0Q=1 ,Ezzb95O}u{%'6 h<*W|;UK4"˴(/ScxvdSXNI GX5%9 C&'qh5kIB \FW Si&<+DM۫SW*9zgɡ#PW! ;1M RiC-szv@\TNs΄|6HKwqAlq` jfLH$z "еbVpK ڊ]?fyRזo? o@ƾ _xʃknF8G/FVKk^!$Ba9M3HLvw"Q*A2 ;3@+8JqN^i(N {1CelJwjn$_V`OCxY.iL62P;Zy(ڇ%pڄRZuͦ<GҪ̀IQ :" Cw3B̼ETѷ|γDKprzC5!qcdǁEXPBӡf_G]sޙ!^d#G `ٓ2 ˳hLawׁpu(aOmV$RgpUhVrr{\rgÄKp>`3=XEGDqrB<ێƺjԀ4"W3\߇#jnJO0MLưc8%jݦ/vgV$]ཱིQ0+`ɞrѫ~-c?ɡJ56|х8}QWPKB9 UsdI6􌯜j&2H`̔lOrXMljڦQr+sivtw0y#e s\rqJc/;6L^ ĕ%xc:bc6T$56B:j}o߈ք\Ҟ1̷8 1|-#+LznJU $0'23Z/񅇹j?uH I(B?M[dغYX]Ky%grY(^O9MAeDbz8`y2$:vscBɢUcp]7P ˀٌz / ;$) I vMT-K-;!Rb@׽.R`=,0Qf{( >ILZA<9*lhk yYWNq.ʖ(xPLe_=*8yp).Bfx^4Ѡ/QhqtZ[E֭:O~L]XM1.Y/ahtYn(FǠYcG)i3Ml %Ԯ4xj$| OVv-Eˍ{WApo 8ӱ ~$iyE-@̶;">XF[;5 y +kFT@6q#i;PLҁwOa}cē,h R=b8}9;asç|ݸ<1Ry-=Lñj͎ad݌;i0׵ gLhKOi.T$S$V5BjC7K0 Dv|T7y*pșO1[9itqV6\qČIjN+ Z!nɿ~;C}MG7 D|w°jהoVJ d#ٽSFL aXs] LRV1JqxDl7rDEI\"?GWY7j-L@Is6֤"+, _VV)/0@ffςR y9]TRfepHا GXAG^eaA- |l\Akbl@/_@g5۪`¡4cձ,Hx,i[ oO1?Av`\91OiX|hnf|Jy(qmiNr˹E/غ-ɺ&ZpAAV2G ?5{Uk)x@UO0B.XO .AoQڬ"p&8hcW|.iv;cu nBe?CXLkeiHi:q- =٤^eb&-9dXFZ:+B2UrvݕgRnΓ:ȃOWp/i2hyrksgC=p!Zn1ĺe%9A ȇ xX)V3-^oig z@njv*5%lWWd)p|d˱!z#Z8tQU1GQ^[C*1m&zJE땥c4N,7 v2n`'tݴ&1֗qr.*Jc. ؗW@_ @JpOu( a(r| L:5MBJ }=U_%yg^Dxm?$FSX i"'x#;HW%UkڃZ !sfcvD^W$q9 <~y7*t&Dc![qOHκNaB8bUaK :ݧ1nj!1*k*F1PT "~V#R@XTӠ11 A Zo(d[Y*͹|x aڎPXν>O3{ECU pyz!,Ghˆ3$o*Rk L!Ql(55( 汍8* =jAgZfK/,K'>GlKDؐV8܎6:vN~BD>k.Rm<'4SmB`[fPM5KmR.)"gי`*EXMv=! fUA)95K;v4+ʩ }${p2,1"bf'T^ OHWbBvDx:O͌$i>Q”9mB]+7Xz:#"NX7 }ףux<= @H_(4"bhBM&`TPEC!K8#fT(xdQ蘥8)]^_\ui $m2 &N柳FI+ܐFqZkňo,ʱb@h SI?.hEy921rbXKt^{ XIp }&@\Q2ϋk8\"Xj3DC~|3hE+"|/׻Q=8:V|p~4IS&+y_/:Zc D}>ƃ˿uJ-? "y, }f*3|#DpcI5ң:]~툉'5G #oKO{0EΖ.FS=f6DՔ~ZU?M'u `xQ!`2N k 1_R\zL ő>j~jVnws4q﯂0ӑ d wDC۷LV#7R[Ai!l"U 2Ŋֺd}C#J=`Fnjsn!9>cW> G4b"' nr2[pEzAk[O7R 8unl_jp /M1R@.h:v.~ = Wߙ׎-]m%7 'a3׎s>M]0 ssQ;pY_3MFY|RA ?}Z+W^ t֚%3Q%Mkz߈l٬eJ;o[gqEܞ@V&_;Is']"{n mNvz{nO Ԅm%/֖ۗ{t ћeԚos,h<QK`l^z @om @#Ԁ5beo^{ - J&}Y2tՐZ>Ę!=xG!BqDƣE;UV1CL4ei2=P*5-РE copB_U1҅Ch{4^SUb0:czZu:?kf}xz0HFX_wc#OlsUj|.||gh2Ŧ=$> P衫՛aB:%{PT&({@ېxn^LտI@d)rm|K6C*,z<u:r~ҮdOo3u'Fvn͋ 7'͐bHm}+zGV|k\ϣ@#ñuh݄G^|F/c-VߗFc[G *ټ)%gr! {B L^itS2[@@. s&K>wlnodMUrMk禭dk{%^2aAZilƀE.d_ʹ.q)sG2H\PG&A|8J"yP0DV&/K`l*|2P>T},GO$iD zem iQ@˵HQ}cQR7zє}b^ޙO;Y6"*haՍ1_BkU0 "Ix˃jv+0怅<Ɏ&)!jj/rs =Y% Lb3h/ ɟxIk-a1V0 ٛ.p0zC()cz#{;B)Uٓm21soIBle P;R-Y5t2a.EpV{~79Ny+WjrR16Hi3G2#=sw527򟣿Ջ ewX܄^#fPWSX`B8SG̸g.ܦTBT)_\z GI,+=sala[$>h {u'/ "^p׵z"ckNs0No~ <1lJԤ*Wr8\^Z^ ݅y 6eu oȮu9j޵Z&h=-O( S3oD8yᑀώ8]rI߁J0 ",}[3g&5EvN';Ʃ 69 OJ%vy<dHHn`c'{cR\UyÈA؂`kP=D~TZa.QFJn|]z`z.4K!BBҍ[zx= rz|~Ÿ¨QE< pDHLBڽe n4Ä91@38AsQN8/tg *xqF?ΈJe l E\ \ͯ茢G$Qx[^ Jۈۦ!ilۢ>zjulڤ43u:7 .ˉΜ"b| ,Stl ["?!s("m:WwXp"q&yj}eIS31\V 5x۩6a\rt+4?=1)VsȯƧePPSCW]t#L!2)$KFT1ue&;cV~! Md-H0=l, SӶ^[`6X 'y3L奧WLU19@T.ɳLpؿ! [yKrQH!_Gc~x]A )%DEji@:xKJz6OvD\% ~RUqvSm.C9j>D>Ǿ%y`Nn9s,qX~NZWGp}¥iSHFv,zu~$-.9d`#t0;$Xkte /fWk?C6ۨ">o9Ώ˟OuэSZ)"*@n4Z ˦[cWHdqJNy{uJdȻe?ɝ "!N3RFE;"{Ҭ(9W^// <+W0Hxume+ \jkQ\BXY+%ѡs" R_Wϼ! FާbP]YLJV`pm¹_jypgQn-wΕp Pw~Nht 3.} yN'r3ͪx[W3%egVR~1>@mN𹁳BAR೸'qK=ͽ5iZ a >i%aMշn)EQ .g fOJcC"J\4aLؐŗ|Uyz;XCbzs5 2 mSꏰBkcYz_$|kyN}-Z r^?K%)ٵW iX* wa2_^ &%f=HӠ{: ђ@ =t:a v]!6Ǭ*!8u:GH;SDh/3vϴuE4N_JQ u EϝV#xHd S^ݠ `B?MM ¨ !Bzc0qk6R`}'pOֽ0:zs%n"!2|̚c  Q3s8ӯŦo4B'LKeK۹Wuv'& `LxXz+=,m!2NCA&(ͻY"T"fMi'MT#Ky7ByEFqQvŤ6߁ Oݙ=jdqݍB ߣݏf8{Y<0@_ˉߵ9B+ĸǻoZB.LX\2%:_)}rN$[֍Ņ ro ͇?8B V \IzZHӹ~﵂?t͒&W\=3k}022yGÄʲ# g 0ra,Q0bpa0< A'JJ N/#[]Vt6}SYhQtqBY }Wtt9:fwqĂTA~Eg [Lk]ɷx+-ʁ- z`V7XTz]4Cl5k*Zh}R|Z6@ ޜcgt=.ǎ%*E:g = w . f`Aw2/NےƠ? ׷ xcҍ@w%eR@v1&5s>Dvk㑚g푑P3?Hkax8ꗼ@A$8Z@3||ϜƧۊM#k1uY&߫ VP3 ]jK$X~IJS> N}mfy,-DYE jl6W,Gx|YuG&mK~L휊zu)0L4'R!a$P{g䎫ZVl(_OjUѱs{&eDm耍(zdsO1p4gƫA6D~טٟ9+fp2k&[1D)5Q,f$dC%,0^_FoNJ'ĬvCųn/Cd꥜OB唞t;!,+aӜ|)ГbAlE^gRrܡ\p[[w"v|Y Qe3-/™2DClEO5dSR %KVf#:MN5M)Ixج8Յ-w`$ӂUzīN~ =6\7+Q,RB䪝l[8=oVAGdϧ&VNxb0J!Bm9 m}Q8dM=}_*=4choզ@ ;'h}b:)0O$&VF뎍LE}X4l̿P9oq?Ue8so-ۙA,Ԟ{m46y D(;L-&+-ԼWحoUՋ''O_?L,$^Ku]eb]?vR{׍鸱k NcLMPf[(. WCTWڞCUvo^SR<‡ Iءޫo?[^QQpK>̞mq2Ԍ0/.6{RXl}BUI+ܮ?t!v+s5+-PY&X6#~އ*o&L3׊`׋X(ۨk'p`>{,P$KP-\7Kk$^_.z>ǢEufcԽOk># }vA;|c2)ɪ6Zi|MSZ¹"˩"e򄼽L,-ړfQys>$RH ~?pj)Ҧ{kQ_jFd\hkbRRnsV8:B@͗~ȑ,g}<mD-j_&pM˰anh}&}UiLj3lx$H[) `_|cB X VNyC`hiaUV:jFHHR{lї&>"퀆qA7ٙNDB[@RnR! Fz$@}tGF@xڽqH(dVWɥ\W߯2aH]4 h5^iuEDa+;{A =(<=}n'ص<(V,KCN~Vx9MNQ otgV*T%sM' n/ܜ;LIY!g{`,tƕHV)}P3n۔*BNUַߨؒqr0^[DDx_ʉ$9f(/HnDZ/.^*v <<+rgvGk0 4pCYK7 D.xfx9Ka37@YUKp= مUdw⩛>di$ ^)ٲ-#lxmܱ'9JŶPJkNt&͡†yYmr%ˬ쐖R r9 4 3mR8r- ڴ$aAV-Qp-a_"U|Z5*/5UeFV%{3f&jљ>{7+7sp\Zh$ׅ=NV$+v$T|gnW 8͞pZ[8!;.ِ zZ^ɤf+$Cf$t(Ϗ=f~oP[\/e RpwP,eo.KM:#\N[o9?7!p$$1 8-uVwI0[J,qg6>-3TUTkᖼ_V(ɞhLy(ςcPή*ׄ5Z+lK\zM *yzw9쨪EX8=sR}_WB;o8kf:ˆiP".8qԣ(|'W_xg֭Qjwd[rOuR{eW3GZܭ0YO!ǻ+,Ϯr Ό2p|v+xjUs]M]Ji18*䟕"I_­6PxzWDsҠ2҆ٲ- .8C SN ȵ$}=]jo-dֺ '^&f[s#-ݲ%gFܑ?j(p[ ҎI-<+G2!+劌(>״5JzQ0s{zШ"XHdo^̅n<6'QB<=AtFI;ؙCem1@HKUZw0njH &5*U[ ĎЖ HH19vM+""ym(ؘ gkW t#,`G㸲LRffKCȄߩbVotUAb IC_|+^~'ݲ+.)ĥj>^sD# D9ݑ\'ي*Vn=qI ˉrFc7 X NaݣIŶ. xHAQ9oea[ߩąp6Bj8q֐AU,yYגn)nJMCPɱOh.aƄ8f0u?Q/!=v znBZ T>ZhG]]j/2^AK!.  <*zWb6zSv-~p5m NQ^ܮ/rOcp7K.z"܏UjwB~zB-/*3yy-9I+bD (tj=&^Xjzso6 d_/>p$s]ɇ@JV=~4iBT@ 07I:zɀ;LLd$݌;A9X_•`Mׅ`M +P;:<#"/ЋRvRx |K+BSV`QZ~ä 1쯑=Q=kL%01^Y.8+QZ–PzR 3 Wc+z(-<^^f L=qsG&Cg%V̓ rv.|U d?O.f-i䡪p<1V _S 1j?syQ>PR-3]g{Kx5Jխ:aik{oA>O |kfWZG 6vQfEo8'࿺bf (qץ[uƧZ&-'u{QF-3K-&3r"Sղ|"5+r3Beh|qY} įG,?h%.ij;44D#hΑ<ݣȂy#czH.ԣf5 t>:6pV&C/sܛAH@ }t[ZNdc-U]HAi^ :(~!?%' Q۲ǸcH<n5$ `4~ʳdU[Ƈ'O[F6ʣt48䣐`Z >*]lhꗦlm|P-qxQ : *}cޘ/NBL0WZPq@Uhnb!ԩ1sJEJ~d:%ϓZG\3y)>BW \esy.Pg hqسN[tigS^:Cn`4Թ{mF#%ޑ9cW:xsL3!FxGlz˨ԻAdW <^O٧(n24Hfei#>WZFD'nslY|A;o@u,DSaa\8`Y)+ylaCb܉.KCuv[ٞC0/c$oE"HrbyPcܾZMF%O§&3I%;O-G6D,#Ֆ{`W[&^FZ*VEO&GQŜ6qO`&#յ0_-Hmq6wV'yqJS!|"HFި$2]4`4I/dJR~C!a0pfUa3(==t;@(2N7J pEAX-R9]#(cFuL4mPZ/*_!':;އ{Mzj/#;>1DM,TϾlAN$"鲏&ǩD-4 A/6ˢv!T-L}a.%A/I8dTp$S=+X"AqQ՗Ee~6<{[MKgY*Ml/ak] EBk8+w$){`NfL6ۼöEmKhlIhӢ@8:a\>K%C_9=u(#GG>Z̖F&{?mFxtCmL՞_JLzbK@r?g0D9}-ڋ`}3Hk?кܪB`vQ N~T <郶483Գq8E4GX\A{?BF'GiXz{E9wZ̦zМg؀Cг@Ԭt&$ w -^~XF5h[En_<%?%Lѭm jln/\ K7ł #wi0?0zQ%Ć?c ]VTWifiMJ\"f;isg\AU,y=f\ƃN(a3qwIy>D5 +:*Xx p:gTKٛ"Ev$o`.;ʪjE5@$j9cAhЃvdbaWD6]u(ZDŽ# G@_}T\87 BS1FT<-TɌ};讌&|R :_Ö.::t؂l #ԞGZ]֌{/Q<", ͂ we?nK"&e >Ptυjm1wh@~w&$yڻX ȡw&1>-36WG/za =Rd gz} F1ec3vAn_19͂u~QYj8tX뢶r&;zi8/BB%.qzȻ?j.]&qd4H&`fJkL'W["!-#ЬwjL\S7> [f[pIYVd>d#&?#jSUZXu]L@;AmlOsI5 P0"p7&uv@*-_5iWt$zKLgPASU[Xͽxq{3P|ebi g;d,ʋ+z=Tmu,w&EU5`&/2#j!Ch)U9( q"㖉ʊFړ5AB2 -;VvԠ$yhN~7DR\q`Tq:qK;5ջ7@OHv }>E< FȈ$ݎۃѶpjUj~bb#+ !>yGuVmA4911j JK"jS⭢0>Yjd{M:EEد{Zm~T<,mP>(hzuu˵ЛjB@rX 4Ѡr ߢd|j<'^ȟP9bC5nJ@& @@0G{rviML8Mc.X;R*_ܯ!=s^) 5v8;I=Q@P -iyih &wz8f!A l64a>*,$4|?a%agEVtv9k9AےS?Jt_VƂʾCpA-\i7o"GU9˫30~gww6"+l}Ͳ=[26kq}=x-#?ɣSk5\Z.ӹk"q`bF p\+?0kf7lk@<IH.}XD34qBx*E- KQqr MmT׷CΟ8FT:?{ڞWr?fb5 G _/3q&sU]YLaqon,#Xhy.(^3?,#1dp?amERL= JmAX:B?R=1 ӓx윦4ퟛx)ޫkE1\JV.o}C*Yc΍8)9.B?Ur;͔P,f bb0=jٹGץ۱-l(drr2 XfUf?15!f.ש¥ iP VqA )i[qc/mEtjڋK&}{b2'뢱?])vCzxEdެWwp-CԼmcDͧfl 5Y?DSCG'p[^2-) +z7x}I Wt)nUz%%ČIZjwiP1n)*L{s-*zkCj RaN\@Bo 7?UEԋǢx'0NF}lZc\aEI>uѦ1@_zSf_ kO52r- rΥ#xcE"8f[(M-Mej~B19:h1,9lêdP o{5XzJ9DV[ed[, /_"51a}*(wMS!щ9Z ?9HK> ?z?g^2N/6D7ZŜ̈+d ,kz C\ .OvNB-(]͑8:T βcppN'lXSHbDᢚ$mNMG{6@jN4Ka1u $go/m&T idӑ L\|D̮ٖsk9 ̶ tQl89%%,D6C"G#[]ZGka͏"^X4@'n6c;y$L0kv1 _s9O:K/"MKI'\NyoGVrܧos\9B]v!Ede~݆$,wLkzܺISJGqVg" bOH^Nmw4d{i"᭲FʄA޿FP:hZrrrA]7x{4"*ۜdbZ尩t,%5GkIyRRKZS(r" ͚ /U/2C`'s9&k|{fn*[}:&-%a-.$ k8q7dETͼv"!z>tNUR^s|&6(,D;lFw0X;:?sVH]($3ŤEɞpe|.A=jd{W-=4FMדK)Nu(djώZ,NPbFsTL@˺s8 w`*QDs^& V9 I֙6>Ih"rU-Ȱ yI3~c jz0i{(pY˕)؁BU8q"E5k[s*y6]J^z# 1.= +,*^fBx Fи y| fY%b5mL?Mh5+gqzd(*48*|L){fv0>SFsjꐾ>JO IԦw&4{o90X,xc͈/QR(]Ky!b-ȶ<9'JH,p0)[>Xa0qS}En r?}.]AdIYpep1} a>XRm߸ۇ4yq}=5lJw!/~Z,(-aeuUG:{eU#Տť<QuHUi?QsbAw׀e⹡jaVYh֙_%b3A\ ~lW6k7 ׃~Uݟn8RtBbܕ3sL=eOi0r4JUrKԥ5tZ7 cy[QhM((rJFSWhZɛQ A Z$^5`nsz^.LBD% dxts1߻77PU?׆qA%KoYY]L}1אľp\m&aCطA=(33B u; %pޖ@5 }y<]0fRe}S)L()`=59W2#Yk@ ,l}D}~&јl_k嶌FX3]ݮTSݥn4{N+><µ=ڕKv]&b]ò`On* JFaC s> k2zA4qEp0DRfJw d-1Yӛx'aFx,>h=Qw`Jd,Q(/U!&CU~oЊ?5UGWl*ΊxIϴs˻9+#-b} EX:Fz9gtW+蹸A-B[W?d;H냘C˪c e(.e"#z>8\Ϙ4xUxE(֌$tLİ8ZH金2u37%ˁ1FeN/Rb'r]'QRC ظ,HCg/cgaFT,$*tNޔoZuK}A3f;)c:ag[?;szV x%hgqM~ɩfۓe~UJYf^BQ.͞Aп>cuEwLVȋv~&2+klT!`DHӬXew֭?j UҮ7)wJd_7X;iG;,<ϜM'KQkM/HeSc[Co~"yn@Ǝ:T2m0Iw6]bbr45tKX50PТ !V'Of&/E=:hN wx9<'>fw ({ svjjVw9=`Y::.ds3t:f g:mn[}WJvs,.+t\~O ļyṫ [F;K> Af} R܎qJYϵەez\8qw #_tz%1kq3.<~hwc"^y)͚OO']%.[##ޟgdzDzRdi$~ &hh3`r5B| ԸߙP{_P{it($]]wUI[dop\Nlmi@F&gqbbe0 PQk| rud1J=Yo72l)5vh̫;$M/O8Ń }2cgw鬽/F׮+CL@2{&Idz-&Z0NS0KH}{_CU FCZ%Yo0v/lKU{Nb쉰dM_fj =fjtٌiI9!U1X3YV cɥ<#V޸d4hP,հXjSٟ}taNcmXLE_ٽQ˔ѤHJe|/"t_Fb_cX:%FYOٜh8t;4> s~[aH lEB$~7gG&dGE7p \;U$Q$$3MQd<VPX tkgrXL {ÚOr'# nQ yCɏ5Cr[\l=RQy@!i[O,8ኝ6:_Le87Om?.5By["VeǭPcTJL v ֟ZXV)_R/OLQ (KY>3K# |n= 7>΂a #Zv Ӽ"xrwI\ Qh4(Oؗ=cբMCeTl,p̷w%2JJ? _TDD`S? #Aꩯ7eLRA2Ymtpg BLv.sCiWFʺDs{rldP۽RnD3 h6s8QVO?x \A ?oY&Do-i \./QIq$*oZnKjqg[ukRK!z9eKՓ'ǀ׺ǹ9C:V%:c5DCV tz+HT|WD>Q2~=-^ezBS`\FqHWF6ZE.2F824J2s+ކiĝO*QڸO[h++g88<+?-s_NVjI_ǛQueo[Ln[ pGbkً ԧmG#:~De=)BG$qij潏=012/)`AŦ㌝|nF$xBM@ ;tbSJ06SI)ӣk]'b$AMdCu[hG\jKAr#v^)s"AijV[˩!Y (n1ύ`B.$IL4s|DyS( ׀E}CУlvjI+^bYJRf :En|`9ʈ ؾ l 3:aP$#J׍sT]L-QGo ڀtCC 7} a?> 9hOQK ǖZYFN3ٵKQc'iqpfM%)ԝ)…UGU(l.܍mxOɑ5"It e]Nh@ aˉAUW1'IgCMzo3a:ve !V."ŃWk7K?yOSK>xۓkJx3{jLj*a7lס5Գ'[XƁ/ܩؚßvb8(h#r;)(u%Q?y4 D"0N@ƁZڌYH/4IH; PA; Oq8uxXPq]Gu5}ѭд{6Xw l,?: (D5.A,6[!\wVm5l[9_<\X#s+Q)W+[ ѕ<8[arJxm30.=\24߄f:uġc\*c*FACdqoS5-*\mS &?-k-wF1(ՔcA3\m@LK(oVQক}d*fߥwAʓ_X{FN:lH!LdVU?0"1^W v P=r7!?0+R @>xxk-nU TyƧHs ]vB$Xu5V@q{?Dd <+]EILWg]Nq剬3V,(-nSkT6Щ <'0. 4ZXw1}uArZO)NNPb* {:{T$x$[w-|oN y`qBשffΝC 2gYז9fQͧ]#cp2[&/VEC($J1sq`͢u]xc;c.uKE⮢C6kCtX@Rw{~=)K(ߴxYASTMzr7='b5CE7Mly8,v u]k!R(Vf g\`[j\.JT$NJU=}RL7XO8~v"";du&!In:.+Ŋ; #21x ;^-+[Ĕo"d a=$Z^xm\7xd;enoJ)zg$cht].x"<$,ɺyZ`V7/Kd8| z |9q}RNۊ/(/b HWؐy`L{}ҏv:? )m"D TUD `C;F'b1Da_kP^<%.N6 ~I*_^{ᇓAWm ']%RwHAmCTQA;Zēgz>J<&r" xן4;R/e]x^{n(P?╀0`~`A):bk~n⟩)5}AUIWp,UWY ^H_gܯQ^(}uc{mX@iܬp"7gHWu5wwqd!7Mys:Bt26)~>ဪӇԊ V=ų@kE`AπeJC'N~+x,/Yڗ{- [K۾" 0G\œb];3λ3VZL"M9Ɋ6w\g/=mhJRdmNP3ao!v>^ZI'NCZ~z2iI1s6€b 2_a:7Ke-2)B'v%h}l﷩įmtWJ8>7jΐEpɇƩLd8{9) N~nz/c\I[ٹ(-ruzA{ކe nlfk.9S┸ @p,t)Zdc(jk~"ܿV@%FF%S053(g-=U ;{J:C1 )f=y؟XsRQ4^ךTDw\L򟟸O ܮdm(6BXNcl_lRR(bJ{[:k%62h#a1rYS7%bH4a[|M] Hmx,R9IU!+쵹uCu0-4h% u%J\Jw ڏC DkG3(v+#GI?|· V γ@ċMb?\X PJy΢?U`fQq*&º3*Dx9C!L;l4' GFرBh6uOsh4k- pƐt@9̒~^:N \nMZ@W'985~m #fgg͖0Y7%/Ν3QG>:N * rCO>z b sJ"Gze|zH•j+/&|@(}u_'5r>f1쎡jjVZ6Aś ;|^!N}\ԉ`I/k:/A>c1?>KB{Up|"rZ'"X&AM-uʟ.I5r+%d%WntfXkc|ӕbcŌ-hdԀ6oS RҜ CX#mYGk8-4"`yֹK.~"rǯzff p+ⴽte9w=?@֪jRK0e8!"hNZ|re='\CC"!U*_Q-a;kI A*b)I~e _Ҭj_Nqo=- UCUia$Ҡ /Ob44 &o'Hk5xjoPqM/qe{'-'$mca-`E5 9pENW_V߫D?xv6xzD$Bb 5Y#q*8:Go2yt?iذY!iœXA#t_sC/vK׌C\xb&xiO`֔T櫔L@!9OȒ$"n*Cʳ -Œ7,V׵}Na{ {'@Mt4@v'큨n]/0$kv= ֚YJJD)LxuF]Fo}@rvķ+]/o탫.:7scm)FO3}~oϋs}Ix5B$3V3r$r DtϩR Uf&逯y}uk1sR:DQqK[볔 k~ׂ.nc_%TP 1r^)7M`0" EvOv}C.pH{꽫 HRC|'w.xlcN3qR$qk=ko$W*(kw4&` T<)KHwN3b*N787.2I#'̊&j sKkkGc?.۵5q5(ɜz >`\9RjWyb{xKU]ןZPp6Ot_ rKM:I=UhKg>`zD4,y&m6nʠd{WP!˥z7d赼<\g/03 wY2K' =@\J̵ћ|T83Cm)DIV릓* H4Ȋ j`5i bsV6*pD ]5Lt!ܠ IH+`s"_2d $ u?JIZP`%K5UoKOj 53VO>90:FpMcdhn^( @̭R|>L/)SM!^;1or.F"MvC,aOoǖ2 bcډ;k T;5R%dtIAqgONt*Q J4siɝuS-)E7Q+V`ߴ_9LɧL~v,S^34$%YD8bY|o1j}(auz҃5=SJCƊ01 Eœ<゚V=Klg+ОJ@_)ۖ ҵqYa Ӯܼ:f\WM(DÎ~gAO١:ȑ\D(`^Pl] 6¢9"}ɝYo%ݾ?X"?Z|է(. pĵZ2fU`ٯ bqHFQ`K:"+\ak?NJI+=WD} /Ak l? mV+G($.wSL ;KyqZ塘!A؊~rڿT"^LŐ^]Z $Ik15FjưQ4ioͥd؇zGf> =Em)+…|Gr4`QSI\˻j1<4S>0Oy (223mF&& )Lx8.:Z @!gW]dw{?90f,(3iUf-RK(܆f?|Uw7ڸ0Մآ^R>"/DrI @ޞ̴>w]iī/Tr ?2@6e_HJKa3Y1\Z5YM`vys`ڼ4Kq삇?vDpmY#cqNc*]uigʿe'㹩E(Is|J.^68t|5&5Š{'r“vxpYZS dJ|ڴDIJ;9f܇o+QN7"4_a@莂_%B<'H޺?3Й;94{m\l8> HB )bysf`I72P; ArLz ED"9Ay'L`'0:;,SB@NLm`K_ۼ](`[UZ"FJ럦'MZyl/{+lڳҲ8Sm:W.a@T;Ehiu2k]拱гXU^8\5xZu%o[0. 4x[ b)}[*~e+X,94yZ!VShXDTDb8t1,8kC<p9&8>RP) Pu4mب#O)/&FAo@C]3,JٱF/A(0km/bFuUl>4}AX EP!y`UyC96sF`ݛk0?5 J.g܅ٷV; E$j Gݖl+(a$qa_eIdc(KpE4KOٜKIFșkO73=- ;?|`VcL%ϫ<$qӥ5fQsѷUAE8C?ʌ? HӐH6W31{9oPKHaح/w[/tt*oh"z}Vm7?oV:.萪JTKR;B?n }0/kw?\֤,Va IgGB_w'|ZɐƢ%v]ArwL U+)B4V8KXeĬ$Mvm3ό\{ĝXK͈td۪@ EHo/r;-=n1C[%YO\@;`1nwx^: 50ǒ d*eqI Y]IVL ~Tt Bm2z 4gOJaE!Ix:8mIOka@7x\1qV,wRvɭE܍~(9)@1'#DB?\tF4C61ڬ|$|_.doRci/` *Å}EOD`?zK͕ԉ !ȻDb[X&3%Zm% ~H=@(bJ %"i8pT1 TCm[mI2N '~a"ZM3ΒQ)T6,Aݿ9&W( 0_իKn#n/8U,;I)VDxnEV@3s_="P;/5m˷d셷ɐ*VyT]/3m oo~UÛ?Do oX\cӃ7O]p0WayC,W'n y:\%LX)⧡FNpSDPXl.1k/3TۄpBT\&T/cw%)-KWjs2Yi>47,p~V'8$S>`83 WG[.ZUAr#אO[6޸;s)4V JRI9?X>*I7.(V83QȍεHe"[ Fm$,^`+ OprQ~ր2%vc׫F n;6Il#rT[ Di"E9O{ !T`^ f.Q1fC\k\ g ׸,ׅO[*(xXU&<&~6#0R_Uc+$|ydK}50…BAN'k"`ٕdq0]WՅ} RZcdLY9_0'K;dQk Y"*$)]bxgDqn|\un7贵oߋ QK Bo P c \IapPUtl#olc)s+w*B g.ejMUF ,4m('MG ,CPCq0෸ Z(Hww=83h-H $|B"v%!㒡l& _<,9. X>r|:\|(k99iniN q&>E23(+lD:(~!,*&'/xb)_tA"9@qakj[x3\BajަgrCUa'{Uљ'ԥLGl0]"VW^ veG rm*!;$M9!E:٥ÍW!ܦAĒ6B +]VzD5HO䃻3NR ۘ9V) 7bf4(׫VfֻɿN"K24fS)^Lz 3[ߜzrW( AC]&V8 Rqy΅(<8ʖC@e(~W2$7jbRbY , ٰ@1ë(q$}c.ݫvq'xxDy[%)~'(4S=#ɧE 2QwOlП eR NXi=䯀w j[F!g/REۆ>x)pXŚۼvP K9&uy+?˘~V 24kqM4xG8^eZw\L 4S6$tQMMJyxݰLyB忝ì5_go2.ӦQxːwx s-^N|Cm{fN IdaMQ t {Y+nnmT׬tγGRj#D+.*7t&GҤ rӨwVm-fOu=-+e&&ùJΡ鴥V,d$J8a*gŞƖQ007@SI5ݗ:_&;#LkJ&SdֈkYrKa}<4r/Xs&ຑИOY#% -ϑ.ھ35.K*&oHΟ&i3uyZ)qy$T!Ҷԥ1wUp"VS)V›~.ӶA5Ol*Xw WDz3$lk3Y_Sf4徿S:_<Is(Rͫ7ԀGwW{B'n,,@v*՟@赅.]&bMĢ'ħࡵ5T>5,ňhn[xN Ԑ1@ILzoBtD.We:.v4L^Z-EbBSQ.n%nn -+{G@ѫ +q.bKʠ XؾTz=SXӀ. Lp50](BIV(%@ k"RALqhy,Vcūpǎ *Xk~r@~y*!~uwU-~h3BJ겓Ѩv@|S,*\6$DF;z;77DE! ,!Mڈp̴0nx;lbӎ[+C ST3DgYGPx J+7[NC˻lŖՊwռiT@$מNzka-;l{zX7.℥<& %wƠ_ nh2it3ʊ0oBtA3pav 02ȋpnuw<JTO\iMI.Ru&gInMfoЯ4cJO?pDoSEJ @RFQc9k#1G;P;F2/爹Qvl=d40}A&,BeRv~mbK %$GBס>3`" BF23.?ItKm|g$tZJ,e;ɶ2A'GLQ "[HQSet2;"yߐOTBNMzg`2/]>f4 [0Cl߁ g[ VXdY2ބxY窸ܒ:ܶ/@24A[|Y"U ‡5h'yv(^3Ɔ#b0Ok!?oZel‚' EbGHx =Fu1*_2%:[U\%n2ZlT)Q  w)sm/H9Lh8U2w U;5hN[m7H4򇴆! eնŝK!Xe%mADXb}I\4Y%QsІQK@W )<#p5J{3|:{Q>SwdWu3Q=`a-d s57YR/a+,?;Elibx~ rJ03}xO{B`kppy1Sa9o8l\)ܟۘmTdZ Ү놣=@po1|5s}{$dW*s@CG>2ur9LBw V^2ePѲ?T8l]M};5;մ˯'"Wjn*E- ɯ,@V^]ZmΫ #@ 9^[̧/J(YR *WIDwĉ%WvV(3&9>h9m͟ \zcY8ȫ;Ukn~#\ʃ2)c9=ӇQ̽H 5XQNt#9WP50,K^VXa"Kc_O2ЄřcnݤFf* `'xcJrhxUD2񷗝Z!\ |: ͹*%L‡38SUW`֣&cތʁQ [ItQ_e? i&ij[^M E1E(8g^T2:]QT7'H֑~gX:~VV_n~ǞtWL5#HÕ ?#'{Lf9O2X..j8bu VLo.s2t7Uz$m.+S^#r'4_C]?߅MxgF:1PQO ӭilmAXhÁg5}0vK`u=H&_yfCo#q#e?3΂ڴ^0v"jR>V/HZyhHІcpb J?gf7>nf MGgBCEߛ'QӶ e%41%v8nn4>K*݋߇@`8%}ƚ=le_7T0;@Jy5 -?"?VE X(˷$rm?:<1SI'X2׶0;ĿnH؅?Y]TrY P7,uQj\nd@U k |,SctA+}}?v|(b>&Sr_R1e 5}{@JNr ;m664Mw{dxD5Bf-ȋIF6;t{} YC ]7}Q"mq0ZfRjHʉ-K%tf}S)MJՏANT%[f@qrP-|bjm(TJHihJX:/e;sw-SU(2yJdQ{^Rԝ eM_&kq e_ = b$nj9EDCBv^5>S,<7 ܣ🚐%n}pØj4@ϯ4Bx=R%=N@=vQ \kt~đAQL*^YF!lf\Z}b{Ysу>Xxި[M|JQd 2Nbiᣠ0oRq |lf6пl;h ykSb7Do毎lsa)fDFM`juf"'F]l=|Ǎ@56.!zq5ߣm#q"7鏜ódfL,?5]ԵCW,UO0Aơ@$rV?=(Zu*iH1ENWSIwhc Dg)8MݪicrC\Qp0r1Gg[b"&,RPL΀XtLT'W\?w7ή.| j@ea5`6'N!=Se;n}+Bfe_lI`D^k"9k7c9ΤT}Ve6FK;|BKCP~9( Qj)5dSN*# xqӿk3|h xG2\2U A4=SK.1w )Gr6R:to&VNWzS3",+VF>MGRob btu[b|qlÎ6Z)sK=)cT)Dg4 _QI9F$ɝP3U&؈yp/ر-Ղش!6*įpߐo[-T-#_A ^ص(? p@a55ʜ),bdp\tF~E{> 'sRW)$6\`6 z)ӣeCY] ]| ytq;&K'\nzL_7??fi v(M,m=lʋ=tЊp!VZ|[tRq!#O"7$k<܆r]c8X拇:ڸKvLg^36B *\5T:SIC q%2~v ܏b0gWTn{бr=EC,[dm'%bbjzqg7yJJ8ֿ PF>5vwh3F7dlV՜ia(rI ie}{A3)7f .}E46Rp;H;y$B"pIk!GG"Aki pjr3ȋ,yg{(wZ-Os`w;չzwy/ƸFhX xvXܻ#-un@!|53Ł#f^Z-Mjwpq혵B,o cM=2o9MER ESZp[)Tޟ]g޴8&DMZ6>>d"n^4N^$dW%hv'f/f[}s X|P]/ @Lf]Sr"L,z|a v61hAB~I*ظCvfFkA-e;;@`nJnB#=l%sǟvd+ BnMz;Q>e6*GS Nw/S6Sb+]=n#6c\9wcbA :VͶX,Έ >:ov7VFؖ# od5,,cq#1}4OI =r$! -[LIS)߀٧k=4Kɹ*Չ1Nk4ykWllÛGd{){^+᫛5NhY:;"De{OvJ#: 2y݇3@,V10e{Mܿ%4%ƛ3NmzIFR^.>GFTfuO<:-n;5Z78ձlYFIh{Zc`B1M::,HtU-9\`)w>B0q |؁ǒistйk~*{z&Eja?`Ak+P6}mډ"iɕQ흇9/~N̠U!b Ua/H4j*@>Af`Qch7\dZm!wzޣxc }er 0W e=B T΂([]?n'vSIl5qA'un'x['tTEGs$)ؗ0W[Qۛ\ּӜ J75}2F-؍ooZXme2=Xk]Ү.y+ iW߁O*`I\̈&$d J!~LC ]Hݍpk^$?H[0 l6:J褜gB2bx/Ė|C {W1&) q9sK4dW-]򁍞Da0~zca*~m5ZwR Ft /oUsc#9欈ǒ.uQQHVȲ X h[OL7#|]8Ù>2|}iv@t$B"+!C37bkB0}[*bja ł!Ԣ 7mh*yL=2#YrD4+ z(Om$Fɍ0 3"alwi,#&P4rtMvmM [[]mEKR95TAw/.i jvDT,W-sۦ}0m5|}E@~j5tEP>D|0o"8Tt7Ilrk6iov̦DWKAЗ'/Q3[34G8Me3$  Nmw_.j(E2<Ӌ T# <%Ǜr vBHRftUafvoڝ}J7^;t^>ЏgmXe.Jw Hǿ<ǼC2wQ'vFD :YU !|xVHRI%NE‚_]l+3;DG$@ '`A71b_L]-[}9a=&;— 3a$r{$2exr;S:D x͌{Ld`sP(T_JNyK\C lTǹDM>/x?XUd RUQ#t5շVl-bǛ8NE@( .8\QTJ'UM{> [t~x,km V{bJ(Zj>hm#.m`$eǙI@qMO126GW o3ί93HEJaE{1ѻ5*P ʼnohvTL\D}ga֐tHZv- C_^Z8[\,kNeo@cM1wҞIy*c}kl T'J[-2iɟ(z219/1af%[~IP2Ic79'xIzA:+ӛEGaކM>0 n*s/ U5.{ff-[hYJl(Nոh:#ٳF2TH H%89G\5 yڡ7*ZA*̅i}5Nݪv%=(9$# DIj|{E5%Mqv*?(㴠qT#8櫎)LN9Ƭٳq8fhhɋ!F! jAS"=V5 V쐧".TI 3nA>S]R@m5gV迅yr-q ֪e/}suݏӯ/+_^r 'o3tb%ޔ-,R[(kY+3&:ONAØy?z #|Bv#kKM5~S4ǩN1¢t$:[ vЇVp"x$2pxQ_U}z&,H@H8M-t.N)3des$LaHNChZ=%s-@%'.!|Z©4/lrŠ]Lr85&/z蹃a_t{߿RlVu>楙,B}jtËϽGdƅ۲ӊ@EC݃AXxD>7lԊv{.@KawF!ι#/`d$(@̶E+)d2Uݑ ȺR;3v":goS''ydu;;ټ^Ftp&/R >;a5s#.=6wE 𐠐csL6mCޢX[OL܌m$um! &jJ]줥H{9L{j)32ߚz eۘ\hg9qx~)[p%b`fBޞ5p}/2¥0{P 4c)\-y`=g}gd׺3HA]\pP:|+n/}k!R,@խxa!ЕKjjFn\?N*#Dċ3GvGJhyq[.i"ca{qeD#r=5W\b^ 8.Է}[[:uemM(`Fj%ۋY|JX!v 3!y? :#d'9 /1DzJ?־LЁ1ZJfbc $?N"!ȹaa{ ʥ<Э l|VM}()/R6BnC / 3q?>HZJ@M,[8 e5}z 3J(TYX3Gn\mW]Trh/zyϨJ}W'( KVWC4Z0FeV}R,Ύr[v2GBU8A*v"|.a6 HtP+5kYas <%$?dlڿrt|ZS2ž D+]݆b$!+;ލXͷql(;>P :)l$"u7W|nCA<ޭ:xQ>衎=+bnkvuq,&ЍJ-+i Ebj=*N+~FPRK#Y(dtOʄŻʇu2iׂa4rsʷ\si|h:7:} P1}} խE#ڰZ593_x52G([ M%Ko LGᵷS |{f6%!ux-P'ZV$s 谍}.{(mR-0J 9]tWZbmH+ [uB-oqVll)T1LtM.mn#yaz(`Z_WS8AwdoudzcꛌHZ&"lLF}R ųۈ[Y7V*H3*r?q̱TM%ڪ=#!mrmкskJrv>e2,@!A:$H rՁDu2DSo#2? oStq9K\á&e ɜEU%cAyW{OQ'o VĢ9R(n[Ā: 2Zk"fRWې~j"rgT%!ץBY~o.͂ܣOoGd$Ȋ&6/%.vw61@t|݄iUzMF\)K1&$yV~¹g'1v0Wp"7VUuMIPs{J ǿ_jIFq?fޜ8rpH8^&* ēPXމ q3K 5ʰ2!5]YJ}-ړ60X BKoLkO 4f^Ԍ@L\4t,5(WWIw(x;w2hK&4rAcv.d~;Rl| {m2cSiN diXBW']jAvw4^ܦ,?Æy]7?9#),;Jb.gc~ݨviNQn.>^7N_"F%Ȏ9f?Q;E̕UZ0G 2V[d0F7|d3ȗ`QB`2enK[ ۴-oh4˕o+>i֫(`)i 5sj h'c!mSvc};0\4!w OP@c abrvN"RsŨXAlr1ν.܊yw)I z-R{q\A]X9Qu祓!]7s! fu}kWݾOao@xV{8zJ 1 /mϯ:$+fGd6sMsuMa$ -׫?k[NL6!b>cK/@fֽh%QE΀䱄lZ*!1lWJa$\jC L#<*GٸAdSY{;—u!( ##!8$N0p0/_ ǖbD*LT8F\ѯuсP{q<9'qF?~@"owD6a5='3d8f1~jn#2[;!Fpte[wyr :M; ~#Ә픃\PÕf٣!} .Z+VwwP5@ t*J%n\Թ~" Nby@9¤6wx!N.|q"E9ʨj2Vw`uf]jI?q#sLUIμÅ|(d`asVh}Id;r8M_0`%`^Gu9}.ւ  -*T@ Re%]t䟽pN_OC&[L0֣xF;rj`UpRd0VD-VYy5 k^0O쬜Ĵ^, ڌ@x& L);II٥4(0=W @+rSGk~-{x™3im׳'x5<2I7Z""EpFB9~;ƎաJpIR6r\xK5F0eDށN:D;>M1S9{}Oƥih5~ّSJ2J8QKcY.ٗ*q( Dluܧ GOr( 'k@7sVm(]UIxMkͽJƥa} (NMϰ=TbWC&?r쨲'DQ J ~>MIǢw/Cm'3yj 4IG!~`[ln?SVU@Ɨu 4Z>e"ㅆ/#Z.ɸױTYxxߏnF>RPN" QPV%asj[5i ~0UĨ:w-8T,psua{?*6ke]!phu=$j% ^yeףanuQ~YOSGt%7Z8͗)J8z-t FBjbFSq˜^};ԭRdzAޏamh5`BҮ4s!/{r)A)|8-Y _4qKȮR:oE fwEc/oR T :0Tv!T(ڸ>u7昙p|*q)"bcnb6z@mڇl#͡KTyLKID}δY@m° UٯM o" H=; ~sBJ+#Nhg"cNn%̀{mb]=RK޾vxoss\Dxo.7^㮏uLp/tuY*-t j He4@#_GpAfG\AwO#W.[q)1pbtqK) u_VUq֦_j rmYvYW{?Gj6S>Y, hUH+T&W y+Ve pwZ `فK*vwSX<9:``28h1>zԇwY㟠@%2a sS]SX؀VfIzg:IȜ{W* E u^lE4[7>47Pq%7>E:,qmhH.i}5m`bkv8lr 3pBketOj+kճѝ)\㑲MnD#!.-7?pHdJs BdZnD+ȵtڌ)#ܤ ,Kmofd~#;Sx#QuN6`bmr#=`OYsdUvTMF%WN  r:2.#0N < 0Pp v{_7+Dt9ַ{~ *yYg^u&F qf߂8&mhƂYvMQii;K.M j(W@V,rud'"9jd;m>Sg.4 B%cXR?fsm: +FJ>ms% evUC?Zp仾4ZߠM0w 'LGl4'̵X 9nd!~؇Qu B;Et;]Je$$79h!O5{Ǻ q5 ;pǼZ*fD/ ֹe}2YFn#Ye>lkߙwu {QہݽVqRKMspoԛ0i߄7 ̠>6 ODsr7$6> ޑ /%Lt3ĵ78ynlx&uU7j|8՜~Zc{vC2fGfF7k9M'c~Kwr2|FC\)N]ۆ(R'Ǔp3NXR3Le(gww%,<À}M {r^,YE{,yyh-}gshb,sC^M^0CWl@͛ A|6k?ԺQt98ssy: 7⁧Z/|Ú61rE }HLf ZZ͕L}z(|2mt5 6STDodOM"1f-,_s+^n[&Qs3 Y0^fH#"uQj}Slz@[ އ>?F ka3g.;fzRKXt:#P MxÞVfϯM#;(,{&rVXclji<- Be3LpMhSOqld䍂05WXjǎޑq=?yc pG1\c^L+\VPؘ7?WC:Kq8ƭp5($zj։]Xq~lg+nGI;ߣC6^EjGTtp9F kfy&21:B6_56KK?=UKl_MJnԷrv8_̡.IRE n6ad7{{Ni-@/>yi})-ݱ#CVfcfPJ6\gEѕD~3Zb)TY}͞ߚ0 ~|2c}̢q2]߅8Pkd+ޙuyʸ")+oF^`Aކo"%j-˳ .݉y&A9W&OmL' ~;"zژD7=)D%5'hLzLm&zh}`Hq?Im1\dknNỡR`څpG0䵬RHԻ83eFϨ$ XfW8pkYb،ǼhpaqKp]YBk[ zve} 4cP8zh/YRt?ff%Y2O'd^'U?XҵBeD-otC@Wֲ[q(X) yH ˶>ن{6]ТK27#0ÚUIQ+ Cm' +R.K;>s|OfVL]'ݬqbB\٭'AȜD&Lw5O HR&2fw7sKXK)8])5Elp}pI`剥XV_޲ _!7gZ6'BΛdP?gOʴ.c >Ehi=3ִ@^q9䬤ڛ!.W+mZ|يݾvuH.hiȢ揬S=B-!2) pFݔ׻Iwn^XOt{!ƻ3'[vtY{?WTuꂫ73BU[գ$O:o;<,2 s%h"P#`ӗHs 5qM|3zc='{T](5;;2jTtjE] y|qñpA`1/0LXfN095*~h26Tn{n`*Op:jwl'1FWtՊe$_5xWsMnݤMďY :r #n6Mqe4%NȚ126}rJ;CKfed]{u&pO鿎ՈBNHaPsI$]8cw%f鸱y`գ[NѦdžNڿOUݖax M'0sŠ%=|1 Vgc?} '*<|gU}HG.ݮQ_F:j.#f$x.ޠVH/C7'8M"6dn @2-fC@Gx1xB^I #;3u}}Si)# ǀu>$Y TStnnjПe j퇇n ^!`"Fl0BsC Ϗ_"߱M{B_0u @Uiy!1 keuG]Tjꁈ,ᆽISR)CDf#BM &agtF_:[MU$xER0rwƝJ&\V:?&]dz*÷10;%0;!t2 S qۋ'' ړqt<@1] ʑ-6mCG`_)hmbv8ArB}Ca.TuNc$rpAvלE@.tdDpG%;6]9Xqxݮ&M.CH*4+QpqE_)_yKJ* Y|Ϋq5E Sb,`w]Y<&w8r9?{.ag3|ky٨gM8x=cd4_žE=;;@"9 %`gY7o%_k=ՓMZMhZ+sⱅ"z"X&;U5F"Г_2z=|^;?7~{0GgHWoiP3ǁ#Qv96 .+򪑱wɦ޷tܱCBsj[0rmPPQj"8e KpWY]2il \dDcgD̿䌛Wpre1Ljf ۛ!4p2ui42.Ʌg$y,B?ຠu(Qw)"͏O^_YG|hB /mz 5!A¦M@ޢ? "|tt?IȔ "eǤZ[i2R[ T= p$Y8.Sֿno,RG*̵=0^h,Yܞ )v R4S9E|5Z/\"%b.J c?W*/??Q64'.!":^)UV-DU8a<C.| FɓBP]NE<2|_CRNQb#zS'Ʒ kRRszT$se _WtaAz:]0sT4̟]^z.W&-{kIZ5.q,C?qV3b%m%ϋ@N1#GI#SVw+B%RLV ,3J+BoX%:[A,?Ogfک(vIJ6uÀ0f%|+)Yn[(e1&BX-O(`2\ ],Im4(C5v&Ϛĉ|jƶ4l^z|YČXzy^rf(E\]WZfN$,o;wk )ueo"~U cx6BLA6MʣN?|ʕftrw7ĩ}dp&GmEF$-0eiI9~ I #2᫵H~]%df:)ʖ,ϜG>2%8sшFkB};Qf >@%4R ; Y7/%<ߵ#H!T<-mBn dr-c.Wko8=:܀HYsc8觃,|O\VԼِ`!JYw1 o]7U &¿·Q>uj>:0|R#Q@";簻BL/Q 8تE)ʈwD!ܣg0-~s l$w^9~c ]/ϲ\;o"d CFK9ҡM3ஆcjmGyOgڒtމqM/R[-='Zjé'Dvqq\fR #vcW81EbIXo &Xb%ڞI5bw?4FSR %%&ΤOs MBa}kH&#n҆J5e.r7ˑk߿R(]"M~DbA|ؾ㴅 4ݗ:s*n>ƛ W= ]mg6,tQ|7o&ͧb :IiF c}2x]ns,} Ls*HC#Ji2䀴θ~fC:Q|P} "pSvm{EQꄌ,<}1_2iNznEGNMybѸ~l'Ifq8bqeG"<8QѷGT6c3\f1| Qa5&xYXAxl ^| $}od^j>>#ı^qxɌ[ P!!etH2Ti}JK L"*G=i _~̀NFog >d1EГ0eQ!i뽈xQmޟK@Ύ@0'&h+g{p\d5פ-_EDsV&>AI%9fe`@b񍌉,ER>($x;…zK VaД6_~V_H-H9`j̯B,VfruhZO@jo0Ϥjɗ\Sx*$ ZkO>qY4fߕ&62o$pҡ>%KEX)i.J #R"dl9+-K}^ [c&[u/u R`^Í۪+:8ks6uHDEsѣʮwq 1%;@/:\7f,e$HҌf,>Y=FGPcu"6"w2k@*!ƙ|jSw묠;ڜ>4q U7ys4577aK4\?V?!q#-W9O  s|%ȱmiWasߕ7h6inx` ߔW\7&6sbq 06D1J8ֺak׮1ip%%"K=j#oJ:3'7=7m9\.*Mz=?KS>; g&N krV/MxzOcƯչ8nrN*XkmB}f@ɋ_1zŏDX|hwss<M @.I1UqVC9/|L=Q)Dʚ /qP_ZMv.bý耼/kjSޖ#XA%Vn6%7 E2m0žBزލXz[{ ar.(:k6l2LٻwMK vӱTR!qVq J5gmJ t_Qb&H;P54yپy|W™.V $ Rٸє1GK^H ъ̬]rcѼ "9 x\CcZT`gc0ϫ%=TPWy7c&x 0f^1uuz?cIpI~am/('}d6Y9ТNy^"AUK~?@>M/ 8]Oo=Äԅ`+ *T5~`t $=7h*~BSDJeE$:AS~N@v,U5T,yyvzH+Essi-}+"ϩƵI|U4Mc8MZL7@TbqkWN4d{$8>HN81 oG\Bٱv&,Fh16Zu `36 2VAq'ULqZ77eC.M&5`K)ݖ .-c݂آS)(7REAs4E!o򃒂*azmNoh'?7wg72_dԴ HI'%.v_5mޅ5 fm-Q`V֤,>AвыJlL1EymfA|_NJmNuwJF¶'6e'8uG@#Dѷp[wbsDaMkYgj\F{tB$S/"J,EF=[gskFP"xziFȵ-sT/ǐena~K%p_TOfC.2рF!^5zx0K)P\;N:x:9Pu%_ߐ=):vB^)s+/ 0fEn0[E{",%* X lܪt(O`f 4wWUn@ @e? tߧI?yT8GR5@?6 Ȱ |;NOַѨ'B;׶ YZ