Source-Changes-HG archive

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

[src/trunk]: src/sys/arch In preparation for debut-ing PVHVM mode:



details:   https://anonhg.NetBSD.org/src/rev/5eb164ff7186
branches:  trunk
changeset: 996911:5eb164ff7186
user:      cherry <cherry%NetBSD.org@localhost>
date:      Wed Feb 13 05:01:57 2019 +0000

description:
In preparation for debut-ing PVHVM mode:

 - Make the struct intrstub uniform across native and XEN.
 - Introduce vector callback entrypoints for PVHVM mode.

diffstat:

 sys/arch/amd64/amd64/vector.S |  109 +++++++++++++++++++++++------------------
 sys/arch/i386/i386/vector.S   |   80 +++++++++++++++++-------------
 sys/arch/xen/xen/evtchn.c     |    5 +-
 3 files changed, 111 insertions(+), 83 deletions(-)

diffs (294 lines):

diff -r 986e9bdb267e -r 5eb164ff7186 sys/arch/amd64/amd64/vector.S
--- a/sys/arch/amd64/amd64/vector.S     Wed Feb 13 04:35:58 2019 +0000
+++ b/sys/arch/amd64/amd64/vector.S     Wed Feb 13 05:01:57 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vector.S,v 1.66 2019/02/11 14:59:32 cherry Exp $       */
+/*     $NetBSD: vector.S,v 1.67 2019/02/13 05:01:57 cherry Exp $       */
 
 /*
  * Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -631,19 +631,7 @@
        INTRSTUB_ENTRY(name ## 31)              ; \
 END(name ## _stubs)
 
-       .section .rodata
-
-INTRSTUB_ARRAY_16(legacy)
-
-#if NIOAPIC > 0
-INTRSTUB_ARRAY_32(ioapic_edge)
-INTRSTUB_ARRAY_32(ioapic_level)
-
-INTRSTUB_ARRAY_32(x2apic_edge)
-INTRSTUB_ARRAY_32(x2apic_level)
-#endif
-
-#endif /* !defined(XENPV) */
+#endif /* !XENPV */
 
 #if defined(XEN)
 /* Resume/recurse procedures for spl() */
@@ -715,39 +703,49 @@
 XENINTRSTUB(xenev,30,voidop,voidop,voidop,hypervisor_asm_unmask,voidop)
 XENINTRSTUB(xenev,31,voidop,voidop,voidop,hypervisor_asm_unmask,voidop)
 
+/* On Xen, the xenev_stubs are purely for spl entry, since there is no
+ * vector based mechanism. We however provide the entrypoint to ensure
+ * that native and Xen struct intrstub ; definitions are uniform.
+ */
+panicmsg:      .ascii "vector Xen event entry path entered."
+LABEL(entry_xenev)
+       movq $panicmsg, %rdi
+       callq _C_LABEL(panic)
+END(entry_xenev)
+
 LABEL(xenev_stubs)
