Source-Changes-HG archive

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

[src/bouyer-xenpvh]: src/sys/arch/xen/x86 kpreempt_disable() only for x86_64 ...



details:   https://anonhg.NetBSD.org/src/rev/7bb24e5e3220
branches:  bouyer-xenpvh
changeset: 930708:7bb24e5e3220
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Sun Apr 12 17:16:58 2020 +0000

description:
kpreempt_disable() only for x86_64 (which calls pmap_changeprot_local)).
On i386 curcpu() is not valid yet and we don't need preemption disabled.

diffstat:

 sys/arch/xen/x86/xenfunc.c |  8 +++++---
 1 files changed, 5 insertions(+), 3 deletions(-)

diffs (38 lines):

diff -r f31a270ea85f -r 7bb24e5e3220 sys/arch/xen/x86/xenfunc.c
--- a/sys/arch/xen/x86/xenfunc.c        Sun Apr 12 16:35:49 2020 +0000
+++ b/sys/arch/xen/x86/xenfunc.c        Sun Apr 12 17:16:58 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: xenfunc.c,v 1.26.8.1 2020/04/11 18:26:07 bouyer Exp $  */
+/*     $NetBSD: xenfunc.c,v 1.26.8.2 2020/04/12 17:16:58 bouyer Exp $  */
 
 /*
  * Copyright (c) 2004 Christian Limpach.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xenfunc.c,v 1.26.8.1 2020/04/11 18:26:07 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xenfunc.c,v 1.26.8.2 2020/04/12 17:16:58 bouyer Exp $");
 
 #include <sys/param.h>
 
@@ -61,7 +61,9 @@
         * will be available at the boot stage when this is called.
         */
        static char xen_idt_page[PAGE_SIZE] __attribute__((__aligned__ (PAGE_SIZE)));
+#if defined(__x86_64__)
        kpreempt_disable();
+#endif
        memset(xen_idt_page, 0, PAGE_SIZE);
        
        struct trap_info *xen_idt = (void * )xen_idt_page;
@@ -96,8 +98,8 @@
 #if defined(__x86_64__)
        /* reset */
        pmap_changeprot_local((vaddr_t) xen_idt, VM_PROT_READ|VM_PROT_WRITE);
+       kpreempt_enable();
 #endif /* __x86_64 */
-       kpreempt_enable();
 }
 
 void



Home | Main Index | Thread Index | Old Index