summaryrefslogtreecommitdiffstats
path: root/OvmfPkg/XenBusDxe/XenHypercall.h
blob: 3627b1886ca77bdc737f503501fc41877ffbb817 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/** @file
  Functions declarations to make Xen hypercalls.

  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.

**/

#ifndef __XENBUS_DXE_HYPERCALL_H__
#define __XENBUS_DXE_HYPERCALL_H__

typedef struct _XENBUS_DEVICE XENBUS_DEVICE;

/**
  This function will put the two arguments in the right place (registers) and
  call HypercallAddr, which correspond to an entry in the hypercall pages.

  @param HypercallAddr  A memory address where the hypercall to call is.
  @param Arg1           First argument.
  @param Arg2           Second argument.

  @return   Return 0 if success otherwise it return an errno.
**/
INTN
EFIAPI
XenHypercall2 (
  IN     VOID *HypercallAddr,
  IN OUT INTN Arg1,
  IN OUT INTN Arg2
  );

/**
  Get the page where all hypercall are from the XenInfo hob.

  @param Dev    A XENBUS_DEVICE instance.

  @retval EFI_NOT_FOUND   hyperpage could not be found.
  @retval EFI_SUCCESS     Successfully retrieve the hyperpage pointer.
**/
EFI_STATUS
XenHyperpageInit (
  XENBUS_DEVICE *Dev
  );

/**
  Return the value of the HVM parameter Index.

  @param Dev    A XENBUS_DEVICE instance.
  @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
XenHypercallHvmGetParam (
  XENBUS_DEVICE *Dev,
  INTN Index
  );

/**
  Hypercall to do different operation on the memory.

  @param Dev        A XENBUS_DEVICE instance.
  @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
XenHypercallMemoryOp (
  IN     XENBUS_DEVICE *Dev,
  IN     UINTN Operation,
  IN OUT VOID *Arguments
  );

/**
  Do an operation on the event channels.

  @param Dev        A XENBUS_DEVICE instance.
  @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
XenHypercallEventChannelOp (
  IN     XENBUS_DEVICE *Dev,
  IN     INTN Operation,
  IN OUT VOID *Arguments
  );

/**
  Map the shared_info_t page into memory.

  @param Dev    A XENBUS_DEVICE instance.

  @retval EFI_SUCCESS     Dev->SharedInfo whill contain a pointer to
                          the shared info page
  @retval EFI_LOAD_ERROR  The shared info page could not be mapped. The
                          hypercall returned an error.
**/
EFI_STATUS
XenGetSharedInfoPage (
  IN OUT XENBUS_DEVICE *Dev
  );

#endif