Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp611738ybi; Fri, 24 May 2019 08:39:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqw8CMjqcq4e1lZggV2FgA3vAe9XntpIAnlT06DnEQc8S8zaQ5RySFXwD2vSv8FfPWvtLEQ2 X-Received: by 2002:a17:902:b492:: with SMTP id y18mr100498799plr.96.1558712378116; Fri, 24 May 2019 08:39:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558712378; cv=none; d=google.com; s=arc-20160816; b=tTaDo3F8M+uRn/MtN6sXa/1Y+MuB3GEdE3Fpr+EHIG53ZGRv4FCtxTYdRzSrPNCznh q8CcwmJbihW3JY3/l7Y+tys+5CBU1EKCRwxftc23fPh3AJYXW41F1Pcqw8qaUbmbTbfi H/MKlZgLLgE9nM/mVfJo/sA1dBOhctPnAI7aU6yjIVFpouyF9bWS3acB99k0tdNl0hzk JeoOB1w5h0zvyYUREMpHXoo03uabLhnCv58KCRylVlNS4cCfC8k5gP91FVgrYE5Z8sk3 kDRHsbB+NnalA+PwSlvtisBDGrMAuxv4/lXgllgAgcH3pDBT3KjF+9s1zJQXoh38QQ9f /RHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=4yxQqi6h6TVYUcswGQNLIQ8ZipBRxcwhUG1Z7u4odyg=; b=I1K+Bss7IjDDmktjTozQ060AFOI2m0Ewm/gf4mm4ikJ6pfIl2Id3b/akpJxdzeGYx5 jCw0iuQeCMWMFS7DpxHotyD7exAx4E5MZkrFABQMZfKyHBywAYg5IOI/biIp/CqblSVc FZsK3yGYXtJ2++y22bmN6AVleBjumBO8MNq2n19Y1iS+40pfANgTXjcOELpQdo1sZkz0 ABbvTJJZjPa30ckH4L82F3c7FdMTrBMO3pWrO6U6l1dKx2U533WTTq0bza5YNdaBN+vm 94Y/XT5GEtpz8f0IccPoPJZqapbpNybt4tHxvk8uSxaTTHCdTakvD1IGy7/3Y73EknXz R2Yg== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g4si5514934plm.324.2019.05.24.08.39.22; Fri, 24 May 2019 08:39:38 -0700 (PDT) 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390443AbfEXPgB (ORCPT + 99 others); Fri, 24 May 2019 11:36:01 -0400 Received: from mga05.intel.com ([192.55.52.43]:31359 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389927AbfEXPfc (ORCPT ); Fri, 24 May 2019 11:35:32 -0400 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 24 May 2019 08:35:31 -0700 X-ExtLoop1: 1 Received: from iweiny-desk2.sc.intel.com ([10.3.52.157]) by orsmga003.jf.intel.com with ESMTP; 24 May 2019 08:35:30 -0700 Date: Fri, 24 May 2019 08:36:25 -0700 From: Ira Weiny To: Dan Williams Cc: Andrew Morton , Michal Hocko , Linux MM , Linux Kernel Mailing List , John Hubbard , =?iso-8859-1?B?Suly9G1l?= Glisse Subject: Re: [PATCH] mm/swap: Fix release_pages() when releasing devmap pages Message-ID: <20190524153625.GA23100@iweiny-DESK2.sc.intel.com> References: <20190523223746.4982-1-ira.weiny@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.11.1 (2018-12-01) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, May 23, 2019 at 08:58:12PM -0700, Dan Williams wrote: > On Thu, May 23, 2019 at 3:37 PM wrote: > > > > From: Ira Weiny > > > > Device pages can be more than type MEMORY_DEVICE_PUBLIC. > > > > Handle all device pages within release_pages() > > > > This was found via code inspection while determining if release_pages() > > and the new put_user_pages() could be interchangeable. > > > > Cc: J?r?me Glisse > > Cc: Dan Williams > > Cc: Michal Hocko > > Cc: John Hubbard > > Signed-off-by: Ira Weiny > > --- > > mm/swap.c | 7 +++---- > > 1 file changed, 3 insertions(+), 4 deletions(-) > > > > diff --git a/mm/swap.c b/mm/swap.c > > index 3a75722e68a9..d1e8122568d0 100644 > > --- a/mm/swap.c > > +++ b/mm/swap.c > > @@ -739,15 +739,14 @@ void release_pages(struct page **pages, int nr) > > if (is_huge_zero_page(page)) > > continue; > > > > - /* Device public page can not be huge page */ > > - if (is_device_public_page(page)) { > > + if (is_zone_device_page(page)) { > > if (locked_pgdat) { > > spin_unlock_irqrestore(&locked_pgdat->lru_lock, > > flags); > > locked_pgdat = NULL; > > } > > - put_devmap_managed_page(page); > > - continue; > > + if (put_devmap_managed_page(page)) > > This "shouldn't" fail, and if it does the code that follows might get I agree it shouldn't based on the check. However... > confused by a ZONE_DEVICE page. If anything I would make this a > WARN_ON_ONCE(!put_devmap_managed_page(page)), but always continue > unconditionally. I was trying to follow the pattern from put_page() Where if fails it indicated it was not a devmap page and so "regular" processing should continue. Since I'm unsure I'll just ask what does this check do? if (!static_branch_unlikely(&devmap_managed_key)) return false; ... In put_devmap_managed_page()? > > Other than that you can add: > > Reviewed-by: Dan Williams Thanks v2 to follow. Ira