Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp6375352rwi; Sun, 23 Oct 2022 23:53:54 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5MR3vaq6Ihi39G5f019oXWNmObxzY4Mu3Sq7cQ5qYMB4x2YaCXSZIullGkjZDd/qTvJLZE X-Received: by 2002:a17:902:c942:b0:180:3f94:2975 with SMTP id i2-20020a170902c94200b001803f942975mr31999351pla.50.1666594423617; Sun, 23 Oct 2022 23:53:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666594423; cv=none; d=google.com; s=arc-20160816; b=Y3UzNfoQ2zyUQYyu5zm4VZKisBTQ+xABgow2pjLooexIj0OAXIoXoeQaSgdN6waLpv IYSunLiyW7ufYZg7azaj38/MWIsXTxQS+iIUsDnWYq3jXTmKdtlU7waGnbgEoRDWd+2y EJRXRcky8Tiizvq6TJXKWGJl2+znu7ag9cU1ltClPX7BkVZMKz7ghvKcQJEqmNUn0Yum SLlRDJQE9XJYqdDvvQJGzvPz0LZyuj9U8PKUybJwvmlG0JqFr8Mr6wi9Eo/BljigBZ0I 2SsJc224Nf8pFAooEkXrHLmxuuNHtravZCbeHek71D/8VCWHQxxqryYusigx0zUNRH8E Cy2w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:subject:user-agent:mime-version:date:message-id; bh=vzJ24NJY8MDG8nL+qMJ25HoP/zYjsJf2GX8y+xA64cQ=; b=Pn1p6gfeTuqG17LS0i4HotQQi4qs1dSxG7oDF9VJbeL3j6VitTbh9k5h8aOSnzfR6q MgQQ/BFaF/QMza4VUgmetyFX6S8AKcvUHUC4HNmbTmMRhZf75kMMZ4hIbsC1b8olSya7 wOKCs0LV9tyvPpAB50hC4amadDKJ+Q2QqUhbueSXe5N0pK6kfAKytAKLERCqrfEC8i7b lqqb1iv0zBsPVwdYrFvSbbJfDWxF4olvX/Bvpyg1WRYt6mbRI6OQVkKi7RPZfwkphuYT PW/R2/sB1la2wkEclNrUqquyOmY/cDJylZEBwO0267wF8UqKaX5q0hg3IxBCW4Xf9nzx JiyQ== 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=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b6-20020a63e706000000b00439c1e186c8si35080831pgi.281.2022.10.23.23.53.30; Sun, 23 Oct 2022 23:53:43 -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=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230214AbiJXGlj (ORCPT + 99 others); Mon, 24 Oct 2022 02:41:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54962 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229649AbiJXGlh (ORCPT ); Mon, 24 Oct 2022 02:41:37 -0400 Received: from out30-133.freemail.mail.aliyun.com (out30-133.freemail.mail.aliyun.com [115.124.30.133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0B15F53024 for ; Sun, 23 Oct 2022 23:41:35 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R191e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046060;MF=baolin.wang@linux.alibaba.com;NM=1;PH=DS;RN=9;SR=0;TI=SMTPD_---0VStCPI._1666593690; Received: from 30.97.48.50(mailfrom:baolin.wang@linux.alibaba.com fp:SMTPD_---0VStCPI._1666593690) by smtp.aliyun-inc.com; Mon, 24 Oct 2022 14:41:32 +0800 Message-ID: <4fcb9065-0d0c-7bd3-d4f9-5830792cce60@linux.alibaba.com> Date: Mon, 24 Oct 2022 14:41:30 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.3.0 Subject: Re: [PATCH v2 1/2] mm: migrate: Fix return value if all subpages of THPs are migrated successfully To: Alistair Popple Cc: akpm@linux-foundation.org, david@redhat.com, ying.huang@intel.com, ziy@nvidia.com, shy828301@gmail.com, jingshan@linux.alibaba.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org References: <87pmeiq6qc.fsf@nvidia.com> From: Baolin Wang In-Reply-To: <87pmeiq6qc.fsf@nvidia.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE, SPF_PASS,UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL 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 On 10/24/2022 10:36 AM, Alistair Popple wrote: > > Baolin Wang writes: > >> When THP migration, if THPs are split and all subpages are migrated successfully >> , the migrate_pages() will still return the number of THP that were not migrated. >> That will confuse the callers of migrate_pages(), for example, which will make >> the longterm pinning failed though all pages are migrated successfully. >> >> Thus we should return 0 to indicate all pages are migrated in this case. >> >> Signed-off-by: Baolin Wang >> --- >> Changes from v1: >> - Fix the return value of migrate_pages() instead of fixing the >> callers' validation. >> --- >> mm/migrate.c | 7 +++++++ >> 1 file changed, 7 insertions(+) >> >> diff --git a/mm/migrate.c b/mm/migrate.c >> index 8e5eb6e..1da0dbc 100644 >> --- a/mm/migrate.c >> +++ b/mm/migrate.c >> @@ -1582,6 +1582,13 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, >> */ >> list_splice(&ret_pages, from); >> >> + /* >> + * Return 0 in case all subpages of fail-to-migrate THPs are >> + * migrated successfully. >> + */ >> + if (nr_thp_split && list_empty(from)) >> + rc = 0; > > Why do you need to check nr_thp_split? Wouldn't list_empty(from) == True Only in the case of THP split, we can meet this abnormal case. So if no THP split, just return the original 'rc' instead of validating the list, since the 'nr_thp_split' validation is cheaper than the list_empty() validation IMHO. > imply success? And if it doesn't imply success wouldn't it be possible > to end up with nr_thp_split && list_empty(from) whilst still having > pages that failed to migrate? > > The list management and return code logic from unmap_and_move() has > gotten pretty difficult to follow and could do with some rework IMHO. Yes, Huang Ying has sent a RFC patchset[1] doing some code refactor, which seems a good start. [1] https://lore.kernel.org/all/20220921060616.73086-1-ying.huang@intel.com/