2014-10-29 07:50:24 +01:00
|
|
|
/** @file
|
|
|
|
Event Channel function implementation.
|
|
|
|
|
|
|
|
Event channel are use to notify of an event that happend in a shared
|
|
|
|
structure for example.
|
|
|
|
|
|
|
|
Copyright (C) 2014, Citrix Ltd.
|
|
|
|
|
|
|
|
This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
#include "EventChannel.h"
|
|
|
|
#include "XenHypercall.h"
|
|
|
|
|
|
|
|
UINT32
|
|
|
|
XenEventChannelNotify (
|
|
|
|
IN XENBUS_DEVICE *Dev,
|
|
|
|
IN evtchn_port_t Port
|
|
|
|
)
|
|
|
|
{
|
|
|
|
INTN ReturnCode;
|
|
|
|
evtchn_send_t Send;
|
|
|
|
|
|
|
|
Send.port = Port;
|
|
|
|
ReturnCode = XenHypercallEventChannelOp (Dev, EVTCHNOP_send, &Send);
|
|
|
|
return ReturnCode;
|
|
|
|
}
|
2014-10-29 07:51:26 +01:00
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelAllocate (
|
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN domid_t DomainId,
|
|
|
|
OUT evtchn_port_t *Port
|
|
|
|
)
|
|
|
|
{
|
|
|
|
XENBUS_PRIVATE_DATA *Private;
|
|
|
|
evtchn_alloc_unbound_t Parameter;
|
|
|
|
UINT32 ReturnCode;
|
|
|
|
|
|
|
|
Private = XENBUS_PRIVATE_DATA_FROM_THIS (This);
|
|
|
|
|
|
|
|
Parameter.dom = DOMID_SELF;
|
|
|
|
Parameter.remote_dom = DomainId;
|
|
|
|
ReturnCode = XenHypercallEventChannelOp (Private->Dev,
|
|
|
|
EVTCHNOP_alloc_unbound,
|
|
|
|
&Parameter);
|
|
|
|
if (ReturnCode != 0) {
|
|
|
|
DEBUG ((EFI_D_ERROR, "ERROR: alloc_unbound failed with rc=%d", ReturnCode));
|
|
|
|
return ReturnCode;
|
|
|
|
}
|
|
|
|
*Port = Parameter.port;
|
|
|
|
return ReturnCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelNotify (
|
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN evtchn_port_t Port
|
|
|
|
)
|
|
|
|
{
|
|
|
|
XENBUS_PRIVATE_DATA *Private;
|
|
|
|
|
|
|
|
Private = XENBUS_PRIVATE_DATA_FROM_THIS(This);
|
|
|
|
return XenEventChannelNotify (Private->Dev, Port);
|
|
|
|
}
|
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelClose (
|
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN evtchn_port_t Port
|
|
|
|
)
|
|
|
|
{
|
|
|
|
XENBUS_PRIVATE_DATA *Private;
|
|
|
|
evtchn_close_t Close;
|
|
|
|
|
|
|
|
Private = XENBUS_PRIVATE_DATA_FROM_THIS (This);
|
|
|
|
Close.port = Port;
|
|
|
|
return XenHypercallEventChannelOp (Private->Dev, EVTCHNOP_close, &Close);
|
|
|
|
}
|