2014-10-29 07:49:10 +01:00
|
|
|
/** @file
|
|
|
|
Functions declarations to make Xen hypercalls.
|
|
|
|
|
|
|
|
Copyright (C) 2014, Citrix Ltd.
|
|
|
|
|
2019-04-04 01:06:33 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2014-10-29 07:49:10 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2015-02-28 21:32:39 +01:00
|
|
|
#ifndef __XEN_HYPERCALL_LIB_H__
|
|
|
|
#define __XEN_HYPERCALL_LIB_H__
|
2014-10-29 07:49:10 +01:00
|
|
|
|
2019-08-13 13:31:00 +02:00
|
|
|
/**
|
|
|
|
To call when the gEfiXenInfoGuid HOB became available after the library init
|
|
|
|
function has already been executed.
|
|
|
|
|
|
|
|
This allow to make hypercall in the PEIM stage.
|
|
|
|
**/
|
|
|
|
RETURN_STATUS
|
|
|
|
EFIAPI
|
|
|
|
XenHypercallLibInit (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2015-03-03 09:13:30 +01:00
|
|
|
/**
|
|
|
|
Check if the Xen Hypercall library is able to make calls to the Xen
|
|
|
|
hypervisor.
|
|
|
|
|
|
|
|
Client code should call further functions in this library only if, and after,
|
|
|
|
this function returns TRUE.
|
|
|
|
|
|
|
|
@retval TRUE Hypercalls are available.
|
|
|
|
@retval FALSE Hypercalls are not available.
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
XenHypercallIsAvailable (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2014-10-29 07:49:10 +01:00
|
|
|
/**
|
|
|
|
This function will put the two arguments in the right place (registers) and
|
2015-02-28 21:32:27 +01:00
|
|
|
invoke the hypercall identified by HypercallID.
|
2014-10-29 07:49:10 +01:00
|
|
|
|
2015-02-28 21:32:27 +01:00
|
|
|
@param HypercallID The symbolic ID of the hypercall to be invoked
|
2014-10-29 07:49:10 +01:00
|
|
|
@param Arg1 First argument.
|
|
|
|
@param Arg2 Second argument.
|
|
|
|
|
|
|
|
@return Return 0 if success otherwise it return an errno.
|
|
|
|
**/
|
|
|
|
INTN
|
|
|
|
EFIAPI
|
|
|
|
XenHypercall2 (
|
2015-02-28 21:32:39 +01:00
|
|
|
IN UINTN HypercallID,
|
|
|
|
IN OUT INTN Arg1,
|
|
|
|
IN OUT INTN Arg2
|
2014-10-29 07:49:10 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Return the value of the HVM parameter Index.
|
|
|
|
|
|
|
|
@param Index The parameter to get, e.g. HVM_PARAM_STORE_EVTCHN.
|
|
|
|
|
|
|
|
@return The value of the asked parameter or 0 in case of error.
|
|
|
|
**/
|
|
|
|
UINT64
|
2016-12-06 13:03:24 +01:00
|
|
|
EFIAPI
|
2014-10-29 07:49:10 +01:00
|
|
|
XenHypercallHvmGetParam (
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT32 Index
|
2014-10-29 07:49:10 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Hypercall to do different operation on the memory.
|
|
|
|
|
|
|
|
@param Operation The operation number, e.g. XENMEM_add_to_physmap.
|
|
|
|
@param Arguments The arguments associated to the operation.
|
|
|
|
|
|
|
|
@return Return the return value from the hypercall, 0 in case of success
|
|
|
|
otherwise, an error code.
|
|
|
|
**/
|
|
|
|
INTN
|
2016-12-06 13:03:24 +01:00
|
|
|
EFIAPI
|
2014-10-29 07:49:10 +01:00
|
|
|
XenHypercallMemoryOp (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN UINTN Operation,
|
|
|
|
IN OUT VOID *Arguments
|
2014-10-29 07:49:10 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Do an operation on the event channels.
|
|
|
|
|
|
|
|
@param Operation The operation number, e.g. EVTCHNOP_send.
|
|
|
|
@param Arguments The argument associated to the operation.
|
|
|
|
|
|
|
|
@return Return the return value from the hypercall, 0 in case of success
|
|
|
|
otherwise, an error code.
|
|
|
|
**/
|
|
|
|
INTN
|
2016-12-06 13:03:24 +01:00
|
|
|
EFIAPI
|
2014-10-29 07:49:10 +01:00
|
|
|
XenHypercallEventChannelOp (
|
2021-12-05 23:54:09 +01:00
|
|
|
IN INTN Operation,
|
|
|
|
IN OUT VOID *Arguments
|
2014-10-29 07:49:10 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|