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 X-Spam-Level: X-Spam-Status: No, score=-15.5 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 40F63C2B9F4 for ; Thu, 17 Jun 2021 07:23:22 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 1C344613BF for ; Thu, 17 Jun 2021 07:23:22 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230280AbhFQHZ1 (ORCPT ); Thu, 17 Jun 2021 03:25:27 -0400 Received: from relay1-d.mail.gandi.net ([217.70.183.193]:36209 "EHLO relay1-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229673AbhFQHZX (ORCPT ); Thu, 17 Jun 2021 03:25:23 -0400 Received: (Authenticated sender: alex@ghiti.fr) by relay1-d.mail.gandi.net (Postfix) with ESMTPSA id E10C7240008; Thu, 17 Jun 2021 07:23:04 +0000 (UTC) Subject: Re: [PATCH] riscv: Ensure BPF_JIT_REGION_START aligned with PMD size To: Jisheng Zhang Cc: Andreas Schwab , Paul Walmsley , Palmer Dabbelt , Albert Ou , Andrey Ryabinin , Alexander Potapenko , Andrey Konovalov , Dmitry Vyukov , =?UTF-8?B?QmrDtnJuIFTDtnBlbA==?= , Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , Martin KaFai Lau , Song Liu , Yonghong Song , John Fastabend , KP Singh , Luke Nelson , Xi Wang , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, kasan-dev@googlegroups.com, netdev@vger.kernel.org, bpf@vger.kernel.org References: <20210330022144.150edc6e@xhacker> <20210330022521.2a904a8c@xhacker> <87o8ccqypw.fsf@igel.home> <20210612002334.6af72545@xhacker> <87bl8cqrpv.fsf@igel.home> <20210614010546.7a0d5584@xhacker> <87im2hsfvm.fsf@igel.home> <20210615004928.2d27d2ac@xhacker> <20210616080328.6548e762@xhacker> From: Alex Ghiti Message-ID: <4cdb1261-6474-8ae6-7a92-a3be81ce8cb5@ghiti.fr> Date: Thu, 17 Jun 2021 09:23:04 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: <20210616080328.6548e762@xhacker> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 16/06/2021 à 02:03, Jisheng Zhang a écrit : > On Tue, 15 Jun 2021 20:54:19 +0200 > Alex Ghiti wrote: > >> Hi Jisheng, > > Hi Alex, > >> >> Le 14/06/2021 à 18:49, Jisheng Zhang a écrit : >>> From: Jisheng Zhang >>> >>> Andreas reported commit fc8504765ec5 ("riscv: bpf: Avoid breaking W^X") >>> breaks booting with one kind of config file, I reproduced a kernel panic >>> with the config: >>> >>> [ 0.138553] Unable to handle kernel paging request at virtual address ffffffff81201220 >>> [ 0.139159] Oops [#1] >>> [ 0.139303] Modules linked in: >>> [ 0.139601] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.13.0-rc5-default+ #1 >>> [ 0.139934] Hardware name: riscv-virtio,qemu (DT) >>> [ 0.140193] epc : __memset+0xc4/0xfc >>> [ 0.140416] ra : skb_flow_dissector_init+0x1e/0x82 >>> [ 0.140609] epc : ffffffff8029806c ra : ffffffff8033be78 sp : ffffffe001647da0 >>> [ 0.140878] gp : ffffffff81134b08 tp : ffffffe001654380 t0 : ffffffff81201158 >>> [ 0.141156] t1 : 0000000000000002 t2 : 0000000000000154 s0 : ffffffe001647dd0 >>> [ 0.141424] s1 : ffffffff80a43250 a0 : ffffffff81201220 a1 : 0000000000000000 >>> [ 0.141654] a2 : 000000000000003c a3 : ffffffff81201258 a4 : 0000000000000064 >>> [ 0.141893] a5 : ffffffff8029806c a6 : 0000000000000040 a7 : ffffffffffffffff >>> [ 0.142126] s2 : ffffffff81201220 s3 : 0000000000000009 s4 : ffffffff81135088 >>> [ 0.142353] s5 : ffffffff81135038 s6 : ffffffff8080ce80 s7 : ffffffff80800438 >>> [ 0.142584] s8 : ffffffff80bc6578 s9 : 0000000000000008 s10: ffffffff806000ac >>> [ 0.142810] s11: 0000000000000000 t3 : fffffffffffffffc t4 : 0000000000000000 >>> [ 0.143042] t5 : 0000000000000155 t6 : 00000000000003ff >>> [ 0.143220] status: 0000000000000120 badaddr: ffffffff81201220 cause: 000000000000000f >>> [ 0.143560] [] __memset+0xc4/0xfc >>> [ 0.143859] [] init_default_flow_dissectors+0x22/0x60 >>> [ 0.144092] [] do_one_initcall+0x3e/0x168 >>> [ 0.144278] [] kernel_init_freeable+0x1c8/0x224 >>> [ 0.144479] [] kernel_init+0x12/0x110 >>> [ 0.144658] [] ret_from_exception+0x0/0xc >>> [ 0.145124] ---[ end trace f1e9643daa46d591 ]--- >>> >>> After some investigation, I think I found the root cause: commit >>> 2bfc6cd81bd ("move kernel mapping outside of linear mapping") moves >>> BPF JIT region after the kernel: >>> >>> The &_end is unlikely aligned with PMD size, so the front bpf jit >>> region sits with part of kernel .data section in one PMD size mapping. >>> But kernel is mapped in PMD SIZE, when bpf_jit_binary_lock_ro() is >>> called to make the first bpf jit prog ROX, we will make part of kernel >>> .data section RO too, so when we write to, for example memset the >>> .data section, MMU will trigger a store page fault. >> >> Good catch, we make sure no physical allocation happens between _end and >> the next PMD aligned address, but I missed this one. >> >>> >>> To fix the issue, we need to ensure the BPF JIT region is PMD size >>> aligned. This patch acchieve this goal by restoring the BPF JIT region >>> to original position, I.E the 128MB before kernel .text section. >> >> But I disagree with your solution: I made sure modules and BPF programs >> get their own virtual regions to avoid worst case scenario where one >> could allocate all the space and leave nothing to the other (we are >> limited to +- 2GB offset). Why don't just align BPF_JIT_REGION_START to >> the next PMD aligned address? > > Originally, I planed to fix the issue by aligning BPF_JIT_REGION_START, but > IIRC, BPF experts are adding (or have added) "Calling kernel functions from BPF" > feature, there's a risk that BPF JIT region is beyond the 2GB of module region: > > ------ > module > ------ > kernel > ------ > BPF_JIT > > So I made this patch finally. In this patch, we let BPF JIT region sit > between module and kernel. > From what I read in the lwn article, I'm not sure BPF programs can call module functions, can someone tell us if it is possible? Or planned? > To address "make sure modules and BPF programs get their own virtual regions", > what about something as below (applied against this patch)? > > diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/pgtable.h > index 380cd3a7e548..da1158f10b09 100644 > --- a/arch/riscv/include/asm/pgtable.h > +++ b/arch/riscv/include/asm/pgtable.h > @@ -31,7 +31,7 @@ > #define BPF_JIT_REGION_SIZE (SZ_128M) > #ifdef CONFIG_64BIT > #define BPF_JIT_REGION_START (BPF_JIT_REGION_END - BPF_JIT_REGION_SIZE) > -#define BPF_JIT_REGION_END (MODULES_END) > +#define BPF_JIT_REGION_END (PFN_ALIGN((unsigned long)&_start)) > #else > #define BPF_JIT_REGION_START (PAGE_OFFSET - BPF_JIT_REGION_SIZE) > #define BPF_JIT_REGION_END (VMALLOC_END) > @@ -40,7 +40,7 @@ > /* Modules always live before the kernel */ > #ifdef CONFIG_64BIT > #define MODULES_VADDR (PFN_ALIGN((unsigned long)&_end) - SZ_2G) > -#define MODULES_END (PFN_ALIGN((unsigned long)&_start)) > +#define MODULES_END (BPF_JIT_REGION_END) > #endif > > In case it is possible, I would let the vmalloc allocator handle the case where modules steal room from BPF: I would then not implement the above but rather your first patch. And do not forget to modify Documentation/riscv/vm-layout.rst accordingly and remove the comment "/* KASLR should leave at least 128MB for BPF after the kernel */" Thanks, Alex > >> >> Again, good catch, thanks, >> >> Alex >> >>> >>> Reported-by: Andreas Schwab >>> Signed-off-by: Jisheng Zhang >>> --- >>> arch/riscv/include/asm/pgtable.h | 5 ++--- >>> 1 file changed, 2 insertions(+), 3 deletions(-) >>> >>> diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/pgtable.h >>> index 9469f464e71a..380cd3a7e548 100644 >>> --- a/arch/riscv/include/asm/pgtable.h >>> +++ b/arch/riscv/include/asm/pgtable.h >>> @@ -30,9 +30,8 @@ >>> >>> #define BPF_JIT_REGION_SIZE (SZ_128M) >>> #ifdef CONFIG_64BIT >>> -/* KASLR should leave at least 128MB for BPF after the kernel */ >>> -#define BPF_JIT_REGION_START PFN_ALIGN((unsigned long)&_end) >>> -#define BPF_JIT_REGION_END (BPF_JIT_REGION_START + BPF_JIT_REGION_SIZE) >>> +#define BPF_JIT_REGION_START (BPF_JIT_REGION_END - BPF_JIT_REGION_SIZE) >>> +#define BPF_JIT_REGION_END (MODULES_END) >>> #else >>> #define BPF_JIT_REGION_START (PAGE_OFFSET - BPF_JIT_REGION_SIZE) >>> #define BPF_JIT_REGION_END (VMALLOC_END) >>> > > > > _______________________________________________ > linux-riscv mailing list > linux-riscv@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-riscv > 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 X-Spam-Level: X-Spam-Status: No, score=-15.7 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS, USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2FCECC2B9F4 for ; Thu, 17 Jun 2021 07:23:33 +0000 (UTC) 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 mail.kernel.org (Postfix) with ESMTPS id B1DF86135C for ; Thu, 17 Jun 2021 07:23:32 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org B1DF86135C Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ghiti.fr Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:Content-Type: Content-Transfer-Encoding:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:From: References:Cc:To:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=TFoRJVLJ0276yAE1sir2P3OO4iSsH9vucygKaoOCmXo=; b=cBTWFV7x1sNxU8xx97LVfWhau2 sAhFL3IEiQt/Zx9tD4RGTYIwP1rtlSFm3C1+vbutZK4qhDIlUfkqbLiA3TufkIxUhr3hiscwFI+Om gqBEZloy5MhBSwcp/b6ZWdGdSzvi6o6CtBJGc+GjCGzEilZ6dV2xOgw54bwHyGBBuB5yMwfDZOmfH dfsU47xgDRf9WRYnVqyXFtM4+43cTOGtw1aQUM0N8lhRMLpXQx17Fv01skkd5QzM1Te3eEEeHs+HJ sNtGpAwsM0VZCYWLe6mTmLkN/jSyozC279bXjdwMk0DxvXV1pU7VauB+r3kjK4IZnUDAVZAUVvBAj NS1j3NLQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1ltmN0-009GWX-Qb; Thu, 17 Jun 2021 07:23:22 +0000 Received: from relay1-d.mail.gandi.net ([217.70.183.193]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1ltmMw-009GTn-I1 for linux-riscv@lists.infradead.org; Thu, 17 Jun 2021 07:23:20 +0000 Received: (Authenticated sender: alex@ghiti.fr) by relay1-d.mail.gandi.net (Postfix) with ESMTPSA id E10C7240008; Thu, 17 Jun 2021 07:23:04 +0000 (UTC) Subject: Re: [PATCH] riscv: Ensure BPF_JIT_REGION_START aligned with PMD size To: Jisheng Zhang Cc: Andreas Schwab , Paul Walmsley , Palmer Dabbelt , Albert Ou , Andrey Ryabinin , Alexander Potapenko , Andrey Konovalov , Dmitry Vyukov , =?UTF-8?B?QmrDtnJuIFTDtnBlbA==?= , Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , Martin KaFai Lau , Song Liu , Yonghong Song , John Fastabend , KP Singh , Luke Nelson , Xi Wang , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, kasan-dev@googlegroups.com, netdev@vger.kernel.org, bpf@vger.kernel.org References: <20210330022144.150edc6e@xhacker> <20210330022521.2a904a8c@xhacker> <87o8ccqypw.fsf@igel.home> <20210612002334.6af72545@xhacker> <87bl8cqrpv.fsf@igel.home> <20210614010546.7a0d5584@xhacker> <87im2hsfvm.fsf@igel.home> <20210615004928.2d27d2ac@xhacker> <20210616080328.6548e762@xhacker> From: Alex Ghiti Message-ID: <4cdb1261-6474-8ae6-7a92-a3be81ce8cb5@ghiti.fr> Date: Thu, 17 Jun 2021 09:23:04 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: <20210616080328.6548e762@xhacker> Content-Language: fr X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210617_002318_894101_9E341313 X-CRM114-Status: GOOD ( 30.13 ) 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-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "linux-riscv" Errors-To: linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org TGUgMTYvMDYvMjAyMSDDoCAwMjowMywgSmlzaGVuZyBaaGFuZyBhIMOpY3JpdMKgOgo+IE9uIFR1 ZSwgMTUgSnVuIDIwMjEgMjA6NTQ6MTkgKzAyMDAKPiBBbGV4IEdoaXRpIDxhbGV4QGdoaXRpLmZy PiB3cm90ZToKPiAKPj4gSGkgSmlzaGVuZywKPiAKPiBIaSBBbGV4LAo+IAo+Pgo+PiBMZSAxNC8w Ni8yMDIxIMOgIDE4OjQ5LCBKaXNoZW5nIFpoYW5nIGEgw6ljcml0wqA6Cj4+PiBGcm9tOiBKaXNo ZW5nIFpoYW5nIDxqc3poYW5nQGtlcm5lbC5vcmc+Cj4+Pgo+Pj4gQW5kcmVhcyByZXBvcnRlZCBj b21taXQgZmM4NTA0NzY1ZWM1ICgicmlzY3Y6IGJwZjogQXZvaWQgYnJlYWtpbmcgV15YIikKPj4+ IGJyZWFrcyBib290aW5nIHdpdGggb25lIGtpbmQgb2YgY29uZmlnIGZpbGUsIEkgcmVwcm9kdWNl ZCBhIGtlcm5lbCBwYW5pYwo+Pj4gd2l0aCB0aGUgY29uZmlnOgo+Pj4KPj4+IFsgICAgMC4xMzg1 NTNdIFVuYWJsZSB0byBoYW5kbGUga2VybmVsIHBhZ2luZyByZXF1ZXN0IGF0IHZpcnR1YWwgYWRk cmVzcyBmZmZmZmZmZjgxMjAxMjIwCj4+PiBbICAgIDAuMTM5MTU5XSBPb3BzIFsjMV0KPj4+IFsg ICAgMC4xMzkzMDNdIE1vZHVsZXMgbGlua2VkIGluOgo+Pj4gWyAgICAwLjEzOTYwMV0gQ1BVOiAw IFBJRDogMSBDb21tOiBzd2FwcGVyLzAgTm90IHRhaW50ZWQgNS4xMy4wLXJjNS1kZWZhdWx0KyAj MQo+Pj4gWyAgICAwLjEzOTkzNF0gSGFyZHdhcmUgbmFtZTogcmlzY3YtdmlydGlvLHFlbXUgKERU KQo+Pj4gWyAgICAwLjE0MDE5M10gZXBjIDogX19tZW1zZXQrMHhjNC8weGZjCj4+PiBbICAgIDAu MTQwNDE2XSAgcmEgOiBza2JfZmxvd19kaXNzZWN0b3JfaW5pdCsweDFlLzB4ODIKPj4+IFsgICAg MC4xNDA2MDldIGVwYyA6IGZmZmZmZmZmODAyOTgwNmMgcmEgOiBmZmZmZmZmZjgwMzNiZTc4IHNw IDogZmZmZmZmZTAwMTY0N2RhMAo+Pj4gWyAgICAwLjE0MDg3OF0gIGdwIDogZmZmZmZmZmY4MTEz NGIwOCB0cCA6IGZmZmZmZmUwMDE2NTQzODAgdDAgOiBmZmZmZmZmZjgxMjAxMTU4Cj4+PiBbICAg IDAuMTQxMTU2XSAgdDEgOiAwMDAwMDAwMDAwMDAwMDAyIHQyIDogMDAwMDAwMDAwMDAwMDE1NCBz MCA6IGZmZmZmZmUwMDE2NDdkZDAKPj4+IFsgICAgMC4xNDE0MjRdICBzMSA6IGZmZmZmZmZmODBh NDMyNTAgYTAgOiBmZmZmZmZmZjgxMjAxMjIwIGExIDogMDAwMDAwMDAwMDAwMDAwMAo+Pj4gWyAg ICAwLjE0MTY1NF0gIGEyIDogMDAwMDAwMDAwMDAwMDAzYyBhMyA6IGZmZmZmZmZmODEyMDEyNTgg YTQgOiAwMDAwMDAwMDAwMDAwMDY0Cj4+PiBbICAgIDAuMTQxODkzXSAgYTUgOiBmZmZmZmZmZjgw Mjk4MDZjIGE2IDogMDAwMDAwMDAwMDAwMDA0MCBhNyA6IGZmZmZmZmZmZmZmZmZmZmYKPj4+IFsg ICAgMC4xNDIxMjZdICBzMiA6IGZmZmZmZmZmODEyMDEyMjAgczMgOiAwMDAwMDAwMDAwMDAwMDA5 IHM0IDogZmZmZmZmZmY4MTEzNTA4OAo+Pj4gWyAgICAwLjE0MjM1M10gIHM1IDogZmZmZmZmZmY4 MTEzNTAzOCBzNiA6IGZmZmZmZmZmODA4MGNlODAgczcgOiBmZmZmZmZmZjgwODAwNDM4Cj4+PiBb ICAgIDAuMTQyNTg0XSAgczggOiBmZmZmZmZmZjgwYmM2NTc4IHM5IDogMDAwMDAwMDAwMDAwMDAw OCBzMTA6IGZmZmZmZmZmODA2MDAwYWMKPj4+IFsgICAgMC4xNDI4MTBdICBzMTE6IDAwMDAwMDAw MDAwMDAwMDAgdDMgOiBmZmZmZmZmZmZmZmZmZmZjIHQ0IDogMDAwMDAwMDAwMDAwMDAwMAo+Pj4g WyAgICAwLjE0MzA0Ml0gIHQ1IDogMDAwMDAwMDAwMDAwMDE1NSB0NiA6IDAwMDAwMDAwMDAwMDAz ZmYKPj4+IFsgICAgMC4xNDMyMjBdIHN0YXR1czogMDAwMDAwMDAwMDAwMDEyMCBiYWRhZGRyOiBm ZmZmZmZmZjgxMjAxMjIwIGNhdXNlOiAwMDAwMDAwMDAwMDAwMDBmCj4+PiBbICAgIDAuMTQzNTYw XSBbPGZmZmZmZmZmODAyOTgwNmM+XSBfX21lbXNldCsweGM0LzB4ZmMKPj4+IFsgICAgMC4xNDM4 NTldIFs8ZmZmZmZmZmY4MDYxZTk4ND5dIGluaXRfZGVmYXVsdF9mbG93X2Rpc3NlY3RvcnMrMHgy Mi8weDYwCj4+PiBbICAgIDAuMTQ0MDkyXSBbPGZmZmZmZmZmODAwMDEwZmM+XSBkb19vbmVfaW5p dGNhbGwrMHgzZS8weDE2OAo+Pj4gWyAgICAwLjE0NDI3OF0gWzxmZmZmZmZmZjgwNjAwZGYwPl0g a2VybmVsX2luaXRfZnJlZWFibGUrMHgxYzgvMHgyMjQKPj4+IFsgICAgMC4xNDQ0NzldIFs8ZmZm ZmZmZmY4MDQ4NjhhOD5dIGtlcm5lbF9pbml0KzB4MTIvMHgxMTAKPj4+IFsgICAgMC4xNDQ2NThd IFs8ZmZmZmZmZmY4MDAwMjJkZT5dIHJldF9mcm9tX2V4Y2VwdGlvbisweDAvMHhjCj4+PiBbICAg IDAuMTQ1MTI0XSAtLS1bIGVuZCB0cmFjZSBmMWU5NjQzZGFhNDZkNTkxIF0tLS0KPj4+Cj4+PiBB ZnRlciBzb21lIGludmVzdGlnYXRpb24sIEkgdGhpbmsgSSBmb3VuZCB0aGUgcm9vdCBjYXVzZTog Y29tbWl0Cj4+PiAyYmZjNmNkODFiZCAoIm1vdmUga2VybmVsIG1hcHBpbmcgb3V0c2lkZSBvZiBs aW5lYXIgbWFwcGluZyIpIG1vdmVzCj4+PiBCUEYgSklUIHJlZ2lvbiBhZnRlciB0aGUga2VybmVs Ogo+Pj4KPj4+IFRoZSAmX2VuZCBpcyB1bmxpa2VseSBhbGlnbmVkIHdpdGggUE1EIHNpemUsIHNv IHRoZSBmcm9udCBicGYgaml0Cj4+PiByZWdpb24gc2l0cyB3aXRoIHBhcnQgb2Yga2VybmVsIC5k YXRhIHNlY3Rpb24gaW4gb25lIFBNRCBzaXplIG1hcHBpbmcuCj4+PiBCdXQga2VybmVsIGlzIG1h cHBlZCBpbiBQTUQgU0laRSwgd2hlbiBicGZfaml0X2JpbmFyeV9sb2NrX3JvKCkgaXMKPj4+IGNh bGxlZCB0byBtYWtlIHRoZSBmaXJzdCBicGYgaml0IHByb2cgUk9YLCB3ZSB3aWxsIG1ha2UgcGFy dCBvZiBrZXJuZWwKPj4+IC5kYXRhIHNlY3Rpb24gUk8gdG9vLCBzbyB3aGVuIHdlIHdyaXRlIHRv LCBmb3IgZXhhbXBsZSBtZW1zZXQgdGhlCj4+PiAuZGF0YSBzZWN0aW9uLCBNTVUgd2lsbCB0cmln Z2VyIGEgc3RvcmUgcGFnZSBmYXVsdC4KPj4KPj4gR29vZCBjYXRjaCwgd2UgbWFrZSBzdXJlIG5v IHBoeXNpY2FsIGFsbG9jYXRpb24gaGFwcGVucyBiZXR3ZWVuIF9lbmQgYW5kCj4+IHRoZSBuZXh0 IFBNRCBhbGlnbmVkIGFkZHJlc3MsIGJ1dCBJIG1pc3NlZCB0aGlzIG9uZS4KPj4KPj4+Cj4+PiBU byBmaXggdGhlIGlzc3VlLCB3ZSBuZWVkIHRvIGVuc3VyZSB0aGUgQlBGIEpJVCByZWdpb24gaXMg UE1EIHNpemUKPj4+IGFsaWduZWQuIFRoaXMgcGF0Y2ggYWNjaGlldmUgdGhpcyBnb2FsIGJ5IHJl c3RvcmluZyB0aGUgQlBGIEpJVCByZWdpb24KPj4+IHRvIG9yaWdpbmFsIHBvc2l0aW9uLCBJLkUg dGhlIDEyOE1CIGJlZm9yZSBrZXJuZWwgLnRleHQgc2VjdGlvbi4KPj4KPj4gQnV0IEkgZGlzYWdy ZWUgd2l0aCB5b3VyIHNvbHV0aW9uOiBJIG1hZGUgc3VyZSBtb2R1bGVzIGFuZCBCUEYgcHJvZ3Jh bXMKPj4gZ2V0IHRoZWlyIG93biB2aXJ0dWFsIHJlZ2lvbnMgdG8gYXZvaWQgd29yc3QgY2FzZSBz Y2VuYXJpbyB3aGVyZSBvbmUKPj4gY291bGQgYWxsb2NhdGUgYWxsIHRoZSBzcGFjZSBhbmQgbGVh dmUgbm90aGluZyB0byB0aGUgb3RoZXIgKHdlIGFyZQo+PiBsaW1pdGVkIHRvICstIDJHQiBvZmZz ZXQpLiBXaHkgZG9uJ3QganVzdCBhbGlnbiBCUEZfSklUX1JFR0lPTl9TVEFSVCB0bwo+PiB0aGUg bmV4dCBQTUQgYWxpZ25lZCBhZGRyZXNzPwo+IAo+IE9yaWdpbmFsbHksIEkgcGxhbmVkIHRvIGZp eCB0aGUgaXNzdWUgYnkgYWxpZ25pbmcgQlBGX0pJVF9SRUdJT05fU1RBUlQsIGJ1dAo+IElJUkMs IEJQRiBleHBlcnRzIGFyZSBhZGRpbmcgKG9yIGhhdmUgYWRkZWQpICJDYWxsaW5nIGtlcm5lbCBm dW5jdGlvbnMgZnJvbSBCUEYiCj4gZmVhdHVyZSwgdGhlcmUncyBhIHJpc2sgdGhhdCBCUEYgSklU IHJlZ2lvbiBpcyBiZXlvbmQgdGhlIDJHQiBvZiBtb2R1bGUgcmVnaW9uOgo+IAo+IC0tLS0tLQo+ IG1vZHVsZQo+IC0tLS0tLQo+IGtlcm5lbAo+IC0tLS0tLQo+IEJQRl9KSVQKPiAKPiBTbyBJIG1h ZGUgdGhpcyBwYXRjaCBmaW5hbGx5LiBJbiB0aGlzIHBhdGNoLCB3ZSBsZXQgQlBGIEpJVCByZWdp b24gc2l0Cj4gYmV0d2VlbiBtb2R1bGUgYW5kIGtlcm5lbC4KPiAKCiBGcm9tIHdoYXQgSSByZWFk IGluIHRoZSBsd24gYXJ0aWNsZSwgSSdtIG5vdCBzdXJlIEJQRiBwcm9ncmFtcyBjYW4gY2FsbCAK bW9kdWxlIGZ1bmN0aW9ucywgY2FuIHNvbWVvbmUgdGVsbCB1cyBpZiBpdCBpcyBwb3NzaWJsZT8g T3IgcGxhbm5lZD8KCj4gVG8gYWRkcmVzcyAibWFrZSBzdXJlIG1vZHVsZXMgYW5kIEJQRiBwcm9n cmFtcyBnZXQgdGhlaXIgb3duIHZpcnR1YWwgcmVnaW9ucyIsCj4gd2hhdCBhYm91dCBzb21ldGhp bmcgYXMgYmVsb3cgKGFwcGxpZWQgYWdhaW5zdCB0aGlzIHBhdGNoKT8KPiAKPiBkaWZmIC0tZ2l0 IGEvYXJjaC9yaXNjdi9pbmNsdWRlL2FzbS9wZ3RhYmxlLmggYi9hcmNoL3Jpc2N2L2luY2x1ZGUv YXNtL3BndGFibGUuaAo+IGluZGV4IDM4MGNkM2E3ZTU0OC4uZGExMTU4ZjEwYjA5IDEwMDY0NAo+ IC0tLSBhL2FyY2gvcmlzY3YvaW5jbHVkZS9hc20vcGd0YWJsZS5oCj4gKysrIGIvYXJjaC9yaXNj di9pbmNsdWRlL2FzbS9wZ3RhYmxlLmgKPiBAQCAtMzEsNyArMzEsNyBAQAo+ICAgI2RlZmluZSBC UEZfSklUX1JFR0lPTl9TSVpFCShTWl8xMjhNKQo+ICAgI2lmZGVmIENPTkZJR182NEJJVAo+ICAg I2RlZmluZSBCUEZfSklUX1JFR0lPTl9TVEFSVAkoQlBGX0pJVF9SRUdJT05fRU5EIC0gQlBGX0pJ VF9SRUdJT05fU0laRSkKPiAtI2RlZmluZSBCUEZfSklUX1JFR0lPTl9FTkQJKE1PRFVMRVNfRU5E KQo+ICsjZGVmaW5lIEJQRl9KSVRfUkVHSU9OX0VORAkoUEZOX0FMSUdOKCh1bnNpZ25lZCBsb25n KSZfc3RhcnQpKQo+ICAgI2Vsc2UKPiAgICNkZWZpbmUgQlBGX0pJVF9SRUdJT05fU1RBUlQJKFBB R0VfT0ZGU0VUIC0gQlBGX0pJVF9SRUdJT05fU0laRSkKPiAgICNkZWZpbmUgQlBGX0pJVF9SRUdJ T05fRU5ECShWTUFMTE9DX0VORCkKPiBAQCAtNDAsNyArNDAsNyBAQAo+ICAgLyogTW9kdWxlcyBh bHdheXMgbGl2ZSBiZWZvcmUgdGhlIGtlcm5lbCAqLwo+ICAgI2lmZGVmIENPTkZJR182NEJJVAo+ ICAgI2RlZmluZSBNT0RVTEVTX1ZBRERSCShQRk5fQUxJR04oKHVuc2lnbmVkIGxvbmcpJl9lbmQp IC0gU1pfMkcpCj4gLSNkZWZpbmUgTU9EVUxFU19FTkQJKFBGTl9BTElHTigodW5zaWduZWQgbG9u ZykmX3N0YXJ0KSkKPiArI2RlZmluZSBNT0RVTEVTX0VORAkoQlBGX0pJVF9SRUdJT05fRU5EKQo+ ICAgI2VuZGlmCj4gICAKPiAKCkluIGNhc2UgaXQgaXMgcG9zc2libGUsIEkgd291bGQgbGV0IHRo ZSB2bWFsbG9jIGFsbG9jYXRvciBoYW5kbGUgdGhlIApjYXNlIHdoZXJlIG1vZHVsZXMgc3RlYWwg cm9vbSBmcm9tIEJQRjogSSB3b3VsZCB0aGVuIG5vdCBpbXBsZW1lbnQgdGhlIAphYm92ZSBidXQg cmF0aGVyIHlvdXIgZmlyc3QgcGF0Y2guCgpBbmQgZG8gbm90IGZvcmdldCB0byBtb2RpZnkgRG9j dW1lbnRhdGlvbi9yaXNjdi92bS1sYXlvdXQucnN0IAphY2NvcmRpbmdseSBhbmQgcmVtb3ZlIHRo ZSBjb21tZW50ICIvKiBLQVNMUiBzaG91bGQgbGVhdmUgYXQgbGVhc3QgMTI4TUIgCmZvciBCUEYg YWZ0ZXIgdGhlIGtlcm5lbCAqLyIKClRoYW5rcywKCkFsZXgKCj4gCj4+Cj4+IEFnYWluLCBnb29k IGNhdGNoLCB0aGFua3MsCj4+Cj4+IEFsZXgKPj4KPj4+Cj4+PiBSZXBvcnRlZC1ieTogQW5kcmVh cyBTY2h3YWIgPHNjaHdhYkBsaW51eC1tNjhrLm9yZz4KPj4+IFNpZ25lZC1vZmYtYnk6IEppc2hl bmcgWmhhbmcgPGpzemhhbmdAa2VybmVsLm9yZz4KPj4+IC0tLQo+Pj4gICAgYXJjaC9yaXNjdi9p bmNsdWRlL2FzbS9wZ3RhYmxlLmggfCA1ICsrLS0tCj4+PiAgICAxIGZpbGUgY2hhbmdlZCwgMiBp bnNlcnRpb25zKCspLCAzIGRlbGV0aW9ucygtKQo+Pj4KPj4+IGRpZmYgLS1naXQgYS9hcmNoL3Jp c2N2L2luY2x1ZGUvYXNtL3BndGFibGUuaCBiL2FyY2gvcmlzY3YvaW5jbHVkZS9hc20vcGd0YWJs ZS5oCj4+PiBpbmRleCA5NDY5ZjQ2NGU3MWEuLjM4MGNkM2E3ZTU0OCAxMDA2NDQKPj4+IC0tLSBh L2FyY2gvcmlzY3YvaW5jbHVkZS9hc20vcGd0YWJsZS5oCj4+PiArKysgYi9hcmNoL3Jpc2N2L2lu Y2x1ZGUvYXNtL3BndGFibGUuaAo+Pj4gQEAgLTMwLDkgKzMwLDggQEAKPj4+ICAgIAo+Pj4gICAg I2RlZmluZSBCUEZfSklUX1JFR0lPTl9TSVpFCShTWl8xMjhNKQo+Pj4gICAgI2lmZGVmIENPTkZJ R182NEJJVAo+Pj4gLS8qIEtBU0xSIHNob3VsZCBsZWF2ZSBhdCBsZWFzdCAxMjhNQiBmb3IgQlBG IGFmdGVyIHRoZSBrZXJuZWwgKi8KPj4+IC0jZGVmaW5lIEJQRl9KSVRfUkVHSU9OX1NUQVJUCVBG Tl9BTElHTigodW5zaWduZWQgbG9uZykmX2VuZCkKPj4+IC0jZGVmaW5lIEJQRl9KSVRfUkVHSU9O X0VORAkoQlBGX0pJVF9SRUdJT05fU1RBUlQgKyBCUEZfSklUX1JFR0lPTl9TSVpFKQo+Pj4gKyNk ZWZpbmUgQlBGX0pJVF9SRUdJT05fU1RBUlQJKEJQRl9KSVRfUkVHSU9OX0VORCAtIEJQRl9KSVRf UkVHSU9OX1NJWkUpCj4+PiArI2RlZmluZSBCUEZfSklUX1JFR0lPTl9FTkQJKE1PRFVMRVNfRU5E KQo+Pj4gICAgI2Vsc2UKPj4+ICAgICNkZWZpbmUgQlBGX0pJVF9SRUdJT05fU1RBUlQJKFBBR0Vf T0ZGU0VUIC0gQlBGX0pJVF9SRUdJT05fU0laRSkKPj4+ICAgICNkZWZpbmUgQlBGX0pJVF9SRUdJ T05fRU5ECShWTUFMTE9DX0VORCkKPj4+ICAgIAo+IAo+IAo+IAo+IF9fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCj4gbGludXgtcmlzY3YgbWFpbGluZyBsaXN0 Cj4gbGludXgtcmlzY3ZAbGlzdHMuaW5mcmFkZWFkLm9yZwo+IGh0dHA6Ly9saXN0cy5pbmZyYWRl YWQub3JnL21haWxtYW4vbGlzdGluZm8vbGludXgtcmlzY3YKPiAKCl9fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4LXJpc2N2IG1haWxpbmcgbGlzdAps aW51eC1yaXNjdkBsaXN0cy5pbmZyYWRlYWQub3JnCmh0dHA6Ly9saXN0cy5pbmZyYWRlYWQub3Jn L21haWxtYW4vbGlzdGluZm8vbGludXgtcmlzY3YK