From nobody Sat Sep 13 22:33:32 2025 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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id A74B7C61D97 for ; Sun, 29 Jan 2023 03:39:34 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232277AbjA2Dj1 (ORCPT ); Sat, 28 Jan 2023 22:39:27 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43564 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229513AbjA2DjZ (ORCPT ); Sat, 28 Jan 2023 22:39:25 -0500 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B43EE2068F for ; Sat, 28 Jan 2023 19:39:24 -0800 (PST) Received: from dggpemm500002.china.huawei.com (unknown [172.30.72.57]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4P4H7x6YHlzJrPk; Sun, 29 Jan 2023 11:37:49 +0800 (CST) Received: from localhost.localdomain (10.175.112.125) by dggpemm500002.china.huawei.com (7.185.36.229) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Sun, 29 Jan 2023 11:39:22 +0800 From: Chen Wandun To: , , , CC: Subject: [PATCH v2] mm/migrate: Continue to migrate for non-hugetlb folios Date: Sun, 29 Jan 2023 11:39:10 +0800 Message-ID: <20230129033910.1327277-1-chenwandun@huawei.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.175.112.125] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpemm500002.china.huawei.com (7.185.36.229) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" migrate_hugetlbs returns -ENOMEM when no enough hugetlb, however there may be free non-hugetlb folios available, so continue to migrate for non-hugetlb folios. Nowdays the only negtive return value of migrate_hugetlbs is -ENOMEM, keep compatible for coming negtive return value instead of ignore return value. Signed-off-by: Chen Wandun Reviewed-by: "Huang, Ying" --- v1 --> v2: modify changelog and comment. thanks Huang Ying. --- mm/migrate.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/mm/migrate.c b/mm/migrate.c index b971edbf32fc..68927aa06f9b 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -1939,7 +1939,8 @@ int migrate_pages(struct list_head *from, new_page_t = get_new_page, =20 rc_gather =3D migrate_hugetlbs(from, get_new_page, put_new_page, private, mode, reason, &stats, &ret_folios); - if (rc_gather < 0) + /* There may be free non-hugetlb folios available, continue to migrate. */ + if (rc_gather < 0 && rc_gather !=3D -ENOMEM) goto out; again: nr_pages =3D 0; --=20 2.25.1