d0b5e15f0c
Before we had SKAS0 UML had two modes of operation TT (tracing thread) and SKAS3/4 (separated kernel address space). TT was known to be insecure and got removed a long time ago. SKAS3/4 required a few (3 or 4) patches on the host side which never went mainline. The last host patch is 10 years old. With SKAS0 mode (separated kernel address space using 0 host patches), default since 2005, SKAS3/4 is obsolete and can be removed. Signed-off-by: Richard Weinberger <richard@nod.at>
33 lines
983 B
C
33 lines
983 B
C
/*
|
|
* Copyright (C) 2004 Fujitsu Siemens Computers GmbH
|
|
* Author: Bodo Stroesser <bstroesser@fujitsu-siemens.com>
|
|
* Licensed under the GPL
|
|
*/
|
|
|
|
#ifndef __FAULTINFO_X86_64_H
|
|
#define __FAULTINFO_X86_64_H
|
|
|
|
/* this structure contains the full arch-specific faultinfo
|
|
* from the traps.
|
|
* On i386, ptrace_faultinfo unfortunately doesn't provide
|
|
* all the info, since trap_no is missing.
|
|
* All common elements are defined at the same position in
|
|
* both structures, thus making it easy to copy the
|
|
* contents without knowledge about the structure elements.
|
|
*/
|
|
struct faultinfo {
|
|
int error_code; /* in ptrace_faultinfo misleadingly called is_write */
|
|
unsigned long cr2; /* in ptrace_faultinfo called addr */
|
|
int trap_no; /* missing in ptrace_faultinfo */
|
|
};
|
|
|
|
#define FAULT_WRITE(fi) ((fi).error_code & 2)
|
|
#define FAULT_ADDRESS(fi) ((fi).cr2)
|
|
|
|
/* This is Page Fault */
|
|
#define SEGV_IS_FIXABLE(fi) ((fi)->trap_no == 14)
|
|
|
|
#define PTRACE_FULL_FAULTINFO 1
|
|
|
|
#endif
|