VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/utils/usb/UsbTestServiceGadget.cpp@ 74911

Last change on this file since 74911 was 73097, checked in by vboxsync, 7 years ago

*: Made RT_UOFFSETOF, RT_OFFSETOF, RT_UOFFSETOF_ADD and RT_OFFSETOF_ADD work like builtin_offsetof() and require compile time resolvable requests, adding RT_UOFFSETOF_DYN for the dynamic questions that can only be answered at runtime.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.6 KB
Line 
1/* $Id: UsbTestServiceGadget.cpp 73097 2018-07-12 21:06:33Z vboxsync $ */
2/** @file
3 * UsbTestServ - Remote USB test configuration and execution server, USB gadget host API.
4 */
5
6/*
7 * Copyright (C) 2016-2017 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
28/*********************************************************************************************************************************
29* Header Files *
30*********************************************************************************************************************************/
31
32#include <iprt/asm.h>
33#include <iprt/cdefs.h>
34#include <iprt/ctype.h>
35#include <iprt/mem.h>
36#include <iprt/string.h>
37#include <iprt/types.h>
38
39#include "UsbTestServiceGadgetInternal.h"
40
41
42/*********************************************************************************************************************************
43* Constants And Macros, Structures and Typedefs *
44*********************************************************************************************************************************/
45
46/**
47 * Internal UTS gadget host instance data.
48 */
49typedef struct UTSGADGETINT
50{
51 /** Reference counter. */
52 volatile uint32_t cRefs;
53 /** Pointer to the gadget class callback table. */
54 PCUTSGADGETCLASSIF pClassIf;
55 /** The gadget host handle. */
56 UTSGADGETHOST hGadgetHost;
57 /** Class specific instance data - variable in size. */
58 uint8_t abClassInst[1];
59} UTSGADGETINT;
60/** Pointer to the internal gadget host instance data. */
61typedef UTSGADGETINT *PUTSGADGETINT;
62
63
64/*********************************************************************************************************************************
65* Global variables *
66*********************************************************************************************************************************/
67
68/** Known gadget host interfaces. */
69static const PCUTSGADGETCLASSIF g_apUtsGadgetClass[] =
70{
71 &g_UtsGadgetClassTest
72};
73
74
75/*********************************************************************************************************************************
76* Internal Functions *
77*********************************************************************************************************************************/
78
79
80/**
81 * Destroys a gadget instance.
82 *
83 * @returns nothing.
84 * @param pThis The gadget instance.
85 */
86static void utsGadgetDestroy(PUTSGADGETINT pThis)
87{
88 pThis->pClassIf->pfnTerm((PUTSGADGETCLASSINT)&pThis->abClassInst[0]);
89 RTMemFree(pThis);
90}
91
92
93DECLHIDDEN(int) utsGadgetCreate(UTSGADGETHOST hGadgetHost, UTSGADGETCLASS enmClass,
94 PCUTSGADGETCFGITEM paCfg, PUTSGADET phGadget)
95{
96 int rc = VINF_SUCCESS;
97 PCUTSGADGETCLASSIF pClassIf = NULL;
98
99 /* Get the interface. */
100 for (unsigned i = 0; i < RT_ELEMENTS(g_apUtsGadgetClass); i++)
101 {
102 if (g_apUtsGadgetClass[i]->enmClass == enmClass)
103 {
104 pClassIf = g_apUtsGadgetClass[i];
105 break;
106 }
107 }
108
109 if (RT_LIKELY(pClassIf))
110 {
111 PUTSGADGETINT pThis = (PUTSGADGETINT)RTMemAllocZ(RT_UOFFSETOF_DYN(UTSGADGETINT, abClassInst[pClassIf->cbClass]));
112 if (RT_LIKELY(pThis))
113 {
114 pThis->cRefs = 1;
115 pThis->hGadgetHost = hGadgetHost;
116 pThis->pClassIf = pClassIf;
117 rc = pClassIf->pfnInit((PUTSGADGETCLASSINT)&pThis->abClassInst[0], paCfg);
118 if (RT_SUCCESS(rc))
119 {
120 /* Connect the gadget to the host. */
121 rc = utsGadgetHostGadgetConnect(pThis->hGadgetHost, pThis);
122 if (RT_SUCCESS(rc))
123 *phGadget = pThis;
124 }
125 else
126 RTMemFree(pThis);
127 }
128 else
129 rc = VERR_NO_MEMORY;
130 }
131 else
132 rc = VERR_INVALID_PARAMETER;
133
134 return rc;
135}
136
137
138DECLHIDDEN(uint32_t) utsGadgetRetain(UTSGADGET hGadget)
139{
140 PUTSGADGETINT pThis = hGadget;
141
142 AssertPtrReturn(pThis, 0);
143
144 return ASMAtomicIncU32(&pThis->cRefs);
145}
146
147
148DECLHIDDEN(uint32_t) utsGadgetRelease(UTSGADGET hGadget)
149{
150 PUTSGADGETINT pThis = hGadget;
151
152 AssertPtrReturn(pThis, 0);
153
154 uint32_t cRefs = ASMAtomicDecU32(&pThis->cRefs);
155 if (!cRefs)
156 utsGadgetDestroy(pThis);
157
158 return cRefs;
159}
160
161
162DECLHIDDEN(uint32_t) utsGadgetGetBusId(UTSGADGET hGadget)
163{
164 PUTSGADGETINT pThis = hGadget;
165
166 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
167 return pThis->pClassIf->pfnGetBusId((PUTSGADGETCLASSINT)&pThis->abClassInst[0]);
168}
169
170
171DECLHIDDEN(uint32_t) utsGadgetGetDevId(UTSGADGET hGadget)
172{
173 PUTSGADGETINT pThis = hGadget;
174
175 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
176 return 1; /** @todo Current assumption which is true on Linux with dummy_hcd. */
177}
178
179
180DECLHIDDEN(int) utsGadgetConnect(UTSGADGET hGadget)
181{
182 PUTSGADGETINT pThis = hGadget;
183
184 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
185 int rc = pThis->pClassIf->pfnConnect((PUTSGADGETCLASSINT)&pThis->abClassInst[0]);
186 if (RT_SUCCESS(rc))
187 rc = utsGadgetHostGadgetConnect(pThis->hGadgetHost, hGadget);
188
189 return rc;
190}
191
192
193DECLHIDDEN(int) utsGadgetDisconnect(UTSGADGET hGadget)
194{
195 PUTSGADGETINT pThis = hGadget;
196
197 AssertPtrReturn(pThis, VERR_INVALID_HANDLE);
198 int rc = utsGadgetHostGadgetDisconnect(pThis->hGadgetHost, hGadget);
199 if (RT_SUCCESS(rc))
200 rc = pThis->pClassIf->pfnDisconnect((PUTSGADGETCLASSINT)&pThis->abClassInst[0]);
201
202 return rc;
203}
204
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