Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/xen/xen No need to run hypercalls at IPL_VM.



details:   https://anonhg.NetBSD.org/src/rev/a1aa74e0fb9f
branches:  trunk
changeset: 1009885:a1aa74e0fb9f
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Wed May 06 17:27:39 2020 +0000

description:
No need to run hypercalls at IPL_VM.
XXX still not MP-safe

diffstat:

 sys/arch/xen/xen/balloon.c |  17 +++--------------
 1 files changed, 3 insertions(+), 14 deletions(-)

diffs (70 lines):

diff -r 7d2aaa16d146 -r a1aa74e0fb9f sys/arch/xen/xen/balloon.c
--- a/sys/arch/xen/xen/balloon.c        Wed May 06 16:50:13 2020 +0000
+++ b/sys/arch/xen/xen/balloon.c        Wed May 06 17:27:39 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: balloon.c,v 1.21 2020/04/25 15:26:18 bouyer Exp $ */
+/* $NetBSD: balloon.c,v 1.22 2020/05/06 17:27:39 bouyer Exp $ */
 
 /*-
  * Copyright (c) 2010 The NetBSD Foundation, Inc.
@@ -75,7 +75,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: balloon.c,v 1.21 2020/04/25 15:26:18 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: balloon.c,v 1.22 2020/05/06 17:27:39 bouyer Exp $");
 
 #include <sys/inttypes.h>
 #include <sys/device.h>
@@ -272,15 +272,11 @@
 static size_t
 xenmem_get_maxreservation(void)
 {
-       int s;
        unsigned int ret;
 
-       s = splvm(); /* XXXSMP */
        ret = HYPERVISOR_memory_op(XENMEM_maximum_reservation, 
            & (domid_t) { DOMID_SELF });
 
-       splx(s);
-
        if (ret == 0) {
                /* well, a maximum reservation of 0 is really bogus */
                panic("%s failed, maximum reservation returned 0", __func__);
@@ -293,12 +289,10 @@
 static size_t
 xenmem_get_currentreservation(void)
 {
-       int s, ret;
+       int ret;
 
-       s = splvm(); /* XXXSMP */
        ret = HYPERVISOR_memory_op(XENMEM_current_reservation,
                                   & (domid_t) { DOMID_SELF });
-       splx(s);
 
        if (ret < 0) {
                panic("%s failed: %d", __func__, ret);
@@ -415,11 +409,8 @@
        set_xen_guest_handle(reservation.extent_start, mfn_list);
        reservation.nr_extents = rpages;
 
-       s = splvm(); /* XXXSMP */
        ret = HYPERVISOR_memory_op(XENMEM_decrease_reservation,
                                   &reservation);
-       splx(s);
-
        if (ret != rpages) {
                /*
                 * we are in bad shape: the operation failed for certain
@@ -481,9 +472,7 @@
        set_xen_guest_handle(reservation.extent_start, mfn_list);
        reservation.nr_extents = tpages;
 
-       s = splvm(); /* XXXSMP */
        ret = HYPERVISOR_memory_op(XENMEM_increase_reservation, &reservation);
-       splx(s);
 
        if (ret < 0) {
                panic("%s: increase reservation failed, ret %d",



Home | Main Index | Thread Index | Old Index