-       .quad _C_LABEL(Xrecurse_xenev0), _C_LABEL(Xresume_xenev0)
-       .quad _C_LABEL(Xrecurse_xenev1) ,_C_LABEL(Xresume_xenev1)
-       .quad _C_LABEL(Xrecurse_xenev2) ,_C_LABEL(Xresume_xenev2)
-       .quad _C_LABEL(Xrecurse_xenev3) ,_C_LABEL(Xresume_xenev3)
-       .quad _C_LABEL(Xrecurse_xenev4) ,_C_LABEL(Xresume_xenev4)
-       .quad _C_LABEL(Xrecurse_xenev5) ,_C_LABEL(Xresume_xenev5)
-       .quad _C_LABEL(Xrecurse_xenev6) ,_C_LABEL(Xresume_xenev6)
-       .quad _C_LABEL(Xrecurse_xenev7) ,_C_LABEL(Xresume_xenev7)
-       .quad _C_LABEL(Xrecurse_xenev8) ,_C_LABEL(Xresume_xenev8)
-       .quad _C_LABEL(Xrecurse_xenev9) ,_C_LABEL(Xresume_xenev9)
-       .quad _C_LABEL(Xrecurse_xenev10), _C_LABEL(Xresume_xenev10)
-       .quad _C_LABEL(Xrecurse_xenev11), _C_LABEL(Xresume_xenev11)
-       .quad _C_LABEL(Xrecurse_xenev12), _C_LABEL(Xresume_xenev12)
-       .quad _C_LABEL(Xrecurse_xenev13), _C_LABEL(Xresume_xenev13)
-       .quad _C_LABEL(Xrecurse_xenev14), _C_LABEL(Xresume_xenev14)
-       .quad _C_LABEL(Xrecurse_xenev15), _C_LABEL(Xresume_xenev15)
-       .quad _C_LABEL(Xrecurse_xenev16), _C_LABEL(Xresume_xenev16)
-       .quad _C_LABEL(Xrecurse_xenev17), _C_LABEL(Xresume_xenev17)
-       .quad _C_LABEL(Xrecurse_xenev18), _C_LABEL(Xresume_xenev18)
-       .quad _C_LABEL(Xrecurse_xenev19), _C_LABEL(Xresume_xenev19)
-       .quad _C_LABEL(Xrecurse_xenev20), _C_LABEL(Xresume_xenev20)
-       .quad _C_LABEL(Xrecurse_xenev21), _C_LABEL(Xresume_xenev21)
-       .quad _C_LABEL(Xrecurse_xenev22), _C_LABEL(Xresume_xenev22)
-       .quad _C_LABEL(Xrecurse_xenev23), _C_LABEL(Xresume_xenev23)
-       .quad _C_LABEL(Xrecurse_xenev24), _C_LABEL(Xresume_xenev24)
-       .quad _C_LABEL(Xrecurse_xenev25), _C_LABEL(Xresume_xenev25)
-       .quad _C_LABEL(Xrecurse_xenev26), _C_LABEL(Xresume_xenev26)
-       .quad _C_LABEL(Xrecurse_xenev27), _C_LABEL(Xresume_xenev27)
-       .quad _C_LABEL(Xrecurse_xenev28), _C_LABEL(Xresume_xenev28)
-       .quad _C_LABEL(Xrecurse_xenev29), _C_LABEL(Xresume_xenev29)
-       .quad _C_LABEL(Xrecurse_xenev30), _C_LABEL(Xresume_xenev30)
-       .quad _C_LABEL(Xrecurse_xenev31), _C_LABEL(Xresume_xenev31)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev0), _C_LABEL(Xresume_xenev0)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev1) ,_C_LABEL(Xresume_xenev1)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev2) ,_C_LABEL(Xresume_xenev2)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev3) ,_C_LABEL(Xresume_xenev3)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev4) ,_C_LABEL(Xresume_xenev4)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev5) ,_C_LABEL(Xresume_xenev5)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev6) ,_C_LABEL(Xresume_xenev6)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev7) ,_C_LABEL(Xresume_xenev7)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev8) ,_C_LABEL(Xresume_xenev8)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev9) ,_C_LABEL(Xresume_xenev9)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev10), _C_LABEL(Xresume_xenev10)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev11), _C_LABEL(Xresume_xenev11)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev12), _C_LABEL(Xresume_xenev12)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev13), _C_LABEL(Xresume_xenev13)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev14), _C_LABEL(Xresume_xenev14)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev15), _C_LABEL(Xresume_xenev15)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev16), _C_LABEL(Xresume_xenev16)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev17), _C_LABEL(Xresume_xenev17)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev18), _C_LABEL(Xresume_xenev18)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev19), _C_LABEL(Xresume_xenev19)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev20), _C_LABEL(Xresume_xenev20)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev21), _C_LABEL(Xresume_xenev21)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev22), _C_LABEL(Xresume_xenev22)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev23), _C_LABEL(Xresume_xenev23)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev24), _C_LABEL(Xresume_xenev24)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev25), _C_LABEL(Xresume_xenev25)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev26), _C_LABEL(Xresume_xenev26)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev27), _C_LABEL(Xresume_xenev27)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev28), _C_LABEL(Xresume_xenev28)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev29), _C_LABEL(Xresume_xenev29)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev30), _C_LABEL(Xresume_xenev30)
+       .quad entry_xenev, _C_LABEL(Xrecurse_xenev31), _C_LABEL(Xresume_xenev31)
 END(xenev_stubs)
 
 /*
@@ -759,6 +757,7 @@
        movq    (%rsp),%rcx
        movq    8(%rsp),%r11
        addq    $16,%rsp
+IDTVEC(hypervisor_pvhvm_callback)
        pushq   $0              /* Dummy error code */
        pushq   $T_ASTFLT
        INTRENTRY
@@ -770,8 +769,11 @@
        jnz     doreti_checkast
 1:
        INTRFASTEXIT
+IDTVEC_END(hypervisor_pvhvm_callback)
 END(hypervisor_callback)
+#endif
 
+#ifdef XENPV
 /* Panic? */
 ENTRY(failsafe_callback)
        movq    (%rsp),%rcx
@@ -787,4 +789,17 @@
 /*     jmp     HYPERVISOR_iret */
 END(failsafe_callback)
 
