Source-Changes-HG archive

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

[src/trunk]: src/sys/arch Inline x86_cpuid2(), prerequisite for future change...



details:   https://anonhg.NetBSD.org/src/rev/988efd3d096c
branches:  trunk
changeset: 962188:988efd3d096c
user:      maxv <maxv%NetBSD.org@localhost>
date:      Wed Jul 03 17:24:37 2019 +0000

description:
Inline x86_cpuid2(), prerequisite for future changes. Also, add "memory"
on certain other inlines, to make sure GCC does not reorder.

diffstat:

 sys/arch/amd64/amd64/cpufunc.S |  16 +---------------
 sys/arch/i386/i386/cpufunc.S   |  20 ++------------------
 sys/arch/x86/include/cpufunc.h |  28 ++++++++++++++++++++++------
 3 files changed, 25 insertions(+), 39 deletions(-)

diffs (132 lines):

diff -r 003de8039d35 -r 988efd3d096c sys/arch/amd64/amd64/cpufunc.S
--- a/sys/arch/amd64/amd64/cpufunc.S    Wed Jul 03 15:52:35 2019 +0000
+++ b/sys/arch/amd64/amd64/cpufunc.S    Wed Jul 03 17:24:37 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.S,v 1.41 2019/05/29 16:54:41 maxv Exp $        */
+/*     $NetBSD: cpufunc.S,v 1.42 2019/07/03 17:24:37 maxv Exp $        */
 
 /*
  * Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -358,20 +358,6 @@
        ret
 END(x86_mwait)
 
-ENTRY(x86_cpuid2)
-       movq    %rbx, %r8
-       movq    %rdi, %rax
-       movq    %rsi, %rcx
-       movq    %rdx, %rsi
-       cpuid
-       movl    %eax, 0(%rsi)
-       movl    %ebx, 4(%rsi)
-       movl    %ecx, 8(%rsi)
-       movl    %edx, 12(%rsi)
-       movq    %r8, %rbx
-       ret
-END(x86_cpuid2)
-
 ENTRY(fnsave)
        fnsave  (%rdi)
        ret
diff -r 003de8039d35 -r 988efd3d096c sys/arch/i386/i386/cpufunc.S
--- a/sys/arch/i386/i386/cpufunc.S      Wed Jul 03 15:52:35 2019 +0000
+++ b/sys/arch/i386/i386/cpufunc.S      Wed Jul 03 17:24:37 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.S,v 1.32 2019/05/19 08:17:02 maxv Exp $        */
+/*     $NetBSD: cpufunc.S,v 1.33 2019/07/03 17:24:37 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.32 2019/05/19 08:17:02 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufunc.S,v 1.33 2019/07/03 17:24:37 maxv Exp $");
 
 #include "opt_xen.h"
 
@@ -244,22 +244,6 @@
        ret
 END(x86_mwait)  
 
-ENTRY(x86_cpuid2)
-       pushl   %ebx
-       pushl   %edi
-       movl    12(%esp), %eax
-       movl    16(%esp), %ecx
-       movl    20(%esp), %edi
-       cpuid
-       movl    %eax, 0(%edi)
-       movl    %ebx, 4(%edi)
-       movl    %ecx, 8(%edi)
-       movl    %edx, 12(%edi)
-       popl    %edi
-       popl    %ebx
-       ret
-END(x86_cpuid2)
-
 ENTRY(fnsave)
        movl    4(%esp), %eax
        fnsave  (%eax)
diff -r 003de8039d35 -r 988efd3d096c sys/arch/x86/include/cpufunc.h
--- a/sys/arch/x86/include/cpufunc.h    Wed Jul 03 15:52:35 2019 +0000
+++ b/sys/arch/x86/include/cpufunc.h    Wed Jul 03 17:24:37 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.h,v 1.32 2019/05/30 21:40:40 christos Exp $    */
+/*     $NetBSD: cpufunc.h,v 1.33 2019/07/03 17:24:37 maxv Exp $        */
 
 /*
  * Copyright (c) 1998, 2007, 2019 The NetBSD Foundation, Inc.
@@ -112,9 +112,24 @@
 
 void   x86_monitor(const void *, uint32_t, uint32_t);
 void   x86_mwait(uint32_t, uint32_t);
-/* x86_cpuid2() writes four 32bit values, %eax, %ebx, %ecx and %edx */
-#define        x86_cpuid(a,b)  x86_cpuid2((a),0,(b))
-void   x86_cpuid2(uint32_t, uint32_t, uint32_t *);
+
+static inline void
+x86_cpuid2(uint32_t eax, uint32_t ecx, uint32_t *regs)
+{
+       uint32_t ebx, edx;
+
+       __asm volatile (
+               "cpuid"
+               : "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx)
+               : "a" (eax), "c" (ecx)
+       );
+
+       regs[0] = eax;
+       regs[1] = ebx;
+       regs[2] = ecx;
+       regs[3] = edx;
+}
+#define x86_cpuid(a,b) x86_cpuid2((a), 0, (b))
 
 /* -------------------------------------------------------------------------- */
 
@@ -176,6 +191,7 @@
                        "mov    %[val],%%cr" #crnum     \
                        :                               \
                        : [val] "r" (val)               \
+                       : "memory"                      \
                );                                      \
        }                                               \
        static inline register_t rcr##crnum(void)       \
@@ -325,13 +341,13 @@
 static inline void
 x86_disable_intr(void)
 {
-       __asm volatile ("cli");
+       __asm volatile ("cli" ::: "memory");
 }
 
 static inline void
 x86_enable_intr(void)
 {
-       __asm volatile ("sti");
+       __asm volatile ("sti" ::: "memory");
 }
 #endif /* XENPV */
 



Home | Main Index | Thread Index | Old Index