ref: a8ae1f43f6f557e7d818709702769b8932c28834
parent: 7d4ffe0306f5e4237d453831ba78bba46c3c34bf
parent: 90bc67ffdf55934e28ff91fa72a8b5afc9c043fc
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Mon Dec 2 18:33:29 EST 2019
merge
--- a/sys/src/9/pc/main.c
+++ b/sys/src/9/pc/main.c
@@ -585,13 +585,18 @@
p->fpstate = FPinit;
fpoff();
- cycles(&p->kentry);
- p->pcycles = -p->kentry;
-
memset(p->gdt, 0, sizeof(p->gdt));
p->nldt = 0;
+ /* clear debug registers */
memset(p->dr, 0, sizeof(p->dr));
+ if(m->dr7 != 0){+ m->dr7 = 0;
+ putdr7(0);
+ }
+
+ cycles(&p->kentry);
+ p->pcycles = -p->kentry;
}
void
@@ -624,9 +629,6 @@
memmove(p->fpsave, up->fpsave, sizeof(FPsave));
p->fpstate = FPinactive;
}
-
- /* clear debug registers */
- memset(p->dr, 0, sizeof(p->dr));
splx(s);
}
@@ -659,15 +661,17 @@
{uvlong t;
+ cycles(&t);
+ p->kentry -= t;
+ p->pcycles += t;
+
/* we could just always putdr7(0) but accessing DR7 might be slow in a VM */
if(m->dr7 != 0){m->dr7 = 0;
putdr7(0);
}
-
- cycles(&t);
- p->kentry -= t;
- p->pcycles += t;
+ if(p->state == Moribund)
+ p->dr[7] = 0;
if(p->fpstate == FPactive){if(p->state == Moribund)
--- a/sys/src/9/pc64/main.c
+++ b/sys/src/9/pc64/main.c
@@ -581,6 +581,14 @@
{p->fpstate = FPinit;
_stts();
+
+ /* clear debug registers */
+ memset(p->dr, 0, sizeof(p->dr));
+ if(m->dr7 != 0){+ m->dr7 = 0;
+ putdr7(0);
+ }
+
cycles(&p->kentry);
p->pcycles = -p->kentry;
}
@@ -639,14 +647,16 @@
{uvlong t;
+ cycles(&t);
+ p->kentry -= t;
+ p->pcycles += t;
+
if(m->dr7 != 0){m->dr7 = 0;
putdr7(0);
}
-
- cycles(&t);
- p->kentry -= t;
- p->pcycles += t;
+ if(p->state == Moribund)
+ p->dr[7] = 0;
switch(p->fpstate & ~(FPnouser|FPkernel|FPindexm)){case FPactive | FPpush:
--
⑨