summaryrefslogtreecommitdiffstats
path: root/arch/sparc/include/asm/tlb_64.h
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2010-02-20 00:19:52 +0100
committerDavid S. Miller <davem@davemloft.net>2010-02-20 00:19:52 +0100
commit1f474646fdc36b457606bbcd6a3592e6cbd31ac4 (patch)
tree706149d39c9de0bc0ceacfb2ab44e909caba5b3c /arch/sparc/include/asm/tlb_64.h
parentsparc: Fix incorrect comparison in of_bus_ambapp_match() (diff)
downloadlinux-1f474646fdc36b457606bbcd6a3592e6cbd31ac4.tar.xz
linux-1f474646fdc36b457606bbcd6a3592e6cbd31ac4.zip
sparc64: Fix sun4u execute bit check in TSB I-TLB load.
Thanks to testcase and report from Brad Spengler: -------------------- #include <stdio.h> typedef int (* _wee)(void); int main(void) { char buf[8] = { '\x81', '\xc7', '\xe0', '\x08', '\x81', '\xe8', '\x00', '\x00' }; _wee wee; printf("%p\n", &buf); wee = (_wee)&buf; wee(); return 0; } -------------------- TSB I-tlb load code tries to use andcc to check the _PAGE_EXEC_4U bit, but that's bit 12 so it gets sign extended all the way up to bit 63 and the test nearly always passes as a result. Use sethi to fix the bug. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/include/asm/tlb_64.h')
0 files changed, 0 insertions, 0 deletions