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

[Xen-changelog] [xen-unstable] [MINI-OS] Extend alloc_unbound so that the remote domain isn't always dom0.



# HG changeset patch
# User sos22@xxxxxxxxxxxxxxxxxxxx
# Node ID 97ffb7856239a937f391583e881fae695c86fb68
# Parent  98a802d258482b4d8e462493eb981741c82a713c
[MINI-OS] Extend alloc_unbound so that the remote domain isn't always dom0.

Signed-off-by: John D. Ramsdell <ramsdell@xxxxxxxxx>
Signed-off-by: Steven Smith <sos22@xxxxxxxxx>
---
 extras/mini-os/events.c         |   32 +++++++++++++++-----------------
 extras/mini-os/include/events.h |    4 ++--
 2 files changed, 17 insertions(+), 19 deletions(-)

diff -r 98a802d25848 -r 97ffb7856239 extras/mini-os/events.c
--- a/extras/mini-os/events.c   Fri Jul 28 14:02:49 2006 +0100
+++ b/extras/mini-os/events.c   Fri Jul 28 14:03:54 2006 +0100
@@ -141,25 +141,23 @@ void default_handler(evtchn_port_t port,
     printk("[Port %d] - event received\n", port);
 }
 
+/* Create a port available to the pal for exchanging notifications.
+   Returns the result of the hypervisor call. */
+
 /* Unfortunate confusion of terminology: the port is unbound as far
    as Xen is concerned, but we automatically bind a handler to it
    from inside mini-os. */
-evtchn_port_t evtchn_alloc_unbound(evtchn_handler_t handler, void *data)
+
+int evtchn_alloc_unbound(domid_t pal, evtchn_handler_t handler,
+                                                void *data, evtchn_port_t 
*port)
 {
-       evtchn_port_t port;
-       evtchn_op_t op;
-       int err;
-
-       op.cmd = EVTCHNOP_alloc_unbound;
-       op.u.alloc_unbound.dom = DOMID_SELF;
-       op.u.alloc_unbound.remote_dom = 0;
-
-       err = HYPERVISOR_event_channel_op(&op);
-       if (err) {
-               printk("Failed to alloc unbound evtchn: %d.\n", err);
-               return -1;
-       }
-       port = op.u.alloc_unbound.port;
-       bind_evtchn(port, handler, data);
-       return port;
+    evtchn_op_t op;
+    op.cmd = EVTCHNOP_alloc_unbound;
+    op.u.alloc_unbound.dom = DOMID_SELF;
+    op.u.alloc_unbound.remote_dom = pal;
+    int err = HYPERVISOR_event_channel_op(&op);
+    if (err)
+               return err;
+    *port = bind_evtchn(op.u.alloc_unbound.port, handler, data);
+    return err;
 }
diff -r 98a802d25848 -r 97ffb7856239 extras/mini-os/include/events.h
--- a/extras/mini-os/include/events.h   Fri Jul 28 14:02:49 2006 +0100
+++ b/extras/mini-os/include/events.h   Fri Jul 28 14:03:54 2006 +0100
@@ -31,8 +31,8 @@ evtchn_port_t bind_evtchn(evtchn_port_t 
                                                  void *data);
 void unbind_evtchn(evtchn_port_t port);
 void init_events(void);
-evtchn_port_t evtchn_alloc_unbound(evtchn_handler_t handler,
-                                                                  void *data);
+int evtchn_alloc_unbound(domid_t pal, evtchn_handler_t handler,
+                                                void *data, evtchn_port_t 
*port);
 
 static inline int notify_remote_via_evtchn(evtchn_port_t port)
 {

_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.