aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-sparc64/a.out.h
diff options
context:
space:
mode:
authorDavid S. Miller <davem@sunset.davemloft.net>2006-03-02 18:12:27 -0800
committerDavid S. Miller <davem@sunset.davemloft.net>2006-03-20 01:14:14 -0800
commit8bcd17411643beb9a601e032d0cf1016909a81d3 (patch)
treefc71e788df4fada768247fa7c12e983d2f6f1a32 /include/asm-sparc64/a.out.h
parent[SPARC64]: Fix _PAGE_EXEC handling. (diff)
downloadlinux-dev-8bcd17411643beb9a601e032d0cf1016909a81d3.tar.xz
linux-dev-8bcd17411643beb9a601e032d0cf1016909a81d3.zip
[SPARC64]: Do not allow mapping pages within 4GB of 64-bit VA hole.
The UltraSPARC T1 manual recommends this because the chip could instruction prefetch into the VA hole, and this would also make decoding certain kinds of memory access traps more difficult (because the chip sign extends certain pieces of trap state). Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/asm-sparc64/a.out.h')
-rw-r--r--include/asm-sparc64/a.out.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/include/asm-sparc64/a.out.h b/include/asm-sparc64/a.out.h
index 02af289e3f46..faac321d5594 100644
--- a/include/asm-sparc64/a.out.h
+++ b/include/asm-sparc64/a.out.h
@@ -95,7 +95,9 @@ struct relocation_info /* used when header.a_machtype == M_SPARC */
#ifdef __KERNEL__
-#define STACK_TOP (test_thread_flag(TIF_32BIT) ? 0xf0000000 : 0x80000000000L)
+#define STACK_TOP (test_thread_flag(TIF_32BIT) ? \
+ 0xf0000000 : \
+ (0x0000080000000000UL - (1UL << 32UL)))
#endif