This refactors the Xen hypercall implementation that is part of the XenBusDxe driver, in preparation of splitting it off entirely into a XenHypercallLib library. This involves: - removing the dependency on XENBUS_DEVICE* pointers in the XenHypercall() prototypes - moving the discovered hyperpage address to a global variable - moving XenGetSharedInfoPage() to its only user XenBusDxe.c (the shared info page is not strictly part of the Xen hypercall interface, and is not used by other expected users of XenHypercallLib such as the Xen console version of SerialPortLib - reimplement XenHypercall2() in C and move the indexing of the hyperpage there; the existing asm implementations are renamed to __XenHypercall2() and invoked from the new C implementation. Contributed-under: TianoCore Contribution Agreement 1.0 Acked-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Anthony PERARD <anthony.perard@citrix.com> Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Laszlo Ersek <lersek@redhat.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16969 6f19259b-4bc3-4df7-8a09-765794883524
84 lines
2.0 KiB
C
84 lines
2.0 KiB
C
/** @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 (EVTCHNOP_send, &Send);
|
|
return (UINT32)ReturnCode;
|
|
}
|
|
|
|
UINT32
|
|
EFIAPI
|
|
XenBusEventChannelAllocate (
|
|
IN XENBUS_PROTOCOL *This,
|
|
IN domid_t DomainId,
|
|
OUT evtchn_port_t *Port
|
|
)
|
|
{
|
|
evtchn_alloc_unbound_t Parameter;
|
|
UINT32 ReturnCode;
|
|
|
|
Parameter.dom = DOMID_SELF;
|
|
Parameter.remote_dom = DomainId;
|
|
ReturnCode = (UINT32)XenHypercallEventChannelOp (
|
|
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
|
|
)
|
|
{
|
|
evtchn_close_t Close;
|
|
|
|
Close.port = Port;
|
|
return (UINT32)XenHypercallEventChannelOp (EVTCHNOP_close, &Close);
|
|
}
|