[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
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |