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.7 KB
Makefile -rw-r--r-- 272 bytes
compress.c -rw-r--r-- 10.1 KB
dir.c -rw-r--r-- 6.5 KB
export.c -rw-r--r-- 5.1 KB
inode.c -rw-r--r-- 38.8 KB
isofs.h -rw-r--r-- 6.3 KB
joliet.c -rw-r--r-- 1.3 KB
namei.c -rw-r--r-- 4.1 KB
rock.c -rw-r--r-- 18.3 KB
rock.h -rw-r--r-- 2.3 KB
util.c -rw-r--r-- 2.2 KB
zisofs.h -rw-r--r-- 807 bytes

back to top