diff options
author | Matt Mackall <mpm@selenic.com> | 2008-12-09 13:14:21 -0800 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2008-12-13 15:29:33 -0800 |
commit | 35b9d8e0aa1268072f0a9238d738558c64c77372 (patch) | |
tree | 10e123ca6edf7993b59911d5b3e34ce1520d90d1 | |
parent | cb01c9ddcbb5a1c8049bacf1f145b402f0ce3a0a (diff) | |
download | lwn-35b9d8e0aa1268072f0a9238d738558c64c77372.tar.gz lwn-35b9d8e0aa1268072f0a9238d738558c64c77372.zip |
pagemap: fix 32-bit pagemap regression
commit 49c50342c728344b79c8f9e8293637fe80ef5ad5 upstream.
The large pages fix from bcf8039ed45 broke 32-bit pagemap by pulling the
pagemap entry code out into a function with the wrong return type.
Pagemap entries are 64 bits on all systems and unsigned long is only 32
bits on 32-bit systems.
Signed-off-by: Matt Mackall <mpm@selenic.com>
Reported-by: Doug Graham <dgraham@nortel.com>
Cc: Alexey Dobriyan <adobriyan@gmail.com>
Cc: Dave Hansen <dave@linux.vnet.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r-- | fs/proc/task_mmu.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index f3ada047c890..8b84227b0c44 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c @@ -563,9 +563,9 @@ static u64 swap_pte_to_pagemap_entry(pte_t pte) return swp_type(e) | (swp_offset(e) << MAX_SWAPFILES_SHIFT); } -static unsigned long pte_to_pagemap_entry(pte_t pte) +static u64 pte_to_pagemap_entry(pte_t pte) { - unsigned long pme = 0; + u64 pme = 0; if (is_swap_pte(pte)) pme = PM_PFRAME(swap_pte_to_pagemap_entry(pte)) | PM_PSHIFT(PAGE_SHIFT) | PM_SWAP; |