2014-10-29 07:50:24 +01:00
|
|
|
/** @file
|
|
|
|
Event Channel function implementation.
|
|
|
|
|
2016-09-09 22:32:15 +02:00
|
|
|
Event channel are use to notify of an event that happened in a shared
|
2014-10-29 07:50:24 +01:00
|
|
|
structure for example.
|
|
|
|
|
|
|
|
Copyright (C) 2014, Citrix Ltd.
|
|
|
|
|
2019-04-04 01:06:33 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2014-10-29 07:50:24 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
#include "EventChannel.h"
|
2015-02-28 21:32:39 +01:00
|
|
|
|
|
|
|
#include <Library/XenHypercallLib.h>
|
2014-10-29 07:50:24 +01:00
|
|
|
|
|
|
|
UINT32
|
|
|
|
XenEventChannelNotify (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN XENBUS_DEVICE *Dev,
|
|
|
|
IN evtchn_port_t Port
|
2014-10-29 07:50:24 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:09 +01:00
|
|
|
INTN ReturnCode;
|
|
|
|
evtchn_send_t Send;
|
2014-10-29 07:50:24 +01:00
|
|
|
|
2021-12-05 23:54:09 +01:00
|
|
|
Send.port = Port;
|
2015-02-28 21:32:27 +01:00
|
|
|
ReturnCode = XenHypercallEventChannelOp (EVTCHNOP_send, &Send);
|
2014-11-14 18:35:35 +01:00
|
|
|
return (UINT32)ReturnCode;
|
2014-10-29 07:50:24 +01:00
|
|
|
}
|
2014-10-29 07:51:26 +01:00
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelAllocate (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN domid_t DomainId,
|
|
|
|
OUT evtchn_port_t *Port
|
2014-10-29 07:51:26 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:09 +01:00
|
|
|
evtchn_alloc_unbound_t Parameter;
|
|
|
|
UINT32 ReturnCode;
|
2014-10-29 07:51:26 +01:00
|
|
|
|
2021-12-05 23:54:09 +01:00
|
|
|
Parameter.dom = DOMID_SELF;
|
2014-10-29 07:51:26 +01:00
|
|
|
Parameter.remote_dom = DomainId;
|
2021-12-05 23:54:09 +01:00
|
|
|
ReturnCode = (UINT32)XenHypercallEventChannelOp (
|
2014-10-29 07:51:26 +01:00
|
|
|
EVTCHNOP_alloc_unbound,
|
2021-12-05 23:54:09 +01:00
|
|
|
&Parameter
|
|
|
|
);
|
2014-10-29 07:51:26 +01:00
|
|
|
if (ReturnCode != 0) {
|
2020-04-29 23:53:27 +02:00
|
|
|
DEBUG ((DEBUG_ERROR, "ERROR: alloc_unbound failed with rc=%d", ReturnCode));
|
2014-10-29 07:51:26 +01:00
|
|
|
return ReturnCode;
|
|
|
|
}
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2014-10-29 07:51:26 +01:00
|
|
|
*Port = Parameter.port;
|
|
|
|
return ReturnCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelNotify (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN evtchn_port_t Port
|
2014-10-29 07:51:26 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:09 +01:00
|
|
|
XENBUS_PRIVATE_DATA *Private;
|
2014-10-29 07:51:26 +01:00
|
|
|
|
2021-12-05 23:54:09 +01:00
|
|
|
Private = XENBUS_PRIVATE_DATA_FROM_THIS (This);
|
2014-10-29 07:51:26 +01:00
|
|
|
return XenEventChannelNotify (Private->Dev, Port);
|
|
|
|
}
|
|
|
|
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
XenBusEventChannelClose (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN XENBUS_PROTOCOL *This,
|
|
|
|
IN evtchn_port_t Port
|
2014-10-29 07:51:26 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:09 +01:00
|
|
|
evtchn_close_t Close;
|
2014-10-29 07:51:26 +01:00
|
|
|
|
|
|
|
Close.port = Port;
|
2015-02-28 21:32:27 +01:00
|
|
|
return (UINT32)XenHypercallEventChannelOp (EVTCHNOP_close, &Close);
|
2014-10-29 07:51:26 +01:00
|
|
|
}
|