Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/amd64/amd64 Remove the sysretq fault handler. It is...



details:   https://anonhg.NetBSD.org/src/rev/0bc7a8a2dd4a
branches:  trunk
changeset: 831298:0bc7a8a2dd4a
user:      maxv <maxv%NetBSD.org@localhost>
date:      Tue Mar 20 14:26:49 2018 +0000

description:
Remove the sysretq fault handler. It is broken with SVS, and not really
needed anyway. Initially I had added it so that if such a fault was
received the kernel would panic "cleanly" instead of crashing in a
potentially undefined way.

I'll re-add this handler later.

diffstat:

 sys/arch/amd64/amd64/amd64_trap.S |  20 +++++++-------------
 sys/arch/amd64/amd64/locore.S     |   4 +---
 2 files changed, 8 insertions(+), 16 deletions(-)

diffs (86 lines):

diff -r 393ece2bdc8e -r 0bc7a8a2dd4a sys/arch/amd64/amd64/amd64_trap.S
--- a/sys/arch/amd64/amd64/amd64_trap.S Tue Mar 20 13:30:40 2018 +0000
+++ b/sys/arch/amd64/amd64/amd64_trap.S Tue Mar 20 14:26:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amd64_trap.S,v 1.37 2018/02/25 12:37:16 maxv Exp $     */
+/*     $NetBSD: amd64_trap.S,v 1.38 2018/03/20 14:26:49 maxv Exp $     */
 
 /*
  * Copyright (c) 1998, 2007, 2008, 2017 The NetBSD Foundation, Inc.
@@ -377,9 +377,8 @@
 
 /*
  * It is possible that we received a trap in kernel mode, but with the user
- * context loaded. There are six cases where this can happen:
+ * context loaded. There are five cases where this can happen:
  *
- *  o Execution of SYSRETQ.
  *  o Execution of IRETQ.
  *  o Reload of ES.
  *  o Reload of DS.
@@ -446,12 +445,7 @@
        /* We will clobber %rdi */
        pushq   %rdi
 
-       /* Case 1: fault on sysretq? */
-       leaq    do_sysret(%rip),%rdi
-       cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
-       je      .Lkernelmode_but_user
-
-       /* Case 2: fault on iretq? */
+       /* Case 1: fault on iretq? */
        leaq    do_iret(%rip),%rdi
        cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
        jne     5f
@@ -461,22 +455,22 @@
        jmp     .Lkernelmode_but_user   /* to user - must restore %gs */
 5:
 
-       /* Case 3: move to %es? */
+       /* Case 2: move to %es? */
        leaq    do_mov_es(%rip),%rdi
        cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
        je      .Lkernelmode_but_user
 
-       /* Case 4: move to %ds? */
+       /* Case 3: move to %ds? */
        leaq    do_mov_ds(%rip),%rdi
        cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
        je      .Lkernelmode_but_user
 
-       /* Case 5: move to %fs? */
+       /* Case 4: move to %fs? */
        leaq    do_mov_fs(%rip),%rdi
        cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
        je      .Lkernelmode_but_user
 
-       /* Case 6: move to %gs? */
+       /* Case 5: move to %gs? */
        leaq    do_mov_gs(%rip),%rdi
        cmpq    %rdi,TF_SMALL_REGPUSHED(TF_RIP, %rsp)
        je      .Lkernelmode_but_user
diff -r 393ece2bdc8e -r 0bc7a8a2dd4a sys/arch/amd64/amd64/locore.S
--- a/sys/arch/amd64/amd64/locore.S     Tue Mar 20 13:30:40 2018 +0000
+++ b/sys/arch/amd64/amd64/locore.S     Tue Mar 20 14:26:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: locore.S,v 1.157 2018/02/25 12:37:16 maxv Exp $        */
+/*     $NetBSD: locore.S,v 1.158 2018/03/20 14:26:49 maxv Exp $        */
 
 /*
  * Copyright-o-rama!
@@ -330,7 +330,6 @@
        .globl  _C_LABEL(biosbasemem)
        .globl  _C_LABEL(biosextmem)
        .globl  _C_LABEL(lwp0uarea)
-       .globl  do_sysret
        .globl  do_mov_es
        .globl  do_mov_ds
        .globl  do_mov_fs
@@ -1471,7 +1470,6 @@
        movq    TF_RIP(%rsp),%rcx       /* %rip for sysret */
        movq    TF_RFLAGS(%rsp),%r11    /* %flags for sysret */
        movq    TF_RSP(%rsp),%rsp
-do_sysret:
        sysretq
 #else
        addq    $TF_RIP,%rsp



Home | Main Index | Thread Index | Old Index