aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKonstantin Belousov <kib@FreeBSD.org>2021-03-30 15:40:02 +0000
committerKonstantin Belousov <kib@FreeBSD.org>2021-03-30 23:07:35 +0000
commit8223717ce62c1ad0becc34ce69fe2d1771f3ba05 (patch)
treeb44fbd615205eda3d130bc6803581b46c7523e64
parent2b98ea2e51a0e38861dc8d29c2c716f2c19433d6 (diff)
downloadsrc-8223717ce62c1ad0becc34ce69fe2d1771f3ba05.tar.gz
src-8223717ce62c1ad0becc34ce69fe2d1771f3ba05.zip
x86: clear %db registers in new process
Reported by: Michał Górny <mgorny@gentoo.org> PR: 254661 Reviewed by: emaste, jhb MFC after: 1 week Sponsored by: The FreeBSD Foundation Differential revision: https://reviews.freebsd.org/D29496
-rw-r--r--sys/amd64/amd64/vm_machdep.c8
-rw-r--r--sys/i386/i386/vm_machdep.c8
2 files changed, 16 insertions, 0 deletions
diff --git a/sys/amd64/amd64/vm_machdep.c b/sys/amd64/amd64/vm_machdep.c
index f64259decbff..98d212dc8771 100644
--- a/sys/amd64/amd64/vm_machdep.c
+++ b/sys/amd64/amd64/vm_machdep.c
@@ -229,6 +229,14 @@ cpu_fork(struct thread *td1, struct proc *p2, struct thread *td2, int flags)
copy_thread(td1, td2);
+ /* Reset debug registers in the new process */
+ pcb2->pcb_dr0 = 0;
+ pcb2->pcb_dr1 = 0;
+ pcb2->pcb_dr2 = 0;
+ pcb2->pcb_dr3 = 0;
+ pcb2->pcb_dr6 = 0;
+ pcb2->pcb_dr7 = 0;
+
/* Point mdproc and then copy over p1's contents */
mdp2 = &p2->p_md;
bcopy(&p1->p_md, mdp2, sizeof(*mdp2));
diff --git a/sys/i386/i386/vm_machdep.c b/sys/i386/i386/vm_machdep.c
index c04fb57db4b1..ed40ebe5d1c8 100644
--- a/sys/i386/i386/vm_machdep.c
+++ b/sys/i386/i386/vm_machdep.c
@@ -241,6 +241,14 @@ cpu_fork(struct thread *td1, struct proc *p2, struct thread *td2, int flags)
copy_thread(td1, td2);
+ /* Reset debug registers in the new process */
+ pcb2->pcb_dr0 = 0;
+ pcb2->pcb_dr1 = 0;
+ pcb2->pcb_dr2 = 0;
+ pcb2->pcb_dr3 = 0;
+ pcb2->pcb_dr6 = 0;
+ pcb2->pcb_dr7 = 0;
+
/* Point mdproc and then copy over td1's contents */
mdp2 = &p2->p_md;
bcopy(&p1->p_md, mdp2, sizeof(*mdp2));