From mboxrd@z Thu Jan 1 00:00:00 1970 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 373E4C433EF for ; Wed, 13 Jul 2022 08:30:46 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id B8C0E94010D; Wed, 13 Jul 2022 04:30:45 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id B3B8E9400E5; Wed, 13 Jul 2022 04:30:45 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id A2ABB94010D; Wed, 13 Jul 2022 04:30:45 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0011.hostedemail.com [216.40.44.11]) by kanga.kvack.org (Postfix) with ESMTP id 945EB9400E5 for ; Wed, 13 Jul 2022 04:30:45 -0400 (EDT) Received: from smtpin11.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay09.hostedemail.com (Postfix) with ESMTP id 3B41134CBA for ; Wed, 13 Jul 2022 08:30:45 +0000 (UTC) X-FDA: 79681405650.11.2A4AC2C Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by imf08.hostedemail.com (Postfix) with ESMTP id 8D76516005F for ; Wed, 13 Jul 2022 08:30:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1657701044; x=1689237044; h=from:to:cc:subject:references:date:in-reply-to: message-id:mime-version; bh=YQUSBazFo/c4fVEPXFT3RG1PGjmSxbf7eA6p2HwqTTo=; b=R5CxOFdVfm/FSauTIQlPkau/mkhhAb9Eh5cZPvJNJAkOHKF0MXX6qboa gih7slikLqeJHW4/6Zw5OjeOFpZQAzmZ/YO2DpNChhiMB7uUpXbe8rY4Y 1eSweqM7KegoAjOOPlItqj+1G5yxSWSbMK1KTo2VMafkzF4Ilxi/aAhmg AwMPuwxa1BvK6PcOP/fX6HckziC2flFi0sz04o+rmhc7v9BEY+QR2tSTy jlvpmK7NVvjIwQHLR+g/LTvDCx83qtCY9/MssS8Q3r89fAkzEGTR97rUt lX5+YDgEmpjO3bT4bFebpWtkLxK2FG57HA8iz9vxufNtn8kSELRIj57r9 A==; X-IronPort-AV: E=McAfee;i="6400,9594,10406"; a="371463040" X-IronPort-AV: E=Sophos;i="5.92,267,1650956400"; d="scan'208";a="371463040" Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 13 Jul 2022 01:30:34 -0700 X-IronPort-AV: E=Sophos;i="5.92,267,1650956400"; d="scan'208";a="570535384" Received: from yhuang6-desk2.sh.intel.com (HELO yhuang6-desk2.ccr.corp.intel.com) ([10.239.13.94]) by orsmga006-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 13 Jul 2022 01:30:32 -0700 From: "Huang, Ying" To: Oscar Salvador Cc: Andrew Morton , linux-mm@kvack.org, linux-kernel@vger.kernel.org, Baolin Wang , Zi Yan , Yang Shi Subject: Re: [PATCH -V2 5/7] migrate_pages(): fix failure counting for THP on -ENOSYS References: <20220711084948.274787-1-ying.huang@intel.com> <20220711084948.274787-6-ying.huang@intel.com> Date: Wed, 13 Jul 2022 16:30:27 +0800 In-Reply-To: (Oscar Salvador's message of "Mon, 11 Jul 2022 14:26:20 +0200") Message-ID: <87wnch4dp8.fsf@yhuang6-desk2.ccr.corp.intel.com> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/27.1 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=ascii ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1657701044; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=BkgAv29tSFpvotwnucNQca/PByR7wAH4syTqOuuQviM=; b=VSDQjW1ONNV3VC4Adz1LLiAt7RYEa6sJ0DUKY2vj75g8JY0Pd1bCCw4FcQndpsXLuPrkCR 4Jc2ynjVqQ4r6tt0NxL7Aqktbm6ru83iR7cD9YFj5evXEj/Y5ILH+PiZaxJ8jjNPBgK0As +ZZHcZbqWM4EyqAKmbqFxJo0vhybv9c= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1657701044; a=rsa-sha256; cv=none; b=sF4zTb3zTuv86KfRGH6fys5Azw6ADrhhSgPXrOZlwxcJefHHp3Yd66kg+VtjQxC37VXt07 joIYdrw32xoHDI0W8lCqr2M7GIDMc80r87bf5jXgWLedgvGlP1nhQAQFgXiwJudn/RDMq8 GZQ16euiesEdIgjPZgPlF/sEcu5KKJo= ARC-Authentication-Results: i=1; imf08.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=R5CxOFdV; dmarc=pass (policy=none) header.from=intel.com; spf=none (imf08.hostedemail.com: domain of ying.huang@intel.com has no SPF policy when checking 192.55.52.43) smtp.mailfrom=ying.huang@intel.com X-Stat-Signature: 7jteqxy1we1e74nf6hs7nezwrehzzsx5 X-Rspamd-Queue-Id: 8D76516005F X-Rspam-User: Authentication-Results: imf08.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=R5CxOFdV; dmarc=pass (policy=none) header.from=intel.com; spf=none (imf08.hostedemail.com: domain of ying.huang@intel.com has no SPF policy when checking 192.55.52.43) smtp.mailfrom=ying.huang@intel.com X-Rspamd-Server: rspam05 X-HE-Tag: 1657701044-817013 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: Oscar Salvador writes: > On Mon, Jul 11, 2022 at 04:49:46PM +0800, Huang Ying wrote: >> If THP or hugetlbfs page migration isn't supported, unmap_and_move() >> or unmap_and_move_huge_page() will return -ENOSYS. For THP, splitting >> will be tried, but if splitting doesn't succeed, the THP will be left >> in "from" list wrongly. If some other pages are retried, the THP >> migration failure will counted again. This is fixed via moving the >> failure THP from "from" to "ret_pages". >> >> Another issue of the original code is that the unsupported failure >> processing isn't consistent between THP and hugetlbfs page. Make them >> consistent in this patch to make the code easier to be understood too. >> >> Signed-off-by: "Huang, Ying" >> Fixes: 5984fabb6e82 ("mm: move_pages: report the number of non-attempted pages") >> Reviewed-by: Baolin Wang >> Cc: Zi Yan >> Cc: Yang Shi >> --- >> mm/migrate.c | 6 +++--- >> 1 file changed, 3 insertions(+), 3 deletions(-) >> >> diff --git a/mm/migrate.c b/mm/migrate.c >> index 4bceba143db0..8cce73b7c046 100644 >> --- a/mm/migrate.c >> +++ b/mm/migrate.c >> @@ -1192,10 +1192,8 @@ static int unmap_and_move_huge_page(new_page_t get_new_page, >> * tables or check whether the hugepage is pmd-based or not before >> * kicking migration. >> */ >> - if (!hugepage_migration_supported(page_hstate(hpage))) { >> - list_move_tail(&hpage->lru, ret); >> + if (!hugepage_migration_supported(page_hstate(hpage))) >> return -ENOSYS; >> - } >> >> if (page_count(hpage) == 1) { >> /* page was freed from under us. So we are done. */ >> @@ -1392,6 +1390,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, >> * page will be put back >> * -EAGAIN: stay on the from list >> * -ENOMEM: stay on the from list >> + * -ENOSYS: stay on the from list >> * Other errno: put on ret_pages list then splice to >> * from list >> */ >> @@ -1421,6 +1420,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, >> } >> >> nr_failed_pages += nr_subpages; >> + list_move_tail(&page->lru, &ret_pages); > > I must be missing something, but migrate_pages() calls unmap_and_move_huge_page() > with ret being ret_pages, so > > list_move_tail(&hpage->lru, ret) == list_move_tail(&page->lru, &ret_pages) > > Yet, you say "This is fixed via moving the failure THP from "from" to "ret_pages"". > /me confused. To make it consistent between hugetlb page and THP/normal page, I have revised the unmap_and_move_huge_page() via deleting the list_move_tail() there for ENOSYS. After that, we move the hugetlb page and THP/normal page in the same way in migrate_pages(). Best Regards, Huang, Ying