Source-Changes-HG archive

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

[src/trunk]: src/sys/arch More inlines, prerequisites for future changes. Als...



details:   https://anonhg.NetBSD.org/src/rev/a372b81741a8
branches:  trunk
changeset: 461758:a372b81741a8
user:      maxv <maxv%NetBSD.org@localhost>
date:      Fri Jul 05 17:08:55 2019 +0000

description:
More inlines, prerequisites for future changes. Also, remove fngetsw(),
which was a duplicate of fnstsw().

diffstat:

 sys/arch/amd64/amd64/cpufunc.S |  27 +------------------
 sys/arch/i386/i386/cpufunc.S   |  33 +----------------------
 sys/arch/x86/include/cpufunc.h |  58 ++++++++++++++++++++++++++++++++++-------
 sys/arch/x86/x86/fpu.c         |   9 ++++--
 4 files changed, 56 insertions(+), 71 deletions(-)

diffs (235 lines):

diff -r d0c6a6507d02 -r a372b81741a8 sys/arch/amd64/amd64/cpufunc.S
--- a/sys/arch/amd64/amd64/cpufunc.S    Fri Jul 05 15:33:07 2019 +0000
+++ b/sys/arch/amd64/amd64/cpufunc.S    Fri Jul 05 17:08:55 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.S,v 1.42 2019/07/03 17:24:37 maxv Exp $        */
+/*     $NetBSD: cpufunc.S,v 1.43 2019/07/05 17:08:55 maxv Exp $        */
 
 /*
  * Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -363,21 +363,6 @@
        ret
 END(fnsave)
 
-ENTRY(fnstcw)
-       fnstcw  (%rdi)
-       ret
-END(fnstcw)
-
-ENTRY(fngetsw)
-       fnstsw  %ax
-       ret
-END(fngetsw)
-
-ENTRY(fnstsw)
-       fnstsw  (%rdi)
-       ret
-END(fnstsw)
-
 ENTRY(frstor)
        frstor  (%rdi)
        ret
@@ -430,16 +415,6 @@
        ret
 END(xrstor)
 
-ENTRY(x86_stmxcsr)
-       stmxcsr (%rdi)
-       ret
-END(x86_stmxcsr)
-
-ENTRY(x86_ldmxcsr)
-       ldmxcsr (%rdi)
-       ret
-END(x86_ldmxcsr)
-
 ENTRY(inb)
        movq    %rdi, %rdx
        xorq    %rax, %rax
diff -r d0c6a6507d02 -r a372b81741a8 sys/arch/i386/i386/cpufunc.S
--- a/sys/arch/i386/i386/cpufunc.S      Fri Jul 05 15:33:07 2019 +0000
+++ b/sys/arch/i386/i386/cpufunc.S      Fri Jul 05 17:08:55 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.S,v 1.33 2019/07/03 17:24:37 maxv Exp $        */
+/*     $NetBSD: cpufunc.S,v 1.34 2019/07/05 17:08:55 maxv Exp $        */
 
 /*-
  * Copyright (c) 1998, 2007 The NetBSD Foundation, Inc.
@@ -38,7 +38,7 @@
 #include <sys/errno.h>
 
 #include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: cpufunc.S,v 1.33 2019/07/03 17:24:37 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufunc.S,v 1.34 2019/07/05 17:08:55 maxv Exp $");
 
 #include "opt_xen.h"
 
@@ -250,23 +250,6 @@
        ret
 END(fnsave)
 
-ENTRY(fnstcw)
-       movl    4(%esp), %eax
-       fnstcw  (%eax)
-       ret
-END(fnstcw)
-
-ENTRY(fngetsw)
-       fnstsw  %ax
-       ret
-END(fngetsw)
-
-ENTRY(fnstsw)
-       movl    4(%esp), %eax
-       fnstsw  (%eax)
-       ret
-END(fnstsw)
-
 ENTRY(frstor)
        movl    4(%esp), %eax
        frstor  (%eax)
@@ -319,18 +302,6 @@
        ret
 END(xrstor)
 
-ENTRY(x86_stmxcsr)
-       movl    4(%esp), %eax
-       stmxcsr (%eax)
-       ret
-END(x86_stmxcsr)
-
-ENTRY(x86_ldmxcsr)
-       movl    4(%esp), %eax
-       ldmxcsr (%eax)
-       ret
-END(x86_ldmxcsr)
-
 ENTRY(fldummy)
        ffree   %st(7)
        fldz
diff -r d0c6a6507d02 -r a372b81741a8 sys/arch/x86/include/cpufunc.h
--- a/sys/arch/x86/include/cpufunc.h    Fri Jul 05 15:33:07 2019 +0000
+++ b/sys/arch/x86/include/cpufunc.h    Fri Jul 05 17:08:55 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.h,v 1.33 2019/07/03 17:24:37 maxv Exp $        */
+/*     $NetBSD: cpufunc.h,v 1.34 2019/07/05 17:08:55 maxv Exp $        */
 
 /*
  * Copyright (c) 1998, 2007, 2019 The NetBSD Foundation, Inc.
@@ -280,11 +280,25 @@
        __asm volatile ("fnclex");
 }
 
-void   fnsave(union savefpu *);
-void   fnstcw(uint16_t *);
-uint16_t fngetsw(void);
-void   fnstsw(uint16_t *);
-void   frstor(const union savefpu *);
+static inline void
+fnstcw(uint16_t *val)
+{
+       __asm volatile (
+               "fnstcw %[val]"
+               : [val] "=m" (*val)
+               :
+       );
+}
+
+static inline void
+fnstsw(uint16_t *val)
+{
+       __asm volatile (
+               "fnstsw %[val]"
+               : [val] "=m" (*val)
+               :
+       );
+}
 
 static inline void
 clts(void)
@@ -293,11 +307,27 @@
 }
 
 void   stts(void);
-void   fxsave(union savefpu *);
-void   fxrstor(const union savefpu *);
+
+static inline void
+x86_stmxcsr(uint32_t *val)
+{
+       __asm volatile (
+               "stmxcsr %[val]"
+               : [val] "=m" (*val)
+               :
+       );
+}
 
-void   x86_ldmxcsr(const uint32_t *);
-void   x86_stmxcsr(uint32_t *);
+static inline void
+x86_ldmxcsr(uint32_t *val)
+{
+       __asm volatile (
+               "ldmxcsr %[val]"
+               :
+               : [val] "m" (*val)
+       );
+}
+
 void   fldummy(void);
 
 static inline uint64_t
@@ -328,9 +358,15 @@
        );
 }
 
-void   xrstor(const union savefpu *, uint64_t);
+void   fnsave(union savefpu *);
+void   frstor(const union savefpu *);
+
+void   fxsave(union savefpu *);
+void   fxrstor(const union savefpu *);
+
 void   xsave(union savefpu *, uint64_t);
 void   xsaveopt(union savefpu *, uint64_t);
+void   xrstor(const union savefpu *, uint64_t);
 
 /* -------------------------------------------------------------------------- */
 
diff -r d0c6a6507d02 -r a372b81741a8 sys/arch/x86/x86/fpu.c
--- a/sys/arch/x86/x86/fpu.c    Fri Jul 05 15:33:07 2019 +0000
+++ b/sys/arch/x86/x86/fpu.c    Fri Jul 05 17:08:55 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fpu.c,v 1.54 2019/06/26 12:30:13 mgorny Exp $  */
+/*     $NetBSD: fpu.c,v 1.55 2019/07/05 17:08:56 maxv Exp $    */
 
 /*
  * Copyright (c) 2008 The NetBSD Foundation, Inc.  All
@@ -96,7 +96,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: fpu.c,v 1.54 2019/06/26 12:30:13 mgorny Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fpu.c,v 1.55 2019/07/05 17:08:56 maxv Exp $");
 
 #include "opt_multiprocessor.h"
 
@@ -188,6 +188,8 @@
 static inline void
 fpu_errata_amd(void)
 {
+       uint16_t sw;
+
        /*
         * AMD FPUs do not restore FIP, FDP, and FOP on fxrstor and xrstor
         * when FSW.ES=0, leaking other threads' execution history.
@@ -203,7 +205,8 @@
         * which indicates that FIP/FDP/FOP are restored (same behavior
         * as Intel). We're not using it though.
         */
-       if (fngetsw() & 0x80)
+       fnstsw(&sw);
+       if (sw & 0x80)
                fnclex();
        fldummy();
 }



Home | Main Index | Thread Index | Old Index