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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id A5DD1C001B0 for ; Mon, 3 Jul 2023 20:03:02 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231308AbjGCUDB (ORCPT ); Mon, 3 Jul 2023 16:03:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57538 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229698AbjGCUC7 (ORCPT ); Mon, 3 Jul 2023 16:02:59 -0400 Received: from mail-qt1-x835.google.com (mail-qt1-x835.google.com [IPv6:2607:f8b0:4864:20::835]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 92954E6E for ; Mon, 3 Jul 2023 13:02:50 -0700 (PDT) Received: by mail-qt1-x835.google.com with SMTP id d75a77b69052e-401d1d967beso507561cf.0 for ; Mon, 03 Jul 2023 13:02:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1688414569; x=1691006569; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=BMuT/+syCV4c1WG89jC5mwfdKqUcMRKNlcTUW/qaIFg=; b=T4wMwr0XDGkMRvR6bldNgg+QHWaQPjK97wh9cIQM8GYjuDBn3iPkYyx03IuCBHGa7g +MB+v5A0BHSJuLGoM/CO3O3L8nKZBXcGNWkElDgrt9QcSyg3/1AOXwnWMfAl+3QF2IAH FXOBm24k2StmHrScGuOy15PUesZCej6CLaOIOlv9Uf0sixOu4welwkTsUbCY0MZtBgjV dALy5faYwPWK7poes51Sany+jq0IsmgJp72q+TZfRwf9Vfdaeesib3mg1oLQYeemou39 Kq6GGzvJvNjFg2H+DM/CORlxemdM9UsRXsCyf1oGaaBU5QbrHE7ymtSDvtnWUj1J2/BA Gfqg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688414569; x=1691006569; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=BMuT/+syCV4c1WG89jC5mwfdKqUcMRKNlcTUW/qaIFg=; b=K40549PzbulrnCviTRE5+6mys/ku9/VZ7W5z8Fex9Dx48EnqEpgqtvudAtFQauvLSk anpIR/ztyVB5L5u647DyYMjgr1xr2NiBmIb4enimeCkIkil8z3+3OGPPlDTxJG2KUBNt p5o8RZav3Tj4YZRTV/IQb1RKZzY68pnTJ/7lvEiELRqnVtuzM31mubTpsVA2mu0jsgXD vMyBB+LaRYE62AQXKyJZehHe0jXZ10C2nhJ8hOXamkR5FyjArU3EmwUwCc7MGl7vabOQ K16+n3knz1OheUAyovl0RpbenTC4eh0fgVUsv84wp+HzbkbYOJRSdLAmPKlC0lJFs25y nlIQ== X-Gm-Message-State: ABy/qLYl6uOa1Nb4uOlP8Nq+Sl4dLx6BKWsi9YoHC+UzKPB6u7WFEhWz 3vtXBx2B/OcwbqI7J9ExoVbOdw39w6BCc0MNLd5Eng== X-Google-Smtp-Source: APBJJlGcGPrHB0fcUR30aX3ykUsThqZrdZrGuMC3nsN9VYDLkTa9bl1zgnL+tlVOV5ZfuXX7BCMr/IF5nuZmUE6JKQQ= X-Received: by 2002:ac8:7f12:0:b0:3f8:5b2:aeee with SMTP id f18-20020ac87f12000000b003f805b2aeeemr15861qtk.22.1688414569607; Mon, 03 Jul 2023 13:02:49 -0700 (PDT) MIME-Version: 1.0 References: <20230703135330.1865927-1-ryan.roberts@arm.com> <20230703135330.1865927-6-ryan.roberts@arm.com> In-Reply-To: <20230703135330.1865927-6-ryan.roberts@arm.com> From: Yu Zhao Date: Mon, 3 Jul 2023 14:02:13 -0600 Message-ID: Subject: Re: [PATCH v2 5/5] arm64: mm: Override arch_wants_pte_order() To: Ryan Roberts Cc: Andrew Morton , Matthew Wilcox , "Kirill A. Shutemov" , Yin Fengwei , David Hildenbrand , Catalin Marinas , Will Deacon , Anshuman Khandual , Yang Shi , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jul 3, 2023 at 7:53=E2=80=AFAM Ryan Roberts = wrote: > > Define an arch-specific override of arch_wants_pte_order() so that when > FLEXIBLE_THP is enabled, large folios will be allocated for anonymous > memory with an order that is compatible with arm64's contpte mappings. > > arch_wants_pte_order() returns an order according to the following > policy: For the unhinted case, when THP is not requested for the vma, > don't allow anything bigger than 64K. This means we don't waste too much > memory. Additionally, for 4K pages this is the contpte size, and for > 16K, this is (usually) the HPA size when the uarch feature is > implemented. For the hinted case, when THP is requested for the vma, > allow the contpte size for all page size configurations; 64K for 4K, 2M > for 16K and 2M for 64K. > > Additionally, the THP and NOTHP order constants are defined using > Kconfig so it is possible to override them at build time. > > Signed-off-by: Ryan Roberts > --- > arch/arm64/Kconfig | 12 ++++++++++++ > arch/arm64/include/asm/pgtable.h | 4 ++++ > arch/arm64/mm/mmu.c | 8 ++++++++ > 3 files changed, 24 insertions(+) > > diff --git a/arch/arm64/Kconfig b/arch/arm64/Kconfig > index 343e1e1cae10..689c5bf13dc1 100644 > --- a/arch/arm64/Kconfig > +++ b/arch/arm64/Kconfig > @@ -281,6 +281,18 @@ config ARM64_CONT_PMD_SHIFT > default 5 if ARM64_16K_PAGES > default 4 > > +config ARM64_PTE_ORDER_NOTHP > + int > + default 0 if ARM64_64K_PAGES # 64K (1 page) > + default 2 if ARM64_16K_PAGES # 64K (4 pages; benefits from HPA= where HW supports it) > + default 4 if ARM64_4K_PAGES # 64K (16 pages; eligible for con= tpte-mapping) > + > +config ARM64_PTE_ORDER_THP > + int > + default 5 if ARM64_64K_PAGES # 2M (32 pages; eligible for con= tpte-mapping) > + default 7 if ARM64_16K_PAGES # 2M (128 pages; eligible for co= ntpte-mapping) > + default 4 if ARM64_4K_PAGES # 64K (16 pages; eligible for con= tpte-mapping) > + > config ARCH_MMAP_RND_BITS_MIN > default 14 if ARM64_64K_PAGES > default 16 if ARM64_16K_PAGES > diff --git a/arch/arm64/include/asm/pgtable.h b/arch/arm64/include/asm/pg= table.h > index 6fd012663a01..8463d5f9f307 100644 > --- a/arch/arm64/include/asm/pgtable.h > +++ b/arch/arm64/include/asm/pgtable.h > @@ -1117,6 +1117,10 @@ extern pte_t ptep_modify_prot_start(struct vm_area= _struct *vma, > extern void ptep_modify_prot_commit(struct vm_area_struct *vma, > unsigned long addr, pte_t *ptep, > pte_t old_pte, pte_t new_pte); > + > +#define arch_wants_pte_order arch_wants_pte_order > +extern int arch_wants_pte_order(struct vm_area_struct *vma); > + > #endif /* !__ASSEMBLY__ */ > > #endif /* __ASM_PGTABLE_H */ > diff --git a/arch/arm64/mm/mmu.c b/arch/arm64/mm/mmu.c > index af6bc8403ee4..8556c4a9b507 100644 > --- a/arch/arm64/mm/mmu.c > +++ b/arch/arm64/mm/mmu.c > @@ -1481,3 +1481,11 @@ void ptep_modify_prot_commit(struct vm_area_struct= *vma, unsigned long addr, pte > { > set_pte_at(vma->vm_mm, addr, ptep, pte); > } > + > +int arch_wants_pte_order(struct vm_area_struct *vma) > +{ > + if (hugepage_vma_check(vma, vma->vm_flags, false, true, true)) > + return CONFIG_ARM64_PTE_ORDER_THP; > + else > + return CONFIG_ARM64_PTE_ORDER_NOTHP; > +} I don't really like this because it's a mix of h/w preference and s/w policy -- from my POV, it's supposed to be the former only. The policy part should be left to core MM (arch-independent). That being said, no objection if ARM MM people think this is really what they want. 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 F0958C001B0 for ; Mon, 3 Jul 2023 20:03:22 +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:Cc:To:Subject:Message-ID:Date:From: In-Reply-To:References:MIME-Version:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=bVskO41J6Jdj0yr4ymTVSwYCRkL2Oy8BJS2tI9TEw88=; b=x0SSSiBtNkI1ef 7VQGTstzjKFPqC4NzGwhr64xLv3Cp4l3dt7Y0AZmIedNgbg8e4tvrWFkIK4uUxMIgSKvmtgfyy2f2 sLsE+whgK+3kLFJiW7muCMIFdkJ5zFpvCVxF7XlF9Uacj5uHHpfjzMkFheGtsW1+LHKqZsWXX3yiU O/NZFaBEZhYZ5nEcf5pDX3cO+zEp7Xhx52OKaWRc4dKp2PU3buatRKhM+2i20ZVfMszC0/6mMUDAI hyBX5Q5cYIBh5bSH4xdafFu1PTqp9soJJzBIuSIMJDDKL1OZUoCo1PQRxJXYvXwF1MbaWhbPxgruw 34O2bWxKAPb8CZLsSOCw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qGPl7-00BLJD-0F; Mon, 03 Jul 2023 20:02:53 +0000 Received: from mail-qt1-x835.google.com ([2607:f8b0:4864:20::835]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1qGPl4-00BLIM-2M for linux-arm-kernel@lists.infradead.org; Mon, 03 Jul 2023 20:02:52 +0000 Received: by mail-qt1-x835.google.com with SMTP id d75a77b69052e-4007b5bafceso446661cf.1 for ; Mon, 03 Jul 2023 13:02:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1688414569; x=1691006569; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=BMuT/+syCV4c1WG89jC5mwfdKqUcMRKNlcTUW/qaIFg=; b=T4wMwr0XDGkMRvR6bldNgg+QHWaQPjK97wh9cIQM8GYjuDBn3iPkYyx03IuCBHGa7g +MB+v5A0BHSJuLGoM/CO3O3L8nKZBXcGNWkElDgrt9QcSyg3/1AOXwnWMfAl+3QF2IAH FXOBm24k2StmHrScGuOy15PUesZCej6CLaOIOlv9Uf0sixOu4welwkTsUbCY0MZtBgjV dALy5faYwPWK7poes51Sany+jq0IsmgJp72q+TZfRwf9Vfdaeesib3mg1oLQYeemou39 Kq6GGzvJvNjFg2H+DM/CORlxemdM9UsRXsCyf1oGaaBU5QbrHE7ymtSDvtnWUj1J2/BA Gfqg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688414569; x=1691006569; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=BMuT/+syCV4c1WG89jC5mwfdKqUcMRKNlcTUW/qaIFg=; b=UgAcfjSWXdEFNUckfnr+Ka+fCIOoN8PceCwZI4J0Bi2ASdMERR5b2bdeC+0jT9Xjzk B1J0il7vYdd2zZhi+2NtzkXmUhl9/hyWOH+FmgOTC2RXaWwCzQ6JPS5Vgesjd68Q4k0g hwchx4rSnfCUB2gh+JUQGA7BWRtbCK2x+hjfhuaKF/JoZiRLTVAnFRZwdZ0gT1k5dxx3 g4ohr8OnBIQc02tGzxkH69CQqOFol+7aELlztmc5FlVfUwczOGXxdqX43II+8uXKt/FF YjiSpsKDNS/rfcMGrB4bedAIzQeB8ITm04wc5ecnHt+8JU50V9jHdOJS0e3UGJEsYu+/ /UKA== X-Gm-Message-State: ABy/qLYSLNx72qJkzswkOsahLRhP6KfyiXHpCevELws5Xxs2AgmyySHF 3gNhI0JFqE2U8mXWyZ2oIJqht3ZHHqaQR0INNPlfTg== X-Google-Smtp-Source: APBJJlGcGPrHB0fcUR30aX3ykUsThqZrdZrGuMC3nsN9VYDLkTa9bl1zgnL+tlVOV5ZfuXX7BCMr/IF5nuZmUE6JKQQ= X-Received: by 2002:ac8:7f12:0:b0:3f8:5b2:aeee with SMTP id f18-20020ac87f12000000b003f805b2aeeemr15861qtk.22.1688414569607; Mon, 03 Jul 2023 13:02:49 -0700 (PDT) MIME-Version: 1.0 References: <20230703135330.1865927-1-ryan.roberts@arm.com> <20230703135330.1865927-6-ryan.roberts@arm.com> In-Reply-To: <20230703135330.1865927-6-ryan.roberts@arm.com> From: Yu Zhao Date: Mon, 3 Jul 2023 14:02:13 -0600 Message-ID: Subject: Re: [PATCH v2 5/5] arm64: mm: Override arch_wants_pte_order() To: Ryan Roberts Cc: Andrew Morton , Matthew Wilcox , "Kirill A. Shutemov" , Yin Fengwei , David Hildenbrand , Catalin Marinas , Will Deacon , Anshuman Khandual , Yang Shi , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230703_130250_773933_21008328 X-CRM114-Status: GOOD ( 27.30 ) X-BeenThere: linux-arm-kernel@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-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org T24gTW9uLCBKdWwgMywgMjAyMyBhdCA3OjUz4oCvQU0gUnlhbiBSb2JlcnRzIDxyeWFuLnJvYmVy dHNAYXJtLmNvbT4gd3JvdGU6Cj4KPiBEZWZpbmUgYW4gYXJjaC1zcGVjaWZpYyBvdmVycmlkZSBv ZiBhcmNoX3dhbnRzX3B0ZV9vcmRlcigpIHNvIHRoYXQgd2hlbgo+IEZMRVhJQkxFX1RIUCBpcyBl bmFibGVkLCBsYXJnZSBmb2xpb3Mgd2lsbCBiZSBhbGxvY2F0ZWQgZm9yIGFub255bW91cwo+IG1l bW9yeSB3aXRoIGFuIG9yZGVyIHRoYXQgaXMgY29tcGF0aWJsZSB3aXRoIGFybTY0J3MgY29udHB0 ZSBtYXBwaW5ncy4KPgo+IGFyY2hfd2FudHNfcHRlX29yZGVyKCkgcmV0dXJucyBhbiBvcmRlciBh Y2NvcmRpbmcgdG8gdGhlIGZvbGxvd2luZwo+IHBvbGljeTogRm9yIHRoZSB1bmhpbnRlZCBjYXNl LCB3aGVuIFRIUCBpcyBub3QgcmVxdWVzdGVkIGZvciB0aGUgdm1hLAo+IGRvbid0IGFsbG93IGFu eXRoaW5nIGJpZ2dlciB0aGFuIDY0Sy4gVGhpcyBtZWFucyB3ZSBkb24ndCB3YXN0ZSB0b28gbXVj aAo+IG1lbW9yeS4gQWRkaXRpb25hbGx5LCBmb3IgNEsgcGFnZXMgdGhpcyBpcyB0aGUgY29udHB0 ZSBzaXplLCBhbmQgZm9yCj4gMTZLLCB0aGlzIGlzICh1c3VhbGx5KSB0aGUgSFBBIHNpemUgd2hl biB0aGUgdWFyY2ggZmVhdHVyZSBpcwo+IGltcGxlbWVudGVkLiBGb3IgdGhlIGhpbnRlZCBjYXNl LCB3aGVuIFRIUCBpcyByZXF1ZXN0ZWQgZm9yIHRoZSB2bWEsCj4gYWxsb3cgdGhlIGNvbnRwdGUg c2l6ZSBmb3IgYWxsIHBhZ2Ugc2l6ZSBjb25maWd1cmF0aW9uczsgNjRLIGZvciA0SywgMk0KPiBm b3IgMTZLIGFuZCAyTSBmb3IgNjRLLgo+Cj4gQWRkaXRpb25hbGx5LCB0aGUgVEhQIGFuZCBOT1RI UCBvcmRlciBjb25zdGFudHMgYXJlIGRlZmluZWQgdXNpbmcKPiBLY29uZmlnIHNvIGl0IGlzIHBv c3NpYmxlIHRvIG92ZXJyaWRlIHRoZW0gYXQgYnVpbGQgdGltZS4KPgo+IFNpZ25lZC1vZmYtYnk6 IFJ5YW4gUm9iZXJ0cyA8cnlhbi5yb2JlcnRzQGFybS5jb20+Cj4gLS0tCj4gIGFyY2gvYXJtNjQv S2NvbmZpZyAgICAgICAgICAgICAgIHwgMTIgKysrKysrKysrKysrCj4gIGFyY2gvYXJtNjQvaW5j bHVkZS9hc20vcGd0YWJsZS5oIHwgIDQgKysrKwo+ICBhcmNoL2FybTY0L21tL21tdS5jICAgICAg ICAgICAgICB8ICA4ICsrKysrKysrCj4gIDMgZmlsZXMgY2hhbmdlZCwgMjQgaW5zZXJ0aW9ucygr KQo+Cj4gZGlmZiAtLWdpdCBhL2FyY2gvYXJtNjQvS2NvbmZpZyBiL2FyY2gvYXJtNjQvS2NvbmZp Zwo+IGluZGV4IDM0M2UxZTFjYWUxMC4uNjg5YzViZjEzZGMxIDEwMDY0NAo+IC0tLSBhL2FyY2gv YXJtNjQvS2NvbmZpZwo+ICsrKyBiL2FyY2gvYXJtNjQvS2NvbmZpZwo+IEBAIC0yODEsNiArMjgx LDE4IEBAIGNvbmZpZyBBUk02NF9DT05UX1BNRF9TSElGVAo+ICAgICAgICAgZGVmYXVsdCA1IGlm IEFSTTY0XzE2S19QQUdFUwo+ICAgICAgICAgZGVmYXVsdCA0Cj4KPiArY29uZmlnIEFSTTY0X1BU RV9PUkRFUl9OT1RIUAo+ICsgICAgICAgaW50Cj4gKyAgICAgICBkZWZhdWx0IDAgaWYgQVJNNjRf NjRLX1BBR0VTICAgICMgNjRLICgxIHBhZ2UpCj4gKyAgICAgICBkZWZhdWx0IDIgaWYgQVJNNjRf MTZLX1BBR0VTICAgICMgNjRLICg0IHBhZ2VzOyBiZW5lZml0cyBmcm9tIEhQQSB3aGVyZSBIVyBz dXBwb3J0cyBpdCkKPiArICAgICAgIGRlZmF1bHQgNCBpZiBBUk02NF80S19QQUdFUyAgICAgIyA2 NEsgKDE2IHBhZ2VzOyBlbGlnaWJsZSBmb3IgY29udHB0ZS1tYXBwaW5nKQo+ICsKPiArY29uZmln IEFSTTY0X1BURV9PUkRFUl9USFAKPiArICAgICAgIGludAo+ICsgICAgICAgZGVmYXVsdCA1IGlm IEFSTTY0XzY0S19QQUdFUyAgICAjIDJNICAoMzIgcGFnZXM7IGVsaWdpYmxlIGZvciBjb250cHRl LW1hcHBpbmcpCj4gKyAgICAgICBkZWZhdWx0IDcgaWYgQVJNNjRfMTZLX1BBR0VTICAgICMgMk0g ICgxMjggcGFnZXM7IGVsaWdpYmxlIGZvciBjb250cHRlLW1hcHBpbmcpCj4gKyAgICAgICBkZWZh dWx0IDQgaWYgQVJNNjRfNEtfUEFHRVMgICAgICMgNjRLICgxNiBwYWdlczsgZWxpZ2libGUgZm9y IGNvbnRwdGUtbWFwcGluZykKPiArCj4gIGNvbmZpZyBBUkNIX01NQVBfUk5EX0JJVFNfTUlOCj4g ICAgICAgICBkZWZhdWx0IDE0IGlmIEFSTTY0XzY0S19QQUdFUwo+ICAgICAgICAgZGVmYXVsdCAx NiBpZiBBUk02NF8xNktfUEFHRVMKPiBkaWZmIC0tZ2l0IGEvYXJjaC9hcm02NC9pbmNsdWRlL2Fz bS9wZ3RhYmxlLmggYi9hcmNoL2FybTY0L2luY2x1ZGUvYXNtL3BndGFibGUuaAo+IGluZGV4IDZm ZDAxMjY2M2EwMS4uODQ2M2Q1ZjlmMzA3IDEwMDY0NAo+IC0tLSBhL2FyY2gvYXJtNjQvaW5jbHVk ZS9hc20vcGd0YWJsZS5oCj4gKysrIGIvYXJjaC9hcm02NC9pbmNsdWRlL2FzbS9wZ3RhYmxlLmgK PiBAQCAtMTExNyw2ICsxMTE3LDEwIEBAIGV4dGVybiBwdGVfdCBwdGVwX21vZGlmeV9wcm90X3N0 YXJ0KHN0cnVjdCB2bV9hcmVhX3N0cnVjdCAqdm1hLAo+ICBleHRlcm4gdm9pZCBwdGVwX21vZGlm eV9wcm90X2NvbW1pdChzdHJ1Y3Qgdm1fYXJlYV9zdHJ1Y3QgKnZtYSwKPiAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICB1bnNpZ25lZCBsb25nIGFkZHIsIHB0ZV90ICpwdGVwLAo+ ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHB0ZV90IG9sZF9wdGUsIHB0ZV90 IG5ld19wdGUpOwo+ICsKPiArI2RlZmluZSBhcmNoX3dhbnRzX3B0ZV9vcmRlciBhcmNoX3dhbnRz X3B0ZV9vcmRlcgo+ICtleHRlcm4gaW50IGFyY2hfd2FudHNfcHRlX29yZGVyKHN0cnVjdCB2bV9h cmVhX3N0cnVjdCAqdm1hKTsKPiArCj4gICNlbmRpZiAvKiAhX19BU1NFTUJMWV9fICovCj4KPiAg I2VuZGlmIC8qIF9fQVNNX1BHVEFCTEVfSCAqLwo+IGRpZmYgLS1naXQgYS9hcmNoL2FybTY0L21t L21tdS5jIGIvYXJjaC9hcm02NC9tbS9tbXUuYwo+IGluZGV4IGFmNmJjODQwM2VlNC4uODU1NmM0 YTliNTA3IDEwMDY0NAo+IC0tLSBhL2FyY2gvYXJtNjQvbW0vbW11LmMKPiArKysgYi9hcmNoL2Fy bTY0L21tL21tdS5jCj4gQEAgLTE0ODEsMyArMTQ4MSwxMSBAQCB2b2lkIHB0ZXBfbW9kaWZ5X3By b3RfY29tbWl0KHN0cnVjdCB2bV9hcmVhX3N0cnVjdCAqdm1hLCB1bnNpZ25lZCBsb25nIGFkZHIs IHB0ZQo+ICB7Cj4gICAgICAgICBzZXRfcHRlX2F0KHZtYS0+dm1fbW0sIGFkZHIsIHB0ZXAsIHB0 ZSk7Cj4gIH0KPiArCj4gK2ludCBhcmNoX3dhbnRzX3B0ZV9vcmRlcihzdHJ1Y3Qgdm1fYXJlYV9z dHJ1Y3QgKnZtYSkKPiArewo+ICsgICAgICAgaWYgKGh1Z2VwYWdlX3ZtYV9jaGVjayh2bWEsIHZt YS0+dm1fZmxhZ3MsIGZhbHNlLCB0cnVlLCB0cnVlKSkKPiArICAgICAgICAgICAgICAgcmV0dXJu IENPTkZJR19BUk02NF9QVEVfT1JERVJfVEhQOwo+ICsgICAgICAgZWxzZQo+ICsgICAgICAgICAg ICAgICByZXR1cm4gQ09ORklHX0FSTTY0X1BURV9PUkRFUl9OT1RIUDsKPiArfQoKSSBkb24ndCBy ZWFsbHkgbGlrZSB0aGlzIGJlY2F1c2UgaXQncyBhIG1peCBvZiBoL3cgcHJlZmVyZW5jZSBhbmQg cy93CnBvbGljeSAtLSBmcm9tIG15IFBPViwgaXQncyBzdXBwb3NlZCB0byBiZSB0aGUgZm9ybWVy IG9ubHkuIFRoZSBwb2xpY3kKcGFydCBzaG91bGQgYmUgbGVmdCB0byBjb3JlIE1NIChhcmNoLWlu ZGVwZW5kZW50KS4KClRoYXQgYmVpbmcgc2FpZCwgbm8gb2JqZWN0aW9uIGlmIEFSTSBNTSBwZW9w bGUgdGhpbmsgdGhpcyBpcyByZWFsbHkKd2hhdCB0aGV5IHdhbnQuCgpfX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1hcm0ta2VybmVsIG1haWxpbmcg bGlzdApsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xpc3RzLmlu ZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51eC1hcm0ta2VybmVsCg==