Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752609AbbHOJE3 (ORCPT ); Sat, 15 Aug 2015 05:04:29 -0400 Received: from verein.lst.de ([213.95.11.211]:55852 "EHLO newverein.lst.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750913AbbHOJE2 (ORCPT ); Sat, 15 Aug 2015 05:04:28 -0400 Date: Sat, 15 Aug 2015 11:04:26 +0200 From: Christoph Hellwig To: Dan Williams Cc: linux-kernel@vger.kernel.org, boaz@plexistor.com, riel@redhat.com, linux-nvdimm@ml01.01.org, Dave Hansen , david@fromorbit.com, mingo@kernel.org, linux-mm@kvack.org, Ingo Molnar , mgorman@suse.de, "H. Peter Anvin" , ross.zwisler@linux.intel.com, torvalds@linux-foundation.org, hch@lst.de Subject: Re: [RFC PATCH 4/7] mm: register_dev_memmap() Message-ID: <20150815090426.GE21033@lst.de> References: <20150813031253.36913.29580.stgit@otcpl-skl-sds-2.jf.intel.com> <20150813035023.36913.56455.stgit@otcpl-skl-sds-2.jf.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150813035023.36913.56455.stgit@otcpl-skl-sds-2.jf.intel.com> User-Agent: Mutt/1.5.17 (2007-11-01) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1426 Lines: 38 > #endif /* _LINUX_KMAP_PFN_H */ > diff --git a/include/linux/mm.h b/include/linux/mm.h > index 8a4f24d7fdb0..07152a54b841 100644 > --- a/include/linux/mm.h > +++ b/include/linux/mm.h > @@ -939,6 +939,7 @@ typedef struct { > * PFN_SG_CHAIN - pfn is a pointer to the next scatterlist entry > * PFN_SG_LAST - pfn references a page and is the last scatterlist entry > * PFN_DEV - pfn is not covered by system memmap > + * PFN_MAP - pfn is covered by a device specific memmap > */ > enum { > PFN_MASK = (1UL << PAGE_SHIFT) - 1, > @@ -949,6 +950,7 @@ enum { > #else > PFN_DEV = 0, > #endif > + PFN_MAP = (1UL << 3), > }; > > static inline __pfn_t pfn_to_pfn_t(unsigned long pfn, unsigned long flags) > @@ -965,7 +967,7 @@ static inline __pfn_t phys_to_pfn_t(dma_addr_t addr, unsigned long flags) > > static inline bool __pfn_t_has_page(__pfn_t pfn) > { > - return (pfn.val & PFN_DEV) == 0; > + return (pfn.val & PFN_DEV) == 0 || (pfn.val & PFN_MAP) == PFN_MAP; Shouldn't we simply not set the PFN_DEV flag instead of needing another one to cancel it out? I also wonder if it might be better to not require the __pfn_t and SG rework patches before this series. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/