-#endif /* !XEN */
+#else  /* XENPV */
+
+       .section .rodata
+
+INTRSTUB_ARRAY_16(legacy)
+
+#if NIOAPIC > 0
+INTRSTUB_ARRAY_32(ioapic_edge)
+INTRSTUB_ARRAY_32(ioapic_level)
+
+INTRSTUB_ARRAY_32(x2apic_edge)
+INTRSTUB_ARRAY_32(x2apic_level)
+#endif
+#endif /* !XENPV */
diff -r 986e9bdb267e -r 5eb164ff7186 sys/arch/i386/i386/vector.S
--- a/sys/arch/i386/i386/vector.S       Wed Feb 13 04:35:58 2019 +0000
+++ b/sys/arch/i386/i386/vector.S       Wed Feb 13 05:01:57 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vector.S,v 1.80 2019/02/11 14:59:32 cherry Exp $       */
+/*     $NetBSD: vector.S,v 1.81 2019/02/13 05:01:58 cherry Exp $       */
 
 /*
  * Copyright 2002 (c) Wasabi Systems, Inc.
@@ -65,7 +65,7 @@
  */
 
 #include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: vector.S,v 1.80 2019/02/11 14:59:32 cherry Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vector.S,v 1.81 2019/02/13 05:01:58 cherry Exp $");
 
 #include "opt_ddb.h"
 #include "opt_multiprocessor.h"
@@ -962,40 +962,50 @@
 XENINTRSTUB(xenev,30,voidop,voidop,voidop,hypervisor_asm_unmask,voidop)
 XENINTRSTUB(xenev,31,voidop,voidop,voidop,hypervisor_asm_unmask,voidop)
 
+/* On Xen, the xenev_stubs are purely for spl entry, since there is no
+ * vector based mechanism. We however provide the entrypoint to ensure
+ * that native and Xen struct intrstub ; definitions are uniform.
+ */
+panicmsg:      .ascii "vector Xen event entry path entered."
+LABEL(entry_xenev)
+       pushl $panicmsg
+       call  _C_LABEL(panic)
+END(entry_xenev)
+
        .type   _C_LABEL(xenev_stubs), @object
 LABEL(xenev_stubs)
