Merge branch 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm

Pull memremap fix from Dan Williams:
"The new memremap() api introduced in the 4.3 cycle to unify/replace
ioremap_cache() and ioremap_wt() is mishandling the highmem case.
This patch has received a build success notification from a
0day-kbuild-robot run and has received an ack from Ard"

From the commit message:
"The impact of this bug is low for now since the pmem driver is the
only user of memremap(), but this is important to fix before more
conversions to memremap arrive in 4.4"

* 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm:
memremap: fix highmem support

Changed files
+12 -2
kernel
+12 -2
kernel/memremap.c
··· 24 24 } 25 25 #endif 26 26 27 + static void *try_ram_remap(resource_size_t offset, size_t size) 28 + { 29 + struct page *page = pfn_to_page(offset >> PAGE_SHIFT); 30 + 31 + /* In the simple case just return the existing linear address */ 32 + if (!PageHighMem(page)) 33 + return __va(offset); 34 + return NULL; /* fallback to ioremap_cache */ 35 + } 36 + 27 37 /** 28 38 * memremap() - remap an iomem_resource as cacheable memory 29 39 * @offset: iomem resource start address ··· 76 66 * the requested range is potentially in "System RAM" 77 67 */ 78 68 if (is_ram == REGION_INTERSECTS) 79 - addr = __va(offset); 80 - else 69 + addr = try_ram_remap(offset, size); 70 + if (!addr) 81 71 addr = ioremap_cache(offset, size); 82 72 } 83 73