Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3329351ybl; Mon, 27 Jan 2020 01:51:06 -0800 (PST) X-Google-Smtp-Source: APXvYqzwi5N+Y7Yq712h/+JJdwu87FWjuqde2qDFiXxFrzEWPWrX3a/rdb0/4ILLrwX3JACQPa+w X-Received: by 2002:a05:6830:1d55:: with SMTP id p21mr11796416oth.145.1580118666231; Mon, 27 Jan 2020 01:51:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580118666; cv=none; d=google.com; s=arc-20160816; b=0CCgycyAjz/p2JkoRTYykpw7aSXgnC+iDwcQriiiCuHmvdftoiP+gpRpSOlTOBPD+L XwZ3KeOvcxgTG/U5xOEwO5L6NfTQEQ+AitpuSEb8S4cCKI7ktgm+GQyPH7odh5lfzpy+ 7EKATMzZ7CXwH6Bixk0logKj7q6Nfs+TE0ab1yCn+osd2gACrGEUIgw6ZWtkbZxXV581 JBoYLlBn2GtGPE+nYexwQZ7eRsF8bvb2NvqfXLsXp3fxNXME/7XnHP2m+kzYaUtibAYO zmzsosrwbG2XyNm6hEWYuRaJ4BaV79+IjgFRcvMSPABu8f7r0d50krKTGzsMby30Ka2O 4Tww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=roaLqSgfifGJecXUxqExqg9D+N1Onbxp/Fi3I5fIEaA=; b=IBlJaFtxPL6boAwq8aQfrX0qWSEKXGnSByPHzaRjlv63FQ11JBAAhjBcPEy/jDx3hm hyRFeH+EqaOBVvlMynn3sUmdmySzKNosDtO9j1/24dBXai8sLTsCT09QTiklnDzLLXHd IE5+U+DFHg7HCOefXC6Vjug6cfRRB/seEPRF+jBVZS45oktEm6DYRIKk5rCbdXNWRtsr Q7nisgM5gc84VJiCL4ClEPdfogBEPR1MQYyCbNGVF9tAX9EJarYNRh2a/k6adwguyP3S OmqpXsicxllEnA1Lzxy0bJHYCzZDzaQjyTcV51kKCI1JJAvVNwwZDZukJrxq1X2UNy/T hW4Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l11si2359596otn.189.2020.01.27.01.50.54; Mon, 27 Jan 2020 01:51:06 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729671AbgA0Jgp (ORCPT + 99 others); Mon, 27 Jan 2020 04:36:45 -0500 Received: from mail-wm1-f65.google.com ([209.85.128.65]:33068 "EHLO mail-wm1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729037AbgA0Jgp (ORCPT ); Mon, 27 Jan 2020 04:36:45 -0500 Received: by mail-wm1-f65.google.com with SMTP id m10so8162588wmc.0 for ; Mon, 27 Jan 2020 01:36:44 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=roaLqSgfifGJecXUxqExqg9D+N1Onbxp/Fi3I5fIEaA=; b=kjCyjXcFJYTfH3dCZhVOMTGXpnN+asyJYi8J5+buwivC0/bEXJFP7TgWD3+l4BE7Wp IxHpE9nO+TZMzxsOFxwg1RWcLWwc+X+rOIM8vf1+uRKHDv7NKgbXdTI0L8qpDEz+kJh9 Oo97ZpyQcvGV1EaUSiPlfVhBHHbJG7OXjzK99NNsy36Qm2B2jOTm7NZ8vjEWiwdd3w0N E12oNocAkeyutuk2nC06DWXWUKTubo5BrQPfLNHWXsM0eDfMv6wz18WAhkDT0Ya7srqv U8rTv3mG3rWRqoqeJ31Pj/4b3SwDqRdmESLPzo0nGWoG0FazcAeursymXDgeLDccxUQ7 Q8NA== X-Gm-Message-State: APjAAAUEfkmk4Ia+EfKCviG9Su76g4ZvvR0Zf6MgSi5jFhOfS3zpb5Ik 9X20tld5cGG1eNInJ64qZHGmoJVM X-Received: by 2002:a1c:9dcb:: with SMTP id g194mr12429547wme.53.1580117803298; Mon, 27 Jan 2020 01:36:43 -0800 (PST) Received: from localhost (prg-ext-pat.suse.com. [213.151.95.130]) by smtp.gmail.com with ESMTPSA id t10sm8734812wmi.40.2020.01.27.01.36.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Jan 2020 01:36:42 -0800 (PST) Date: Mon, 27 Jan 2020 10:36:42 +0100 From: Michal Hocko To: Wei Yang Cc: akpm@linux-foundation.org, yang.shi@linux.alibaba.com, rientjes@google.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [Patch v3 2/4] mm/migrate.c: wrap do_move_pages_to_node() and store_status() Message-ID: <20200127093642.GC1183@dhcp22.suse.cz> References: <20200126102623.9616-1-richardw.yang@linux.intel.com> <20200126102623.9616-3-richardw.yang@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200126102623.9616-3-richardw.yang@linux.intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun 26-01-20 18:26:21, Wei Yang wrote: > Usually do_move_pages_to_node() and store_status() is a pair. There are > three places call this pair of functions with almost the same form. > > This patch just wrap it to make it friendly to audience and also > consolidate the move and store action into one place. > > Signed-off-by: Wei Yang I believe I have already acked this one. Anyway Acked-by: Michal Hocko > --- > mm/migrate.c | 61 ++++++++++++++++++++++++++-------------------------- > 1 file changed, 30 insertions(+), 31 deletions(-) > > diff --git a/mm/migrate.c b/mm/migrate.c > index ae3db45c6a42..e816c8990296 100644 > --- a/mm/migrate.c > +++ b/mm/migrate.c > @@ -1583,6 +1583,29 @@ static int add_page_for_migration(struct mm_struct *mm, unsigned long addr, > return err; > } > > +static int move_pages_and_store_status(struct mm_struct *mm, int node, > + struct list_head *pagelist, int __user *status, > + unsigned long nr_pages, int start, int i) > +{ > + int err; > + > + err = do_move_pages_to_node(mm, pagelist, node); > + if (err) { > + /* > + * Positive err means the number of failed > + * pages to migrate. Since we are going to > + * abort and return the number of non-migrated > + * pages, so need incude the rest of the > + * nr_pages that have not attempted as well. > + */ > + if (err > 0) > + err += nr_pages - i - 1; > + return err; > + } > + err = store_status(status, start, node, i - start); > + return err; > +} > + > /* > * Migrate an array of page address onto an array of nodes and fill > * the corresponding array of status. > @@ -1626,20 +1649,9 @@ static int do_pages_move(struct mm_struct *mm, nodemask_t task_nodes, > current_node = node; > start = i; > } else if (node != current_node) { > - err = do_move_pages_to_node(mm, &pagelist, current_node); > - if (err) { > - /* > - * Positive err means the number of failed > - * pages to migrate. Since we are going to > - * abort and return the number of non-migrated > - * pages, so need incude the rest of the > - * nr_pages that have not attempted as well. > - */ > - if (err > 0) > - err += nr_pages - i - 1; > - goto out; > - } > - err = store_status(status, start, current_node, i - start); > + err = move_pages_and_store_status(mm, current_node, > + &pagelist, status, nr_pages, > + start, i); > if (err) > goto out; > start = i; > @@ -1668,13 +1680,8 @@ static int do_pages_move(struct mm_struct *mm, nodemask_t task_nodes, > if (err) > goto out_flush; > > - err = do_move_pages_to_node(mm, &pagelist, current_node); > - if (err) { > - if (err > 0) > - err += nr_pages - i - 1; > - goto out; > - } > - err = store_status(status, start, current_node, i - start); > + err = move_pages_and_store_status(mm, current_node, &pagelist, > + status, nr_pages, start, i); > if (err) > goto out; > current_node = NUMA_NO_NODE; > @@ -1684,16 +1691,8 @@ static int do_pages_move(struct mm_struct *mm, nodemask_t task_nodes, > return err; > > /* Make sure we do not overwrite the existing error */ > - err1 = do_move_pages_to_node(mm, &pagelist, current_node); > - /* > - * Don't have to report non-attempted pages here since: > - * - If the above loop is done gracefully there is not non-attempted > - * page. > - * - If the above loop is aborted to it means more fatal error > - * happened, should return err. > - */ > - if (!err1) > - err1 = store_status(status, start, current_node, i - start); > + err1 = move_pages_and_store_status(mm, current_node, &pagelist, > + status, nr_pages, start, i); > if (err >= 0) > err = err1; > out: > -- > 2.17.1 -- Michal Hocko SUSE Labs