]> git.proxmox.com Git - mirror_edk2.git/blob - OvmfPkg/XenBusDxe/EventChannel.h
OvmfPkg/XenBusDxe: Add Event Channel into XenBus protocol.
[mirror_edk2.git] / OvmfPkg / XenBusDxe / EventChannel.h
1 /** @file
2 Event Channel function declaration.
3
4 Copyright (C) 2014, Citrix Ltd.
5
6 This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
10
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
13
14 **/
15 #ifndef __XENBUS_EVENT_CHANNEL_H
16 #define __XENBUS_EVENT_CHANNEL_H
17
18 #include "XenBusDxe.h"
19
20 #include <IndustryStandard/Xen/event_channel.h>
21
22 /**
23 Send an event to the remote end of the channel whose local endpoint is Port.
24
25 @param Dev A pointer to XENBUS_DEVICE.
26 @param Port The port to notify.
27
28 @return Return 0 on success, or return the errno code from the hypercall.
29 **/
30 UINT32
31 XenEventChannelNotify (
32 IN XENBUS_DEVICE *Dev,
33 IN evtchn_port_t Port
34 );
35
36 /*
37 * XenBus protocol
38 */
39
40 /**
41 Allocate a port that can be bind from domain DomainId.
42
43 @param This A pointer to the XENBUS_PROTOCOL.
44 @param DomainId The domain ID that can bind the newly allocated port.
45 @param Port A pointer to a evtchn_port_t that will contain the newly
46 allocated port.
47
48 @retval UINT32 The return value from the hypercall, 0 if success.
49 **/
50 UINT32
51 EFIAPI
52 XenBusEventChannelAllocate (
53 IN XENBUS_PROTOCOL *This,
54 IN domid_t DomainId,
55 OUT evtchn_port_t *Port
56 );
57
58 /**
59 Send an event to the remote end of the channel whose local endpoint is Port.
60
61 @param This A pointer to the XENBUS_PROTOCOL.
62 @param Port Local port to the the event from.
63
64 @retval UINT32 The return value from the hypercall, 0 if success.
65 **/
66 UINT32
67 EFIAPI
68 XenBusEventChannelNotify (
69 IN XENBUS_PROTOCOL *This,
70 IN evtchn_port_t Port
71 );
72
73 /**
74 Close a local event channel Port.
75
76 @param This A pointer to the XENBUS_PROTOCOL.
77 @param Port The event channel to close.
78
79 @retval UINT32 The return value from the hypercall, 0 if success.
80 **/
81 UINT32
82 EFIAPI
83 XenBusEventChannelClose (
84 IN XENBUS_PROTOCOL *This,
85 IN evtchn_port_t Port
86 );
87
88 #endif