From patchwork Mon May 20 02:17:27 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Byungchul Park X-Patchwork-Id: 13667999 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 CB7DEC25B75 for ; Mon, 20 May 2024 02:17:58 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id EB3956B0099; Sun, 19 May 2024 22:17:52 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id D1DAC6B0098; Sun, 19 May 2024 22:17:52 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id A5E576B009A; Sun, 19 May 2024 22:17:52 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0017.hostedemail.com [216.40.44.17]) by kanga.kvack.org (Postfix) with ESMTP id 7BB236B0096 for ; Sun, 19 May 2024 22:17:52 -0400 (EDT) Received: from smtpin28.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id 35B381C058B for ; Mon, 20 May 2024 02:17:52 +0000 (UTC) X-FDA: 82137163584.28.4BA000E Received: from invmail4.hynix.com (exvmail4.skhynix.com [166.125.252.92]) by imf01.hostedemail.com (Postfix) with ESMTP id 5E6DD40012 for ; Mon, 20 May 2024 02:17:50 +0000 (UTC) Authentication-Results: imf01.hostedemail.com; dkim=none; spf=pass (imf01.hostedemail.com: domain of byungchul@sk.com designates 166.125.252.92 as permitted sender) smtp.mailfrom=byungchul@sk.com; dmarc=none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1716171470; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:content-type: content-transfer-encoding:in-reply-to:in-reply-to: references:references; bh=Riu8nANP1gQmwqYLhEmoeVBEqJ6gKrJm9jcEuXrAJxE=; b=yq1LdMRR9RT+zeX2bAa5crTC1JJCL+kt99wSKQqPzEy9l9aHHAMvs2wohjpUasHuGeZCLx 53Rea0pQUF5jiGQ9eoY+y6kSn3UWVwV5qjPVMy6otLacL5rzWL0HDYa+0vE4rFsA1gOI3O dXycZD2F3AQV44tLYnu87GhtPwUDuFo= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1716171470; a=rsa-sha256; cv=none; b=Y+GJysmQlmcbGGJ3nc5M927XKAvNHo9CpSIktDn4iu305RLeaS6GmkUHl+xcTNrjy43Nhc NlieN3M2ESnm/LDRrH+TgGGcyb8tJr6CNQo4Z8ZG84UGKp3kZTx7cajNhWmC68g5wgnn3x VrztqZrU89dhHFcR5sR/TAHCEKFik+U= ARC-Authentication-Results: i=1; imf01.hostedemail.com; dkim=none; spf=pass (imf01.hostedemail.com: domain of byungchul@sk.com designates 166.125.252.92 as permitted sender) smtp.mailfrom=byungchul@sk.com; dmarc=none X-AuditID: a67dfc5b-d6dff70000001748-ae-664ab2c88e13 From: Byungchul Park To: linux-kernel@vger.kernel.org, linux-mm@kvack.org Cc: kernel_team@skhynix.com, akpm@linux-foundation.org, ying.huang@intel.com, vernhao@tencent.com, mgorman@techsingularity.net, hughd@google.com, willy@infradead.org, david@redhat.com, peterz@infradead.org, luto@kernel.org, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, dave.hansen@linux.intel.com, rjgolo@gmail.com Subject: [RESEND PATCH v10 05/12] mm: buddy: make room for a new variable, ugen, in struct page Date: Mon, 20 May 2024 11:17:27 +0900 Message-Id: <20240520021734.21527-6-byungchul@sk.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240520021734.21527-1-byungchul@sk.com> References: <20240520021734.21527-1-byungchul@sk.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFnrGLMWRmVeSWpSXmKPExsXC9ZZnoe7JTV5pBsdus1jMWb+GzeLzhn9s Fi82tDNafF3/i9ni6ac+FovLu+awWdxb85/V4vyutawWO5buY7K4dGABk8Xx3gNMFvPvfWaz 2LxpKrPF8SlTGS1+/wAqPjlrMouDgMf31j4Wj52z7rJ7LNhU6rF5hZbH4j0vmTw2repk89j0 aRK7x7tz59g9Tsz4zeIx72Sgx/t9V9k8tv6y82iceo3N4/MmuQC+KC6blNSczLLUIn27BK6M Bd8eshVcVak43DmJpYGxTbaLkZNDQsBEonvlRBYYe+rrZlYQm01AXeLGjZ/MILaIgJnEwdY/ 7CA2s8BdJokD/WwgtrBAvMTfOzvBbBYBVYn13Z1g9bwCphKLb15hgpgpL7F6wwGwOCfQnBmr doLtEgKq+XH0K1AvF1DNezaJi6eOsUI0SEocXHGDZQIj7wJGhlWMQpl5ZbmJmTkmehmVeZkV esn5uZsYgaG/rPZP9A7GTxeCDzEKcDAq8fDueOSZJsSaWFZcmXuIUYKDWUmEd9MWoBBvSmJl VWpRfnxRaU5q8SFGaQ4WJXFeo2/lKUIC6YklqdmpqQWpRTBZJg5OqQZG/v/3r/10/bc1JHse a7XXV8bXGWEd3s6bo7xE5oZKTVbemPFn6at161w+xx99IKD3d9Htg4r7j8S++BBrVhC6K+fE n9VTuwo+ns9eMu1NfO/Po85fLmZYzN/J1JmjOLnMiD/ha/x0YVbZDddDTVk+p7Hc55ywbevG nRfttkxuj+xXjt8hKWW2RYmlOCPRUIu5qDgRADq+n6F5AgAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrLLMWRmVeSWpSXmKPExsXC5WfdrHtik1eawYQbZhZz1q9hs/i84R+b xYsN7YwWX9f/YrZ4+qmPxeLw3JOsFpd3zWGzuLfmP6vF+V1rWS12LN3HZHHpwAImi+O9B5gs 5t/7zGaxedNUZovjU6YyWvz+AVR8ctZkFgdBj++tfSweO2fdZfdYsKnUY/MKLY/Fe14yeWxa 1cnmsenTJHaPd+fOsXucmPGbxWPeyUCP9/uusnksfvGByWPrLzuPxqnX2Dw+b5IL4I/isklJ zcksSy3St0vgyljw7SFbwVWVisOdk1gaGNtkuxg5OSQETCSmvm5mBbHZBNQlbtz4yQxiiwiY SRxs/cMOYjML3GWSONDPBmILC8RL/L2zE8xmEVCVWN/dCVbPK2AqsfjmFSaImfISqzccAItz As2ZsWonC4gtBFTz4+hXtgmMXAsYGVYximTmleUmZuaY6hVnZ1TmZVboJefnbmIEBvKy2j8T dzB+uex+iFGAg1GJh3fDbc80IdbEsuLK3EOMEhzMSiK8m7YAhXhTEiurUovy44tKc1KLDzFK c7AoifN6hacmCAmkJ5akZqemFqQWwWSZODilGhinrg2xCigXv7j77lRNn2ciXUfnbrnRYzpv j0f6ey+N2MWvjWfk/lG89kte/ckCqzkTTrhNO/aopCvVO/bSkuIHXxRZ+nJWTVZ4MktpysFL RcsWT069s6OXwyQ74vPiWCf/vbd4xDb+v/Ar0znZ+NifCW1X2I/mvPmk8nc3Y9XfOULr5Td5 RK5mUWIpzkg01GIuKk4EAClSB6NgAgAA X-CFilter-Loop: Reflected X-Rspam-User: X-Stat-Signature: i4wa8x9mzix1jnqgnzqr3fh6juqzh7ox X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 5E6DD40012 X-HE-Tag: 1716171470-407054 X-HE-Meta: U2FsdGVkX1+jSTl/cg3aBrSNTbcQOBSMaYI/lpMn8IdV5r5rD91siJu7bigXvuRqbXjaoEjt00/ytog9uyC4dLLlg0XadJ1Vq32vHbSBfRYIXFxV7moLJTqsMwDu1rtGcXcPoopCbpUsFFNdvr/ene1DiEH1K5wcd6GwnwdZ2QyAotz6m0mIdGpweBG+Oz1dxDmgJSGG8Y7haX3BYs2sHoYVKeLXn5UgWvWRI6OpF7t6DCeytaHisjvjdJy9zaIHaVOwfw5O80eARDz8GzDTNzPJfV+7lGKE/MYV11Girg3DPEgd0FdQ4mEWQb+JVII1hqT2XC3Q7rEfrd7qHrNXScrOnBybB2j8QC2DDttOETMMnzPFhr+vlblbIJWQW53csgw47jHN9SZKgcsn+FMfg5vzF8cHOy8bwyR1FK3qf0zUrN/WikNzQKWnxRS9fcdqIxuR2JjgwzaflOG3kqm6f0yZeCakcOJ2E11YA1sMtGDj3bCDJK+Ln/csMsIKmlFNXBdmmJoT6PkpSVpWP18FH+c/EXwS4j5l3KI0N56z51gJ5xORLV+oFgoMJO8zERNbcDVt9KhGUUZ81iqeI2/DM3y8Z1XFdLY5Y4MUERSkiava+tacVQWQXmQ1Fq69/iaPAY25MejK2R7NTLooRAQ3nW8PpRFEFL/NSNwbVPszFgJGcO50cTjEOWRohy3Fmg+T7dH5ipFk8MlJuozPxfq0LkovdE6+TLxBaHBor/QMtsspMdIYi4yPDkoNC9oWpYnV4sgd+NbOjw5sofzKUs/GaC45m90Y9FU3A0dxmzuecH+ydndtbG7ySaVuSPWkFFNJZ1gB9B65BaeusRhoPee5YxHBSTqAisnNYd9MPQJlDhLOcuOwYqIczwL3tEb614KIZpii08V+5e7NT/jZyAoxJ6tH06veEKdz2+pbXT/0zbfNSESF/yHTdEHbn7cCE/HttyJnzk1uXUkMYL7AVPl MpQ== 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: Functionally, no change. This is a preparation for luf mechanism that tracks need of tlb flush for each page residing in buddy, using a generation number in struct page. Fortunately, since the private field in struct page is used only to store page order in buddy, ranging from 0 to MAX_PAGE_ORDER, that can be covered with unsigned short int. So splitted it into two smaller ones, order and ugen, so that the both can be used in buddy at the same time. Signed-off-by: Byungchul Park --- include/linux/mm_types.h | 40 +++++++++++++++++++++++++++++++++------- mm/internal.h | 4 ++-- mm/page_alloc.c | 13 ++++++++----- 3 files changed, 43 insertions(+), 14 deletions(-) diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h index db0adf5721cc..cd4ec0d10ffb 100644 --- a/include/linux/mm_types.h +++ b/include/linux/mm_types.h @@ -108,13 +108,25 @@ struct page { pgoff_t index; /* Our offset within mapping. */ unsigned long share; /* share count for fsdax */ }; - /** - * @private: Mapping-private opaque data. - * Usually used for buffer_heads if PagePrivate. - * Used for swp_entry_t if PageSwapCache. - * Indicates order in the buddy system if PageBuddy. - */ - unsigned long private; + union { + /** + * @private: Mapping-private opaque data. + * Usually used for buffer_heads if PagePrivate. + * Used for swp_entry_t if PageSwapCache. + */ + unsigned long private; + struct { + /* + * Indicates order in the buddy system if PageBuddy. + */ + unsigned short int order; + /* + * Tracks need of tlb flush used by luf, + * which stands for lazy unmap flush. + */ + unsigned short int ugen; + }; + }; }; struct { /* page_pool used by netstack */ /** @@ -521,6 +533,20 @@ static inline void set_page_private(struct page *page, unsigned long private) page->private = private; } +#define page_buddy_order(page) ((page)->order) + +static inline void set_page_buddy_order(struct page *page, unsigned int order) +{ + page->order = (unsigned short int)order; +} + +#define page_buddy_ugen(page) ((page)->ugen) + +static inline void set_page_buddy_ugen(struct page *page, unsigned short int ugen) +{ + page->ugen = ugen; +} + static inline void *folio_get_private(struct folio *folio) { return folio->private; diff --git a/mm/internal.h b/mm/internal.h index c6483f73ec13..eb9c7d8650fc 100644 --- a/mm/internal.h +++ b/mm/internal.h @@ -453,7 +453,7 @@ struct alloc_context { static inline unsigned int buddy_order(struct page *page) { /* PageBuddy() must be checked by the caller */ - return page_private(page); + return page_buddy_order(page); } /* @@ -467,7 +467,7 @@ static inline unsigned int buddy_order(struct page *page) * times, potentially observing different values in the tests and the actual * use of the result. */ -#define buddy_order_unsafe(page) READ_ONCE(page_private(page)) +#define buddy_order_unsafe(page) READ_ONCE(page_buddy_order(page)) /* * This function checks whether a page is free && is the buddy diff --git a/mm/page_alloc.c b/mm/page_alloc.c index 33d4a1be927b..917b22b429d1 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -565,9 +565,12 @@ void prep_compound_page(struct page *page, unsigned int order) prep_compound_head(page, order); } -static inline void set_buddy_order(struct page *page, unsigned int order) +static inline void set_buddy_order_ugen(struct page *page, + unsigned int order, + unsigned short int ugen) { - set_page_private(page, order); + set_page_buddy_order(page, order); + set_page_buddy_ugen(page, order); __SetPageBuddy(page); } @@ -834,7 +837,7 @@ static inline void __free_one_page(struct page *page, } done_merging: - set_buddy_order(page, order); + set_buddy_order_ugen(page, order, 0); if (fpi_flags & FPI_TO_TAIL) to_tail = true; @@ -1344,7 +1347,7 @@ static inline void expand(struct zone *zone, struct page *page, continue; __add_to_free_list(&page[size], zone, high, migratetype, false); - set_buddy_order(&page[size], high); + set_buddy_order_ugen(&page[size], high, 0); nr_added += size; } account_freepages(zone, nr_added, migratetype); @@ -6802,7 +6805,7 @@ static void break_down_buddy_pages(struct zone *zone, struct page *page, continue; add_to_free_list(current_buddy, zone, high, migratetype, false); - set_buddy_order(current_buddy, high); + set_buddy_order_ugen(current_buddy, high, 0); } }