be662a18b7
I hadn't been running a SKAS3 host when testing the "uml: fix hang in TT mode on fault" patch (commit 546fe1cbf91d4d62e3849517c31a2327c992e5c5), and I didn't think enough to the missing trap_no in SKAS3 mode. In fact, the resulting kernel doesn't work at all in SKAS3 mode. Signed-off-by: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
54 lines
1.3 KiB
C
54 lines
1.3 KiB
C
/*
|
|
* Copyright 2003 PathScale, Inc.
|
|
*
|
|
* Licensed under the GPL
|
|
*/
|
|
|
|
#ifndef __SYSDEP_X86_64_SIGCONTEXT_H
|
|
#define __SYSDEP_X86_64_SIGCONTEXT_H
|
|
|
|
#include <sysdep/sc.h>
|
|
|
|
#define IP_RESTART_SYSCALL(ip) ((ip) -= 2)
|
|
|
|
#define SC_RESTART_SYSCALL(sc) IP_RESTART_SYSCALL(SC_IP(sc))
|
|
#define SC_SET_SYSCALL_RETURN(sc, result) SC_RAX(sc) = (result)
|
|
|
|
#define SC_FAULT_ADDR(sc) SC_CR2(sc)
|
|
#define SC_FAULT_TYPE(sc) SC_ERR(sc)
|
|
|
|
#define GET_FAULTINFO_FROM_SC(fi,sc) \
|
|
{ \
|
|
(fi).cr2 = SC_CR2(sc); \
|
|
(fi).error_code = SC_ERR(sc); \
|
|
(fi).trap_no = SC_TRAPNO(sc); \
|
|
}
|
|
|
|
/* ptrace expects that, at the start of a system call, %eax contains
|
|
* -ENOSYS, so this makes it so.
|
|
*/
|
|
|
|
#define SC_START_SYSCALL(sc) do SC_RAX(sc) = -ENOSYS; while(0)
|
|
|
|
/* This is Page Fault */
|
|
#define SEGV_IS_FIXABLE(fi) ((fi)->trap_no == 14)
|
|
|
|
/* No broken SKAS API, which doesn't pass trap_no, here. */
|
|
#define SEGV_MAYBE_FIXABLE(fi) 0
|
|
|
|
extern unsigned long *sc_sigmask(void *sc_ptr);
|
|
|
|
#endif
|
|
|
|
/*
|
|
* Overrides for Emacs so that we follow Linus's tabbing style.
|
|
* Emacs will notice this stuff at the end of the file and automatically
|
|
* adjust the settings for this buffer only. This must remain at the end
|
|
* of the file.
|
|
* ---------------------------------------------------------------------------
|
|
* Local variables:
|
|
* c-file-style: "linux"
|
|
* End:
|
|
*/
|
|
|