-       .long _C_LABEL(Xrecurse_xenev0), _C_LABEL(Xresume_xenev0)
-       .long _C_LABEL(Xrecurse_xenev1) ,_C_LABEL(Xresume_xenev1)
-       .long _C_LABEL(Xrecurse_xenev2) ,_C_LABEL(Xresume_xenev2)
-       .long _C_LABEL(Xrecurse_xenev3) ,_C_LABEL(Xresume_xenev3)
-       .long _C_LABEL(Xrecurse_xenev4) ,_C_LABEL(Xresume_xenev4)
-       .long _C_LABEL(Xrecurse_xenev5) ,_C_LABEL(Xresume_xenev5)
-       .long _C_LABEL(Xrecurse_xenev6) ,_C_LABEL(Xresume_xenev6)
-       .long _C_LABEL(Xrecurse_xenev7) ,_C_LABEL(Xresume_xenev7)
-       .long _C_LABEL(Xrecurse_xenev8) ,_C_LABEL(Xresume_xenev8)
-       .long _C_LABEL(Xrecurse_xenev9) ,_C_LABEL(Xresume_xenev9)
-       .long _C_LABEL(Xrecurse_xenev10), _C_LABEL(Xresume_xenev10)
-       .long _C_LABEL(Xrecurse_xenev11), _C_LABEL(Xresume_xenev11)
-       .long _C_LABEL(Xrecurse_xenev12), _C_LABEL(Xresume_xenev12)
-       .long _C_LABEL(Xrecurse_xenev13), _C_LABEL(Xresume_xenev13)
-       .long _C_LABEL(Xrecurse_xenev14), _C_LABEL(Xresume_xenev14)
-       .long _C_LABEL(Xrecurse_xenev15), _C_LABEL(Xresume_xenev15)
-       .long _C_LABEL(Xrecurse_xenev16), _C_LABEL(Xresume_xenev16)
-       .long _C_LABEL(Xrecurse_xenev17), _C_LABEL(Xresume_xenev17)
-       .long _C_LABEL(Xrecurse_xenev18), _C_LABEL(Xresume_xenev18)
-       .long _C_LABEL(Xrecurse_xenev19), _C_LABEL(Xresume_xenev19)
-       .long _C_LABEL(Xrecurse_xenev20), _C_LABEL(Xresume_xenev20)
-       .long _C_LABEL(Xrecurse_xenev21), _C_LABEL(Xresume_xenev21)
-       .long _C_LABEL(Xrecurse_xenev22), _C_LABEL(Xresume_xenev22)
-       .long _C_LABEL(Xrecurse_xenev23), _C_LABEL(Xresume_xenev23)
-       .long _C_LABEL(Xrecurse_xenev24), _C_LABEL(Xresume_xenev24)
-       .long _C_LABEL(Xrecurse_xenev25), _C_LABEL(Xresume_xenev25)
-       .long _C_LABEL(Xrecurse_xenev26), _C_LABEL(Xresume_xenev26)
-       .long _C_LABEL(Xrecurse_xenev27), _C_LABEL(Xresume_xenev27)
-       .long _C_LABEL(Xrecurse_xenev28), _C_LABEL(Xresume_xenev28)
-       .long _C_LABEL(Xrecurse_xenev29), _C_LABEL(Xresume_xenev29)
-       .long _C_LABEL(Xrecurse_xenev30), _C_LABEL(Xresume_xenev30)
-       .long _C_LABEL(Xrecurse_xenev31), _C_LABEL(Xresume_xenev31)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev0), _C_LABEL(Xresume_xenev0)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev1) ,_C_LABEL(Xresume_xenev1)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev2) ,_C_LABEL(Xresume_xenev2)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev3) ,_C_LABEL(Xresume_xenev3)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev4) ,_C_LABEL(Xresume_xenev4)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev5) ,_C_LABEL(Xresume_xenev5)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev6) ,_C_LABEL(Xresume_xenev6)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev7) ,_C_LABEL(Xresume_xenev7)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev8) ,_C_LABEL(Xresume_xenev8)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev9) ,_C_LABEL(Xresume_xenev9)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev10), _C_LABEL(Xresume_xenev10)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev11), _C_LABEL(Xresume_xenev11)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev12), _C_LABEL(Xresume_xenev12)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev13), _C_LABEL(Xresume_xenev13)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev14), _C_LABEL(Xresume_xenev14)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev15), _C_LABEL(Xresume_xenev15)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev16), _C_LABEL(Xresume_xenev16)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev17), _C_LABEL(Xresume_xenev17)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev18), _C_LABEL(Xresume_xenev18)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev19), _C_LABEL(Xresume_xenev19)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev20), _C_LABEL(Xresume_xenev20)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev21), _C_LABEL(Xresume_xenev21)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev22), _C_LABEL(Xresume_xenev22)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev23), _C_LABEL(Xresume_xenev23)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev24), _C_LABEL(Xresume_xenev24)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev25), _C_LABEL(Xresume_xenev25)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev26), _C_LABEL(Xresume_xenev26)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev27), _C_LABEL(Xresume_xenev27)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev28), _C_LABEL(Xresume_xenev28)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev29), _C_LABEL(Xresume_xenev29)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev30), _C_LABEL(Xresume_xenev30)
+       .long entry_xenev, _C_LABEL(Xrecurse_xenev31), _C_LABEL(Xresume_xenev31)
 END(xenev_stubs)
 
 #endif /* XEN */
@@ -1018,6 +1028,7 @@
  * activation and restart the handler using the previous one.
  */
 ENTRY(hypervisor_callback)
+IDTVEC(hypervisor_pvhvm_callback)      
        pushl   $0                      /* dummy error code */
        pushl   $T_ASTFLT
        INTRENTRY
@@ -1078,6 +1089,7 @@
        loop    15b
 16:    movl    %edi,%esp       /* final %edi is top of merged stack */
        jmp     11b
+IDTVEC_END(hypervisor_pvhvm_callback)
 END(hypervisor_callback)
 
 
diff -r 986e9bdb267e -r 5eb164ff7186 sys/arch/xen/xen/evtchn.c
--- a/sys/arch/xen/xen/evtchn.c Wed Feb 13 04:35:58 2019 +0000
+++ b/sys/arch/xen/xen/evtchn.c Wed Feb 13 05:01:57 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: evtchn.c,v 1.83 2018/12/25 06:50:12 cherry Exp $       */
+/*     $NetBSD: evtchn.c,v 1.84 2019/02/13 05:01:58 cherry Exp $       */
 
 /*
  * Copyright (c) 2006 Manuel Bouyer.
@@ -54,7 +54,7 @@
 
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: evtchn.c,v 1.83 2018/12/25 06:50:12 cherry Exp $");
+__KERNEL_RCSID(0, "$NetBSD: evtchn.c,v 1.84 2019/02/13 05:01:58 cherry Exp $");
 
 #include "opt_xen.h"
 #include "isa.h"
@@ -943,6 +943,7 @@
                    KM_NOSLEEP);
                if (ipls == NULL)
                        panic("can't allocate fixed interrupt source");
+               ipls->is_recurse = xenev_stubs[level].ist_entry;
                ipls->is_recurse = xenev_stubs[level].ist_recurse;
                ipls->is_resume = xenev_stubs[level].ist_resume;
                ipls->is_handlers = ih;



Home | Main Index | Thread Index | Old Index