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 Add the codepath for grant table updates fo...



details:   https://anonhg.NetBSD.org/src/rev/2dd11332a66c
branches:  trunk
changeset: 996690:2dd11332a66c
user:      cherry <cherry%NetBSD.org@localhost>
date:      Wed Feb 06 12:24:46 2019 +0000

description:
Add the codepath for grant table updates for VMs with an auto
translated physmap.

diffstat:

 sys/arch/xen/xen/xengnt.c |  56 ++++++++++++++++++++++++++++++++--------------
 1 files changed, 39 insertions(+), 17 deletions(-)

diffs (78 lines):

diff -r 664a946b4fbd -r 2dd11332a66c sys/arch/xen/xen/xengnt.c
--- a/sys/arch/xen/xen/xengnt.c Wed Feb 06 12:10:00 2019 +0000
+++ b/sys/arch/xen/xen/xengnt.c Wed Feb 06 12:24:46 2019 +0000
@@ -1,4 +1,4 @@
-/*      $NetBSD: xengnt.c,v 1.25 2012/10/24 13:07:46 royger Exp $      */
+/*      $NetBSD: xengnt.c,v 1.26 2019/02/06 12:24:46 cherry Exp $      */
 
 /*
  * Copyright (c) 2006 Manuel Bouyer.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xengnt.c,v 1.25 2012/10/24 13:07:46 royger Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xengnt.c,v 1.26 2019/02/06 12:24:46 cherry Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -174,22 +174,44 @@
        if (pages == NULL)
                return ENOMEM;
 
-       setup.dom = DOMID_SELF;
-       setup.nr_frames = nframes_new;
-       set_xen_guest_handle(setup.frame_list, pages);
+       if (xen_feature(XENFEAT_auto_translated_physmap)) {
+               /*
+                * Note: Although we allocate space for the entire
+                * table, in this mode we only update one entry at a
+                * time.
+                */
+               struct vm_page *pg;
+               struct xen_add_to_physmap xmap;
+
+               pg = uvm_pagealloc(NULL, 0, NULL, UVM_PGA_USERESERVE|UVM_PGA_ZERO);
+               pages[gnt_nr_grant_frames] = atop(uvm_vm_page_to_phys(pg));
+
+               xmap.domid = DOMID_SELF;
+               xmap.space = XENMAPSPACE_grant_table;
+               xmap.idx = gnt_nr_grant_frames;
+               xmap.gpfn = pages[gnt_nr_grant_frames];
 
-       /*
-        * setup the grant table, made of nframes_new frames
-        * and return the list of their virtual addresses
-        * in 'pages'
-        */
-       if (HYPERVISOR_grant_table_op(GNTTABOP_setup_table, &setup, 1) != 0)
-               panic("%s: setup table failed", __func__);
-       if (setup.status != GNTST_okay) {
-               aprint_error("%s: setup table returned %d\n",
-                   __func__, setup.status);
-               free(pages, M_DEVBUF);
-               return ENOMEM;
+               if (HYPERVISOR_memory_op(XENMEM_add_to_physmap, &xmap) < 0)
+                       panic("%s: Unable to register HYPERVISOR_shared_info\n", __func__);
+
+       } else {
+               setup.dom = DOMID_SELF;
+               setup.nr_frames = nframes_new;
+               set_xen_guest_handle(setup.frame_list, pages);
+
+               /*
+                * setup the grant table, made of nframes_new frames
+                * and return the list of their virtual addresses
+                * in 'pages'
+                */
+               if (HYPERVISOR_grant_table_op(GNTTABOP_setup_table, &setup, 1) != 0)
+                       panic("%s: setup table failed", __func__);
+               if (setup.status != GNTST_okay) {
+                       aprint_error("%s: setup table returned %d\n",
+                           __func__, setup.status);
+                       free(pages, M_DEVBUF);
+                       return ENOMEM;
+               }
        }
 
        DPRINTF(("xengnt_more_entries: map 0x%lx -> %p\n",



Home | Main Index | Thread Index | Old Index