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 7F4E5C3ABDD for ; Tue, 20 May 2025 06:06:23 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 25C4D6B0092; Tue, 20 May 2025 02:06:23 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 2333E6B0093; Tue, 20 May 2025 02:06:23 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 149C36B0095; Tue, 20 May 2025 02:06:23 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id EAAB36B0092 for ; Tue, 20 May 2025 02:06:22 -0400 (EDT) Received: from smtpin14.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 9041E1CC271 for ; Tue, 20 May 2025 06:06:22 +0000 (UTC) X-FDA: 83462251404.14.22B8AB6 Received: from mail-pj1-f49.google.com (mail-pj1-f49.google.com [209.85.216.49]) by imf02.hostedemail.com (Postfix) with ESMTP id D1CF680009 for ; Tue, 20 May 2025 06:06:20 +0000 (UTC) Authentication-Results: imf02.hostedemail.com; dkim=pass header.d=gmail.com header.s=20230601 header.b=gi3OQkPL; spf=pass (imf02.hostedemail.com: domain of laoar.shao@gmail.com designates 209.85.216.49 as permitted sender) smtp.mailfrom=laoar.shao@gmail.com; dmarc=pass (policy=none) header.from=gmail.com ARC-Authentication-Results: i=1; imf02.hostedemail.com; dkim=pass header.d=gmail.com header.s=20230601 header.b=gi3OQkPL; spf=pass (imf02.hostedemail.com: domain of laoar.shao@gmail.com designates 209.85.216.49 as permitted sender) smtp.mailfrom=laoar.shao@gmail.com; dmarc=pass (policy=none) header.from=gmail.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1747721180; 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=oMBA7d6UZalbeb3iJQhCyUuvULAsLBrIg9tSXAts4m0=; b=Xruc9jet18EE2Ngbuoak6sP8/HjoyxKDZTW1mqM6DJTajAZCxhZi9/9jirpWbnJdNQCkOX EWSS3r9WXwfmdPjLwRjXqrHkRz7KxRHx3qzJjnD6VPJ5O8K5dXOtbphKFQe7XZF8mcqbtK AU4E5XqoxAuBijCojdpTTJt4cGnDIxw= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1747721180; a=rsa-sha256; cv=none; b=yCL+FfG8C5vE4aReyKSWJdq5Yr80vIQzhsVQlR9aWEuqKVLpgTcS74T2Vy27W19AwF/rXX nyqe87EgH/J1sI+GX1OoeXD7spm/xcruquiXOF/F2tOkmj2IMdyjwaJ36tM9Z5gae/TEB2 fV72DSa5oB8+/9mF1sTjOMIwwiD9i2Q= Received: by mail-pj1-f49.google.com with SMTP id 98e67ed59e1d1-30e7bfef364so3793001a91.1 for ; Mon, 19 May 2025 23:06:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1747721180; x=1748325980; darn=kvack.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=oMBA7d6UZalbeb3iJQhCyUuvULAsLBrIg9tSXAts4m0=; b=gi3OQkPL4msWwTYnkej5XF3+Q0JcQ6/ge80YAmw7SXqW7yLbrrYTBZmfRz+8osorWy PEbtrpztPni5PI7SnEFXy8OgOSCXlsqT6eJ0uBENafxVsxVoHJbitbQFwrNn7IblRtKx czbPt53GNLEhqt9CWxSbkqKzpxHQwZss7uasc1++jYS8JYmDAcqsRseyygMCvAMac0nc FD9VzEb340LLOiIMH/uYXNm8ynPSnI8GzMnnTN6goi1qXEzCZEnXoscWXn2Otk/2SrYg uSFOMFS9fBZLE832PyCtedk35UFRZJF3YgNYcylUkn3Xs8r7XFgfXBdeEW9KXh2PR4kL cR9g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1747721180; x=1748325980; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=oMBA7d6UZalbeb3iJQhCyUuvULAsLBrIg9tSXAts4m0=; b=EJDD2UmUu63vb/0GdSukmRyD5p+KKv1z0Yk7m5SzVfJ1MLnh9NTvxRy4Pn9CyvSXRo glrnlJz2ezdn4XW4zD4rt7C/29VYjj54GHpb7vX7J22K4X5DlZQITpeksZnSeRkjz6/D lp0crfwIC70IYIYNSFKG3/cw2Y+V4ul1GsCGKdlDopOpHQ30YrZIQ4AmXmsn7L3TIdg5 C7LkISWQ4ggYM+Z04zqG3iY56Df0/ibkem0geEyF8XgVtprsTEXvVVVhnfZ7Ax951n6T y6KuThrewgmGKyFZ5Q1DSn4n452YAeRvtTUGAYvOeulIQgaWGwaICqsyOKezCLB8YSyN ILTw== X-Forwarded-Encrypted: i=1; AJvYcCW2yWwU19Of2ejcpwZgRKFu0nlkEZ4oavLvgojhnzwjsxFG6TxhRB+Zcv6qv6QfpKvUUK+Phw8XhQ==@kvack.org X-Gm-Message-State: AOJu0Ywxq1Y/+Z9H+DzAtSEzMzkY+jwafx6VebMjzYpdUR2coQOCLvZI SJ+/93Ij5rUbbKGHgQQjZo0z2MuuSbUY4A6g85ZtEuBdhBMXiOT+ZYPF X-Gm-Gg: ASbGncsIRntdGECyEhl3U/cpELTA0YIL/9N72BuHGvLvm/mRMhgmoL3OXV6MiqVcisX arRKuaATCHPg6ks+WhoNL6+C+iGN19e0d3qz8f/pjVED7g6f8z0JLHyLJClkpQ4QBRTMJpPcwpY +XaukP3iscJ9b0XJFrza/wr1BiY7anqav+63OOzO5amYvk1HyRaY9LsN63yuCpWf5PnNbhHweqL jN5DuPOKrYvSd3uVll9lFNuW6fivlyYlvJQkPKZMLmzDoIfQ077ioRLsW7CG9071ZREA/BoGhDk RM1xk3AGPbGRGLaNalifAcQofSr8Y9NLPOKRkLeckRY+Igr8MuhpOyZNlZ8tZh3azcI2GWCrRu0 = X-Google-Smtp-Source: AGHT+IFoo08Y61pkP9GewiXExlx7Tav+LS5zb//iA1K/M3XCeG6QBragcDGBxhCdcTYC4l6AG5zWqQ== X-Received: by 2002:a17:90b:1d4f:b0:2fe:b470:dde4 with SMTP id 98e67ed59e1d1-30e7d50b00amr30918692a91.12.1747721179547; Mon, 19 May 2025 23:06:19 -0700 (PDT) Received: from localhost.localdomain ([39.144.103.61]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-30f36385e91sm823428a91.12.2025.05.19.23.06.11 (version=TLS1_3 cipher=TLS_CHACHA20_POLY1305_SHA256 bits=256/256); Mon, 19 May 2025 23:06:19 -0700 (PDT) From: Yafang Shao To: akpm@linux-foundation.org, david@redhat.com, ziy@nvidia.com, baolin.wang@linux.alibaba.com, lorenzo.stoakes@oracle.com, Liam.Howlett@oracle.com, npache@redhat.com, ryan.roberts@arm.com, dev.jain@arm.com, hannes@cmpxchg.org, usamaarif642@gmail.com, gutierrez.asier@huawei-partners.com, willy@infradead.org, ast@kernel.org, daniel@iogearbox.net, andrii@kernel.org Cc: bpf@vger.kernel.org, linux-mm@kvack.org, Yafang Shao Subject: [RFC PATCH v2 3/5] mm: thp: add struct ops for BPF based THP adjustment Date: Tue, 20 May 2025 14:05:01 +0800 Message-Id: <20250520060504.20251-4-laoar.shao@gmail.com> X-Mailer: git-send-email 2.37.1 (Apple Git-137.1) In-Reply-To: <20250520060504.20251-1-laoar.shao@gmail.com> References: <20250520060504.20251-1-laoar.shao@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: D1CF680009 X-Stat-Signature: 5dpymcq8fqndqrfsw6xyw96xfbap4m8k X-Rspam-User: X-HE-Tag: 1747721180-532597 X-HE-Meta: U2FsdGVkX18mTTSe/H/Qdb0qGhkKC9L45lXImt1423XlLHdcdQL4wKgr4+YAmSY58m9zYkItSJtjVJCOpNT1Wy8VVjXEXP94nNUmIOcubHCVzqh2GHq+cOqdqHT1Ps0RK2Js2M9wFcIvwacLTPTnWC31thiJAZFLOV5F+rNQ7JWkOK/WHnI+ByC4VSda4SIGaGSEL2RRQ2qzt520toxolWaBcFGvKgGkY6PKfDMoryR3hZq0w3tYT7evAHRQ2oiWruzw0cP2Fo9Y7HczDpWLOXixY1RW3rUCfKYLuhckcm6jYA2PIb9dUGsgxJc2CmrcP5EUUVXzHuMrsxu2rYazxYt77zzta4b3fh3Y4qlzGw24AQsyJsZ3wS5qpR2Jbck0GajJtCVTPMGDOYN+VIpW2VWr4wJaIuh4IAgzwDSi3l1KUmQDqqX+meu/E75/pFaxVmVAn5j0HAd5yJMc+AI7Tf6gtucXDbwAwxmxAHdhXynnPDcoHxxz9bbZXw0w/snPBb/xKjibpxWpciU5sCJ5wV20XpRvd143jz1JoLJ34hOVztISuu5xp1cUVkCwxhk6OKclLy2gNdmMZtnHc8mXy3j7l29wt5gln30W0tthadjcSHu51eWG3ZTldK4dsnYpKFhpU/SXt6n5GMzdpUleeeDecLGOBl3QvPhx4WmfX9CTUPnnuaRk+nBotFqs3/h2sl/QR8CzLT2e2955zV482YQOIvCNIhG75r9js0DHvTSWOrR+MeavlgJRFSW9McdOyxLFG2f4Mbi9gMBnfzIiorfHqJVeIRhrUqrFzKnDa3twJIDhWZEdyRYiHLGqoRQ3SymSWa1uYZirN4xBR618EUVep97uruJB6BKeY0QUCszVaLJGCNVWGZUQHI78C3A4blomSN7vXPFuPYVDPVnnlQvssKXWlopiCfyn5lqX53pMkWjieaYycBK7cy31wIcuoAzXnwL99nk/XkS4eq3 Aldr1beG JkcHgS7UFKW330dXcJif3deOgReBqsUh+NKK62Clwnt+YX8Ox55AWJW/XE8jeTGv7Tl+UvAm3gShOoOdG12NjGnIXVEE3Y7crF1gNBmtGcGkdyNXs/E/P1c5pgFa1O4lV/lJi 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: This patch introduces a minimal struct_ops for BPF-based THP adjustment. Currently, only a single BPF program can be attached. Support for multiple attachments will be added in the future. Signed-off-by: Yafang Shao --- include/linux/huge_mm.h | 13 +---- mm/Makefile | 3 + mm/bpf_thp.c | 120 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 124 insertions(+), 12 deletions(-) create mode 100644 mm/bpf_thp.c diff --git a/include/linux/huge_mm.h b/include/linux/huge_mm.h index fedb5b014d9a..a75f5f902af0 100644 --- a/include/linux/huge_mm.h +++ b/include/linux/huge_mm.h @@ -193,18 +193,7 @@ static inline bool hugepage_global_always(void) (1< +#include +#include + +struct bpf_thp_ops { + /** + * @thp_bpf_allowable: Determines whether a task is permitted to + * allocate a THP when it is allocating anon memory. + * + * Return: %true if THP allocation is allowed, %false otherwise. + */ + bool (*thp_bpf_allowable)(void); +}; + +static struct bpf_thp_ops bpf_thp; + +bool hugepage_bpf_allowable(void) +{ + /* Works only for "bpf" mode */ + if (!(transparent_hugepage_flags & (1<thp_bpf_allowable; + return 0; +} + +static void bpf_thp_unreg(void *kdata, struct bpf_link *link) +{ + clear_bit(TRANSPARENT_HUGEPAGE_BPF_ATTACHED, &transparent_hugepage_flags); + bpf_thp.thp_bpf_allowable = NULL; +} + +static int bpf_thp_check_member(const struct btf_type *t, + const struct btf_member *member, + const struct bpf_prog *prog) +{ + return 0; +} + +static int bpf_thp_init_member(const struct btf_type *t, + const struct btf_member *member, + void *kdata, const void *udata) +{ + return 0; +} + +static int bpf_thp_init(struct btf *btf) +{ + return 0; +} + +static bool thp_bpf_allowable(void) +{ + return 0; +} + +static struct bpf_thp_ops __bpf_thp_ops = { + .thp_bpf_allowable = thp_bpf_allowable, +}; + +static struct bpf_struct_ops bpf_bpf_thp_ops = { + .verifier_ops = &thp_bpf_verifier_ops, + .init = bpf_thp_init, + .check_member = bpf_thp_check_member, + .init_member = bpf_thp_init_member, + .reg = bpf_thp_reg, + .unreg = bpf_thp_unreg, + .name = "bpf_thp_ops", + .cfi_stubs = &__bpf_thp_ops, + .owner = THIS_MODULE, +}; + +static int __init bpf_thp_ops_init(void) +{ + int err = register_bpf_struct_ops(&bpf_bpf_thp_ops, bpf_thp_ops); + + if (err) + pr_err("bpf_thp: Failed to register struct_ops (%d)\n", err); + return err; +} +late_initcall(bpf_thp_ops_init); -- 2.43.5