VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/utils/usb/UsbTestServiceGadgetHostInternal.h@ 61239

Last change on this file since 61239 was 60324, checked in by vboxsync, 9 years ago

ValidationKit/usb/UsbTestService: Updates, start implementing the USB/IP specific interfaces (laptop -> desktop)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.1 KB
Line 
1/* $Id: UsbTestServiceGadgetHostInternal.h 60324 2016-04-05 08:33:05Z vboxsync $ */
2/** @file
3 * UsbTestServ - Remote USB test configuration and execution server, Gadget API.
4 */
5
6/*
7 * Copyright (C) 2016 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 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef ___UsbTestServiceGadgetHostInternal_h___
28#define ___UsbTestServiceGadgetHostInternal_h___
29
30#include <iprt/cdefs.h>
31#include <iprt/types.h>
32
33#include "UsbTestServiceGadget.h"
34
35RT_C_DECLS_BEGIN
36
37/** Pointer to an opaque type dependent gadget host instance data. */
38typedef struct UTSGADGETHOSTTYPEINT *PUTSGADGETHOSTTYPEINT;
39/** Pointer to a gadget host instance pointer. */
40typedef PUTSGADGETHOSTTYPEINT *PPUTSGADETHOSTTYPEINT;
41
42/**
43 * Gadget host interface.
44 */
45typedef struct UTSGADGETHOSTIF
46{
47 /** The gadget host type implemented. */
48 UTSGADGETHOSTTYPE enmType;
49 /** Description. */
50 const char *pszDesc;
51 /** Size of the interface specific instance data. */
52 size_t cbIf;
53
54 /**
55 * Initializes the gadget host interface.
56 *
57 * @returns IPRT status code.
58 * @param pIf The interface specific instance data.
59 * @param paCfg The configuration of the interface.
60 */
61 DECLR3CALLBACKMEMBER(int, pfnInit, (PUTSGADGETHOSTTYPEINT pIf, PCUTSGADGETCFGITEM paCfg));
62
63 /**
64 * Terminates the gadget host interface.
65 *
66 * @returns nothing.
67 * @param pIf The interface specific instance data.
68 */
69 DECLR3CALLBACKMEMBER(void, pfnTerm, (PUTSGADGETHOSTTYPEINT pIf));
70
71 /**
72 * Adds the given gadget to the host interface.
73 *
74 * @returns IPRT status code.
75 * @param pIf The interface specific instance data.
76 * @param hGadget The gadget handle to add.
77 */
78 DECLR3CALLBACKMEMBER(int, pfnGadgetAdd, (PUTSGADGETHOSTTYPEINT pIf, UTSGADGET hGadget));
79
80 /**
81 * Removes the given gadget from the host interface.
82 *
83 * @returns IPRT status code.
84 * @param pIf The interface specific instance data.
85 * @param hGadget The gadget handle to remove.
86 */
87 DECLR3CALLBACKMEMBER(int, pfnGadgetRemove, (PUTSGADGETHOSTTYPEINT pIf, UTSGADGET hGadget));
88
89 /**
90 * Connects the given gadget to the host interface so it appears as connected to the client
91 * of the gadget host.
92 *
93 * @returns IPRT status code.
94 * @param pIf The interface specific instance data.
95 * @param hGadget The gadget handle to add.
96 */
97 DECLR3CALLBACKMEMBER(int, pfnGadgetConnect, (PUTSGADGETHOSTTYPEINT pIf, UTSGADGET hGadget));
98
99 /**
100 * Disconnects the given gadget from the host interface so it appears as disconnected to the client
101 * of the gadget host.
102 *
103 * @returns IPRT status code.
104 * @param pIf The interface specific instance data.
105 * @param hGadget The gadget handle to add.
106 */
107 DECLR3CALLBACKMEMBER(int, pfnGadgetDisconnect, (PUTSGADGETHOSTTYPEINT pIf, UTSGADGET hGadget));
108
109} UTSGADGETHOSTIF;
110/** Pointer to a gadget host callback table. */
111typedef UTSGADGETHOSTIF *PUTSGADGETHOSTIF;
112/** Pointer to a const gadget host callback table. */
113typedef const struct UTSGADGETHOSTIF *PCUTSGADGETHOSTIF;
114
115extern UTSGADGETHOSTIF const g_UtsGadgetHostIfUsbIp;
116
117RT_C_DECLS_END
118
119#endif
120
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