Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2672700pxb; Tue, 13 Apr 2021 07:32:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxuF9c4qL+a60oFoxs9MVixs4ve5Owkn/wHKB2/qgSdKCK7hFMBjPRLQckRV6xG6Vf+K3JV X-Received: by 2002:a63:78cc:: with SMTP id t195mr31483442pgc.196.1618324378490; Tue, 13 Apr 2021 07:32:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618324378; cv=none; d=google.com; s=arc-20160816; b=JseRqRXuPNyKZ8nWNZWxGWPDziovMXuWFgFTFysUkXgYpKEHz5sO39i0rEQktl5vF9 Myyfg7afSImoapODSIx0qDhU80y+tMvuKoQ4BYQCM/h73Ax0+56MiRoycjfD7azbHU9b g4PoAR7tYD3Mn9da2HzLmPCDrhMwot6Af7N6atOWxG8keOF0gtNNFGkMRl9G86Y63gX8 tvvvHcX3ndhsBGJkM1p+jWv1XHR3UZsDO3PLXggHy38RcTHPVSQkNColmM+dzD9M7RWy Jd75EibTUpDCVTWvkyRPDo2XnxZ7MPrFu5xd1JrOT2a6GhxRs5iNUyvjYY6NYvZjzyn6 lZuw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=TEDsnUapPrxqx1V/9AlQl5lqUdtIPflQV7h07TLHvHQ=; b=NJZK4EYSzTZUSbw21ZqxSDEIy9BfAbTqk9dmi8elA2mAoes1M5S+lzcvywM8XiEL3x hsp3zbmRzzM9Msv4O1H20bYF+CtWjtpnyOMcKuUF/JuL3pqtk7ZqUp0zes97j1pxELjN HpVktte2GAs2AAAqiwcvd8hzAetH6bbT5PBQe6xefJPBHpDaFt3ciE4U1q7GfS4TFO4A w8oew8FApVSnHvwnw+reR4BZ+FwnY1WzNK/q6EqkL7a/IvrOrUFykrnfDif3/S7Lc0BP ALG0XJaEoIJ0huzGtMRSA4OQ15i9HmuSlVoHa8/fQIK3j5leXJ12rLLyV3t8nsMBAlpR gZhA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p24si3324859pjo.68.2021.04.13.07.32.45; Tue, 13 Apr 2021 07:32:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343879AbhDMKs4 (ORCPT + 99 others); Tue, 13 Apr 2021 06:48:56 -0400 Received: from mx2.suse.de ([195.135.220.15]:52872 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343819AbhDMKsY (ORCPT ); Tue, 13 Apr 2021 06:48:24 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 40277B158; Tue, 13 Apr 2021 10:48:04 +0000 (UTC) From: Oscar Salvador To: Andrew Morton Cc: Mike Kravetz , Vlastimil Babka , David Hildenbrand , Michal Hocko , Muchun Song , linux-mm@kvack.org, linux-kernel@vger.kernel.org, Oscar Salvador Subject: [PATCH v7 4/7] mm,hugetlb: Split prep_new_huge_page functionality Date: Tue, 13 Apr 2021 12:47:44 +0200 Message-Id: <20210413104747.12177-5-osalvador@suse.de> X-Mailer: git-send-email 2.13.7 In-Reply-To: <20210413104747.12177-1-osalvador@suse.de> References: <20210413104747.12177-1-osalvador@suse.de> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, prep_new_huge_page() performs two functions. It sets the right state for a new hugetlb, and increases the hstate's counters to account for the new page. Let us split its functionality into two separate functions, decoupling the handling of the counters from initializing a hugepage. The outcome is having __prep_new_huge_page(), which only initializes the page , and __prep_account_new_huge_page(), which adds the new page to the hstate's counters. This allows us to be able to set a hugetlb without having to worry about the counter/locking. It will prove useful in the next patch. prep_new_huge_page() still calls both functions. Signed-off-by: Oscar Salvador --- mm/hugetlb.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/mm/hugetlb.c b/mm/hugetlb.c index e40d5fe5c63c..0607b2b71ac6 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c @@ -1483,7 +1483,16 @@ void free_huge_page(struct page *page) } } -static void prep_new_huge_page(struct hstate *h, struct page *page, int nid) +/* + * Must be called with the hugetlb lock held + */ +static void __prep_account_new_huge_page(struct hstate *h, int nid) +{ + h->nr_huge_pages++; + h->nr_huge_pages_node[nid]++; +} + +static void __prep_new_huge_page(struct page *page) { INIT_LIST_HEAD(&page->lru); set_compound_page_dtor(page, HUGETLB_PAGE_DTOR); @@ -1491,9 +1500,13 @@ static void prep_new_huge_page(struct hstate *h, struct page *page, int nid) set_hugetlb_cgroup(page, NULL); set_hugetlb_cgroup_rsvd(page, NULL); ClearHPageFreed(page); +} + +static void prep_new_huge_page(struct hstate *h, struct page *page, int nid) +{ + __prep_new_huge_page(page); spin_lock_irq(&hugetlb_lock); - h->nr_huge_pages++; - h->nr_huge_pages_node[nid]++; + __prep_account_new_huge_page(h, nid); spin_unlock_irq(&hugetlb_lock); } -- 2.16.3