Source-Changes-HG archive

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

[src/trunk]: src/sys/arch We reorganise definitions for XEN source support as...



details:   https://anonhg.NetBSD.org/src/rev/63df941d33e9
branches:  trunk
changeset: 996870:63df941d33e9
user:      cherry <cherry%NetBSD.org@localhost>
date:      Mon Feb 11 14:59:32 2019 +0000

description:
We reorganise definitions for XEN source support as follows:

XEN - common sources required for baseline XEN support.
XENPV - sources required for support of XEN in PV mode.
XENPVHVM - sources required for support for XEN in HVM mode.
XENPVH - sources required for support for XEN in PVH mode.

diffstat:

 sys/arch/amd64/amd64/amd64_trap.S      |   12 +-
 sys/arch/amd64/amd64/cpufunc.S         |   14 +-
 sys/arch/amd64/amd64/db_interface.c    |   20 ++--
 sys/arch/amd64/amd64/gdt.c             |   26 +++---
 sys/arch/amd64/amd64/genassym.cf       |    6 +-
 sys/arch/amd64/amd64/lock_stubs.S      |    6 +-
 sys/arch/amd64/amd64/locore.S          |   32 ++++---
 sys/arch/amd64/amd64/machdep.c         |   80 ++++++++++----------
 sys/arch/amd64/amd64/process_machdep.c |    6 +-
 sys/arch/amd64/amd64/spl.S             |    6 +-
 sys/arch/amd64/amd64/trap.c            |   10 +-
 sys/arch/amd64/amd64/vector.S          |   10 +-
 sys/arch/amd64/conf/XEN3_DOM0          |    5 +-
 sys/arch/amd64/conf/XEN3_DOMU          |    5 +-
 sys/arch/amd64/include/cpu.h           |    8 +-
 sys/arch/amd64/include/frame.h         |    4 +-
 sys/arch/amd64/include/frameasm.h      |    6 +-
 sys/arch/amd64/include/param.h         |    4 +-
 sys/arch/amd64/include/pmap.h          |   10 +-
 sys/arch/amd64/include/profile.h       |    8 +-
 sys/arch/amd64/include/segments.h      |   12 +-
 sys/arch/amd64/include/types.h         |    4 +-
 sys/arch/amd64/include/vmparam.h       |    4 +-
 sys/arch/i386/conf/XEN3PAE_DOM0        |    3 +-
 sys/arch/i386/conf/XEN3PAE_DOMU        |    3 +-
 sys/arch/i386/i386/cpufunc.S           |   12 +-
 sys/arch/i386/i386/db_interface.c      |   20 ++--
 sys/arch/i386/i386/gdt.c               |   16 ++--
 sys/arch/i386/i386/genassym.cf         |    4 +-
 sys/arch/i386/i386/i386_trap.S         |   10 +-
 sys/arch/i386/i386/lock_stubs.S        |   10 +-
 sys/arch/i386/i386/locore.S            |   42 +++++-----
 sys/arch/i386/i386/machdep.c           |   92 ++++++++++++------------
 sys/arch/i386/i386/spl.S               |   26 +++---
 sys/arch/i386/i386/trap.c              |   12 +-
 sys/arch/i386/i386/vector.S            |    8 +-
 sys/arch/i386/include/cpu.h            |    8 +-
 sys/arch/i386/include/frame.h          |    4 +-
 sys/arch/i386/include/frameasm.h       |    4 +-
 sys/arch/i386/include/pmap.h           |   16 ++--
 sys/arch/i386/include/segments.h       |   14 +-
 sys/arch/i386/include/vmparam.h        |    6 +-
 sys/arch/x86/acpi/acpi_machdep.c       |   12 +-
 sys/arch/x86/include/cpu.h             |   24 +++--
 sys/arch/x86/include/cpuvar.h          |   10 +-
 sys/arch/x86/include/intr.h            |    8 +-
 sys/arch/x86/include/intrdefs.h        |    6 +-
 sys/arch/x86/include/pmap.h            |    6 +-
 sys/arch/x86/include/specialreg.h      |    6 +-
 sys/arch/x86/isa/isa_machdep.c         |    8 +-
 sys/arch/x86/pci/pci_intr_machdep.c    |    8 +-
 sys/arch/x86/pci/pci_machdep.c         |    8 +-
 sys/arch/x86/pci/pcib.c                |    6 +-
 sys/arch/x86/x86/bios32.c              |   10 +-
 sys/arch/x86/x86/bus_space.c           |   16 ++--
 sys/arch/x86/x86/cpu_ucode.c           |    6 +-
 sys/arch/x86/x86/fpu.c                 |   10 +-
 sys/arch/x86/x86/i8259.c               |    8 +-
 sys/arch/x86/x86/identcpu.c            |   14 +-
 sys/arch/x86/x86/idt.c                 |   10 +-
 sys/arch/x86/x86/pmap.c                |  126 ++++++++++++++++----------------
 sys/arch/x86/x86/sys_machdep.c         |   16 ++--
 sys/arch/x86/x86/vm_machdep.c          |    6 +-
 sys/arch/x86/x86/x86_machdep.c         |   26 +++---
 sys/arch/x86/x86/x86_tlb.c             |   14 +-
 65 files changed, 493 insertions(+), 479 deletions(-)

diffs (truncated from 4095 to 300 lines):

diff -r a51417610530 -r 63df941d33e9 sys/arch/amd64/amd64/amd64_trap.S
--- a/sys/arch/amd64/amd64/amd64_trap.S Mon Feb 11 11:12:58 2019 +0000
+++ b/sys/arch/amd64/amd64/amd64_trap.S Mon Feb 11 14:59:32 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amd64_trap.S,v 1.45 2018/08/12 06:11:47 maxv Exp $     */
+/*     $NetBSD: amd64_trap.S,v 1.46 2019/02/11 14:59:32 cherry Exp $   */
 
 /*
  * Copyright (c) 1998, 2007, 2008, 2017 The NetBSD Foundation, Inc.
@@ -89,7 +89,7 @@
  * handler.
  */
 
-#ifdef XEN
+#ifdef XENPV
 #define        PRE_TRAP        movq (%rsp),%rcx ; movq 8(%rsp),%r11 ; addq $0x10,%rsp
 #else
 #define        PRE_TRAP
@@ -179,7 +179,7 @@
  * to contain secrets.
  */
 IDTVEC(trap01)
-#ifndef XEN
+#ifndef XENPV
        subq    $(TF_REGSIZE+16),%rsp
 
        /* We clobber only RDX, RCX and RAX. */
@@ -247,7 +247,7 @@
  * running in kernel mode with a userland %gs.
  */
 IDTVEC(trap02)
-#if defined(XEN)
+#if defined(XENPV)
        ZTRAP(T_NMI)
 #else
        ZTRAP_NJ(T_NMI)
@@ -346,7 +346,7 @@
  * of it. So don't enable interrupts.
  */
 IDTVEC(trap08)
-#if defined(XEN)
+#if defined(XENPV)
        TRAP(T_DOUBLEFLT)
 #else
        TRAP_NJ(T_DOUBLEFLT)
@@ -390,7 +390,7 @@
        TRAP(T_TSSFLT)
 IDTVEC_END(trap10)
 
-#ifdef XEN
+#ifdef XENPV
 /*
  * I don't believe XEN generates in-kernel traps for the
  * equivalent of iret, if it does this code would be needed
diff -r a51417610530 -r 63df941d33e9 sys/arch/amd64/amd64/cpufunc.S
--- a/sys/arch/amd64/amd64/cpufunc.S    Mon Feb 11 11:12:58 2019 +0000
+++ b/sys/arch/amd64/amd64/cpufunc.S    Mon Feb 11 14:59:32 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.S,v 1.35 2019/01/06 14:35:31 cherry Exp $      */
+/*     $NetBSD: cpufunc.S,v 1.36 2019/02/11 14:59:32 cherry Exp $      */
 
 /*
  * Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -63,7 +63,7 @@
        ret
 END(x86_mfence)
 
-#ifndef XEN
+#ifndef XENPV
 ENTRY(invlpg)
        invlpg  (%rdi)
        ret
@@ -158,7 +158,7 @@
  *
  * If PGE is not in use, we reload CR3.
  */
-#ifndef XEN
+#ifndef XENPV
 ENTRY(tlbflushg)
        movq    %cr4, %rax
        testq   $CR4_PGE, %rax
@@ -262,7 +262,7 @@
 END(x86_write_flags)
 
 STRONG_ALIAS(x86_write_psl,x86_write_flags)
-#endif /* XEN */
+#endif /* XENPV */
 
 ENTRY(rdmsr)
        movq    %rdi, %rcx
@@ -352,7 +352,7 @@
        ret
 END(msr_onfault)
 
-#ifndef XEN
+#ifndef XENPV
 ENTRY(wbinvd)
        wbinvd
        ret
@@ -434,7 +434,7 @@
  * is necessary, since the actual descriptor data is not changed except by
  * process creation and exit, both of which clean up via task switches.
  */
-#ifndef XEN
+#ifndef XENPV
 ENTRY(lgdt)
        /* Reload the descriptor table. */
        movq    %rdi,%rax
@@ -754,7 +754,7 @@
        ret
 END(setfs)
 
-#ifndef XEN
+#ifndef XENPV
 ENTRY(setusergs)
        CLI(ax)
        swapgs
diff -r a51417610530 -r 63df941d33e9 sys/arch/amd64/amd64/db_interface.c
--- a/sys/arch/amd64/amd64/db_interface.c       Mon Feb 11 11:12:58 2019 +0000
+++ b/sys/arch/amd64/amd64/db_interface.c       Mon Feb 11 14:59:32 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: db_interface.c,v 1.34 2018/09/23 00:59:59 cherry Exp $ */
+/*     $NetBSD: db_interface.c,v 1.35 2019/02/11 14:59:32 cherry Exp $ */
 
 /*
  * Mach Operating System
@@ -33,7 +33,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.34 2018/09/23 00:59:59 cherry Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.35 2019/02/11 14:59:32 cherry Exp $");
 
 #include "opt_ddb.h"
 #include "opt_multiprocessor.h"
@@ -88,9 +88,9 @@
 #ifdef MULTIPROCESSOR
 extern void ddb_ipi(struct trapframe);
 static void ddb_suspend(struct trapframe *);
-#ifndef XEN
+#ifndef XENPV
 int ddb_vec;
-#endif /* XEN */
+#endif /* XENPV */
 static bool ddb_mp_online;
 #endif
 
@@ -106,7 +106,7 @@
 {
 
 #ifdef MULTIPROCESSOR
-#ifndef XEN
+#ifndef XENPV
        vector *handler = &Xintr_ddbipi;
 #if NLAPIC > 0
        if (lapic_is_x2apic())
@@ -117,7 +117,7 @@
            GSEL(GCODE_SEL, SEL_KPL));
 #else
        /* Initialised as part of xen_ipi_init() */
-#endif /* XEN */
+#endif /* XENPV */
 #endif
 }
 
@@ -131,10 +131,10 @@
        int cpu_me = cpu_number();
        int win;
 
-#ifndef XEN
+#ifndef XENPV
        if (ddb_vec == 0)
                return 1;
-#endif /* XEN */
+#endif /* XENPV */
 
        __cpu_simple_lock(&db_lock);
        if (ddb_cpu == NOCPU)
@@ -142,11 +142,11 @@
        win = (ddb_cpu == cpu_me);
        __cpu_simple_unlock(&db_lock);
        if (win) {
-#ifdef XEN
+#ifdef XENPV
                xen_broadcast_ipi(XEN_IPI_DDB);
 #else
                x86_ipi(ddb_vec, LAPIC_DEST_ALLEXCL, LAPIC_DLMODE_FIXED);
-#endif /* XEN */
+#endif /* XENPV */
        }
        ddb_mp_online = x86_mp_online;
        x86_mp_online = false;
diff -r a51417610530 -r 63df941d33e9 sys/arch/amd64/amd64/gdt.c
--- a/sys/arch/amd64/amd64/gdt.c        Mon Feb 11 11:12:58 2019 +0000
+++ b/sys/arch/amd64/amd64/gdt.c        Mon Feb 11 14:59:32 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: gdt.c,v 1.45 2018/01/05 08:04:20 maxv Exp $    */
+/*     $NetBSD: gdt.c,v 1.46 2019/02/11 14:59:32 cherry Exp $  */
 
 /*
  * Copyright (c) 1996, 1997, 2009 The NetBSD Foundation, Inc.
@@ -37,7 +37,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.45 2018/01/05 08:04:20 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gdt.c,v 1.46 2019/02/11 14:59:32 cherry Exp $");
 
 #include "opt_multiprocessor.h"
 #include "opt_xen.h"
@@ -53,7 +53,7 @@
 
 #include <machine/gdt.h>
 
-#ifdef XEN
+#ifdef XENPV
 #include <xen/hypervisor.h>
 #endif
 
@@ -67,7 +67,7 @@
 } gdt_bitmap_t;
 
 /* size of GDT in bytes */
-#ifdef XEN
+#ifdef XENPV
 const size_t gdt_size = FIRST_RESERVED_GDT_BYTE;
 #else
 const size_t gdt_size = MAXGDTSIZ;
@@ -76,7 +76,7 @@
 /* bitmap of busy slots */
 static gdt_bitmap_t gdt_bitmap;
 
-#if defined(USER_LDT) || !defined(XEN)
+#if defined(USER_LDT) || !defined(XENPV)
 static void set_sys_gdt(int, void *, size_t, int, int, int);
 #endif
 
@@ -88,7 +88,7 @@
        table = tp;
        entry = ep;
 
-#ifndef XEN
+#ifndef XENPV
        *table = *entry;
 #else
        paddr_t pa;
@@ -99,7 +99,7 @@
 #endif
 }
 
-#if defined(USER_LDT) || !defined(XEN)
+#if defined(USER_LDT) || !defined(XENPV)
 /*
  * Called on a newly-allocated GDT slot, so no race between CPUs.
  */
@@ -122,7 +122,7 @@
                update_descriptor(&ci->ci_gdt[idx + 1], &d.bits[1]);
        }
 }
-#endif /* USER_LDT || !XEN */
+#endif /* USER_LDT || !XENPV */
 
 /*
  * Initialize the GDT. We already have a gdtstore, which was temporarily used
@@ -165,7 +165,7 @@
        /* Copy the initial bootstrap GDT into the new area. */
        memcpy(gdtstore, old_gdt, DYNSEL_START);
        ci->ci_gdt = (void *)gdtstore;
-#ifndef XEN
+#ifndef XENPV
        set_sys_segment(GDT_ADDR_SYS(gdtstore, GLDT_SEL), ldtstore,
            LDT_SIZE - 1, SDT_SYSLDT, SEL_KPL, 0);
 #endif
@@ -218,7 +218,7 @@
        lgdt(&region);
 }
 
-#if !defined(XEN) || defined(USER_LDT)
+#if !defined(XENPV) || defined(USER_LDT)
 static int
 gdt_get_slot(void)
 {
@@ -250,7 +250,7 @@
 int
 tss_alloc(struct x86_64_tss *tss)
 {
-#ifndef XEN
+#ifndef XENPV
        int slot;
 
        mutex_enter(&cpu_lock);
@@ -271,7 +271,7 @@
 void
 tss_free(int sel)
 {
-#ifndef XEN
+#ifndef XENPV
        mutex_enter(&cpu_lock);
        gdt_put_slot(IDXDYNSEL(sel));
        mutex_exit(&cpu_lock);



Home | Main Index | Thread Index | Old Index