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 CE80EEB64DA for ; Tue, 4 Jul 2023 11:20:35 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230413AbjGDLUe (ORCPT ); Tue, 4 Jul 2023 07:20:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40420 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230258AbjGDLUb (ORCPT ); Tue, 4 Jul 2023 07:20:31 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 634EF10FD for ; Tue, 4 Jul 2023 04:19:54 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id EBCF22F4; Tue, 4 Jul 2023 04:20:35 -0700 (PDT) Received: from [10.1.35.40] (C02Z41KALVDN.cambridge.arm.com [10.1.35.40]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id EB4C63F73F; Tue, 4 Jul 2023 04:19:51 -0700 (PDT) Message-ID: <753fe3a7-e077-09d0-8233-fa834c11d280@arm.com> Date: Tue, 4 Jul 2023 12:19:50 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.12.0 Subject: Re: [PATCH v2 1/5] mm: Non-pmd-mappable, large folios for folio_add_new_anon_rmap() To: "Yin, Fengwei" , Yu Zhao Cc: Andrew Morton , Matthew Wilcox , "Kirill A. Shutemov" , 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 References: <20230703135330.1865927-1-ryan.roberts@arm.com> <20230703135330.1865927-2-ryan.roberts@arm.com> <9e2fe34e-7615-119c-43b3-31d0b8be3af0@intel.com> From: Ryan Roberts In-Reply-To: <9e2fe34e-7615-119c-43b3-31d0b8be3af0@intel.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/07/2023 03:13, Yin, Fengwei wrote: > > > On 7/4/2023 3:05 AM, Yu Zhao wrote: >> On Mon, Jul 3, 2023 at 7:53 AM Ryan Roberts wrote: >>> >>> In preparation for FLEXIBLE_THP support, improve >>> folio_add_new_anon_rmap() to allow a non-pmd-mappable, large folio to be >>> passed to it. In this case, all contained pages are accounted using the >>> "small" pages scheme. >> >> Nit: In this case, all *subpages* are accounted using the *order-0 >> folio* (or base page) scheme. > Matthew suggested not to use subpage with folio. Using page with folio: > https://lore.kernel.org/linux-mm/Y9qiS%2FIxZOMx62t6@casper.infradead.org/ OK, I'll change this to "In this case, all contained pages are accounted using the *order-0 folio* (or base page) scheme." > >> >>> Signed-off-by: Ryan Roberts >> >> Reviewed-by: Yu Zhao Thanks! >> >>> mm/rmap.c | 26 +++++++++++++++++++------- >>> 1 file changed, 19 insertions(+), 7 deletions(-) >>> >>> diff --git a/mm/rmap.c b/mm/rmap.c >>> index 1d8369549424..82ef5ba363d1 100644 >>> --- a/mm/rmap.c >>> +++ b/mm/rmap.c >>> @@ -1278,31 +1278,43 @@ void page_add_anon_rmap(struct page *page, struct vm_area_struct *vma, >>> * This means the inc-and-test can be bypassed. >>> * The folio does not have to be locked. >>> * >>> - * If the folio is large, it is accounted as a THP. As the folio >>> + * If the folio is pmd-mappable, it is accounted as a THP. As the folio >>> * is new, it's assumed to be mapped exclusively by a single process. >>> */ >>> void folio_add_new_anon_rmap(struct folio *folio, struct vm_area_struct *vma, >>> unsigned long address) >>> { >>> - int nr; >>> + int nr = folio_nr_pages(folio); >>> + int i; >>> + struct page *page; >>> >>> - VM_BUG_ON_VMA(address < vma->vm_start || address >= vma->vm_end, vma); >>> + VM_BUG_ON_VMA(address < vma->vm_start || >>> + address + (nr << PAGE_SHIFT) > vma->vm_end, vma); >>> __folio_set_swapbacked(folio); >>> >>> - if (likely(!folio_test_pmd_mappable(folio))) { >>> + if (!folio_test_large(folio)) { >>> /* increment count (starts at -1) */ >>> atomic_set(&folio->_mapcount, 0); >>> - nr = 1; >>> + __page_set_anon_rmap(folio, &folio->page, vma, address, 1); >>> + } else if (!folio_test_pmd_mappable(folio)) { >>> + /* increment count (starts at 0) */ >>> + atomic_set(&folio->_nr_pages_mapped, nr); >>> + >>> + page = &folio->page; >>> + for (i = 0; i < nr; i++, page++, address += PAGE_SIZE) { >>> + /* increment count (starts at -1) */ >>> + atomic_set(&page->_mapcount, 0); >>> + __page_set_anon_rmap(folio, page, vma, address, 1); >>> + } >> >> Nit: use folio_page(), e.g., Yep, will change for v3. >> >> } else if (!folio_test_pmd_mappable(folio)) { >> int i; >> >> for (i = 0; i < nr; i++) { >> struct page *page = folio_page(folio, i); >> >> /* increment count (starts at -1) */ >> atomic_set(&page->_mapcount, 0); >> __page_set_anon_rmap(folio, page, vma, address + PAGE_SIZE * i, 1); >> } >> /* increment count (starts at 0) */ >> atomic_set(&folio->_nr_pages_mapped, nr); >> } else { >> >>> } else { >>> /* increment count (starts at -1) */ >>> atomic_set(&folio->_entire_mapcount, 0); >>> atomic_set(&folio->_nr_pages_mapped, COMPOUND_MAPPED); >>> - nr = folio_nr_pages(folio); >>> __lruvec_stat_mod_folio(folio, NR_ANON_THPS, nr); >>> + __page_set_anon_rmap(folio, &folio->page, vma, address, 1); >>> } >>> >>> __lruvec_stat_mod_folio(folio, NR_ANON_MAPPED, nr); >>> - __page_set_anon_rmap(folio, &folio->page, vma, address, 1); >>> } 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 91399EB64D9 for ; Tue, 4 Jul 2023 11:20:26 +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:In-Reply-To:From:References:Cc:To: Subject:MIME-Version:Date:Message-ID:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=cr06iC2jaCc0sEJIWD4L1GUMjV9ykV/z+OyzIYUU2zY=; b=PykE5ObXjQMURH 6Da2EXnKBHq99TIYmMhx58T30A+x1DLnDRrnGI1htF6qb7I6udwCLkJQnspcWsgUF761U1s3om7wc J5fPehOHoz/19AIq+rE7poLuB1zVkCArcs1p0etC6PIUzMUGPuVQWtsrXl7UCQXDqnuyZexlvXTwf RkQwwz5R4FbMBADEB3x19t8crJVgB1EobVNEN0FBdwrcmAgekjEa189i25vbrYQmkPHr2D3qWTstF W/57ovSVws7pPt5jeKuMulIUO5bTPww/eNXCkQoL68ZJ5yZUMp5kk1uYZCz/Ra3M1S2U8Lm9qLAZX X63J8b1KrdhGGS/CUTgg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qGe4d-00D6iD-0h; Tue, 04 Jul 2023 11:19:59 +0000 Received: from foss.arm.com ([217.140.110.172]) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qGe4a-00D6gj-0Q for linux-arm-kernel@lists.infradead.org; Tue, 04 Jul 2023 11:19:58 +0000 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id EBCF22F4; Tue, 4 Jul 2023 04:20:35 -0700 (PDT) Received: from [10.1.35.40] (C02Z41KALVDN.cambridge.arm.com [10.1.35.40]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id EB4C63F73F; Tue, 4 Jul 2023 04:19:51 -0700 (PDT) Message-ID: <753fe3a7-e077-09d0-8233-fa834c11d280@arm.com> Date: Tue, 4 Jul 2023 12:19:50 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.12.0 Subject: Re: [PATCH v2 1/5] mm: Non-pmd-mappable, large folios for folio_add_new_anon_rmap() To: "Yin, Fengwei" , Yu Zhao Cc: Andrew Morton , Matthew Wilcox , "Kirill A. Shutemov" , 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 References: <20230703135330.1865927-1-ryan.roberts@arm.com> <20230703135330.1865927-2-ryan.roberts@arm.com> <9e2fe34e-7615-119c-43b3-31d0b8be3af0@intel.com> From: Ryan Roberts In-Reply-To: <9e2fe34e-7615-119c-43b3-31d0b8be3af0@intel.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230704_041956_266749_28FEB230 X-CRM114-Status: GOOD ( 20.02 ) 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 T24gMDQvMDcvMjAyMyAwMzoxMywgWWluLCBGZW5nd2VpIHdyb3RlOgo+IAo+IAo+IE9uIDcvNC8y MDIzIDM6MDUgQU0sIFl1IFpoYW8gd3JvdGU6Cj4+IE9uIE1vbiwgSnVsIDMsIDIwMjMgYXQgNzo1 M+KAr0FNIFJ5YW4gUm9iZXJ0cyA8cnlhbi5yb2JlcnRzQGFybS5jb20+IHdyb3RlOgo+Pj4KPj4+ IEluIHByZXBhcmF0aW9uIGZvciBGTEVYSUJMRV9USFAgc3VwcG9ydCwgaW1wcm92ZQo+Pj4gZm9s aW9fYWRkX25ld19hbm9uX3JtYXAoKSB0byBhbGxvdyBhIG5vbi1wbWQtbWFwcGFibGUsIGxhcmdl IGZvbGlvIHRvIGJlCj4+PiBwYXNzZWQgdG8gaXQuIEluIHRoaXMgY2FzZSwgYWxsIGNvbnRhaW5l ZCBwYWdlcyBhcmUgYWNjb3VudGVkIHVzaW5nIHRoZQo+Pj4gInNtYWxsIiBwYWdlcyBzY2hlbWUu Cj4+Cj4+IE5pdDogSW4gdGhpcyBjYXNlLCBhbGwgKnN1YnBhZ2VzKiAgYXJlIGFjY291bnRlZCB1 c2luZyB0aGUgKm9yZGVyLTAKPj4gZm9saW8qIChvciBiYXNlIHBhZ2UpIHNjaGVtZS4KPiBNYXR0 aGV3IHN1Z2dlc3RlZCBub3QgdG8gdXNlIHN1YnBhZ2Ugd2l0aCBmb2xpby4gVXNpbmcgcGFnZSB3 aXRoIGZvbGlvOgo+IGh0dHBzOi8vbG9yZS5rZXJuZWwub3JnL2xpbnV4LW1tL1k5cWlTJTJGSXha T014NjJ0NkBjYXNwZXIuaW5mcmFkZWFkLm9yZy8KCk9LLCBJJ2xsIGNoYW5nZSB0aGlzIHRvICJJ biB0aGlzIGNhc2UsIGFsbCBjb250YWluZWQgcGFnZXMgYXJlIGFjY291bnRlZCB1c2luZwp0aGUg Km9yZGVyLTAgZm9saW8qIChvciBiYXNlIHBhZ2UpIHNjaGVtZS4iCgo+IAo+Pgo+Pj4gU2lnbmVk LW9mZi1ieTogUnlhbiBSb2JlcnRzIDxyeWFuLnJvYmVydHNAYXJtLmNvbT4KPj4KPj4gUmV2aWV3 ZWQtYnk6IFl1IFpoYW8gPHl1emhhb0Bnb29nbGUuY29tPgoKVGhhbmtzIQoKPj4KPj4+ICBtbS9y bWFwLmMgfCAyNiArKysrKysrKysrKysrKysrKysrLS0tLS0tLQo+Pj4gIDEgZmlsZSBjaGFuZ2Vk LCAxOSBpbnNlcnRpb25zKCspLCA3IGRlbGV0aW9ucygtKQo+Pj4KPj4+IGRpZmYgLS1naXQgYS9t bS9ybWFwLmMgYi9tbS9ybWFwLmMKPj4+IGluZGV4IDFkODM2OTU0OTQyNC4uODJlZjViYTM2M2Qx IDEwMDY0NAo+Pj4gLS0tIGEvbW0vcm1hcC5jCj4+PiArKysgYi9tbS9ybWFwLmMKPj4+IEBAIC0x Mjc4LDMxICsxMjc4LDQzIEBAIHZvaWQgcGFnZV9hZGRfYW5vbl9ybWFwKHN0cnVjdCBwYWdlICpw YWdlLCBzdHJ1Y3Qgdm1fYXJlYV9zdHJ1Y3QgKnZtYSwKPj4+ICAgKiBUaGlzIG1lYW5zIHRoZSBp bmMtYW5kLXRlc3QgY2FuIGJlIGJ5cGFzc2VkLgo+Pj4gICAqIFRoZSBmb2xpbyBkb2VzIG5vdCBo YXZlIHRvIGJlIGxvY2tlZC4KPj4+ICAgKgo+Pj4gLSAqIElmIHRoZSBmb2xpbyBpcyBsYXJnZSwg aXQgaXMgYWNjb3VudGVkIGFzIGEgVEhQLiAgQXMgdGhlIGZvbGlvCj4+PiArICogSWYgdGhlIGZv bGlvIGlzIHBtZC1tYXBwYWJsZSwgaXQgaXMgYWNjb3VudGVkIGFzIGEgVEhQLiAgQXMgdGhlIGZv bGlvCj4+PiAgICogaXMgbmV3LCBpdCdzIGFzc3VtZWQgdG8gYmUgbWFwcGVkIGV4Y2x1c2l2ZWx5 IGJ5IGEgc2luZ2xlIHByb2Nlc3MuCj4+PiAgICovCj4+PiAgdm9pZCBmb2xpb19hZGRfbmV3X2Fu b25fcm1hcChzdHJ1Y3QgZm9saW8gKmZvbGlvLCBzdHJ1Y3Qgdm1fYXJlYV9zdHJ1Y3QgKnZtYSwK Pj4+ICAgICAgICAgICAgICAgICB1bnNpZ25lZCBsb25nIGFkZHJlc3MpCj4+PiAgewo+Pj4gLSAg ICAgICBpbnQgbnI7Cj4+PiArICAgICAgIGludCBuciA9IGZvbGlvX25yX3BhZ2VzKGZvbGlvKTsK Pj4+ICsgICAgICAgaW50IGk7Cj4+PiArICAgICAgIHN0cnVjdCBwYWdlICpwYWdlOwo+Pj4KPj4+ IC0gICAgICAgVk1fQlVHX09OX1ZNQShhZGRyZXNzIDwgdm1hLT52bV9zdGFydCB8fCBhZGRyZXNz ID49IHZtYS0+dm1fZW5kLCB2bWEpOwo+Pj4gKyAgICAgICBWTV9CVUdfT05fVk1BKGFkZHJlc3Mg PCB2bWEtPnZtX3N0YXJ0IHx8Cj4+PiArICAgICAgICAgICAgICAgICAgICAgICBhZGRyZXNzICsg KG5yIDw8IFBBR0VfU0hJRlQpID4gdm1hLT52bV9lbmQsIHZtYSk7Cj4+PiAgICAgICAgIF9fZm9s aW9fc2V0X3N3YXBiYWNrZWQoZm9saW8pOwo+Pj4KPj4+IC0gICAgICAgaWYgKGxpa2VseSghZm9s aW9fdGVzdF9wbWRfbWFwcGFibGUoZm9saW8pKSkgewo+Pj4gKyAgICAgICBpZiAoIWZvbGlvX3Rl c3RfbGFyZ2UoZm9saW8pKSB7Cj4+PiAgICAgICAgICAgICAgICAgLyogaW5jcmVtZW50IGNvdW50 IChzdGFydHMgYXQgLTEpICovCj4+PiAgICAgICAgICAgICAgICAgYXRvbWljX3NldCgmZm9saW8t Pl9tYXBjb3VudCwgMCk7Cj4+PiAtICAgICAgICAgICAgICAgbnIgPSAxOwo+Pj4gKyAgICAgICAg ICAgICAgIF9fcGFnZV9zZXRfYW5vbl9ybWFwKGZvbGlvLCAmZm9saW8tPnBhZ2UsIHZtYSwgYWRk cmVzcywgMSk7Cj4+PiArICAgICAgIH0gZWxzZSBpZiAoIWZvbGlvX3Rlc3RfcG1kX21hcHBhYmxl KGZvbGlvKSkgewo+Pj4gKyAgICAgICAgICAgICAgIC8qIGluY3JlbWVudCBjb3VudCAoc3RhcnRz IGF0IDApICovCj4+PiArICAgICAgICAgICAgICAgYXRvbWljX3NldCgmZm9saW8tPl9ucl9wYWdl c19tYXBwZWQsIG5yKTsKPj4+ICsKPj4+ICsgICAgICAgICAgICAgICBwYWdlID0gJmZvbGlvLT5w YWdlOwo+Pj4gKyAgICAgICAgICAgICAgIGZvciAoaSA9IDA7IGkgPCBucjsgaSsrLCBwYWdlKyss IGFkZHJlc3MgKz0gUEFHRV9TSVpFKSB7Cj4+PiArICAgICAgICAgICAgICAgICAgICAgICAvKiBp bmNyZW1lbnQgY291bnQgKHN0YXJ0cyBhdCAtMSkgKi8KPj4+ICsgICAgICAgICAgICAgICAgICAg ICAgIGF0b21pY19zZXQoJnBhZ2UtPl9tYXBjb3VudCwgMCk7Cj4+PiArICAgICAgICAgICAgICAg ICAgICAgICBfX3BhZ2Vfc2V0X2Fub25fcm1hcChmb2xpbywgcGFnZSwgdm1hLCBhZGRyZXNzLCAx KTsKPj4+ICsgICAgICAgICAgICAgICB9Cj4+Cj4+IE5pdDogdXNlIGZvbGlvX3BhZ2UoKSwgZS5n LiwKClllcCwgd2lsbCBjaGFuZ2UgZm9yIHYzLgoKPj4KPj4gICB9IGVsc2UgaWYgKCFmb2xpb190 ZXN0X3BtZF9tYXBwYWJsZShmb2xpbykpIHsKPj4gICAgIGludCBpOwo+Pgo+PiAgICAgZm9yIChp ID0gMDsgaSA8IG5yOyBpKyspIHsKPj4gICAgICAgc3RydWN0IHBhZ2UgKnBhZ2UgPSBmb2xpb19w YWdlKGZvbGlvLCBpKTsKPj4KPj4gICAgICAgLyogaW5jcmVtZW50IGNvdW50IChzdGFydHMgYXQg LTEpICovCj4+ICAgICAgIGF0b21pY19zZXQoJnBhZ2UtPl9tYXBjb3VudCwgMCk7Cj4+ICAgICAg IF9fcGFnZV9zZXRfYW5vbl9ybWFwKGZvbGlvLCBwYWdlLCB2bWEsIGFkZHJlc3MgKyBQQUdFX1NJ WkUgKiBpLCAxKTsKPj4gICAgIH0KPj4gICAgIC8qIGluY3JlbWVudCBjb3VudCAoc3RhcnRzIGF0 IDApICovCj4+ICAgICBhdG9taWNfc2V0KCZmb2xpby0+X25yX3BhZ2VzX21hcHBlZCwgbnIpOwo+ PiAgIH0gZWxzZSB7Cj4+Cj4+PiAgICAgICAgIH0gZWxzZSB7Cj4+PiAgICAgICAgICAgICAgICAg LyogaW5jcmVtZW50IGNvdW50IChzdGFydHMgYXQgLTEpICovCj4+PiAgICAgICAgICAgICAgICAg YXRvbWljX3NldCgmZm9saW8tPl9lbnRpcmVfbWFwY291bnQsIDApOwo+Pj4gICAgICAgICAgICAg ICAgIGF0b21pY19zZXQoJmZvbGlvLT5fbnJfcGFnZXNfbWFwcGVkLCBDT01QT1VORF9NQVBQRUQp Owo+Pj4gLSAgICAgICAgICAgICAgIG5yID0gZm9saW9fbnJfcGFnZXMoZm9saW8pOwo+Pj4gICAg ICAgICAgICAgICAgIF9fbHJ1dmVjX3N0YXRfbW9kX2ZvbGlvKGZvbGlvLCBOUl9BTk9OX1RIUFMs IG5yKTsKPj4+ICsgICAgICAgICAgICAgICBfX3BhZ2Vfc2V0X2Fub25fcm1hcChmb2xpbywgJmZv bGlvLT5wYWdlLCB2bWEsIGFkZHJlc3MsIDEpOwo+Pj4gICAgICAgICB9Cj4+Pgo+Pj4gICAgICAg ICBfX2xydXZlY19zdGF0X21vZF9mb2xpbyhmb2xpbywgTlJfQU5PTl9NQVBQRUQsIG5yKTsKPj4+ IC0gICAgICAgX19wYWdlX3NldF9hbm9uX3JtYXAoZm9saW8sICZmb2xpby0+cGFnZSwgdm1hLCBh ZGRyZXNzLCAxKTsKPj4+ICB9CgoKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX18KbGludXgtYXJtLWtlcm5lbCBtYWlsaW5nIGxpc3QKbGludXgtYXJtLWtlcm5l bEBsaXN0cy5pbmZyYWRlYWQub3JnCmh0dHA6Ly9saXN0cy5pbmZyYWRlYWQub3JnL21haWxtYW4v bGlzdGluZm8vbGludXgtYXJtLWtlcm5lbAo=