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 kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id C43D0C02181 for ; Mon, 20 Jan 2025 13:38:44 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 598B36B0082; Mon, 20 Jan 2025 08:38:44 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 548816B0083; Mon, 20 Jan 2025 08:38:44 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3EA5C6B0085; Mon, 20 Jan 2025 08:38:44 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0010.hostedemail.com [216.40.44.10]) by kanga.kvack.org (Postfix) with ESMTP id 2420F6B0082 for ; Mon, 20 Jan 2025 08:38:44 -0500 (EST) Received: from smtpin10.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id D79B21606E7 for ; Mon, 20 Jan 2025 13:38:43 +0000 (UTC) X-FDA: 83027935326.10.08E153C Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by imf20.hostedemail.com (Postfix) with ESMTP id 5E98B1C000E for ; Mon, 20 Jan 2025 13:38:41 +0000 (UTC) Authentication-Results: imf20.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=LI7LvlcZ; spf=pass (imf20.hostedemail.com: domain of david@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1737380321; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=77ySSBm3Ue9u/BQKETkuVelem4K4fa02GCJIZYADsKw=; b=bCBxO83QBpnieLf0oe2GUvY4STmHL2mjzjwBdEUHN1M0hg+uMsyep+ikhRQu0E1QSrB9dY bVnImU2Ixv38G/qsqAKJdJLMkM4xcT34sG12dGqiCE8kl+LumJPv8LtFIZ1tIcXEVCykO9 wNtor8FU6AK/FTZUMH4Hll46W7F22eQ= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1737380321; a=rsa-sha256; cv=none; b=BpXH2AUbUWqRptFDghifgzo9dW0YjHGQwIV4TPugLmLD+WaOaEn2twciHAFt6Ck99ZcGqR lBccAoleq8yQ0pjCUqU7G0vkUHkxiXFvRTpc9XAexoOxBJvVC6EcHWYlU/REyyRac9v3NC ypzu6vTtijFtrjnM7YkmW/5+CubxMXQ= ARC-Authentication-Results: i=1; imf20.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=LI7LvlcZ; spf=pass (imf20.hostedemail.com: domain of david@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=david@redhat.com; dmarc=pass (policy=none) header.from=redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1737380320; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:autocrypt:autocrypt; bh=77ySSBm3Ue9u/BQKETkuVelem4K4fa02GCJIZYADsKw=; b=LI7LvlcZDxoNTzgEz2bok8fT8E4YAVGCe/661EAfk41yPvVWUaf4v7tE+kYB/J3Mj2SrhH e8/ljZ3Q9L0ITF1s9kMdKxuDKs6sae6JnSmnoS0a1w3j0fXBS/nkmxmH970e/PWnPNFkNv jMOkCq/NtK4NN1aJekXedDd4R26G5Tw= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-495-WUb0Dym2MQ2t8FyMfzHTiA-1; Mon, 20 Jan 2025 08:38:39 -0500 X-MC-Unique: WUb0Dym2MQ2t8FyMfzHTiA-1 X-Mimecast-MFC-AGG-ID: WUb0Dym2MQ2t8FyMfzHTiA Received: by mail-wr1-f70.google.com with SMTP id ffacd0b85a97d-385dcadffebso1962847f8f.0 for ; Mon, 20 Jan 2025 05:38:39 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1737380318; x=1737985118; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:from:references:cc:to:subject:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=77ySSBm3Ue9u/BQKETkuVelem4K4fa02GCJIZYADsKw=; b=QFsS9rmmnsJ2XyU6mGy5h48yLzFX9atNrcmllpHNbNHiAB9LZNoOJYsefe6hdcNWHp T0ErxcThjeT2OHGQiScgaG6yzNZevUfYMBsMOOxp2YhO4MWP9Meez1RJ0PrC56kpBkq3 LGS9fsoTqko1htkkIhSokaIZjwXwGoZ5/iWLvtfDcshysZyVtKxW/hhjB1wGzVMqSNEA YW7eTflHrgkJRMl7sjlMRSAmdruWHySVzJnJv84imOACkS9uSL5FOTE2eVrdC1nBfiir S/YRGob/uPL8p9Fhw7YzlI4qv9b5ckF1WO4yKvdIysp68ksL2THrs0ywfh6pkMpaekHd uJAQ== X-Forwarded-Encrypted: i=1; AJvYcCWobEy9atILjKA7rjl6PkvPDHkxMJu3Dq4OWihhPhfIVC6uAAV5DtI/7ET1e/fdrfR6XZ9fSn5nrQ==@kvack.org X-Gm-Message-State: AOJu0YxHlGdqstb7pc/j/7gYC7rjJq3nS3k2+6mPB73+7k/k7zWoY5JU 8VpOEI8GG4pvZMLMlZw/nKj39/mr2wXtPMTVEUFOpuRLPOZp/VyTkN703GTl52BjsOctktsnu3g w+MGUHET6dcRiO/e04JR3SE3KuDvq6XhRVtYsooxeqnqRZiAs X-Gm-Gg: ASbGncsaKBmbTm7u43xxNOlUnUOSrXSnG8vdZsHtQx0UR+wvn1iDchYu3qX9yANDJtW p3W7ylCXb0EW/xSCdRGAg1gqZlgb6RsIt4JEx+rf9ViDUFIHWGGITJK/9tX4s7U96D5hKbngPMu 1EdNPvhjyixOdzHmMg9i2arX8aHJOTdotinetO/l21wIXjFINjCbG19ydZW+UVP8J3N2dvydnrX m9/oHYZTj2dmGk87otyl4IEVRnsS6sWw6kNosPX2jAmtcs8LHeRc+/FZhOhmRaQTZyk2E7eS1Zm ZBDR6159+HpNkhtwZ+1DOr+u3pgbSXkNj6YXGSIBPpudPMtouCs+3YsVUqNATXnMHmpYrnHKUdD VtdRU3y6rv9BiH/sej8qWkQ== X-Received: by 2002:adf:ffc4:0:b0:385:f47b:1501 with SMTP id ffacd0b85a97d-38bf5678f0bmr8486690f8f.32.1737380318032; Mon, 20 Jan 2025 05:38:38 -0800 (PST) X-Google-Smtp-Source: AGHT+IEiGF1PNzf2N5SRQ3JizSclZIiNBVwuzesYMoqh7P6r/9WFlNGFq9CuLVe89IYwUOdqAoRt6w== X-Received: by 2002:adf:ffc4:0:b0:385:f47b:1501 with SMTP id ffacd0b85a97d-38bf5678f0bmr8486665f8f.32.1737380317593; Mon, 20 Jan 2025 05:38:37 -0800 (PST) Received: from ?IPV6:2003:d8:2f22:1000:d72d:fd5f:4118:c70b? (p200300d82f221000d72dfd5f4118c70b.dip0.t-ipconnect.de. [2003:d8:2f22:1000:d72d:fd5f:4118:c70b]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-38bf32151e6sm10322184f8f.20.2025.01.20.05.38.35 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 20 Jan 2025 05:38:37 -0800 (PST) Message-ID: Date: Mon, 20 Jan 2025 14:38:35 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [RFC 2/2] mm/mthp: relax anon mTHP PTE Mapping restrictions To: Lance Yang , Barry Song <21cnbao@gmail.com> Cc: akpm@linux-foundation.org, ryan.roberts@arm.com, dev.jain@arm.com, shy828301@gmail.com, ziy@nvidia.com, libang.li@antgroup.com, baolin.wang@linux.alibaba.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org, Mingzhe Yang References: <20250120012230.3343-1-ioworker0@gmail.com> <20250120012230.3343-3-ioworker0@gmail.com> From: David Hildenbrand Autocrypt: addr=david@redhat.com; keydata= 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 WNyWQQ== Organization: Red Hat In-Reply-To: X-Mimecast-Spam-Score: 0 X-Mimecast-MFC-PROC-ID: sL6_X_SE7yyWdObTxRsdId5i_2KilGHffvvGIH8HJxM_1737380318 X-Mimecast-Originator: redhat.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Stat-Signature: rigahpt41ajwq8otw4oix8hh953i9j49 X-Rspamd-Queue-Id: 5E98B1C000E X-Rspam-User: X-Rspamd-Server: rspam06 X-HE-Tag: 1737380321-185945 X-HE-Meta: U2FsdGVkX1+XPKfAb5s0gElIxzC6TY8R7yfi/mwK3zu41JBxov02CUE19r/Hxifu/HiqOVV3CC8BKkfi/1+DEgY9CHwuf4JxjfOFEXtASSo3UL66eTUfreojIaRy5iwYy4IuGlN7P9PrNuu/uy78uRRVv6PR1EyfWAlUkGmiuQICmm2QrAKkVZdPYGO5EKdqOsMUNbJGSBU95UEybpneXnxoGGJKpbbbIpGkO+rtgcBOW/o74h7C1JervssBgEBASthmyp4z6rmwDx5Ya3skQLiyzoROrgB2AKaegmiBWrzzF7w/AvBF2DReaeusHCsftlW81InEsTP/zZ8ZZ5k/+KvZCPnzmUnxrse2UzdmopM+jNBEuqN3g2zj1ZGXqEtULmolYksLg7H/1q42UCBxqCjtSvgV49NnvY0lQIw2Db1DJb4N7L+rX3wc6JTN2jjJZ4P18mRGArYhZ2QTnR14e9Ne8IlsiMlJ0PUe6k4IG7JeakXwQDffBqOLR+1XnGmN9dbjQDiKb30TllmVayXusrGgbiwluI7ccBFK6jkR1eguVZIRQDyJ1vxvMnkQEwVwcdb3UG4pU7siwkbkQXuiTSFr9wcBWUZ1VbeWTQkuiBCtwarcnMYvHMijZhSgQFeZylwXueGMK2JJLT3y7n6JzpzmMaAda60jIGIYKbTTd6H6Ca3Ga0oDFcF0Q/so0Ek0jQWSPf1hnwv+c7f4ks1CYmwZf1zSiYS/SlIwxKya26CKDi62xTeZrFPxXuCSFU9KB6rKDHQnoLIrGoVLY61ClkZ0IlXL+b5Zi460XVyvN6X6ywaQ9T0+a+ns0Klx5C+S/rLVXDXP6lJRTXs027oFMGXpYiXXYZ+0pndc9VXEMyirzNVZW6YXcUMSdTRXtMNySU61rpIzNpxIp2/Rhyn0+LMe9u/p1LsP5W8FSiUy3jzsohJf/fyZrFu2ekUha9o+AwWQsk4x02uwPtI6XEY J0Y91xDl KfShJsrIsWhNRTtkYY+gLJ1aG+2v9in+RJVN86mcAOd2nKai8yIFaiLFeqqI7s6C6uV9t/HsMulSd8iKBQ37lExQtlzZgQWhfbrcGzkYyzyPdIguEehlnoshWAcutBRIBEy15NfizSUxYf1i2pTu1JtJ/B9gLAKQnThlkogsdghbCQLRrxUkKU+l5ipLdbPYE9CH6L7Fl3wdVBHrmTcoL/X0qjxmPyD/QszZYFe5wNfF4WqCiJakDa5qQz2nfNAU8xwJ8c5+s/TT7+HAGgVFXe0eAIPE1bbwntWkmR2xKUG0LsMqumxdkRHc2GXAAr+4/V1WMrzIPCy7SVRgCUJhm6C6ltLEBU9Yu+bdgxzTz8s83hGyh14eCAIRvroNiTOMLke9BQ2abmVceWb9CM/6Zsrr0ya4+QTPi3wHIMbwtv1W7jlJBtn529WI48l8jlqu2/SEVnVMvJwcanj1tBoGXgs3Nn8uaRNnsi8TdCzyn3zSAJ4NiIVl26UKeV7kX9XPSfRDm X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: On 20.01.25 14:20, Lance Yang wrote: > On Mon, Jan 20, 2025 at 10:15 AM Barry Song <21cnbao@gmail.com> wrote: >> >> On Mon, Jan 20, 2025 at 2:23 PM Lance Yang wrote: >>> >>> Previously, mTHP could only be mapped to PTEs where all entries were none. >>> With this change, PTEs within the range mapping the demand-zero page can >>> now be treated as `pte_none` and remapped to a new mTHP, providing more >>> opportunities to take advantage of mTHP. >>> >>> Signed-off-by: Mingzhe Yang >>> Signed-off-by: Lance Yang >>> --- >>> mm/memory.c | 11 +++++++++-- >>> 1 file changed, 9 insertions(+), 2 deletions(-) >>> >>> diff --git a/mm/memory.c b/mm/memory.c >>> index 4e148309b3e0..99ec75c6f0fe 100644 >>> --- a/mm/memory.c >>> +++ b/mm/memory.c >>> @@ -4815,7 +4815,8 @@ static struct folio *alloc_anon_folio(struct vm_fault *vmf) >>> order = highest_order(orders); >>> while (orders) { >>> addr = ALIGN_DOWN(vmf->address, PAGE_SIZE << order); >>> - if (pte_range_none(pte + pte_index(addr), 1 << order)) >>> + if (pte_range_none_or_zeropfn(pte + pte_index(addr), 1 << order, >>> + NULL)) >>> break; >>> order = next_order(&orders, order); >>> } >>> @@ -4867,6 +4868,7 @@ static vm_fault_t do_anonymous_page(struct vm_fault *vmf) >>> { >>> struct vm_area_struct *vma = vmf->vma; >>> unsigned long addr = vmf->address; >>> + bool any_zeropfn = false; >>> struct folio *folio; >>> vm_fault_t ret = 0; >>> int nr_pages = 1; >>> @@ -4939,7 +4941,8 @@ static vm_fault_t do_anonymous_page(struct vm_fault *vmf) >>> if (nr_pages == 1 && vmf_pte_changed(vmf)) { >>> update_mmu_tlb(vma, addr, vmf->pte); >>> goto release; >>> - } else if (nr_pages > 1 && !pte_range_none(vmf->pte, nr_pages)) { >>> + } else if (nr_pages > 1 && !pte_range_none_or_zeropfn( >>> + vmf->pte, nr_pages, &any_zeropfn)) { >>> update_mmu_tlb_range(vma, addr, vmf->pte, nr_pages); >>> goto release; >>> } >>> @@ -4965,6 +4968,10 @@ static vm_fault_t do_anonymous_page(struct vm_fault *vmf) >>> entry = pte_mkuffd_wp(entry); >>> set_ptes(vma->vm_mm, addr, vmf->pte, entry, nr_pages); >>> >>> + /* At least one PTE was mapped to the zero page */ >>> + if (nr_pages > 1 && any_zeropfn) >>> + flush_tlb_range(vma, addr, addr + (nr_pages * PAGE_SIZE)); >> > > Thanks for taking time to review! > >> Do we also need mmu_notifier? >> >> mmu_notifier_range_init(...) >> mmu_notifier_invalidate_range_start(&range); >> >> By the way, this is getting much more complex, but are we seeing any real >> benefits? I’ve tested this before, and it seems that zeropfn-mapped >> anonymous folios are quite rare. > > Hmm... Agreed that it's getting more complex. I don't have any data > showing real benefits yet, so let's put this patch aside for now until I do. The motivation for the huge zeropage case was that we would install the huge zeropage on read fault, to then PTE-map it on write fault and only COW a single PTE. It would require khugepaged to collapse in order to get a THP again. So read-then-immediately-write would not give us a PMD-mapped THP with the huge shared zeropage enabled, but would give us a PMD-mapped THP with the huge shared zeropage disabled, which is rather inconsistent. In case of mTHP, the behavior is at least always the same, and the performance gain is likely not as huge as in the PMD case. Maybe we can just wait until khugepaged will fix it up, where a lot of that complexity will reside either way. So I agree that it might be useful, but also that there must be a good reason to have that complexity here. It might also be a valid question if we should even always use the shared zeropage on read faults with mTHP enabled, because maybe it could be more efficient to avoid the TLB flush when ripping out the shared zeropage etc and just give it an mTHP, if our shrinker works as expected Using the huge zeropage is rather "obviously good" because it also reduces TLB pressure + page table walk and can be zapped fairly easily and efficiently to install a fresh PMD-mapped THP. -- Cheers, David / dhildenb