Source-Changes-HG archive

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

[src/trunk]: src/sys/arch Use absolute jumps, and drop the PC-relative patchi...



details:   https://anonhg.NetBSD.org/src/rev/40d64fe81cd3
branches:  trunk
changeset: 1009715:40d64fe81cd3
user:      maxv <maxv%NetBSD.org@localhost>
date:      Fri May 01 09:17:58 2020 +0000

description:
Use absolute jumps, and drop the PC-relative patching. We want exact
templates.

diffstat:

 sys/arch/i386/i386/lock_stubs.S |  16 ++++++++++------
 sys/arch/i386/i386/spl.S        |  13 +++++++------
 sys/arch/x86/x86/patch.c        |  36 +++++-------------------------------
 3 files changed, 22 insertions(+), 43 deletions(-)

diffs (165 lines):

diff -r 0bb5f9c9eb00 -r 40d64fe81cd3 sys/arch/i386/i386/lock_stubs.S
--- a/sys/arch/i386/i386/lock_stubs.S   Fri May 01 08:45:01 2020 +0000
+++ b/sys/arch/i386/i386/lock_stubs.S   Fri May 01 09:17:58 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: lock_stubs.S,v 1.33 2020/04/25 15:26:17 bouyer Exp $   */
+/*     $NetBSD: lock_stubs.S,v 1.34 2020/05/01 09:17:58 maxv Exp $     */
 
 /*-
  * Copyright (c) 2006, 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -35,7 +35,7 @@
  */
 
 #include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: lock_stubs.S,v 1.33 2020/04/25 15:26:17 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lock_stubs.S,v 1.34 2020/05/01 09:17:58 maxv Exp $");
 
 #include "opt_lockdebug.h"
 
@@ -271,13 +271,14 @@
        movl    %ecx, CPUVAR(ILEVEL)
        sti
 1:     ret
-       .space 32
+       .space  32, 0xCC
        .align  32
 LABEL(mutex_spin_exit_end)
 END(mutex_spin_exit)
 #else  /* XENPV */
 STRONG_ALIAS(mutex_spin_exit, i686_mutex_spin_exit)
 #endif /* !XENPV */
+
 /*
  * Patch for i686 CPUs where cli/sti is prohibitively expensive.
  * Must be the same size as mutex_spin_exit().
@@ -302,9 +303,12 @@
 2:
        popl    %ebx
        movl    %ecx,4(%esp)
-LABEL(i686_mutex_spin_exit_patch)
-       jmp     _C_LABEL(Xspllower)
-       .space 16
+
+       /* The reference must be absolute, hence the indirect jump. */
+       movl    $Xspllower,%eax
+       jmp     *%eax
+
+       .space  16, 0xCC
        .align  32
 LABEL(i686_mutex_spin_exit_end)
 END(i686_mutex_spin_exit)
diff -r 0bb5f9c9eb00 -r 40d64fe81cd3 sys/arch/i386/i386/spl.S
--- a/sys/arch/i386/i386/spl.S  Fri May 01 08:45:01 2020 +0000
+++ b/sys/arch/i386/i386/spl.S  Fri May 01 09:17:58 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: spl.S,v 1.51 2020/04/25 15:26:17 bouyer Exp $  */
+/*     $NetBSD: spl.S,v 1.52 2020/05/01 09:17:58 maxv Exp $    */
 
 /*
  * Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: spl.S,v 1.51 2020/04/25 15:26:17 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: spl.S,v 1.52 2020/05/01 09:17:58 maxv Exp $");
 
 #include "opt_ddb.h"
 #include "opt_spldebug.h"
@@ -147,10 +147,11 @@
 2:
        popl    %ebx
 
-       .type   _C_LABEL(cx8_spllower_patch), @function
-LABEL(cx8_spllower_patch)
-       jmp     _C_LABEL(Xspllower)
-       .align  32
+       /* The reference must be absolute, hence the indirect jump. */
+       movl    $Xspllower,%eax
+       jmp     *%eax
+
+       .align  32, 0xCC
 LABEL(cx8_spllower_end)
 END(cx8_spllower)
 
diff -r 0bb5f9c9eb00 -r 40d64fe81cd3 sys/arch/x86/x86/patch.c
--- a/sys/arch/x86/x86/patch.c  Fri May 01 08:45:01 2020 +0000
+++ b/sys/arch/x86/x86/patch.c  Fri May 01 09:17:58 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: patch.c,v 1.44 2020/05/01 08:32:50 maxv Exp $  */
+/*     $NetBSD: patch.c,v 1.45 2020/05/01 09:17:58 maxv Exp $  */
 
 /*-
  * Copyright (c) 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: patch.c,v 1.44 2020/05/01 08:32:50 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: patch.c,v 1.45 2020/05/01 09:17:58 maxv Exp $");
 
 #include "opt_lockdebug.h"
 #ifdef i386
@@ -62,35 +62,13 @@
 void   spllower_end(void);
 void   cx8_spllower(int);
 void   cx8_spllower_end(void);
-void   cx8_spllower_patch(void);
 
 void   mutex_spin_exit_end(void);
 void   i686_mutex_spin_exit(int);
 void   i686_mutex_spin_exit_end(void);
-void   i686_mutex_spin_exit_patch(void);
-
-#define        X86_CS          0x2e
-#define        X86_DS          0x3e
-#define        X86_GROUP_0F    0x0f
-
-static void
-adjust_jumpoff(uint8_t *ptr, void *from_s, void *to_s)
-{
-
-       /* Branch hints */
-       if (ptr[0] == X86_CS || ptr[0] == X86_DS)
-               ptr++;
-       /* Conditional jumps */
-       if (ptr[0] == X86_GROUP_0F)
-               ptr++;          
-       /* 4-byte relative jump or call */
-       *(uint32_t *)(ptr + 1 - (uintptr_t)from_s + (uintptr_t)to_s) +=
-           ((uint32_t)(uintptr_t)from_s - (uint32_t)(uintptr_t)to_s);
-}
 
 static void __unused
-patchfunc(void *from_s, void *from_e, void *to_s, void *to_e,
-         void *pcrel)
+patchfunc(void *from_s, void *from_e, void *to_s, void *to_e)
 {
 
        if ((uintptr_t)from_e - (uintptr_t)from_s !=
@@ -98,8 +76,6 @@
                panic("patchfunc: sizes do not match (from=%p)", from_s);
 
        memcpy(to_s, from_s, (uintptr_t)to_e - (uintptr_t)to_s);
-       if (pcrel != NULL)
-               adjust_jumpoff(pcrel, from_s, to_s);
 }
 
 static inline void __unused
@@ -233,14 +209,12 @@
                /* Faster splx(), mutex_spin_exit(). */
                patchfunc(
                    cx8_spllower, cx8_spllower_end,
-                   spllower, spllower_end,
-                   cx8_spllower_patch
+                   spllower, spllower_end
                );
 #if !defined(LOCKDEBUG)
                patchfunc(
                    i686_mutex_spin_exit, i686_mutex_spin_exit_end,
-                   mutex_spin_exit, mutex_spin_exit_end,
-                   i686_mutex_spin_exit_patch
+                   mutex_spin_exit, mutex_spin_exit_end
                );
 #endif /* !LOCKDEBUG */
        }



Home | Main Index | Thread Index | Old Index