Source-Changes-HG archive

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

[src/trunk]: src/sys/arch Introduce Xen PVH support in GENERIC.



details:   https://anonhg.NetBSD.org/src/rev/aef6f0b09ec8
branches:  trunk
changeset: 1009758:aef6f0b09ec8
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Sat May 02 16:44:34 2020 +0000

description:
Introduce Xen PVH support in GENERIC.
This is compiled in with
options XENPVHVM
x86 changes:
- add Xen section and xen pvh entry points to locore.S. Set vm_guest
  to VM_GUEST_XENPVH in this entry point.
  Most of the boot procedure (especially page table setup and switch to
  paged mode) is shared with native.
- change some x86_delay() to delay_func(), which points to x86_delay() for
  native/HVM, and xen_delay() for PVH

Xen changes:
- remove Xen bits from init_x86_64_ksyms() and init386_ksyms()
  and move to xen_init_ksyms(), used for both PV and PVH
- set ISA no-legacy-devices property for PVH
- factor out code from Xen's cpu_bootconf() to xen_bootconf()
  in xen_machdep.c
- set up a specific pvh_consinit() which starts with printk()
  (which uses a simple hypercall that is available early) and switch to
  xencons when we can use pmap_kenter_pa().

diffstat:

 sys/arch/amd64/amd64/autoconf.c       |   11 +-
 sys/arch/amd64/amd64/genassym.cf      |    6 +-
 sys/arch/amd64/amd64/locore.S         |   89 +++++++++++-
 sys/arch/amd64/amd64/machdep.c        |   31 ++-
 sys/arch/amd64/conf/GENERIC           |    5 +-
 sys/arch/i386/i386/autoconf.c         |   11 +-
 sys/arch/i386/i386/genassym.cf        |    6 +-
 sys/arch/i386/i386/locore.S           |  140 +++++++++++++++---
 sys/arch/i386/i386/machdep.c          |   28 +++-
 sys/arch/x86/acpi/acpi_machdep.c      |   15 +-
 sys/arch/x86/include/cpu.h            |   14 +-
 sys/arch/x86/isa/clock.c              |    9 +-
 sys/arch/x86/isa/isa_machdep.c        |    7 +-
 sys/arch/x86/x86/consinit.c           |   15 +-
 sys/arch/x86/x86/cpu.c                |   18 +-
 sys/arch/x86/x86/lapic.c              |    8 +-
 sys/arch/x86/x86/pmap.c               |   10 +-
 sys/arch/x86/x86/x86_autoconf.c       |   12 +-
 sys/arch/x86/x86/x86_machdep.c        |   30 +++-
 sys/arch/xen/conf/Makefile.xen        |    4 +-
 sys/arch/xen/conf/files.xen           |    4 +-
 sys/arch/xen/include/hypervisor.h     |   10 +-
 sys/arch/xen/include/xen.h            |    6 +-
 sys/arch/xen/x86/autoconf.c           |   85 +-----------
 sys/arch/xen/x86/hypervisor_machdep.c |   36 ++++-
 sys/arch/xen/x86/pvh_consinit.c       |  115 +++++++++++++++
 sys/arch/xen/x86/x86_xpmap.c          |    5 +-
 sys/arch/xen/x86/xen_mainbus.c        |    5 +-
 sys/arch/xen/xen/hypervisor.c         |  249 +++++++++++++++++++++------------
 sys/arch/xen/xen/xen_clock.c          |   37 ++--
 sys/arch/xen/xen/xen_machdep.c        |  114 ++++++++++++++-
 31 files changed, 827 insertions(+), 308 deletions(-)

diffs (truncated from 2151 to 300 lines):

diff -r 165d0e7ff2e4 -r aef6f0b09ec8 sys/arch/amd64/amd64/autoconf.c
--- a/sys/arch/amd64/amd64/autoconf.c   Sat May 02 16:28:37 2020 +0000
+++ b/sys/arch/amd64/amd64/autoconf.c   Sat May 02 16:44:34 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: autoconf.c,v 1.29 2019/12/27 12:51:56 ad Exp $ */
+/*     $NetBSD: autoconf.c,v 1.30 2020/05/02 16:44:34 bouyer Exp $     */
 
 /*-
  * Copyright (c) 1990 The Regents of the University of California.
@@ -46,7 +46,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: autoconf.c,v 1.29 2019/12/27 12:51:56 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: autoconf.c,v 1.30 2020/05/02 16:44:34 bouyer Exp $");
 
 #include "opt_multiprocessor.h"
 #include "opt_intrdebug.h"
@@ -92,7 +92,14 @@
 void
 cpu_configure(void)
 {
+#ifdef XEN
+       if (vm_guest == VM_GUEST_XENPVH)
+               xen_startrtclock();
+       else
+               startrtclock();
+#else
        startrtclock();
+#endif
 
 #if NBIOS32 > 0
        efi_init();
diff -r 165d0e7ff2e4 -r aef6f0b09ec8 sys/arch/amd64/amd64/genassym.cf
--- a/sys/arch/amd64/amd64/genassym.cf  Sat May 02 16:28:37 2020 +0000
+++ b/sys/arch/amd64/amd64/genassym.cf  Sat May 02 16:44:34 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: genassym.cf,v 1.83 2020/04/25 15:26:16 bouyer Exp $
+#      $NetBSD: genassym.cf,v 1.84 2020/05/02 16:44:34 bouyer Exp $
 
 #
 # Copyright (c) 1998, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -120,6 +120,7 @@
 
 ifdef XEN
 include <xen/include/public/xen.h>
+include <xen/include/public/arch-x86/hvm/start_info.h>
 endif  
 
 include <sys/bus.h>
@@ -361,6 +362,7 @@
 define BST_TYPE                offsetof(struct bus_space_tag, bst_type)
 
 define VM_GUEST_XENPV          VM_GUEST_XENPV
+define VM_GUEST_XENPVH         VM_GUEST_XENPVH
 
 ifdef XEN
 define CPU_INFO_VCPU           offsetof(struct cpu_info, ci_vcpu)
@@ -373,7 +375,7 @@
 define XEN_NR_PT_FRAMES                offsetof(struct start_info, nr_pt_frames)
 define __HYPERVISOR_iret       __HYPERVISOR_iret
 endif /* XENPV */
-endif
+endif /* XEN */
 
 define NKL4_KIMG_ENTRIES       NKL4_KIMG_ENTRIES
 define NKL3_KIMG_ENTRIES       NKL3_KIMG_ENTRIES
diff -r 165d0e7ff2e4 -r aef6f0b09ec8 sys/arch/amd64/amd64/locore.S
--- a/sys/arch/amd64/amd64/locore.S     Sat May 02 16:28:37 2020 +0000
+++ b/sys/arch/amd64/amd64/locore.S     Sat May 02 16:44:34 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: locore.S,v 1.205 2020/05/02 16:28:37 maxv Exp $        */
+/*     $NetBSD: locore.S,v 1.206 2020/05/02 16:44:34 bouyer Exp $      */
 
 /*
  * Copyright-o-rama!
@@ -279,9 +279,7 @@
 #define __ASSEMBLY__
 #include <xen/include/public/elfnote.h>
 #include <xen/include/public/xen.h>
-#endif /* XEN */
 
-#ifdef XENPV   
 #define ELFNOTE(name, type, desctype, descdata...) \
 .pushsection .note.name                        ;       \
   .align 4                             ;       \
@@ -302,11 +300,16 @@
        ELFNOTE(Xen, XEN_ELFNOTE_GUEST_VERSION,  .asciz, "4.99")
        ELFNOTE(Xen, XEN_ELFNOTE_XEN_VERSION,    .asciz, "xen-3.0")
        ELFNOTE(Xen, XEN_ELFNOTE_VIRT_BASE,      .quad,  KERNBASE)
+#ifdef XENPV
        ELFNOTE(Xen, XEN_ELFNOTE_PADDR_OFFSET,   .quad,  KERNBASE)
        ELFNOTE(Xen, XEN_ELFNOTE_ENTRY,          .quad,  start)
+#else
+       ELFNOTE(Xen, XEN_ELFNOTE_PADDR_OFFSET,   .quad,  0)
+       ELFNOTE(Xen, XEN_ELFNOTE_PHYS32_ENTRY,   .long,  RELOC(start_xen32))
+#endif /* XENPV */
        ELFNOTE(Xen, XEN_ELFNOTE_HYPERCALL_PAGE, .quad,  hypercall_page)
        ELFNOTE(Xen, XEN_ELFNOTE_HV_START_LOW,   .quad,  HYPERVISOR_VIRT_START)
-       ELFNOTE(Xen, XEN_ELFNOTE_FEATURES,       .asciz, "")
+       ELFNOTE(Xen, XEN_ELFNOTE_FEATURES,       .asciz, "writable_descriptor_tables|auto_translated_physmap|supervisor_mode_kernel|hvm_callback_vector")
        ELFNOTE(Xen, XEN_ELFNOTE_PAE_MODE,       .asciz, "yes")
        ELFNOTE(Xen, XEN_ELFNOTE_L1_MFN_VALID,   .long,  PTE_P, PTE_P)\
        ELFNOTE(Xen, XEN_ELFNOTE_LOADER,         .asciz, "generic")     
@@ -314,7 +317,7 @@
 #if NKSYMS > 0 || defined(DDB) || defined(MODULAR)
        ELFNOTE(Xen, XEN_ELFNOTE_BSD_SYMTAB,     .asciz, "yes")
 #endif
-#endif  /* XENPV */    
+#endif  /* XEN */
 
 /*
  * Initialization
@@ -418,6 +421,21 @@
        .word   GSEL(GCODE_SEL, SEL_KPL)
 END(farjmp64)
 
+#ifdef XEN
+/* 32bit GDT */
+gdtdesc32:
+       .word   gdt32end - gdt32
+       .long   RELOC(gdt32)
+       .long   0
+gdt32:  
+       .long   0                       # null descriptor
+       .long   0
+       .long   0x0000ffff              # %cs
+       .long   0x00cf9a00 
+       .long   0x0000ffff              # %ds, %es, %ss
+       .long   0x00cf9200
+gdt32end:
+#endif /* XEN */
 #endif /* !XENPV */
 
        /* Space for the temporary stack */
@@ -973,6 +991,9 @@
 #endif /* XENPV */
 
        pushq   %rdi
+#if defined(XEN) && !defined(XENPV)
+       call    _C_LABEL(init_xen_early)
+#endif
        call    _C_LABEL(init_bootspace)
 #ifdef KASAN
        movq    _C_LABEL(lwp0uarea)(%rip),%rdi
@@ -984,6 +1005,64 @@
        call    _C_LABEL(main)
 END(start)
 
+#ifndef XENPV
+/* entry point for Xen PVH */
+       .code32
+ENTRY(start_xen32)
+       /* Xen doesn't start us with a valid gdt */
+       movl    $RELOC(gdtdesc32), %eax
+       lgdt    (%eax)
+       jmp     $GSEL(GCODE_SEL, SEL_KPL), $RELOC(.Lreload_cs)
+
+.Lreload_cs:
+       movw    $GSEL(GDATA_SEL, SEL_KPL), %ax          
+       movw    %ax, %ds
+       movw    %ax, %es
+       movw    %ax, %ss   
+
+       /* we need a valid stack */
+       movl    $RELOC(tmpstk),%esp
+
+       /* clear BSS */
+        xorl    %eax,%eax
+       movl    $RELOC(__bss_start),%edi
+       movl    $RELOC(_end),%ecx
+       subl    %edi,%ecx
+       rep
+       stosb
+
+       /*
+        * save addr of the hvm_start_info structure. This is also the end
+        * of the symbol table
+        */
+       movl    %ebx, RELOC(hvm_start_paddr)
+       movl    %ebx, %eax
+       addl    $KERNBASE_LO,%eax
+       movl    $RELOC(esym),%ebp
+       movl    %eax,(%ebp)
+       movl    $KERNBASE_HI,4(%ebp)
+       /* get a page for HYPERVISOR_shared_info */
+       addl    $PAGE_SIZE, %ebx
+       addl    $PGOFSET,%ebx
+       andl    $~PGOFSET,%ebx
+       movl    $RELOC(HYPERVISOR_shared_info_pa),%ebp
+       movl    %ebx,(%ebp)
+       movl    $0,4(%ebp)
+       /* XXX assume hvm_start_info+dependant struture fits in a single page */
+       addl    $PAGE_SIZE, %ebx
+       addl    $PGOFSET,%ebx
+       andl    $~PGOFSET,%ebx
+       addl    $KERNBASE_LO,%ebx
+       movl    $RELOC(eblob),%ebp
+       movl    %ebx,(%ebp)
+       movl    $KERNBASE_HI,4(%ebp)
+
+       /* annouce ourself */
+       movl    $VM_GUEST_XENPVH, RELOC(vm_guest)
+       jmp .Lbiosbasemem_finished
+END(start_xen32)
+       .code64
+#endif /* XENPV */
 #if defined(XEN)
 /* space for the hypercall call page */
 #define HYPERCALL_PAGE_OFFSET 0x1000
diff -r 165d0e7ff2e4 -r aef6f0b09ec8 sys/arch/amd64/amd64/machdep.c
--- a/sys/arch/amd64/amd64/machdep.c    Sat May 02 16:28:37 2020 +0000
+++ b/sys/arch/amd64/amd64/machdep.c    Sat May 02 16:44:34 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: machdep.c,v 1.351 2020/05/02 16:28:37 maxv Exp $       */
+/*     $NetBSD: machdep.c,v 1.352 2020/05/02 16:44:34 bouyer Exp $     */
 
 /*
  * Copyright (c) 1996, 1997, 1998, 2000, 2006, 2007, 2008, 2011
@@ -110,7 +110,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.351 2020/05/02 16:28:37 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.352 2020/05/02 16:44:34 bouyer Exp $");
 
 #include "opt_modular.h"
 #include "opt_user_ldt.h"
@@ -1483,22 +1483,20 @@
 extern vector IDTVEC(osyscall);
 extern vector *x86_exceptions[];
 
+#ifndef XENPV
 static void
 init_x86_64_ksyms(void)
 {
 #if NKSYMS || defined(DDB) || defined(MODULAR)
        extern int end;
        extern int *esym;
-#ifndef XENPV
        struct btinfo_symtab *symtab;
        vaddr_t tssym, tesym;
-#endif
 
 #ifdef DDB
        db_machine_init();
 #endif
 
-#ifndef XENPV
        symtab = lookup_bootinfo(BTINFO_SYMTAB);
        if (symtab) {
 #ifdef KASLR
@@ -1512,15 +1510,9 @@
        } else
                ksyms_addsyms_elf(*(long *)(void *)&end,
                    ((long *)(void *)&end) + 1, esym);
-#else  /* XENPV */
-       esym = xen_start_info.mod_start ?
-           (void *)xen_start_info.mod_start :
-           (void *)xen_start_info.mfn_list;
-       ksyms_addsyms_elf(*(int *)(void *)&end,
-           ((int *)(void *)&end) + 1, esym);
-#endif /* XENPV */
 #endif
 }
+#endif /* XENPV */
 
 void __noasan
 init_bootspace(void)
@@ -1676,6 +1668,10 @@
        cpu_info_primary.ci_vcpu = &HYPERVISOR_shared_info->vcpu_info[0];
 #endif
 
+#ifdef XEN
+       if (vm_guest == VM_GUEST_XENPVH)
+               xen_parse_cmdline(XEN_PARSE_BOOTFLAGS, NULL);
+#endif
        init_pte();
 
        uvm_lwp_setuarea(&lwp0, lwp0uarea);
@@ -1903,7 +1899,16 @@
 
        cpu_init_idt();
 
-       init_x86_64_ksyms();
+#ifdef XENPV
+       xen_init_ksyms();
+#else /* XENPV */
+#ifdef XEN
+       if (vm_guest == VM_GUEST_XENPVH)
+               xen_init_ksyms();
+       else
+#endif /* XEN */
+               init_x86_64_ksyms();
+#endif /* XENPV */
 
 #ifndef XENPV
        intr_default_setup();
diff -r 165d0e7ff2e4 -r aef6f0b09ec8 sys/arch/amd64/conf/GENERIC
--- a/sys/arch/amd64/conf/GENERIC       Sat May 02 16:28:37 2020 +0000



Home | Main Index | Thread Index | Old Index