Received: by 2002:a25:86ce:0:0:0:0:0 with SMTP id y14csp2591886ybm; Thu, 23 May 2019 21:00:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqzbqDZoIVj4/ju7a1yLLd60gs9GxukQd+1KBXqvFxgEU/l8TViHaq6DLw9WQrXZilv95QCa X-Received: by 2002:a17:902:a407:: with SMTP id p7mr13189569plq.41.1558670418498; Thu, 23 May 2019 21:00:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558670418; cv=none; d=google.com; s=arc-20160816; b=FgghHvhv2Apr5P0jNAmXA7c51uOHAutGt+DUAUqLpFRifDC9YLF6IQqF4JtstvRX6t 0pMZ2pTEbDQ2tS+r5U01ta1Pt0BOWclf6mXsqcd40IzdnDzHcVU5J+fxmeqDO+c1XUjR 9GeCVS13ixVDNXOzFyZasOm6PKjQecfFJE6gfIq5m5H+GyYISC+L9I52jxxQYzv38CAi QLx63Md9CAhhBR+RM5stLkXiqeSkMNqyV0k7mjs2fHWLGEr6a5Pjk04pUpdjVk3z8gVQ w1TVRCHQBXPinnqTQCG0xW5HMmxiECVUi0Sefbuhxo0VfXbL2i2VJDLjOOnDrFGGjYcP Z6qw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=f6c9m1oolNz7qnNp31NpIo+ILEox6NGu8lwYyMw+NLU=; b=w3lx7PegVGRA12mZy2B+QRLz4iBpCNVTAgH32k+GUvkms2gpCzYxajjHCmPUlq2cPS q7so0qNIQsNi9pJU20nHFkLp1P1zP2wPPoouNELqbhSYLNoGVKx2hRwPMwmqKQjAYb+d zy8UuzA8DNmS4+Vr2MLUPhS2TOc/djTKO08LTuQidVD6rP4aMWiCTrxu4+DM11UjyATW 3oLS11d+6m9mFJ7Qw+63KGJ6YfjEo8SWUmYjz32xRNpKHUgj1QYC5uv2Libeow/jvXdA B8b5Q770y1NovSnDf5asyxHaceXcKt3hg33R7+5oRFMsmM/we8b77mt1ZZBrUzu2dqK0 4vfQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel-com.20150623.gappssmtp.com header.s=20150623 header.b=Qs74XkHj; 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 z1si2517705plo.211.2019.05.23.20.59.56; Thu, 23 May 2019 21:00:18 -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; dkim=pass header.i=@intel-com.20150623.gappssmtp.com header.s=20150623 header.b=Qs74XkHj; 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 S2388335AbfEXD6Y (ORCPT + 99 others); Thu, 23 May 2019 23:58:24 -0400 Received: from mail-ot1-f65.google.com ([209.85.210.65]:35243 "EHLO mail-ot1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387703AbfEXD6Y (ORCPT ); Thu, 23 May 2019 23:58:24 -0400 Received: by mail-ot1-f65.google.com with SMTP id n14so7500990otk.2 for ; Thu, 23 May 2019 20:58:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=intel-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=f6c9m1oolNz7qnNp31NpIo+ILEox6NGu8lwYyMw+NLU=; b=Qs74XkHjFhIG5eWAqZuHInffVvs+3AV05OrIpZ2xTnqAoDqX14pggyRk9f9DKHpuSs IRIBA2Ri/L1Hws5vXuO4/80WJMPdl81Bfp9VTtv6MkS+yeMMugK5uHJSDrPNnXcruuw3 fJM4itI1+d6xJhugS2SaMdwDq6lT+66DbFSttJHrPC9+6vC2KDSJ8ido/7gjDGJXyt6f Eli8t58rYv3qybUABQC+8jQRyJo3F65nGswTPDcjH5BfeMOzlFdaSN0IOzN5j/p+fvgV 4gO7UElauHskekm3kCMewjQB2ilKCmqgQOr8DJjZu2CsqzL0iuxZTXFDWF/JNWUVpQX/ GcNg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=f6c9m1oolNz7qnNp31NpIo+ILEox6NGu8lwYyMw+NLU=; b=C7w6F8T09osbLZFMnSeMmmJ9H3mPA9JlVqQHIXtUJBJqY24dlJG5blbxsOtLzGslt+ 82DsY2Mky8tXTiap+aTZcaD+XRAlLuQumR+5Jpe0LSmY606xT+UVsh17pyaas4orJ5vr /R+etpePoZj7OULSxWGwAyNxVeTMTFHR1hnITZB+LcRPkKInFDHg58fV3pJT3QNtvhgC bx5z0crOyUjpj3auB/qsSaeJrnN/zoGXd5kbwADJ0AXUy5dSjgCqvuFOYB5ATWvv0rJy G2HhfpCVrY4PPAbHBq8Gd8tut/yLR9D4pmW0j42kVA7/7n7Cr9LMY3rwheGHbpPwp667 J6aw== X-Gm-Message-State: APjAAAVqNJ5w+k7HN7mzd3oVGpc+HnOAJ5YEiEmpRm5/eGDV8LK6Db8K e3+C1XN9IuQvuiy//F3IsxPRyh4B3REgbFpw/ns92g== X-Received: by 2002:a9d:6e96:: with SMTP id a22mr4573516otr.207.1558670303779; Thu, 23 May 2019 20:58:23 -0700 (PDT) MIME-Version: 1.0 References: <20190523223746.4982-1-ira.weiny@intel.com> In-Reply-To: <20190523223746.4982-1-ira.weiny@intel.com> From: Dan Williams Date: Thu, 23 May 2019 20:58:12 -0700 Message-ID: Subject: Re: [PATCH] mm/swap: Fix release_pages() when releasing devmap pages To: "Weiny, Ira" Cc: Andrew Morton , Michal Hocko , Linux MM , Linux Kernel Mailing List , John Hubbard , =?UTF-8?B?SsOpcsO0bWUgR2xpc3Nl?= Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable 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 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=C3=A9r=C3=B4me 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 =3D 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 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. Other than that you can add: Reviewed-by: Dan Williams