Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3014130pxj; Mon, 10 May 2021 16:26:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyuQmTmsp11J+6++JXCPoEkfrdPTtaTCpcLY+hIqwF0wJZhGGX6JP53CtiuIR4gLVZ420Hk X-Received: by 2002:a5d:8481:: with SMTP id t1mr20512177iom.39.1620689188373; Mon, 10 May 2021 16:26:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620689188; cv=none; d=google.com; s=arc-20160816; b=fhQOwEX/Pr7CBUIRnXi8bScA9a+FsESA0247I1XB1KU8vzRuDAgXeSu0LuqL3kjERp 5ncFlIcrMkpg0RV8u91lUfnCDOtC4bKUd0eWxKJ9pJ6O/JgxNAhhGpW3M5Kok1up1E1v 8Bqs32dQoMufQgBlet13jhZe68KeDnIJKqDxS+SAgV0hpJa9EcLBc2/EThUNaeqoTKvS yyPHaRKg2QLqzeqes1dDel179Rh1T6GsZaxBJHxBWR6vU3Vo7JDdhZeKsST2+154qQWC /ty2c4K8AqKLBcoa7TJjbicok5Nc3UgIRPwAk4XtluOxtgxJIESqt9uQCwiUxBSYbYhq vtRg== 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 :dkim-signature; bh=TeUuXq9To8lgcl1o5k4sCzqTpRU5GNmM8WZRtq2XAHM=; b=c+jhgVYMiHsbY8s2Q0ZpUb92Bnn6xtxWsvR1tRxS35wZk3gvZb87Nkx0cXx/Jh2ZjO +XWap+Q2cTyFSwbPBug+oCf7Vav9CTR/HrIPz4JPauA+n5ziqdQNHAUo+jj+T5m5mNjY rF5E060H3zDIVgG51B0UeABmzMfTt6fOn+/d5EwKDyneNy9E04yfNj7zWjXLvFx439/M bs8e+G0VFByUl3aZrozCfu8a2MspviJuHsJN+89T/73qepAaS6P6bUkHYOzG0Ci0MjTe US9rMerqOKaBIz943wj31CrOG8ztQ1ZC/pKJTDJz72bY3wbnDHD40z0T7rjmbq9CFClC 2FlQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=i7uMGqhj; 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 k5si17361893ils.114.2021.05.10.16.26.15; Mon, 10 May 2021 16:26:28 -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; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=i7uMGqhj; 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 S229925AbhEJX0O (ORCPT + 99 others); Mon, 10 May 2021 19:26:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43518 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229561AbhEJX0N (ORCPT ); Mon, 10 May 2021 19:26:13 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E0C8EC061574 for ; Mon, 10 May 2021 16:25:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=Content-Transfer-Encoding:MIME-Version: References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender:Reply-To: Content-Type:Content-ID:Content-Description; bh=TeUuXq9To8lgcl1o5k4sCzqTpRU5GNmM8WZRtq2XAHM=; b=i7uMGqhjU70AcV3rLCnq7FFUGZ Xaas7OmrkB8xq7IRzd5gsQXfdaop46lQO1e+iWm84pCZsW/JAxRLTbOZYIVvfadTMGJ3BWGps0AZC JxH6zk/zdtQF4fnctsrEw+hQmEZjM1XTRy0pDjJXwwDQG2cR6REdmIbdoE1w3ZNUuyGZxs7UQ6zVW ldWxgUcAN7z9CNHSsc3yw3E7IHsomSOi2ardBJ1+RMnm36srL6GaIru8abEGso82zISVoMuUdGpQE 9eKlzCzbHLxV/squSMK3iYBK7HhQPgpQDya+D87qFKhki5y/Vdoy55lW1VpPtfIE+QvCY6iCO6RY8 9drN44qw==; Received: from willy by casper.infradead.org with local (Exim 4.94 #2 (Red Hat Linux)) id 1lgFFf-006gOK-8T; Mon, 10 May 2021 23:24:06 +0000 From: "Matthew Wilcox (Oracle)" To: linux-mm@kvack.org Cc: "Matthew Wilcox (Oracle)" , linux-kernel@vger.kernel.org Subject: [RFC PATCH 3/3] mm/migrate: Add folio_migrate_copy Date: Tue, 11 May 2021 00:23:08 +0100 Message-Id: <20210510232308.1592750-4-willy@infradead.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210510232308.1592750-1-willy@infradead.org> References: <20210510232308.1592750-1-willy@infradead.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Combine the THP, hugetlb and base page routines together into a simple loop. It does iterate the pages backwards, but real CPUs can prefetch a backwards walk. Signed-off-by: Matthew Wilcox (Oracle) --- include/linux/migrate.h | 1 + mm/folio-compat.c | 6 ++++ mm/migrate.c | 68 ++++++++--------------------------------- 3 files changed, 19 insertions(+), 56 deletions(-) diff --git a/include/linux/migrate.h b/include/linux/migrate.h index 7993faffa46d..cb67692e659a 100644 --- a/include/linux/migrate.h +++ b/include/linux/migrate.h @@ -52,6 +52,7 @@ extern int migrate_huge_page_move_mapping(struct address_space *mapping, extern int migrate_page_move_mapping(struct address_space *mapping, struct page *newpage, struct page *page, int extra_count); void folio_migrate_flags(struct folio *newfolio, struct folio *folio); +void folio_migrate_copy(struct folio *newfolio, struct folio *folio); int folio_migrate_mapping(struct address_space *mapping, struct folio *newfolio, struct folio *folio, int extra_count); #else diff --git a/mm/folio-compat.c b/mm/folio-compat.c index f0ac904d396f..316c912e49e0 100644 --- a/mm/folio-compat.c +++ b/mm/folio-compat.c @@ -76,4 +76,10 @@ void migrate_page_states(struct page *newpage, struct page *page) folio_migrate_flags(page_folio(newpage), page_folio(page)); } EXPORT_SYMBOL(migrate_page_states); + +void migrate_page_copy(struct page *newpage, struct page *page) +{ + folio_migrate_copy(page_folio(newpage), page_folio(page)); +} +EXPORT_SYMBOL(migrate_page_copy); #endif diff --git a/mm/migrate.c b/mm/migrate.c index 38006cdece60..ee1220d6b40a 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -529,54 +529,6 @@ int migrate_huge_page_move_mapping(struct address_space *mapping, return MIGRATEPAGE_SUCCESS; } -/* - * Gigantic pages are so large that we do not guarantee that page++ pointer - * arithmetic will work across the entire page. We need something more - * specialized. - */ -static void __copy_gigantic_page(struct page *dst, struct page *src, - int nr_pages) -{ - int i; - struct page *dst_base = dst; - struct page *src_base = src; - - for (i = 0; i < nr_pages; ) { - cond_resched(); - copy_highpage(dst, src); - - i++; - dst = mem_map_next(dst, dst_base, i); - src = mem_map_next(src, src_base, i); - } -} - -static void copy_huge_page(struct page *dst, struct page *src) -{ - int i; - int nr_pages; - - if (PageHuge(src)) { - /* hugetlbfs page */ - struct hstate *h = page_hstate(src); - nr_pages = pages_per_huge_page(h); - - if (unlikely(nr_pages > MAX_ORDER_NR_PAGES)) { - __copy_gigantic_page(dst, src, nr_pages); - return; - } - } else { - /* thp page */ - BUG_ON(!PageTransHuge(src)); - nr_pages = thp_nr_pages(src); - } - - for (i = 0; i < nr_pages; i++) { - cond_resched(); - copy_highpage(dst + i, src + i); - } -} - /* * Copy the flags and some other ancillary information */ @@ -650,16 +602,20 @@ void folio_migrate_flags(struct folio *newfolio, struct folio *folio) } EXPORT_SYMBOL(folio_migrate_flags); -void migrate_page_copy(struct page *newpage, struct page *page) +void folio_migrate_copy(struct folio *newfolio, struct folio *folio) { - if (PageHuge(page) || PageTransHuge(page)) - copy_huge_page(newpage, page); - else - copy_highpage(newpage, page); + unsigned int i = folio_nr_pages(folio) - 1; - migrate_page_states(newpage, page); + copy_highpage(folio_page(newfolio, i), folio_page(folio, i)); + while (i-- > 0) { + cond_resched(); + /* folio_page() handles discontinuities in memmap */ + copy_highpage(folio_page(newfolio, i), folio_page(folio, i)); + } + + folio_migrate_flags(newfolio, folio); } -EXPORT_SYMBOL(migrate_page_copy); +EXPORT_SYMBOL(folio_migrate_copy); /************************************************************ * Migration functions @@ -687,7 +643,7 @@ int migrate_page(struct address_space *mapping, return rc; if (mode != MIGRATE_SYNC_NO_COPY) - migrate_page_copy(newpage, page); + folio_migrate_copy(newfolio, folio); else folio_migrate_flags(newfolio, folio); return MIGRATEPAGE_SUCCESS; -- 2.30.2