Received: by 2002:a5d:925a:0:0:0:0:0 with SMTP id e26csp232810iol; Sat, 11 Jun 2022 02:59:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwSiQMrrKgY/pDpg9eksg4ou8HKfQzvKL2teSeSH3XjGV0nh5M7r7Ogcblf2ASslEN/e9WH X-Received: by 2002:a17:906:7a12:b0:711:f686:a84d with SMTP id d18-20020a1709067a1200b00711f686a84dmr15084191ejo.41.1654941559548; Sat, 11 Jun 2022 02:59:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654941559; cv=none; d=google.com; s=arc-20160816; b=yQpqnGatALw5FCQUSNw6/B6PZjLRdBc+XygQ7+M9P5HJVd3e5T4HFUhlJkQ77Q+Y6y k7f7RUyH0UhzxyWs1ifzC22mhKiHktakx0pWZvVStVloXtqe3cvZV0FYrogUBqsbnzM8 abfR6g3S1MLdvRWNmTNV8/IZ6TsOmvjWbgIiJO7n6YhNQ/ZyK/LyWt0QEuW9WRXxvraV 8XT87FSuER6LLJtt0x/+FvjsRB5DflVSc8kwvwxCeU+pUpQqKoBEFt+Jy9uRmTd1amJ/ FHdVCl3jibiYcRBX7Ubjhigc4iEBqLJ15zbbFdIjuD7ga/pxE7WY+svm0um0Gfc4qqAQ /8oQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=pK1aJ/tp0wV/o2k1uh33rMqUJUM6ubVFYAFBRs8M5lM=; b=FC/fyYKldQw6CRBp0xE6h16PKDMCpmn5ymg8MsLm3xrm74C256N0dVcnmpyNIvYSWv SaRy3cBPn1WvFZw1tDV7/mu/H1SgjFYCNdJNROUmg3oUI6vqzd/ARdW3YwUBaH08XI3D mGZt4oz9mk74GbgKQeMKXH7PDafPybOSgCPgy30Cjm+hE4DdiX6J/M6QUEed6XyFzi7q vkCcTN1sy6E7HvdA+F/oovg1e+FFbX60I0gX9SW8mFVaNjPPH1nJfIfOGutfx8VNf69m VbCMbXkRFmlprXliD/65B1HAFtr1L/ata8YI9fdiVfkmDWl5ZNIt27/ioBSg/33tmgO7 JiRA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y20-20020a056402271400b0042dc9a133a6si1864355edd.423.2022.06.11.02.58.55; Sat, 11 Jun 2022 02:59:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231783AbiFKIrx (ORCPT + 99 others); Sat, 11 Jun 2022 04:47:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57228 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231689AbiFKIre (ORCPT ); Sat, 11 Jun 2022 04:47:34 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C82053AD for ; Sat, 11 Jun 2022 01:47:33 -0700 (PDT) Received: from canpemm500002.china.huawei.com (unknown [172.30.72.57]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4LKrzC2SkqzjXRb; Sat, 11 Jun 2022 16:46:31 +0800 (CST) Received: from huawei.com (10.175.124.27) by canpemm500002.china.huawei.com (7.192.104.244) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Sat, 11 Jun 2022 16:47:31 +0800 From: Miaohe Lin To: CC: , , , , , , , , , , , Subject: [PATCH 7/7] mm/khugepaged: try to free transhuge swapcache when possible Date: Sat, 11 Jun 2022 16:47:31 +0800 Message-ID: <20220611084731.55155-8-linmiaohe@huawei.com> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20220611084731.55155-1-linmiaohe@huawei.com> References: <20220611084731.55155-1-linmiaohe@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.124.27] X-ClientProxiedBy: dggems701-chm.china.huawei.com (10.3.19.178) To canpemm500002.china.huawei.com (7.192.104.244) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Transhuge swapcaches won't be freed in __collapse_huge_page_copy(). It's because release_pte_page() is not called for these pages and thus free_page_and_swap_cache can't grab the page lock. These pages won't be freed from swap cache even if we are the only user until next time reclaim. It shouldn't hurt indeed, but we could try to free these pages to save more memory for system. Signed-off-by: Miaohe Lin --- include/linux/swap.h | 5 +++++ mm/khugepaged.c | 1 + mm/swap.h | 5 ----- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/include/linux/swap.h b/include/linux/swap.h index 8672a7123ccd..ccb83b12b724 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h @@ -456,6 +456,7 @@ static inline unsigned long total_swapcache_pages(void) return global_node_page_state(NR_SWAPCACHE); } +extern void free_swap_cache(struct page *page); extern void free_page_and_swap_cache(struct page *); extern void free_pages_and_swap_cache(struct page **, int); /* linux/mm/swapfile.c */ @@ -540,6 +541,10 @@ static inline void put_swap_device(struct swap_info_struct *si) /* used to sanity check ptes in zap_pte_range when CONFIG_SWAP=0 */ #define free_swap_and_cache(e) is_pfn_swap_entry(e) +static inline void free_swap_cache(struct page *page) +{ +} + static inline int add_swap_count_continuation(swp_entry_t swp, gfp_t gfp_mask) { return 0; diff --git a/mm/khugepaged.c b/mm/khugepaged.c index ee0a719c8be9..52109ad13f78 100644 --- a/mm/khugepaged.c +++ b/mm/khugepaged.c @@ -756,6 +756,7 @@ static void __collapse_huge_page_copy(pte_t *pte, struct page *page, list_for_each_entry_safe(src_page, tmp, compound_pagelist, lru) { list_del(&src_page->lru); release_pte_page(src_page); + free_swap_cache(src_page); } } diff --git a/mm/swap.h b/mm/swap.h index 0193797b0c92..863f6086c916 100644 --- a/mm/swap.h +++ b/mm/swap.h @@ -41,7 +41,6 @@ void __delete_from_swap_cache(struct page *page, void delete_from_swap_cache(struct page *page); void clear_shadow_from_swap_cache(int type, unsigned long begin, unsigned long end); -void free_swap_cache(struct page *page); struct page *lookup_swap_cache(swp_entry_t entry, struct vm_area_struct *vma, unsigned long addr); @@ -81,10 +80,6 @@ static inline struct address_space *swap_address_space(swp_entry_t entry) return NULL; } -static inline void free_swap_cache(struct page *page) -{ -} - static inline void show_swap_cache_info(void) { } -- 2.23.0