Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp4337801imj; Tue, 12 Feb 2019 14:10:00 -0800 (PST) X-Google-Smtp-Source: AHgI3IYlLbuy6p+nNW1fjgUAOCkN+JyrpOo1SO3lzwQ8VGd5srAYUiEh3Naj+Ba479hREePqi9M0 X-Received: by 2002:a65:5301:: with SMTP id m1mr5470929pgq.90.1550009400473; Tue, 12 Feb 2019 14:10:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550009400; cv=none; d=google.com; s=arc-20160816; b=ffLf+WqRlLBqysP09Ix6lIbcvmnYvUMfgg1/C+JDxoAPuLd7HEA9L52Ci2CrKFZxyP eHjjNYxG35FPUwrpT0SRCD9xIo1LhxDQbIZleXe5VT/SJ+t2iMc0Dg6EnNAZMTQOIKzN +xav8tG9Xm3cartOuo5zwQdoPYPMF+WM1PDTrWkxbU5rgP3Zz5qAQgq1na31x55FEJ+V zq9OltdZZ0gmztJqtBCx74Plrbetb7w/E5lLOeibN4PS37TfupEPkTLowFoSP3ziFH1z njpm0XLFSsJSgv69MzmPJ8sjv2584sqfmpCg9GsQL1Sp2PBQAdv3fXKCelQs8RKy0Yuk KY6g== 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:mime-version :user-agent:references:in-reply-to:message-id:date:cc:to:from :subject; bh=rrUPm9+0X9cCPbS+KWTsXt17bYatlS+Htk8mU6IbWJI=; b=UbCHNaWVK1LVbAfS7ioY6myDD68fdUBmK6/2GH4EC33loWorfvFyu/X41k+8SHkz0t SyqChLcpZliDnBR/mVqPUQfOIQI3pJiShCd1mgIkKMczLE6mn1StmikO0EYyVOAep3yq F1zqhvKe+fU5V2U4PFqB68KvkMQ+xdVEv8cyzuw+tliLUBXRT6ARF9xZ829AtOLPurQg +60qO72/K69sJ1C+129jQGR+avZGShnVxk6Il4dXbZPjnfndHuUBQvBTcwlKFZydTKng SawRTXkXuLnfrktWXFEcZod2mll7r+MCww2pZbQ3CKj6hSVVhKCxqp3bsjS8lgG47W2f c+vw== 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 n8si9247243pgv.483.2019.02.12.14.09.44; Tue, 12 Feb 2019 14:10:00 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732563AbfBLVhb (ORCPT + 99 others); Tue, 12 Feb 2019 16:37:31 -0500 Received: from mga14.intel.com ([192.55.52.115]:57721 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732533AbfBLVha (ORCPT ); Tue, 12 Feb 2019 16:37:30 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 12 Feb 2019 13:37:29 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,362,1544515200"; d="scan'208";a="115696737" Received: from dwillia2-desk3.jf.intel.com (HELO dwillia2-desk3.amr.corp.intel.com) ([10.54.39.16]) by orsmga006.jf.intel.com with ESMTP; 12 Feb 2019 13:37:29 -0800 Subject: [PATCH 2/7] libnvdimm/pmem: Honor force_raw for legacy pmem regions From: Dan Williams To: linux-nvdimm@lists.01.org Cc: stable@vger.kernel.org, linux-kernel@vger.kernel.org, vishal.l.verma@intel.com, linux-fsdevel@vger.kernel.org Date: Tue, 12 Feb 2019 13:24:51 -0800 Message-ID: <155000669130.348031.13764885263577554365.stgit@dwillia2-desk3.amr.corp.intel.com> In-Reply-To: <155000668075.348031.9371497273408112600.stgit@dwillia2-desk3.amr.corp.intel.com> References: <155000668075.348031.9371497273408112600.stgit@dwillia2-desk3.amr.corp.intel.com> User-Agent: StGit/0.18-2-gc94f MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For recovery, where non-dax access is needed to a given physical address range, and testing, allow the 'force_raw' attribute to override the default establishment of a dev_pagemap. Otherwise without this capability it is possible to end up with a namespace that can not be activated due to corrupted info-block, and one that can not be repaired due to a section collision. Cc: Fixes: 004f1afbe199 ("libnvdimm, pmem: direct map legacy pmem by default") Signed-off-by: Dan Williams --- drivers/nvdimm/namespace_devs.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/nvdimm/namespace_devs.c b/drivers/nvdimm/namespace_devs.c index 4b077555ac70..33a3b23b3db7 100644 --- a/drivers/nvdimm/namespace_devs.c +++ b/drivers/nvdimm/namespace_devs.c @@ -138,6 +138,7 @@ bool nd_is_uuid_unique(struct device *dev, u8 *uuid) bool pmem_should_map_pages(struct device *dev) { struct nd_region *nd_region = to_nd_region(dev->parent); + struct nd_namespace_common *ndns = to_ndns(dev); struct nd_namespace_io *nsio; if (!IS_ENABLED(CONFIG_ZONE_DEVICE)) @@ -149,6 +150,9 @@ bool pmem_should_map_pages(struct device *dev) if (is_nd_pfn(dev) || is_nd_btt(dev)) return false; + if (ndns->force_raw) + return false; + nsio = to_nd_namespace_io(dev); if (region_intersects(nsio->res.start, resource_size(&nsio->res), IORESOURCE_SYSTEM_RAM,