From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 433DC5680 for ; Wed, 30 Aug 2023 13:59:16 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 34420C433C8; Wed, 30 Aug 2023 13:59:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1693403956; bh=d9a2Lkt0CdRYTYaUVKeVK96Rn1ZsJPsUkJpNSX/C/84=; h=From:To:Subject:In-Reply-To:References:Date:From; b=vD0E9NBEFL/jtTJuezEl5XEWMbU3rp57Vz+IuJUUxtnsngqfBjPNbSMc0BvukXMPI y9Yap+3gE0FncVgZFqcxfDyokNREy4iDfxQoB3fT2BFsxibB5wLBj+SElSIJZBBiMR XZu/mWdaqhThle/TZppC1CAqvtEOKGMyLcyccvWlI3UpAwGUwZabgtHMwjw1tIzO+Q j8Sg06UDOBrK33XQRXVTuRSy0Ij0fifnH7lht3M5GMws4HVl0uRZC0Cpi5w0tiX0xc vr2hXH5AonP2Niv7fFHNZ89sksZzrOVRfTEHHN5G3pM8Mx38F7q7M+4yWqkY451JDo KhISsR2A2ETxA== From: =?utf-8?B?QmrDtnJuIFTDtnBlbA==?= To: Daniel Borkmann , Puranjay Mohan , paul.walmsley@sifive.com, palmer@dabbelt.com, aou@eecs.berkeley.edu, pulehui@huawei.com, conor.dooley@microchip.com, ast@kernel.org, andrii@kernel.org, martin.lau@linux.dev, song@kernel.org, yhs@fb.com, kpsingh@kernel.org, bpf@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH bpf-next v3 0/3] bpf, riscv: use BPF prog pack allocator in BPF JIT In-Reply-To: <9ab91c63-0712-d2d8-9b2b-6f2098287baa@iogearbox.net> References: <20230828165958.1714079-1-puranjay12@gmail.com> <87edjmb1t8.fsf@all.your.base.are.belong.to.us> <9ab91c63-0712-d2d8-9b2b-6f2098287baa@iogearbox.net> Date: Wed, 30 Aug 2023 15:59:13 +0200 Message-ID: <87fs40k4we.fsf@all.your.base.are.belong.to.us> Precedence: bulk X-Mailing-List: bpf@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Daniel Borkmann writes: > On 8/29/23 12:06 PM, Bj=C3=B6rn T=C3=B6pel wrote: >> Puranjay Mohan writes: >>=20 >>> Changes in v2 -> v3: >>> 1. Fix maximum width of code in patches from 80 to 100. [All patches] >>> 2. Add checks for ctx->ro_insns =3D=3D NULL. [Patch 3] >>> 3. Fix check for edge condition where amount of text to set > 2 * pages= ize >>> [Patch 1 and 2] >>> 4. Add reviewed-by in patches. >>> 5. Adding results of selftest here: >>> Using the command: ./test_progs on qemu >>> Without the series: Summary: 336/3162 PASSED, 56 SKIPPED, 90 FAILED >>> With this series: Summary: 336/3162 PASSED, 56 SKIPPED, 90 FAILED >>> >>> Changes in v1 -> v2: >>> 1. Implement a new function patch_text_set_nosync() to be used in bpf_a= rch_text_invalidate(). >>> The implementation in v1 called patch_text_nosync() in a loop and i= t was bad as it would >>> call flush_icache_range() for every word making it really slow. Thi= s was found by running >>> the test_tag selftest which would take forever to complete. >>> >>> Here is some data to prove the V2 fixes the problem: >>> >>> Without this series: >>> root@rv-selftester:~/src/kselftest/bpf# time ./test_tag >>> test_tag: OK (40945 tests) >>> >>> real 7m47.562s >>> user 0m24.145s >>> sys 6m37.064s >>> >>> With this series applied: >>> root@rv-selftester:~/src/selftest/bpf# time ./test_tag >>> test_tag: OK (40945 tests) >>> >>> real 7m29.472s >>> user 0m25.865s >>> sys 6m18.401s >>> >>> BPF programs currently consume a page each on RISCV. For systems with m= any BPF >>> programs, this adds significant pressure to instruction TLB. High iTLB = pressure >>> usually causes slow down for the whole system. >>> >>> Song Liu introduced the BPF prog pack allocator[1] to mitigate the abov= e issue. >>> It packs multiple BPF programs into a single huge page. It is currently= only >>> enabled for the x86_64 BPF JIT. >>> >>> I enabled this allocator on the ARM64 BPF JIT[2]. It is being reviewed = now. >>> >>> This patch series enables the BPF prog pack allocator for the RISCV BPF= JIT. >>> This series needs a patch[3] from the ARM64 series to work. >>> >>> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D >>> Performance Analysis of prog pack allocator on RISCV64 >>> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D >>> >>> Test setup: >>> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D >>> >>> Host machine: Debian GNU/Linux 11 (bullseye) >>> Qemu Version: QEMU emulator version 8.0.3 (Debian 1:8.0.3+dfsg-1) >>> u-boot-qemu Version: 2023.07+dfsg-1 >>> opensbi Version: 1.3-1 >>> >>> To test the performance of the BPF prog pack allocator on RV, a stresser >>> tool[4] linked below was built. This tool loads 8 BPF programs on the s= ystem and >>> triggers 5 of them in an infinite loop by doing system calls. >>> >>> The runner script starts 20 instances of the above which loads 8*20=3D1= 60 BPF >>> programs on the system, 5*20=3D100 of which are being constantly trigge= red. >>> The script is passed a command which would be run in the above environm= ent. >>> >>> The script was run with following perf command: >>> ./run.sh "perf stat -a \ >>> -e iTLB-load-misses \ >>> -e dTLB-load-misses \ >>> -e dTLB-store-misses \ >>> -e instructions \ >>> --timeout 60000" >>> >>> The output of the above command is discussed below before and after ena= bling the >>> BPF prog pack allocator. >>> >>> The tests were run on qemu-system-riscv64 with 8 cpus, 16G memory. The = rootfs >>> was created using Bjorn's riscv-cross-builder[5] docker container linke= d below. >>> >>> Results >>> =3D=3D=3D=3D=3D=3D=3D >>> >>> Before enabling prog pack allocator: >>> ------------------------------------ >>> >>> Performance counter stats for 'system wide': >>> >>> 4939048 iTLB-load-misses >>> 5468689 dTLB-load-misses >>> 465234 dTLB-store-misses >>> 1441082097998 instructions >>> >>> 60.045791200 seconds time elapsed >>> >>> After enabling prog pack allocator: >>> ----------------------------------- >>> >>> Performance counter stats for 'system wide': >>> >>> 3430035 iTLB-load-misses >>> 5008745 dTLB-load-misses >>> 409944 dTLB-store-misses >>> 1441535637988 instructions >>> >>> 60.046296600 seconds time elapsed >>> >>> Improvements in metrics >>> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D >>> >>> It was expected that the iTLB-load-misses would decrease as now a singl= e huge >>> page is used to keep all the BPF programs compared to a single page for= each >>> program earlier. >>> >>> -------------------------------------------- >>> The improvement in iTLB-load-misses: -30.5 % >>> -------------------------------------------- >>> >>> I repeated this expriment more than 100 times in different setups and t= he >>> improvement was always greater than 30%. >>> >>> This patch series is boot tested on the Starfive VisionFive 2 board[6]. >>> The performance analysis was not done on the board because it doesn't >>> expose iTLB-load-misses, etc. The stresser program was run on the board= to test >>> the loading and unloading of BPF programs >>> >>> [1] https://lore.kernel.org/bpf/20220204185742.271030-1-song@kernel.org/ >>> [2] https://lore.kernel.org/all/20230626085811.3192402-1-puranjay12@gma= il.com/ >>> [3] https://lore.kernel.org/all/20230626085811.3192402-2-puranjay12@gma= il.com/ >>> [4] https://github.com/puranjaymohan/BPF-Allocator-Bench >>> [5] https://github.com/bjoto/riscv-cross-builder >>> [6] https://www.starfivetech.com/en/site/boards >>> >>> Puranjay Mohan (3): >>> riscv: extend patch_text_nosync() for multiple pages >>> riscv: implement a memset like function for text >>> bpf, riscv: use prog pack allocator in the BPF JIT >>=20 >> Thank you! For the series: >>=20 >> Acked-by: Bj=C3=B6rn T=C3=B6pel >> Tested-by: Bj=C3=B6rn T=C3=B6pel >>=20 >> @Alexei @Daniel This series depends on a core BPF patch from the Arm >> series [3]. [snip] > If not yet, perhaps you could ship this series along with your PR to Linus > during this merge window given the big net PR (incl. bpf) was already mer= ged > yesterday. So from our side only fixes ship to Linus. Are you OK with this patch going thru the riscv tree as well? From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id AB03FC83F15 for ; Wed, 30 Aug 2023 13:59:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-ID:Date:References :In-Reply-To:Subject:To:From:Reply-To:Cc:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=1Pu5noA/j/1naFtIYF11k15aVpCQtKLiEyDl0LUxCx8=; b=nrf4vAHRa4RmzF belW7BlaidUaN0+zeUFEwLKPKwlVbvWhjRw4RvtJQHdNw4DIk7uehxGDXzkgDwpX+TcxRZqsUwGKD xSQPSrno4HncUbGX4PiOOpFLxhcBrgRMIo6PwOF502D22dc5X2tZtp5mv90r5e1T6AGMIcCLTphgl tLfO4zLQEUHUWy9nUFdDQc4GZfdEBEQ3PoHk6RPM28SVq70InFqcSm5O7L7+6lFd46lOghRc0Y7JS JfbnYqomjK8JwPjhRafalmkrlmEZov73FNVAfu3RWUEcvr+5/OqQqaPEyiXhjtCwbQ9yM8BjVOuDl q3Fk7yDqfHfP7FFzADlw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qbLj7-00DdJY-2c; Wed, 30 Aug 2023 13:59:21 +0000 Received: from dfw.source.kernel.org ([139.178.84.217]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1qbLj4-00DdJ0-26 for linux-riscv@lists.infradead.org; Wed, 30 Aug 2023 13:59:20 +0000 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 4204B6207A; Wed, 30 Aug 2023 13:59:17 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 34420C433C8; Wed, 30 Aug 2023 13:59:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1693403956; bh=d9a2Lkt0CdRYTYaUVKeVK96Rn1ZsJPsUkJpNSX/C/84=; h=From:To:Subject:In-Reply-To:References:Date:From; b=vD0E9NBEFL/jtTJuezEl5XEWMbU3rp57Vz+IuJUUxtnsngqfBjPNbSMc0BvukXMPI y9Yap+3gE0FncVgZFqcxfDyokNREy4iDfxQoB3fT2BFsxibB5wLBj+SElSIJZBBiMR XZu/mWdaqhThle/TZppC1CAqvtEOKGMyLcyccvWlI3UpAwGUwZabgtHMwjw1tIzO+Q j8Sg06UDOBrK33XQRXVTuRSy0Ij0fifnH7lht3M5GMws4HVl0uRZC0Cpi5w0tiX0xc vr2hXH5AonP2Niv7fFHNZ89sksZzrOVRfTEHHN5G3pM8Mx38F7q7M+4yWqkY451JDo KhISsR2A2ETxA== From: =?utf-8?B?QmrDtnJuIFTDtnBlbA==?= To: Daniel Borkmann , Puranjay Mohan , paul.walmsley@sifive.com, palmer@dabbelt.com, aou@eecs.berkeley.edu, pulehui@huawei.com, conor.dooley@microchip.com, ast@kernel.org, andrii@kernel.org, martin.lau@linux.dev, song@kernel.org, yhs@fb.com, kpsingh@kernel.org, bpf@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH bpf-next v3 0/3] bpf, riscv: use BPF prog pack allocator in BPF JIT In-Reply-To: <9ab91c63-0712-d2d8-9b2b-6f2098287baa@iogearbox.net> References: <20230828165958.1714079-1-puranjay12@gmail.com> <87edjmb1t8.fsf@all.your.base.are.belong.to.us> <9ab91c63-0712-d2d8-9b2b-6f2098287baa@iogearbox.net> Date: Wed, 30 Aug 2023 15:59:13 +0200 Message-ID: <87fs40k4we.fsf@all.your.base.are.belong.to.us> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230830_065918_797395_E29DD3F0 X-CRM114-Status: GOOD ( 19.31 ) X-BeenThere: linux-riscv@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-riscv" Errors-To: linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org RGFuaWVsIEJvcmttYW5uIDxkYW5pZWxAaW9nZWFyYm94Lm5ldD4gd3JpdGVzOgoKPiBPbiA4LzI5 LzIzIDEyOjA2IFBNLCBCasO2cm4gVMO2cGVsIHdyb3RlOgo+PiBQdXJhbmpheSBNb2hhbiA8cHVy YW5qYXkxMkBnbWFpbC5jb20+IHdyaXRlczoKPj4gCj4+PiBDaGFuZ2VzIGluIHYyIC0+IHYzOgo+ Pj4gMS4gRml4IG1heGltdW0gd2lkdGggb2YgY29kZSBpbiBwYXRjaGVzIGZyb20gODAgdG8gMTAw LiBbQWxsIHBhdGNoZXNdCj4+PiAyLiBBZGQgY2hlY2tzIGZvciBjdHgtPnJvX2luc25zID09IE5V TEwuIFtQYXRjaCAzXQo+Pj4gMy4gRml4IGNoZWNrIGZvciBlZGdlIGNvbmRpdGlvbiB3aGVyZSBh bW91bnQgb2YgdGV4dCB0byBzZXQgPiAyICogcGFnZXNpemUKPj4+ICAgICBbUGF0Y2ggMSBhbmQg Ml0KPj4+IDQuIEFkZCByZXZpZXdlZC1ieSBpbiBwYXRjaGVzLgo+Pj4gNS4gQWRkaW5nIHJlc3Vs dHMgb2Ygc2VsZnRlc3QgaGVyZToKPj4+ICAgICBVc2luZyB0aGUgY29tbWFuZDogLi90ZXN0X3By b2dzIG9uIHFlbXUKPj4+ICAgICBXaXRob3V0IHRoZSBzZXJpZXM6IFN1bW1hcnk6IDMzNi8zMTYy IFBBU1NFRCwgNTYgU0tJUFBFRCwgOTAgRkFJTEVECj4+PiAgICAgV2l0aCB0aGlzIHNlcmllczog U3VtbWFyeTogMzM2LzMxNjIgUEFTU0VELCA1NiBTS0lQUEVELCA5MCBGQUlMRUQKPj4+Cj4+PiBD aGFuZ2VzIGluIHYxIC0+IHYyOgo+Pj4gMS4gSW1wbGVtZW50IGEgbmV3IGZ1bmN0aW9uIHBhdGNo X3RleHRfc2V0X25vc3luYygpIHRvIGJlIHVzZWQgaW4gYnBmX2FyY2hfdGV4dF9pbnZhbGlkYXRl KCkuCj4+PiAgICAgVGhlIGltcGxlbWVudGF0aW9uIGluIHYxIGNhbGxlZCBwYXRjaF90ZXh0X25v c3luYygpIGluIGEgbG9vcCBhbmQgaXQgd2FzIGJhZCBhcyBpdCB3b3VsZAo+Pj4gICAgIGNhbGwg Zmx1c2hfaWNhY2hlX3JhbmdlKCkgZm9yIGV2ZXJ5IHdvcmQgbWFraW5nIGl0IHJlYWxseSBzbG93 LiBUaGlzIHdhcyBmb3VuZCBieSBydW5uaW5nCj4+PiAgICAgdGhlIHRlc3RfdGFnIHNlbGZ0ZXN0 IHdoaWNoIHdvdWxkIHRha2UgZm9yZXZlciB0byBjb21wbGV0ZS4KPj4+Cj4+PiBIZXJlIGlzIHNv bWUgZGF0YSB0byBwcm92ZSB0aGUgVjIgZml4ZXMgdGhlIHByb2JsZW06Cj4+Pgo+Pj4gV2l0aG91 dCB0aGlzIHNlcmllczoKPj4+IHJvb3RAcnYtc2VsZnRlc3Rlcjp+L3NyYy9rc2VsZnRlc3QvYnBm IyB0aW1lIC4vdGVzdF90YWcKPj4+IHRlc3RfdGFnOiBPSyAoNDA5NDUgdGVzdHMpCj4+Pgo+Pj4g cmVhbCAgICA3bTQ3LjU2MnMKPj4+IHVzZXIgICAgMG0yNC4xNDVzCj4+PiBzeXMgICAgIDZtMzcu MDY0cwo+Pj4KPj4+IFdpdGggdGhpcyBzZXJpZXMgYXBwbGllZDoKPj4+IHJvb3RAcnYtc2VsZnRl c3Rlcjp+L3NyYy9zZWxmdGVzdC9icGYjIHRpbWUgLi90ZXN0X3RhZwo+Pj4gdGVzdF90YWc6IE9L ICg0MDk0NSB0ZXN0cykKPj4+Cj4+PiByZWFsICAgIDdtMjkuNDcycwo+Pj4gdXNlciAgICAwbTI1 Ljg2NXMKPj4+IHN5cyAgICAgNm0xOC40MDFzCj4+Pgo+Pj4gQlBGIHByb2dyYW1zIGN1cnJlbnRs eSBjb25zdW1lIGEgcGFnZSBlYWNoIG9uIFJJU0NWLiBGb3Igc3lzdGVtcyB3aXRoIG1hbnkgQlBG Cj4+PiBwcm9ncmFtcywgdGhpcyBhZGRzIHNpZ25pZmljYW50IHByZXNzdXJlIHRvIGluc3RydWN0 aW9uIFRMQi4gSGlnaCBpVExCIHByZXNzdXJlCj4+PiB1c3VhbGx5IGNhdXNlcyBzbG93IGRvd24g Zm9yIHRoZSB3aG9sZSBzeXN0ZW0uCj4+Pgo+Pj4gU29uZyBMaXUgaW50cm9kdWNlZCB0aGUgQlBG IHByb2cgcGFjayBhbGxvY2F0b3JbMV0gdG8gbWl0aWdhdGUgdGhlIGFib3ZlIGlzc3VlLgo+Pj4g SXQgcGFja3MgbXVsdGlwbGUgQlBGIHByb2dyYW1zIGludG8gYSBzaW5nbGUgaHVnZSBwYWdlLiBJ dCBpcyBjdXJyZW50bHkgb25seQo+Pj4gZW5hYmxlZCBmb3IgdGhlIHg4Nl82NCBCUEYgSklULgo+ Pj4KPj4+IEkgZW5hYmxlZCB0aGlzIGFsbG9jYXRvciBvbiB0aGUgQVJNNjQgQlBGIEpJVFsyXS4g SXQgaXMgYmVpbmcgcmV2aWV3ZWQgbm93Lgo+Pj4KPj4+IFRoaXMgcGF0Y2ggc2VyaWVzIGVuYWJs ZXMgdGhlIEJQRiBwcm9nIHBhY2sgYWxsb2NhdG9yIGZvciB0aGUgUklTQ1YgQlBGIEpJVC4KPj4+ IFRoaXMgc2VyaWVzIG5lZWRzIGEgcGF0Y2hbM10gZnJvbSB0aGUgQVJNNjQgc2VyaWVzIHRvIHdv cmsuCj4+Pgo+Pj4gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09Cj4+PiBQZXJmb3JtYW5jZSBBbmFseXNpcyBvZiBwcm9nIHBhY2sgYWxsb2NhdG9y IG9uIFJJU0NWNjQKPj4+ID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PQo+Pj4KPj4+IFRlc3Qgc2V0dXA6Cj4+PiA9PT09PT09PT09PQo+Pj4KPj4+ IEhvc3QgbWFjaGluZTogRGViaWFuIEdOVS9MaW51eCAxMSAoYnVsbHNleWUpCj4+PiBRZW11IFZl cnNpb246IFFFTVUgZW11bGF0b3IgdmVyc2lvbiA4LjAuMyAoRGViaWFuIDE6OC4wLjMrZGZzZy0x KQo+Pj4gdS1ib290LXFlbXUgVmVyc2lvbjogMjAyMy4wNytkZnNnLTEKPj4+IG9wZW5zYmkgVmVy c2lvbjogMS4zLTEKPj4+Cj4+PiBUbyB0ZXN0IHRoZSBwZXJmb3JtYW5jZSBvZiB0aGUgQlBGIHBy b2cgcGFjayBhbGxvY2F0b3Igb24gUlYsIGEgc3RyZXNzZXIKPj4+IHRvb2xbNF0gbGlua2VkIGJl bG93IHdhcyBidWlsdC4gVGhpcyB0b29sIGxvYWRzIDggQlBGIHByb2dyYW1zIG9uIHRoZSBzeXN0 ZW0gYW5kCj4+PiB0cmlnZ2VycyA1IG9mIHRoZW0gaW4gYW4gaW5maW5pdGUgbG9vcCBieSBkb2lu ZyBzeXN0ZW0gY2FsbHMuCj4+Pgo+Pj4gVGhlIHJ1bm5lciBzY3JpcHQgc3RhcnRzIDIwIGluc3Rh bmNlcyBvZiB0aGUgYWJvdmUgd2hpY2ggbG9hZHMgOCoyMD0xNjAgQlBGCj4+PiBwcm9ncmFtcyBv biB0aGUgc3lzdGVtLCA1KjIwPTEwMCBvZiB3aGljaCBhcmUgYmVpbmcgY29uc3RhbnRseSB0cmln Z2VyZWQuCj4+PiBUaGUgc2NyaXB0IGlzIHBhc3NlZCBhIGNvbW1hbmQgd2hpY2ggd291bGQgYmUg cnVuIGluIHRoZSBhYm92ZSBlbnZpcm9ubWVudC4KPj4+Cj4+PiBUaGUgc2NyaXB0IHdhcyBydW4g d2l0aCBmb2xsb3dpbmcgcGVyZiBjb21tYW5kOgo+Pj4gLi9ydW4uc2ggInBlcmYgc3RhdCAtYSBc Cj4+PiAgICAgICAgICAtZSBpVExCLWxvYWQtbWlzc2VzIFwKPj4+ICAgICAgICAgIC1lIGRUTEIt bG9hZC1taXNzZXMgIFwKPj4+ICAgICAgICAgIC1lIGRUTEItc3RvcmUtbWlzc2VzIFwKPj4+ICAg ICAgICAgIC1lIGluc3RydWN0aW9ucyBcCj4+PiAgICAgICAgICAtLXRpbWVvdXQgNjAwMDAiCj4+ Pgo+Pj4gVGhlIG91dHB1dCBvZiB0aGUgYWJvdmUgY29tbWFuZCBpcyBkaXNjdXNzZWQgYmVsb3cg YmVmb3JlIGFuZCBhZnRlciBlbmFibGluZyB0aGUKPj4+IEJQRiBwcm9nIHBhY2sgYWxsb2NhdG9y Lgo+Pj4KPj4+IFRoZSB0ZXN0cyB3ZXJlIHJ1biBvbiBxZW11LXN5c3RlbS1yaXNjdjY0IHdpdGgg OCBjcHVzLCAxNkcgbWVtb3J5LiBUaGUgcm9vdGZzCj4+PiB3YXMgY3JlYXRlZCB1c2luZyBCam9y bidzIHJpc2N2LWNyb3NzLWJ1aWxkZXJbNV0gZG9ja2VyIGNvbnRhaW5lciBsaW5rZWQgYmVsb3cu Cj4+Pgo+Pj4gUmVzdWx0cwo+Pj4gPT09PT09PQo+Pj4KPj4+IEJlZm9yZSBlbmFibGluZyBwcm9n IHBhY2sgYWxsb2NhdG9yOgo+Pj4gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t Cj4+Pgo+Pj4gUGVyZm9ybWFuY2UgY291bnRlciBzdGF0cyBmb3IgJ3N5c3RlbSB3aWRlJzoKPj4+ Cj4+PiAgICAgICAgICAgICA0OTM5MDQ4ICAgICAgaVRMQi1sb2FkLW1pc3Nlcwo+Pj4gICAgICAg ICAgICAgNTQ2ODY4OSAgICAgIGRUTEItbG9hZC1taXNzZXMKPj4+ICAgICAgICAgICAgICA0NjUy MzQgICAgICBkVExCLXN0b3JlLW1pc3Nlcwo+Pj4gICAgICAgMTQ0MTA4MjA5Nzk5OCAgICAgIGlu c3RydWN0aW9ucwo+Pj4KPj4+ICAgICAgICA2MC4wNDU3OTEyMDAgc2Vjb25kcyB0aW1lIGVsYXBz ZWQKPj4+Cj4+PiBBZnRlciBlbmFibGluZyBwcm9nIHBhY2sgYWxsb2NhdG9yOgo+Pj4gLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KPj4+Cj4+PiBQZXJmb3JtYW5jZSBjb3VudGVy IHN0YXRzIGZvciAnc3lzdGVtIHdpZGUnOgo+Pj4KPj4+ICAgICAgICAgICAgIDM0MzAwMzUgICAg ICBpVExCLWxvYWQtbWlzc2VzCj4+PiAgICAgICAgICAgICA1MDA4NzQ1ICAgICAgZFRMQi1sb2Fk LW1pc3Nlcwo+Pj4gICAgICAgICAgICAgIDQwOTk0NCAgICAgIGRUTEItc3RvcmUtbWlzc2VzCj4+ PiAgICAgICAxNDQxNTM1NjM3OTg4ICAgICAgaW5zdHJ1Y3Rpb25zCj4+Pgo+Pj4gICAgICAgIDYw LjA0NjI5NjYwMCBzZWNvbmRzIHRpbWUgZWxhcHNlZAo+Pj4KPj4+IEltcHJvdmVtZW50cyBpbiBt ZXRyaWNzCj4+PiA9PT09PT09PT09PT09PT09PT09PT09PQo+Pj4KPj4+IEl0IHdhcyBleHBlY3Rl ZCB0aGF0IHRoZSBpVExCLWxvYWQtbWlzc2VzIHdvdWxkIGRlY3JlYXNlIGFzIG5vdyBhIHNpbmds ZSBodWdlCj4+PiBwYWdlIGlzIHVzZWQgdG8ga2VlcCBhbGwgdGhlIEJQRiBwcm9ncmFtcyBjb21w YXJlZCB0byBhIHNpbmdsZSBwYWdlIGZvciBlYWNoCj4+PiBwcm9ncmFtIGVhcmxpZXIuCj4+Pgo+ Pj4gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KPj4+IFRoZSBp bXByb3ZlbWVudCBpbiBpVExCLWxvYWQtbWlzc2VzOiAtMzAuNSAlCj4+PiAtLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQo+Pj4KPj4+IEkgcmVwZWF0ZWQgdGhpcyBl eHByaW1lbnQgbW9yZSB0aGFuIDEwMCB0aW1lcyBpbiBkaWZmZXJlbnQgc2V0dXBzIGFuZCB0aGUK Pj4+IGltcHJvdmVtZW50IHdhcyBhbHdheXMgZ3JlYXRlciB0aGFuIDMwJS4KPj4+Cj4+PiBUaGlz IHBhdGNoIHNlcmllcyBpcyBib290IHRlc3RlZCBvbiB0aGUgU3RhcmZpdmUgVmlzaW9uRml2ZSAy IGJvYXJkWzZdLgo+Pj4gVGhlIHBlcmZvcm1hbmNlIGFuYWx5c2lzIHdhcyBub3QgZG9uZSBvbiB0 aGUgYm9hcmQgYmVjYXVzZSBpdCBkb2Vzbid0Cj4+PiBleHBvc2UgaVRMQi1sb2FkLW1pc3Nlcywg ZXRjLiBUaGUgc3RyZXNzZXIgcHJvZ3JhbSB3YXMgcnVuIG9uIHRoZSBib2FyZCB0byB0ZXN0Cj4+ PiB0aGUgbG9hZGluZyBhbmQgdW5sb2FkaW5nIG9mIEJQRiBwcm9ncmFtcwo+Pj4KPj4+IFsxXSBo dHRwczovL2xvcmUua2VybmVsLm9yZy9icGYvMjAyMjAyMDQxODU3NDIuMjcxMDMwLTEtc29uZ0Br ZXJuZWwub3JnLwo+Pj4gWzJdIGh0dHBzOi8vbG9yZS5rZXJuZWwub3JnL2FsbC8yMDIzMDYyNjA4 NTgxMS4zMTkyNDAyLTEtcHVyYW5qYXkxMkBnbWFpbC5jb20vCj4+PiBbM10gaHR0cHM6Ly9sb3Jl Lmtlcm5lbC5vcmcvYWxsLzIwMjMwNjI2MDg1ODExLjMxOTI0MDItMi1wdXJhbmpheTEyQGdtYWls LmNvbS8KPj4+IFs0XSBodHRwczovL2dpdGh1Yi5jb20vcHVyYW5qYXltb2hhbi9CUEYtQWxsb2Nh dG9yLUJlbmNoCj4+PiBbNV0gaHR0cHM6Ly9naXRodWIuY29tL2Jqb3RvL3Jpc2N2LWNyb3NzLWJ1 aWxkZXIKPj4+IFs2XSBodHRwczovL3d3dy5zdGFyZml2ZXRlY2guY29tL2VuL3NpdGUvYm9hcmRz Cj4+Pgo+Pj4gUHVyYW5qYXkgTW9oYW4gKDMpOgo+Pj4gICAgcmlzY3Y6IGV4dGVuZCBwYXRjaF90 ZXh0X25vc3luYygpIGZvciBtdWx0aXBsZSBwYWdlcwo+Pj4gICAgcmlzY3Y6IGltcGxlbWVudCBh IG1lbXNldCBsaWtlIGZ1bmN0aW9uIGZvciB0ZXh0Cj4+PiAgICBicGYsIHJpc2N2OiB1c2UgcHJv ZyBwYWNrIGFsbG9jYXRvciBpbiB0aGUgQlBGIEpJVAo+PiAKPj4gVGhhbmsgeW91ISBGb3IgdGhl IHNlcmllczoKPj4gCj4+IEFja2VkLWJ5OiBCasO2cm4gVMO2cGVsIDxiam9ybkBrZXJuZWwub3Jn Pgo+PiBUZXN0ZWQtYnk6IEJqw7ZybiBUw7ZwZWwgPGJqb3JuQHJpdm9zaW5jLmNvbT4KPj4gCj4+ IEBBbGV4ZWkgQERhbmllbCBUaGlzIHNlcmllcyBkZXBlbmRzIG9uIGEgY29yZSBCUEYgcGF0Y2gg ZnJvbSB0aGUgQXJtCj4+ICAgICAgICAgICAgICAgICAgc2VyaWVzIFszXS4KCltzbmlwXQo+IElm IG5vdCB5ZXQsIHBlcmhhcHMgeW91IGNvdWxkIHNoaXAgdGhpcyBzZXJpZXMgYWxvbmcgd2l0aCB5 b3VyIFBSIHRvIExpbnVzCj4gZHVyaW5nIHRoaXMgbWVyZ2Ugd2luZG93IGdpdmVuIHRoZSBiaWcg bmV0IFBSIChpbmNsLiBicGYpIHdhcyBhbHJlYWR5IG1lcmdlZAo+IHllc3RlcmRheS4gU28gZnJv bSBvdXIgc2lkZSBvbmx5IGZpeGVzIHNoaXAgdG8gTGludXMuCgpBcmUgeW91IE9LIHdpdGggdGhp cyBwYXRjaCBnb2luZyB0aHJ1IHRoZSByaXNjdiB0cmVlIGFzIHdlbGw/CgpfX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1yaXNjdiBtYWlsaW5nIGxp c3QKbGludXgtcmlzY3ZAbGlzdHMuaW5mcmFkZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFk Lm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LXJpc2N2Cg==