summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/i386/i386/genassym.cf4
-rw-r--r--sys/arch/i386/i386/locore.s6
-rw-r--r--sys/arch/i386/include/pcb.h4
3 files changed, 11 insertions, 3 deletions
diff --git a/sys/arch/i386/i386/genassym.cf b/sys/arch/i386/i386/genassym.cf
index e20ff580910..88c086d6526 100644
--- a/sys/arch/i386/i386/genassym.cf
+++ b/sys/arch/i386/i386/genassym.cf
@@ -1,4 +1,4 @@
-# $OpenBSD: genassym.cf,v 1.26 2007/04/03 10:14:47 art Exp $
+# $OpenBSD: genassym.cf,v 1.27 2007/10/03 07:51:26 kettenis Exp $
#
# Copyright (c) 1982, 1990 The Regents of the University of California.
# All rights reserved.
@@ -115,6 +115,8 @@ member pcb_ldt
member pcb_ldt_sel
member pcb_onfault
member pcb_fpcpu
+member pcb_flags
+export PCB_SAVECTX
# frame definitions
struct trapframe
diff --git a/sys/arch/i386/i386/locore.s b/sys/arch/i386/i386/locore.s
index 5a39b580a5c..d8e379cb506 100644
--- a/sys/arch/i386/i386/locore.s
+++ b/sys/arch/i386/i386/locore.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.s,v 1.114 2007/05/29 23:02:02 tom Exp $ */
+/* $OpenBSD: locore.s,v 1.115 2007/10/03 07:51:26 kettenis Exp $ */
/* $NetBSD: locore.s,v 1.145 1996/05/03 19:41:19 christos Exp $ */
/*-
@@ -1770,6 +1770,10 @@ ENTRY(savectx)
movl %esp,PCB_ESP(%edx)
movl %ebp,PCB_EBP(%edx)
+ movl PCB_FLAGS(%edx),%ecx
+ orl $PCB_SAVECTX,%ecx
+ movl %ecx,PCB_FLAGS(%edx)
+
ret
/*****************************************************************************/
diff --git a/sys/arch/i386/include/pcb.h b/sys/arch/i386/include/pcb.h
index 0788135e06d..fa3623eafad 100644
--- a/sys/arch/i386/include/pcb.h
+++ b/sys/arch/i386/include/pcb.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcb.h,v 1.13 2004/07/02 16:29:55 niklas Exp $ */
+/* $OpenBSD: pcb.h,v 1.14 2007/10/03 07:51:26 kettenis Exp $ */
/* $NetBSD: pcb.h,v 1.21 1996/01/08 13:51:42 mycroft Exp $ */
/*-
@@ -77,6 +77,8 @@ struct pcb {
struct cpu_info *pcb_fpcpu; /* cpu holding our fpu state */
u_long pcb_iomap[NIOPORTS/32]; /* I/O bitmap */
u_char pcb_iomap_pad; /* required; must be 0xff, says intel */
+ int pcb_flags;
+#define PCB_SAVECTX 0x00000001
};
/*