summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/i386/i386/vm86.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/sys/arch/i386/i386/vm86.c b/sys/arch/i386/i386/vm86.c
index 9ce1c9db6da..9dda35ab6de 100644
--- a/sys/arch/i386/i386/vm86.c
+++ b/sys/arch/i386/i386/vm86.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: vm86.c,v 1.4 1996/04/21 22:16:42 deraadt Exp $ */
-/* $NetBSD: vm86.c,v 1.9 1996/04/12 05:57:43 mycroft Exp $ */
+/* $OpenBSD: vm86.c,v 1.5 1996/05/02 13:42:56 deraadt Exp $ */
+/* $NetBSD: vm86.c,v 1.13 1996/04/25 13:50:21 mycroft Exp $ */
/*-
* Copyright (c) 1996 The NetBSD Foundation, Inc.
@@ -269,6 +269,7 @@ vm86_return(p, retval)
#define CLI 0xFA
#define STI 0xFB
#define INTxx 0xCD
+#define INTO 0xCE
#define IRET 0xCF
#define OPSIZ 0x66
#define INT3 0xCC /* Actually the process gets 32-bit IDT to handle it */
@@ -292,14 +293,17 @@ vm86_gpfault(p, type)
* address space for checking. remember that the frame's
* segment selectors are real-mode style selectors.
*/
- u_char tmpbyte;
u_long cs, ip, ss, sp;
+ u_char tmpbyte;
+ int trace;
cs = CS(tf) << 4;
ip = IP(tf);
ss = SS(tf) << 4;
sp = SP(tf);
+ trace = tf->tf_eflags & PSL_T;
+
/*
* For most of these, we must set all the registers before calling
* macros/functions which might do a vm86_return.
@@ -327,6 +331,11 @@ vm86_gpfault(p, type)
fast_intxx(p, tmpbyte);
break;
+ case INTO:
+ if (tf->tf_eflags & PSL_V)
+ fast_intxx(p, 4);
+ break;
+
case PUSHF:
putword(ss, sp, get_vflags_short(p));
SP(tf) = sp;
@@ -368,6 +377,9 @@ vm86_gpfault(p, type)
IP(tf) -= 1;
goto bad;
}
+
+ if (trace && tf->tf_eflags & PSL_VM)
+ trapsignal(p, SIGTRAP, T_TRCTRAP);
return;
bad: