Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/bouyer-xenpvh]: src/sys/arch Include ci_isources[] for XenPV too.
details: https://anonhg.NetBSD.org/src/rev/95ed1091bd99
branches: bouyer-xenpvh
changeset: 930794:95ed1091bd99
user: bouyer <bouyer%NetBSD.org@localhost>
date: Sat Apr 11 10:11:30 2020 +0000
description:
Include ci_isources[] for XenPV too.
Adjust spllower() to XenPV needs, and switch XenPV to the native spllower().
Remove xen_spllower().
diffstat:
sys/arch/amd64/amd64/genassym.cf | 4 +---
sys/arch/amd64/amd64/spl.S | 18 +++++++++++++-----
sys/arch/amd64/include/frameasm.h | 14 +++++++++++++-
sys/arch/i386/i386/genassym.cf | 4 +---
sys/arch/i386/i386/spl.S | 21 ++++++++++++++-------
sys/arch/i386/include/frameasm.h | 9 ++++++++-
sys/arch/x86/include/cpu.h | 4 +---
sys/arch/xen/x86/xen_intr.c | 36 ++----------------------------------
8 files changed, 53 insertions(+), 57 deletions(-)
diffs (truncated from 304 to 300 lines):
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/amd64/amd64/genassym.cf
--- a/sys/arch/amd64/amd64/genassym.cf Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/amd64/amd64/genassym.cf Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: genassym.cf,v 1.82.4.1 2020/04/08 17:59:16 bouyer Exp $
+# $NetBSD: genassym.cf,v 1.82.4.2 2020/04/11 10:11:30 bouyer Exp $
#
# Copyright (c) 1998, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -246,13 +246,11 @@
define CPU_INFO_GDT offsetof(struct cpu_info, ci_gdt)
define CPU_INFO_ILEVEL offsetof(struct cpu_info, ci_ilevel)
define CPU_INFO_IDEPTH offsetof(struct cpu_info, ci_idepth)
-if !defined(XENPV)
define CPU_INFO_IPENDING offsetof(struct cpu_info, ci_ipending)
define CPU_INFO_IMASKED offsetof(struct cpu_info, ci_imasked)
define CPU_INFO_IMASK offsetof(struct cpu_info, ci_imask)
define CPU_INFO_IUNMASK offsetof(struct cpu_info, ci_iunmask)
define CPU_INFO_ISOURCES offsetof(struct cpu_info, ci_isources)
-endif
define CPU_INFO_MTX_COUNT offsetof(struct cpu_info, ci_mtx_count)
define CPU_INFO_MTX_OLDSPL offsetof(struct cpu_info, ci_mtx_oldspl)
define CPU_INFO_CPUID offsetof(struct cpu_info, ci_cpuid)
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/amd64/amd64/spl.S
--- a/sys/arch/amd64/amd64/spl.S Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/amd64/amd64/spl.S Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: spl.S,v 1.43.4.3 2020/04/10 14:41:59 bouyer Exp $ */
+/* $NetBSD: spl.S,v 1.43.4.4 2020/04/11 10:11:30 bouyer Exp $ */
/*
* Copyright (c) 2003 Wasabi Systems, Inc.
@@ -226,7 +226,6 @@
IDTVEC_END(resume_preempt)
#endif /* XEN */
-#ifndef XENPV
/*
* void spllower(int s);
*
@@ -238,8 +237,8 @@
cmpl CPUVAR(ILEVEL),%edi
jae 1f
movl CPUVAR(IUNMASK)(,%rdi,4),%edx
- pushf
- cli
+ PUSHF(ax)
+ CLI(ax)
testl CPUVAR(IPENDING),%edx
jnz 2f
#if defined(XEN)
@@ -248,12 +247,20 @@
jnz 2f
#endif
movl %edi,CPUVAR(ILEVEL)
- popf
+ POPF /* clobbers %rdi */
1:
ret
ret
2:
+#ifdef XENPV
+ /*
+ * no need to call stipending, we're going to CLI again
+ * just drop the saved value on stack
+ */
+ addq $8,%rsp
+#else
popf
+#endif
jmp _C_LABEL(Xspllower)
3:
.space 16
@@ -261,6 +268,7 @@
END(spllower)
LABEL(spllower_end)
+#ifndef XENPV
/*
* void cx8_spllower(int s);
*
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/amd64/include/frameasm.h
--- a/sys/arch/amd64/include/frameasm.h Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/amd64/include/frameasm.h Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: frameasm.h,v 1.47 2019/11/17 14:07:00 maxv Exp $ */
+/* $NetBSD: frameasm.h,v 1.47.6.1 2020/04/11 10:11:30 bouyer Exp $ */
#ifndef _AMD64_MACHINE_FRAMEASM_H
#define _AMD64_MACHINE_FRAMEASM_H
@@ -31,11 +31,23 @@
movq CPUVAR(VCPU),%r ## temp_reg ; \
movb $0,EVTCHN_UPCALL_MASK(%r ## temp_reg);
+#define PUSHF(temp_reg) \
+ movq CPUVAR(VCPU),%r ## temp_reg ; \
+ movzbl EVTCHN_UPCALL_MASK(%r ## temp_reg), %e ## temp_reg; \
+ pushq %r ## temp_reg
+
+#define POPF \
+ popq %rdi; \
+ call _C_LABEL(xen_write_psl)
+
+
#else /* XENPV */
#define XEN_ONLY2(x,y)
#define NOT_XEN(x) x
#define CLI(temp_reg) cli
#define STI(temp_reg) sti
+#define PUSHF(temp_reg) pushf
+#define POPL popl
#endif /* XEN */
#define HP_NAME_CLAC 1
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/i386/i386/genassym.cf
--- a/sys/arch/i386/i386/genassym.cf Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/i386/i386/genassym.cf Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: genassym.cf,v 1.119.4.1 2020/04/08 17:59:16 bouyer Exp $
+# $NetBSD: genassym.cf,v 1.119.4.2 2020/04/11 10:11:31 bouyer Exp $
#
# Copyright (c) 1998, 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -268,13 +268,11 @@
define CPU_INFO_SIGNATURE offsetof(struct cpu_info, ci_signature)
define CPU_INFO_GDT offsetof(struct cpu_info, ci_gdt)
-if !defined(XENPV)
define CPU_INFO_IPENDING offsetof(struct cpu_info, ci_ipending)
define CPU_INFO_IMASKED offsetof(struct cpu_info, ci_imasked)
define CPU_INFO_IMASK offsetof(struct cpu_info, ci_imask)
define CPU_INFO_ISOURCES offsetof(struct cpu_info, ci_isources)
define CPU_INFO_IUNMASK offsetof(struct cpu_info, ci_iunmask)
-endif
define CPU_INFO_ILEVEL offsetof(struct cpu_info, ci_ilevel)
define CPU_INFO_IDEPTH offsetof(struct cpu_info, ci_idepth)
define CPU_INFO_MTX_COUNT offsetof(struct cpu_info, ci_mtx_count)
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/i386/i386/spl.S
--- a/sys/arch/i386/i386/spl.S Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/i386/i386/spl.S Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: spl.S,v 1.50.4.1 2020/04/10 14:42:00 bouyer Exp $ */
+/* $NetBSD: spl.S,v 1.50.4.2 2020/04/11 10:11:31 bouyer Exp $ */
/*
* Copyright (c) 1998, 2007, 2008 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: spl.S,v 1.50.4.1 2020/04/10 14:42:00 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: spl.S,v 1.50.4.2 2020/04/11 10:11:31 bouyer Exp $");
#include "opt_ddb.h"
#include "opt_spldebug.h"
@@ -67,8 +67,6 @@
ret
END(splraise)
-#ifndef XENPV
-
/*
* void spllower(int s);
*
@@ -90,8 +88,8 @@
cmpl CPUVAR(ILEVEL),%ecx
jae 1f
movl CPUVAR(IUNMASK)(,%ecx,4),%edx
- pushf
- cli
+ PUSHF(%eax)
+ CLI(%eax)
testl CPUVAR(IPENDING),%edx
jnz 2f
#if defined(XEN)
@@ -100,16 +98,25 @@
jnz 2f
#endif
movl %ecx,CPUVAR(ILEVEL)
- popf
+ POPF(%eax)
1:
ret
2:
+#ifdef XENPV
+ /*
+ * no need to call stipending, we're going to CLI again
+ * just drop the saved value on stack
+ */
+ addl $4,%esp
+#else
popf
+#endif
jmp _C_LABEL(Xspllower)
.align 32
LABEL(spllower_end)
END(spllower)
+#ifndef XENPV
/*
* void cx8_spllower(int s);
*
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/i386/include/frameasm.h
--- a/sys/arch/i386/include/frameasm.h Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/i386/include/frameasm.h Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: frameasm.h,v 1.29 2019/10/12 06:31:03 maxv Exp $ */
+/* $NetBSD: frameasm.h,v 1.29.6.1 2020/04/11 10:11:31 bouyer Exp $ */
#ifndef _I386_FRAMEASM_H_
#define _I386_FRAMEASM_H_
@@ -25,9 +25,16 @@
#define STIC(reg) movl CPUVAR(VCPU),reg ; \
XEN_UNBLOCK_EVENTS(reg) ; \
testb $0xff,EVTCHN_UPCALL_PENDING(reg)
+#define PUSHF(reg) movl CPUVAR(VCPU),reg ; \
+ movzbl EVTCHN_UPCALL_MASK(reg), reg; \
+ pushl reg
+#define POPF(reg) call _C_LABEL(xen_write_psl); \
+ addl $4,%esp
#else
#define CLI(reg) cli
#define STI(reg) sti
+#define PUSHF(reg) pushf
+#define POPF(reg) popf
#ifdef XENPVHVM
#define STIC(reg) sti ; \
movl CPUVAR(VCPU),reg ; \
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/x86/include/cpu.h
--- a/sys/arch/x86/include/cpu.h Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/x86/include/cpu.h Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu.h,v 1.117.4.2 2020/04/10 14:37:54 bouyer Exp $ */
+/* $NetBSD: cpu.h,v 1.117.4.3 2020/04/11 10:11:31 bouyer Exp $ */
/*
* Copyright (c) 1990 The Regents of the University of California.
@@ -132,9 +132,7 @@
int ci_kfpu_spl;
-#ifndef XENPV
struct intrsource *ci_isources[MAX_INTR_SOURCES];
-#endif
#if defined(XEN)
struct intrsource *ci_xsources[NIPL];
uint32_t ci_xmask[NIPL];
diff -r acd6f21d1ce8 -r 95ed1091bd99 sys/arch/xen/x86/xen_intr.c
--- a/sys/arch/xen/x86/xen_intr.c Sat Apr 11 08:06:16 2020 +0000
+++ b/sys/arch/xen/x86/xen_intr.c Sat Apr 11 10:11:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xen_intr.c,v 1.21 2020/04/06 19:26:00 jdolecek Exp $ */
+/* $NetBSD: xen_intr.c,v 1.21.2.1 2020/04/11 10:11:31 bouyer Exp $ */
/*-
* Copyright (c) 1998, 2001 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xen_intr.c,v 1.21 2020/04/06 19:26:00 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xen_intr.c,v 1.21.2.1 2020/04/11 10:11:31 bouyer Exp $");
#include "opt_multiprocessor.h"
@@ -73,38 +73,6 @@
static const char *xen_ipi_names[XEN_NIPIS] = XEN_IPI_NAMES;
#endif
-/*
- * Restore a value to cpl (unmasking interrupts). If any unmasked
- * interrupts are pending, call Xspllower() to process them.
- */
-void xen_spllower(int nlevel);
-
-void
-xen_spllower(int nlevel)
-{
- struct cpu_info *ci = curcpu();
- uint32_t xmask;
- u_long psl;
-
- if (ci->ci_ilevel <= nlevel)
- return;
-
- __insn_barrier();
-
- xmask = XUNMASK(ci, nlevel);
- psl = xen_read_psl();
- x86_disable_intr();
- if (ci->ci_xpending & xmask) {
- KASSERT(psl == 0);
- Xspllower(nlevel);
- /* Xspllower does enable_intr() */
- } else {
- ci->ci_ilevel = nlevel;
- xen_write_psl(psl);
- }
-}
-
Home |
Main Index |
Thread Index |
Old Index