blob: a930ce3d48318d0c008b499a473052c986c89f01 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * Copyright (C) 2000, 2001, 2002 Jeff Dike (jdike@karaya.com)
3 * Licensed under the GPL
4 */
5
6#ifndef __SYS_SIGCONTEXT_I386_H
7#define __SYS_SIGCONTEXT_I386_H
8
Paolo 'Blaisorblade' Giarrussobe662a12005-09-30 11:58:59 -07009#include "uml-config.h"
Jeff Dikec28b59d2007-10-16 01:26:54 -070010#include "skas.h"
11#include "sysdep/sc.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070012
13#define IP_RESTART_SYSCALL(ip) ((ip) -= 2)
14
15#define SC_RESTART_SYSCALL(sc) IP_RESTART_SYSCALL(SC_IP(sc))
16#define SC_SET_SYSCALL_RETURN(sc, result) SC_EAX(sc) = (result)
17
Bodo Stroesserc5784552005-05-05 16:15:31 -070018#define GET_FAULTINFO_FROM_SC(fi,sc) \
19 { \
20 (fi).cr2 = SC_CR2(sc); \
21 (fi).error_code = SC_ERR(sc); \
22 (fi).trap_no = SC_TRAPNO(sc); \
23 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
25/* ptrace expects that, at the start of a system call, %eax contains
26 * -ENOSYS, so this makes it so.
27 */
28#define SC_START_SYSCALL(sc) do SC_EAX(sc) = -ENOSYS; while(0)
29
30/* This is Page Fault */
Paolo 'Blaisorblade' Giarrussobe662a12005-09-30 11:58:59 -070031#define SEGV_IS_FIXABLE(fi) ((fi)->trap_no == 14)
32
33/* SKAS3 has no trap_no on i386, but get_skas_faultinfo() sets it to 0. */
Paolo 'Blaisorblade' Giarrussobe662a12005-09-30 11:58:59 -070034#define SEGV_MAYBE_FIXABLE(fi) ((fi)->trap_no == 0 && ptrace_faultinfo)
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
36extern unsigned long *sc_sigmask(void *sc_ptr);
37extern int sc_get_fpregs(unsigned long buf, void *sc_ptr);
38
39#endif
40/*
41 * Overrides for Emacs so that we follow Linus's tabbing style.
42 * Emacs will notice this stuff at the end of the file and automatically
43 * adjust the settings for this buffer only. This must remain at the end
44 * of the file.
45 * ---------------------------------------------------------------------------
46 * Local variables:
47 * c-file-style: "linux"
48 * End:
49 */