Revision c45442055dfdeb265cc20c9eeaa9fd11a75fbf51 authored by Arnd Bergmann on 22 February 2016, 21:58:34 UTC, committed by Dan Williams on 24 February 2016, 01:17:20 UTC
A recent bugfix changed pfn_t to always be 64-bit wide, but did not
change the code in pmem.c, which is now broken on 32-bit architectures
as reported by gcc:

In file included from ../drivers/nvdimm/pmem.c:28:0:
drivers/nvdimm/pmem.c: In function 'pmem_alloc':
include/linux/pfn_t.h:15:17: error: large integer implicitly truncated to unsigned type [-Werror=overflow]
 #define PFN_DEV (1ULL << (BITS_PER_LONG_LONG - 3))

This changes the intermediate pfn_flags in struct pmem_device to
be 64 bit wide as well, so they can store the flags correctly.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Fixes: db78c22230d0 ("mm: fix pfn_t vs highmem")
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
1 parent 93f834d
History
File Mode Size
Kconfig -rw-r--r-- 1.4 KB
Makefile -rw-r--r-- 265 bytes
bind.c -rw-r--r-- 7.0 KB
daemon.c -rw-r--r-- 16.4 KB
interface.c -rw-r--r-- 14.8 KB
internal.h -rw-r--r-- 10.7 KB
key.c -rw-r--r-- 3.7 KB
main.c -rw-r--r-- 2.4 KB
namei.c -rw-r--r-- 24.4 KB
proc.c -rw-r--r-- 3.1 KB
rdwr.c -rw-r--r-- 24.3 KB
security.c -rw-r--r-- 2.7 KB
xattr.c -rw-r--r-- 7.0 KB

back to top