VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/HGSMI/HGSMIHost.h@ 78046

Last change on this file since 78046 was 76565, checked in by vboxsync, 6 years ago

Devices: Use VBOX_INCLUDED_SRC_ as header guard prefix with scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.2 KB
Line 
1/* $Id: HGSMIHost.h 76565 2019-01-01 04:23:20Z vboxsync $ */
2/** @file
3 * VBox Host Guest Shared Memory Interface (HGSMI), host part.
4 */
5
6/*
7 * Copyright (C) 2006-2019 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef VBOX_INCLUDED_SRC_Graphics_HGSMI_HGSMIHost_h
19#define VBOX_INCLUDED_SRC_Graphics_HGSMI_HGSMIHost_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24#include <VBox/vmm/vm.h>
25
26#include <HGSMI.h>
27#include <HGSMIChSetup.h>
28
29struct HGSMIINSTANCE;
30typedef struct HGSMIINSTANCE *PHGSMIINSTANCE;
31
32/** Callback for the guest notification about a new host buffer. */
33typedef DECLCALLBACK(void) FNHGSMINOTIFYGUEST(void *pvCallback);
34typedef FNHGSMINOTIFYGUEST *PFNHGSMINOTIFYGUEST;
35
36/*
37 * Public Host API for virtual devices.
38 */
39
40int HGSMICreate(PHGSMIINSTANCE *ppIns,
41 PVM pVM,
42 const char *pszName,
43 HGSMIOFFSET offBase,
44 uint8_t *pu8MemBase,
45 HGSMISIZE cbMem,
46 PFNHGSMINOTIFYGUEST pfnNotifyGuest,
47 void *pvNotifyGuest,
48 size_t cbContext);
49void HGSMIDestroy(PHGSMIINSTANCE pIns);
50void *HGSMIContext(PHGSMIINSTANCE pIns);
51
52void RT_UNTRUSTED_VOLATILE_GUEST *HGSMIOffsetToPointerHost(PHGSMIINSTANCE pIns, HGSMIOFFSET offBuffer);
53HGSMIOFFSET HGSMIPointerToOffsetHost(PHGSMIINSTANCE pIns, const void RT_UNTRUSTED_VOLATILE_GUEST *pv);
54bool HGSMIIsOffsetValid(PHGSMIINSTANCE pIns, HGSMIOFFSET offBuffer);
55HGSMIOFFSET HGSMIGetAreaOffset(PHGSMIINSTANCE pIns);
56HGSMIOFFSET HGSMIGetAreaSize(PHGSMIINSTANCE pIns);
57
58
59int HGSMIHostChannelRegister(PHGSMIINSTANCE pIns, uint8_t u8Channel,
60 PFNHGSMICHANNELHANDLER pfnChannelHandler, void *pvChannelHandler);
61#if 0 /* unused */
62int HGSMIChannelRegisterName (PHGSMIINSTANCE pIns,
63 const char *pszChannel,
64 PFNHGSMICHANNELHANDLER pfnChannelHandler,
65 void *pvChannelHandler,
66 uint8_t *pu8Channel);
67#endif
68
69int HGSMIHostHeapSetup(PHGSMIINSTANCE pIns, HGSMIOFFSET RT_UNTRUSTED_GUEST offHeap, HGSMISIZE RT_UNTRUSTED_GUEST cbHeap);
70
71/*
72 * Virtual hardware IO handlers.
73 */
74
75/* Guests passes a new command buffer to the host. */
76void HGSMIGuestWrite(PHGSMIINSTANCE pIns, HGSMIOFFSET offBuffer);
77
78/* Guest reads information about guest buffers. */
79HGSMIOFFSET HGSMIGuestRead(PHGSMIINSTANCE pIns);
80
81/* Guest reads the host FIFO to get a command. */
82HGSMIOFFSET HGSMIHostRead(PHGSMIINSTANCE pIns);
83
84/* Guest reports that the command at this offset has been processed. */
85void HGSMIHostWrite(PHGSMIINSTANCE pIns, HGSMIOFFSET offBuffer);
86
87void HGSMISetHostGuestFlags(PHGSMIINSTANCE pIns, uint32_t flags);
88uint32_t HGSMIGetHostGuestFlags(HGSMIINSTANCE *pIns);
89
90void HGSMIClearHostGuestFlags(PHGSMIINSTANCE pIns, uint32_t flags);
91
92/*
93 * Low level interface for submitting buffers to the guest.
94 *
95 * These functions are not directly available for anyone but the
96 * virtual hardware device.
97 */
98
99/* Allocate a buffer in the host heap. */
100int HGSMIHostCommandAlloc(PHGSMIINSTANCE pIns, void RT_UNTRUSTED_VOLATILE_GUEST **ppvData, HGSMISIZE cbData,
101 uint8_t u8Channel, uint16_t u16ChannelInfo);
102int HGSMIHostCommandSubmitAndFreeAsynch(PHGSMIINSTANCE pIns, void RT_UNTRUSTED_VOLATILE_GUEST *pvData, bool fDoIrq);
103int HGSMIHostCommandFree(PHGSMIINSTANCE pIns, void RT_UNTRUSTED_VOLATILE_GUEST *pvData);
104
105int HGSMIHostLoadStateExec(PHGSMIINSTANCE pIns, PSSMHANDLE pSSM, uint32_t u32Version);
106int HGSMIHostSaveStateExec(PHGSMIINSTANCE pIns, PSSMHANDLE pSSM);
107
108#ifdef VBOX_WITH_WDDM
109int HGSMICompleteGuestCommand(PHGSMIINSTANCE pIns, void RT_UNTRUSTED_VOLATILE_GUEST *pvMem, bool fDoIrq);
110#endif
111
112#endif /* !VBOX_INCLUDED_SRC_Graphics_HGSMI_HGSMIHost_h */
113
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette