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 753F9C369C2 for ; Thu, 17 Apr 2025 00:07:58 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 08BF7280155; Wed, 16 Apr 2025 20:07:57 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 063B4280150; Wed, 16 Apr 2025 20:07:57 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id E46B1280155; Wed, 16 Apr 2025 20:07:56 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id C487E280150 for ; Wed, 16 Apr 2025 20:07:56 -0400 (EDT) Received: from smtpin23.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id 81AB31A0F4F for ; Thu, 17 Apr 2025 00:07:57 +0000 (UTC) X-FDA: 83341597794.23.E227E6A Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by imf25.hostedemail.com (Postfix) with ESMTP id C73EFA0011 for ; Thu, 17 Apr 2025 00:07:55 +0000 (UTC) Authentication-Results: imf25.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=T1TKDvE+; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf25.hostedemail.com: domain of npache@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=npache@redhat.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744848475; a=rsa-sha256; cv=none; b=ZRmRzOStETEsaetFW47k8yIyeQrcoJsUJKk0t1qRETeGE8zJCfUpkp7oq54LfCPRNgcW3O +VwpfrOBwAbYBLbHKyh5edeJ2SrpEm/uIglTemVCygIlC26m34rnXZGtQHSIQ2Kw90lOcM zKIiGxScIex9WYM1yOsF/+TZDmKZZMo= ARC-Authentication-Results: i=1; imf25.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=T1TKDvE+; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf25.hostedemail.com: domain of npache@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=npache@redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1744848475; 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-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=YwgfUM8JwJbA0iQF0LdD8dJp+2ea27Yg2QmSTdEXXUw=; b=poRsDk/Vh9YdLclTe3Vvv/hWXkHPUd1fKSoyQe8QELD00MgGlN2NRNywxyn7gPxXe13v5/ H6Afo+ZhyWIZb+eMzxVMul3gd6i+YkrXUC0tIU0P779/56bCeYqmcDTt1sWcSnV63SJvMT eagaw8WZ7MJQmXdMm+IqnEmOLWs6Ero= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1744848475; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=YwgfUM8JwJbA0iQF0LdD8dJp+2ea27Yg2QmSTdEXXUw=; b=T1TKDvE+mSim08+HMYzoCJ+taLe+mzcxJ9QzobSx1BND3CYvGmgEOhag1YnkQ0Gu9BzSOM GgYKcL6uwUGGkn2vrF6biuqEm4V2MGoXG1tFEliAkeNab5TV9DilStz5sEP77lnfmBZLuU MNTzBsJYpZ3rR5kdXO7Flyy+cvFM5eE= Received: from mx-prod-mc-04.mail-002.prod.us-west-2.aws.redhat.com (ec2-54-186-198-63.us-west-2.compute.amazonaws.com [54.186.198.63]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-210-9yDmiuLHPCmnKNQ90mv0mg-1; Wed, 16 Apr 2025 20:07:53 -0400 X-MC-Unique: 9yDmiuLHPCmnKNQ90mv0mg-1 X-Mimecast-MFC-AGG-ID: 9yDmiuLHPCmnKNQ90mv0mg_1744848469 Received: from mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.111]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mx-prod-mc-04.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id 947F61956048; Thu, 17 Apr 2025 00:07:49 +0000 (UTC) Received: from h1.redhat.com (unknown [10.22.88.34]) by mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP id 4B8FC1800352; Thu, 17 Apr 2025 00:07:39 +0000 (UTC) From: Nico Pache To: linux-mm@kvack.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org Cc: akpm@linux-foundation.org, corbet@lwn.net, rostedt@goodmis.org, mhiramat@kernel.org, mathieu.desnoyers@efficios.com, david@redhat.com, baohua@kernel.org, baolin.wang@linux.alibaba.com, ryan.roberts@arm.com, willy@infradead.org, peterx@redhat.com, ziy@nvidia.com, wangkefeng.wang@huawei.com, usamaarif642@gmail.com, sunnanyong@huawei.com, vishal.moola@gmail.com, thomas.hellstrom@linux.intel.com, yang@os.amperecomputing.com, kirill.shutemov@linux.intel.com, aarcange@redhat.com, raquini@redhat.com, dev.jain@arm.com, anshuman.khandual@arm.com, catalin.marinas@arm.com, tiwai@suse.de, will@kernel.org, dave.hansen@linux.intel.com, jack@suse.cz, cl@gentwo.org, jglisse@google.com, surenb@google.com, zokeefe@google.com, hannes@cmpxchg.org, rientjes@google.com, mhocko@suse.com, rdunlap@infradead.org Subject: [PATCH v4 12/12] Documentation: mm: update the admin guide for mTHP collapse Date: Wed, 16 Apr 2025 18:02:38 -0600 Message-ID: <20250417000238.74567-13-npache@redhat.com> In-Reply-To: <20250417000238.74567-1-npache@redhat.com> References: <20250417000238.74567-1-npache@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.4.1 on 10.30.177.111 X-Rspam-User: X-Rspamd-Server: rspam02 X-Rspamd-Queue-Id: C73EFA0011 X-Stat-Signature: cwn7w9ox3wegb5ak7tk8p17hhyj71q49 X-HE-Tag: 1744848475-778700 X-HE-Meta: U2FsdGVkX1/czFlCRncietND1I3dEf29QaIGEpcLL+A46Yghwq92f0W4qaZ3/UZ/zWYvI1e6yfBb0IBjJ4OOyF0N1m994HaPREYU/K8P1O8cnwE1Ikkkz6i9hMAsdLX3C3cfvpM//vNC32PVcHWDQtQ88Pb5STUu/LeNBO+nL76clvO2XLENOmx6FLF+nm6kNJStUHCX8DttPYGhCrDlxopCr991+R+zWmSXANkJi3G8kwJNmf32ab9EGyEOSZMsWagtI/4Mj2G12XjefNx4LLPVPr7d5C3CWgNHqIm+M2dKRNSTic2y3pMUqDFZ371euuYTK6KpH9ohS1HbtkuRlokZbh+5WQg0bWt49Cq3Swjzybb2eyQmpTxp+nlbPcdECG+nHFJAgbmJuR1mNR1q9U5mbKw+3U63Fru5Og8MAecwUhdQ3BXSlcBbcN8suAdblHmfqCqwOpLv4USw5u6OHm/9k1C5NB1AbTbeiL47XUhwOeC/pFm/9GBLPg/gQXb4Ft1kFELZ+fNTsXcH7fgqiCort1FWjlIPKgdwS/urS87etpgGS37YDGUNsGJ8nGx/re8UCWThB67+Tz6R+xWvRTQHByUNXPp3Qd/rerfIjmx0BEfXWQ+rfjw+BmNSe08V6Tloc71G85hpoXYaQy2IouhKcGXhbJeYkZ1K/pe+Pois1J137KfWPkJVbhkNPju/uceleWOZWNE8XDvwWONumw8iA4/7wzAXrxAopLmnSg6ezk8GaJ9pgXT2cKHQVAfmr3ftQvBCSN3z3EV0yEfWpvfnRn+3PdopUH6wHzMFEIkrBJdJmQYaxR+SQP1d+M7anbUV2BUpkg/ifGLT3COvFQWMBt+OfbewDrigBS99jwprEHMaxyMyltHDqoGrj/3duqaAwgrw0dMHBtw/DABG6xtk4YHlz/W+dxUZRD7Ih8086tY4Oedmw//T27G8FRd1303oGuTO3con0s8fFu5 y02BW6Qw u+g09emezeJNVsXFAZZsSkZ5bpiIIGtQKC7pokSbacWOGDTTzFKEXtCCJ9C23bw2Y8flV7GkoHrN2ralrFzwkjMZipDobYqcie4l9m1N+yEd9UTv68zOSoU9H4T3IjzHHiqcF6cYL2QiungRJZlKghk5imZCFbd2bexG5kArjbeTEeP8oNlkjcjcf6Bzgxa7wLwccfULH1Vfbw6uyA09LX5BSVZZiMi9CRCnDrpgwTTwku1lYd91B/fobyle1YJ2IE521Nfufg2QvelNuNLzj8FK/2tl02OMXGmUkBeSCPg+G2+1v+dxdRMDtjDFsJ5paYyAHl01bLxcfNaQnqZ3+tSXMAKKB0bKpzPbEjnQQS4ZFTIRdey6kAChix+PPnwRZmgkLZn2EmZpBv5nG99sY/N4rjw== 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: Now that we can collapse to mTHPs lets update the admin guide to reflect these changes and provide proper guidence on how to utilize it. Signed-off-by: Nico Pache --- Documentation/admin-guide/mm/transhuge.rst | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/Documentation/admin-guide/mm/transhuge.rst b/Documentation/admin-guide/mm/transhuge.rst index dff8d5985f0f..06814e05e1d5 100644 --- a/Documentation/admin-guide/mm/transhuge.rst +++ b/Documentation/admin-guide/mm/transhuge.rst @@ -63,7 +63,7 @@ often. THP can be enabled system wide or restricted to certain tasks or even memory ranges inside task's address space. Unless THP is completely disabled, there is ``khugepaged`` daemon that scans memory and -collapses sequences of basic pages into PMD-sized huge pages. +collapses sequences of basic pages into huge pages. The THP behaviour is controlled via :ref:`sysfs ` interface and using madvise(2) and prctl(2) system calls. @@ -144,6 +144,14 @@ hugepage sizes have enabled="never". If enabling multiple hugepage sizes, the kernel will select the most appropriate enabled size for a given allocation. +khugepaged uses max_ptes_none scaled to the order of the enabled mTHP size to +determine collapses. When using mTHPs it's recommended to set max_ptes_none +low-- ideally less than HPAGE_PMD_NR / 2 (255 on 4k page size). This will +prevent undesired "creep" behavior that leads to continuously collapsing to a +larger mTHP size. max_ptes_shared and max_ptes_swap have no effect when +collapsing to a mTHP, and mTHP collapse will fail on shared or swapped out +pages. + It's also possible to limit defrag efforts in the VM to generate anonymous hugepages in case they're not immediately free to madvise regions or to never try to defrag memory and simply fallback to regular -- 2.48.1