VirtualBox

source: vbox/trunk/include/VBox/vusb.h@ 29776

Last change on this file since 29776 was 28800, checked in by vboxsync, 15 years ago

Automated rebranding to Oracle copyright/license strings via filemuncher

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 32.9 KB
Line 
1/** @file
2 * VUSB - VirtualBox USB. (DEV,VMM)
3 */
4
5/*
6 * Copyright (C) 2006-2007 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_vusb_h
27#define ___VBox_vusb_h
28
29#include <VBox/cdefs.h>
30#include <VBox/types.h>
31
32RT_C_DECLS_BEGIN
33
34/** @defgroup grp_vusb VBox USB API
35 * @{
36 */
37
38/** @defgroup grp_vusb_std Standard Stuff
39 * @{ */
40
41/** Frequency of USB bus (from spec). */
42#define VUSB_BUS_HZ 12000000
43
44
45/** @name USB Descriptor types (from spec)
46 * @{ */
47#define VUSB_DT_DEVICE 0x01
48#define VUSB_DT_CONFIG 0x02
49#define VUSB_DT_STRING 0x03
50#define VUSB_DT_INTERFACE 0x04
51#define VUSB_DT_ENDPOINT 0x05
52#define VUSB_DT_DEVICE_QUALIFIER 0x06
53#define VUSB_DT_OTHER_SPEED_CFG 0x07
54#define VUSB_DT_INTERFACE_POWER 0x08
55/** @} */
56
57/** @name USB Descriptor minimum sizes (from spec)
58 * @{ */
59#define VUSB_DT_DEVICE_MIN_LEN 18
60#define VUSB_DT_CONFIG_MIN_LEN 9
61#define VUSB_DT_CONFIG_STRING_MIN_LEN 2
62#define VUSB_DT_INTERFACE_MIN_LEN 9
63#define VUSB_DT_ENDPOINT_MIN_LEN 7
64/** @} */
65
66
67#pragma pack(1) /* ensure byte packing of the descriptors. */
68
69/**
70 * USB language id descriptor (from specs).
71 */
72typedef struct VUSBDESCLANGID
73{
74 uint8_t bLength;
75 uint8_t bDescriptorType;
76} VUSBDESCLANGID;
77/** Pointer to a USB language id descriptor. */
78typedef VUSBDESCLANGID *PVUSBDESCLANGID;
79/** Pointer to a const USB language id descriptor. */
80typedef const VUSBDESCLANGID *PCVUSBDESCLANGID;
81
82
83/**
84 * USB string descriptor (from specs).
85 */
86typedef struct VUSBDESCSTRING
87{
88 uint8_t bLength;
89 uint8_t bDescriptorType;
90} VUSBDESCSTRING;
91/** Pointer to a USB string descriptor. */
92typedef VUSBDESCSTRING *PVUSBDESCSTRING;
93/** Pointer to a const USB string descriptor. */
94typedef const VUSBDESCSTRING *PCVUSBDESCSTRING;
95
96
97/**
98 * USB device descriptor (from spec)
99 */
100typedef struct VUSBDESCDEVICE
101{
102 uint8_t bLength;
103 uint8_t bDescriptorType;
104 uint16_t bcdUSB;
105 uint8_t bDeviceClass;
106 uint8_t bDeviceSubClass;
107 uint8_t bDeviceProtocol;
108 uint8_t bMaxPacketSize0;
109 uint16_t idVendor;
110 uint16_t idProduct;
111 uint16_t bcdDevice;
112 uint8_t iManufacturer;
113 uint8_t iProduct;
114 uint8_t iSerialNumber;
115 uint8_t bNumConfigurations;
116} VUSBDESCDEVICE;
117/** Pointer to a USB device descriptor. */
118typedef VUSBDESCDEVICE *PVUSBDESCDEVICE;
119/** Pointer to a const USB device descriptor. */
120typedef const VUSBDESCDEVICE *PCVUSBDESCDEVICE;
121
122
123/**
124 * USB configuration descriptor (from spec).
125 */
126typedef struct VUSBDESCCONFIG
127{
128 uint8_t bLength;
129 uint8_t bDescriptorType;
130 uint16_t wTotalLength; /**< recalculated by VUSB when involved in URB. */
131 uint8_t bNumInterfaces;
132 uint8_t bConfigurationValue;
133 uint8_t iConfiguration;
134 uint8_t bmAttributes;
135 uint8_t MaxPower;
136} VUSBDESCCONFIG;
137/** Pointer to a USB configuration descriptor. */
138typedef VUSBDESCCONFIG *PVUSBDESCCONFIG;
139/** Pointer to a readonly USB configuration descriptor. */
140typedef const VUSBDESCCONFIG *PCVUSBDESCCONFIG;
141
142
143/**
144 * USB interface descriptor (from spec)
145 */
146typedef struct VUSBDESCINTERFACE
147{
148 uint8_t bLength;
149 uint8_t bDescriptorType;
150 uint8_t bInterfaceNumber;
151 uint8_t bAlternateSetting;
152 uint8_t bNumEndpoints;
153 uint8_t bInterfaceClass;
154 uint8_t bInterfaceSubClass;
155 uint8_t bInterfaceProtocol;
156 uint8_t iInterface;
157} VUSBDESCINTERFACE;
158/** Pointer to an USB interface descriptor. */
159typedef VUSBDESCINTERFACE *PVUSBDESCINTERFACE;
160/** Pointer to a const USB interface descriptor. */
161typedef const VUSBDESCINTERFACE *PCVUSBDESCINTERFACE;
162
163
164/**
165 * USB endpoint descriptor (from spec)
166 */
167typedef struct VUSBDESCENDPOINT
168{
169 uint8_t bLength;
170 uint8_t bDescriptorType;
171 uint8_t bEndpointAddress;
172 uint8_t bmAttributes;
173 uint16_t wMaxPacketSize;
174 uint8_t bInterval;
175} VUSBDESCENDPOINT;
176/** Pointer to an USB endpoint descriptor. */
177typedef VUSBDESCENDPOINT *PVUSBDESCENDPOINT;
178/** Pointer to a const USB endpoint descriptor. */
179typedef const VUSBDESCENDPOINT *PCVUSBDESCENDPOINT;
180
181#pragma pack() /* end of the byte packing. */
182
183
184/**
185 * USB configuration descriptor, the parsed variant used by VUSB.
186 */
187typedef struct VUSBDESCCONFIGEX
188{
189 /** The USB descriptor data.
190 * @remark The wTotalLength member is recalculated before the data is passed to the guest. */
191 VUSBDESCCONFIG Core;
192 /** Pointer to additional descriptor bytes following what's covered by VUSBDESCCONFIG. */
193 void *pvMore;
194 /** Pointer to an array of the interfaces referenced in the configuration.
195 * Core.bNumInterfaces in size. */
196 const struct VUSBINTERFACE *paIfs;
197} VUSBDESCCONFIGEX;
198/** Pointer to a parsed USB configuration descriptor. */
199typedef VUSBDESCCONFIGEX *PVUSBDESCCONFIGEX;
200/** Pointer to a const parsed USB configuration descriptor. */
201typedef const VUSBDESCCONFIGEX *PCVUSBDESCCONFIGEX;
202
203
204/**
205 * For tracking the alternate interface settings of a configuration.
206 */
207typedef struct VUSBINTERFACE
208{
209 /** Pointer to an array of interfaces. */
210 const struct VUSBDESCINTERFACEEX *paSettings;
211 /** The number of entries in the array. */
212 uint32_t cSettings;
213} VUSBINTERFACE;
214/** Pointer to a VUSBINTERFACE. */
215typedef VUSBINTERFACE *PVUSBINTERFACE;
216/** Pointer to a const VUSBINTERFACE. */
217typedef const VUSBINTERFACE *PCVUSBINTERFACE;
218
219
220/**
221 * USB interface descriptor, the parsed variant used by VUSB.
222 */
223typedef struct VUSBDESCINTERFACEEX
224{
225 /** The USB descriptor data. */
226 VUSBDESCINTERFACE Core;
227 /** Pointer to additional descriptor bytes following what's covered by VUSBDESCINTERFACE. */
228 const void *pvMore;
229 /** Pointer to additional class- or vendor-specific interface descriptors. */
230 const void *pvClass;
231 /** Size of class- or vendor-specific descriptors. */
232 uint16_t cbClass;
233 /** Pointer to an array of the endpoints referenced by the interface.
234 * Core.bNumEndpoints in size. */
235 const struct VUSBDESCENDPOINTEX *paEndpoints;
236} VUSBDESCINTERFACEEX;
237/** Pointer to an prased USB interface descriptor. */
238typedef VUSBDESCINTERFACEEX *PVUSBDESCINTERFACEEX;
239/** Pointer to a const parsed USB interface descriptor. */
240typedef const VUSBDESCINTERFACEEX *PCVUSBDESCINTERFACEEX;
241
242
243/**
244 * USB endpoint descriptor, the parsed variant used by VUSB.
245 */
246typedef struct VUSBDESCENDPOINTEX
247{
248 /** The USB descriptor data.
249 * @remark The wMaxPacketSize member is converted to native endian. */
250 VUSBDESCENDPOINT Core;
251 /** Pointer to additional descriptor bytes following what's covered by VUSBDESCENDPOINT. */
252 const void *pvMore;
253 /** Pointer to additional class- or vendor-specific interface descriptors. */
254 const void *pvClass;
255 /** Size of class- or vendor-specific descriptors. */
256 uint16_t cbClass;
257} VUSBDESCENDPOINTEX;
258/** Pointer to a parsed USB endpoint descriptor. */
259typedef VUSBDESCENDPOINTEX *PVUSBDESCENDPOINTEX;
260/** Pointer to a const parsed USB endpoint descriptor. */
261typedef const VUSBDESCENDPOINTEX *PCVUSBDESCENDPOINTEX;
262
263
264/** @name USB Control message recipient codes (from spec)
265 * @{ */
266#define VUSB_TO_DEVICE 0x0
267#define VUSB_TO_INTERFACE 0x1
268#define VUSB_TO_ENDPOINT 0x2
269#define VUSB_TO_OTHER 0x3
270#define VUSB_RECIP_MASK 0x1f
271/** @} */
272
273/** @name USB control pipe setup packet structure (from spec)
274 * @{ */
275#define VUSB_REQ_SHIFT (5)
276#define VUSB_REQ_STANDARD (0x0 << VUSB_REQ_SHIFT)
277#define VUSB_REQ_CLASS (0x1 << VUSB_REQ_SHIFT)
278#define VUSB_REQ_VENDOR (0x2 << VUSB_REQ_SHIFT)
279#define VUSB_REQ_RESERVED (0x3 << VUSB_REQ_SHIFT)
280#define VUSB_REQ_MASK (0x3 << VUSB_REQ_SHIFT)
281/** @} */
282
283#define VUSB_DIR_TO_DEVICE 0x00
284#define VUSB_DIR_TO_HOST 0x80
285#define VUSB_DIR_MASK 0x80
286
287/**
288 * USB Setup request (from spec)
289 */
290typedef struct vusb_setup
291{
292 uint8_t bmRequestType;
293 uint8_t bRequest;
294 uint16_t wValue;
295 uint16_t wIndex;
296 uint16_t wLength;
297} VUSBSETUP;
298/** Pointer to a setup request. */
299typedef VUSBSETUP *PVUSBSETUP;
300/** Pointer to a const setup request. */
301typedef const VUSBSETUP *PCVUSBSETUP;
302
303/** @name USB Standard device requests (from spec)
304 * @{ */
305#define VUSB_REQ_GET_STATUS 0x00
306#define VUSB_REQ_CLEAR_FEATURE 0x01
307#define VUSB_REQ_SET_FEATURE 0x03
308#define VUSB_REQ_SET_ADDRESS 0x05
309#define VUSB_REQ_GET_DESCRIPTOR 0x06
310#define VUSB_REQ_SET_DESCRIPTOR 0x07
311#define VUSB_REQ_GET_CONFIGURATION 0x08
312#define VUSB_REQ_SET_CONFIGURATION 0x09
313#define VUSB_REQ_GET_INTERFACE 0x0a
314#define VUSB_REQ_SET_INTERFACE 0x0b
315#define VUSB_REQ_SYNCH_FRAME 0x0c
316#define VUSB_REQ_MAX 0x0d
317/** @} */
318
319/** @} */ /* end of grp_vusb_std */
320
321
322
323/** @name USB Standard version flags.
324 * @{ */
325/** Indicates USB 1.1 support. */
326#define VUSB_STDVER_11 RT_BIT(1)
327/** Indicates USB 2.0 support. */
328#define VUSB_STDVER_20 RT_BIT(2)
329/** @} */
330
331
332/** Pointer to a VBox USB device interface. */
333typedef struct VUSBIDEVICE *PVUSBIDEVICE;
334
335/** Pointer to a VUSB RootHub port interface. */
336typedef struct VUSBIROOTHUBPORT *PVUSBIROOTHUBPORT;
337
338/** Pointer to an USB request descriptor. */
339typedef struct VUSBURB *PVUSBURB;
340
341
342
343/**
344 * VBox USB port bitmap.
345 *
346 * Bit 0 == Port 0, ... , Bit 127 == Port 127.
347 */
348typedef struct VUSBPORTBITMAP
349{
350 /** 128 bits */
351 char ach[16];
352} VUSBPORTBITMAP;
353/** Pointer to a VBox USB port bitmap. */
354typedef VUSBPORTBITMAP *PVUSBPORTBITMAP;
355
356
357/**
358 * The VUSB RootHub port interface provided by the HCI (down).
359 * Pair with VUSBIROOTCONNECTOR
360 */
361typedef struct VUSBIROOTHUBPORT
362{
363 /**
364 * Get the number of avilable ports in the hub.
365 *
366 * @returns The number of ports available.
367 * @param pInterface Pointer to this structure.
368 * @param pAvailable Bitmap indicating the available ports. Set bit == available port.
369 */
370 DECLR3CALLBACKMEMBER(unsigned, pfnGetAvailablePorts,(PVUSBIROOTHUBPORT pInterface, PVUSBPORTBITMAP pAvailable));
371
372 /**
373 * Gets the supported USB versions.
374 *
375 * @returns The mask of supported USB versions.
376 * @param pInterface Pointer to this structure.
377 */
378 DECLR3CALLBACKMEMBER(uint32_t, pfnGetUSBVersions,(PVUSBIROOTHUBPORT pInterface));
379
380 /**
381 * A device is being attached to a port in the roothub.
382 *
383 * @param pInterface Pointer to this structure.
384 * @param pDev Pointer to the device being attached.
385 * @param uPort The port number assigned to the device.
386 */
387 DECLR3CALLBACKMEMBER(int, pfnAttach,(PVUSBIROOTHUBPORT pInterface, PVUSBIDEVICE pDev, unsigned uPort));
388
389 /**
390 * A device is being detached from a port in the roothub.
391 *
392 * @param pInterface Pointer to this structure.
393 * @param pDev Pointer to the device being detached.
394 * @param uPort The port number assigned to the device.
395 */
396 DECLR3CALLBACKMEMBER(void, pfnDetach,(PVUSBIROOTHUBPORT pInterface, PVUSBIDEVICE pDev, unsigned uPort));
397
398 /**
399 * Reset the root hub.
400 *
401 * @returns VBox status code.
402 * @param pInterface Pointer to this structure.
403 * @param pResetOnLinux Whether or not to do real reset on linux.
404 */
405 DECLR3CALLBACKMEMBER(int, pfnReset,(PVUSBIROOTHUBPORT pInterface, bool fResetOnLinux));
406
407 /**
408 * Transfer completion callback routine.
409 *
410 * VUSB will call this when a transfer have been completed
411 * in a one or another way.
412 *
413 * @param pInterface Pointer to this structure.
414 * @param pUrb Pointer to the URB in question.
415 */
416 DECLR3CALLBACKMEMBER(void, pfnXferCompletion,(PVUSBIROOTHUBPORT pInterface, PVUSBURB urb));
417
418 /**
419 * Handle transfer errors.
420 *
421 * VUSB calls this when a transfer attempt failed. This function will respond
422 * indicating wheter to retry or complete the URB with failure.
423 *
424 * @returns Retry indicator.
425 * @param pInterface Pointer to this structure.
426 * @param pUrb Pointer to the URB in question.
427 */
428 DECLR3CALLBACKMEMBER(bool, pfnXferError,(PVUSBIROOTHUBPORT pInterface, PVUSBURB pUrb));
429
430 /** Alignment dummy. */
431 RTR3PTR Alignment;
432
433} VUSBIROOTHUBPORT;
434/** VUSBIROOTHUBPORT interface ID. */
435#define VUSBIROOTHUBPORT_IID "e38e2978-7aa2-4860-94b6-9ef4a066d8a0"
436
437
438/** Pointer to a VUSB RootHub connector interface. */
439typedef struct VUSBIROOTHUBCONNECTOR *PVUSBIROOTHUBCONNECTOR;
440/**
441 * The VUSB RootHub connector interface provided by the VBox USB RootHub driver
442 * (up).
443 * Pair with VUSBIROOTHUBPORT.
444 */
445typedef struct VUSBIROOTHUBCONNECTOR
446{
447 /**
448 * Allocates a new URB for a transfer.
449 *
450 * Either submit using pfnSubmitUrb or free using VUSBUrbFree().
451 *
452 * @returns Pointer to a new URB.
453 * @returns NULL on failure - try again later.
454 * This will not fail if the device wasn't found. We'll fail it
455 * at submit time, since that makes the usage of this api simpler.
456 * @param pInterface Pointer to this struct.
457 * @param DstAddress The destination address of the URB.
458 * @param cbData The amount of data space required.
459 * @param cTds The amount of TD space.
460 */
461 DECLR3CALLBACKMEMBER(PVUSBURB, pfnNewUrb,(PVUSBIROOTHUBCONNECTOR pInterface, uint8_t DstAddress, uint32_t cbData, uint32_t cTds));
462
463 /**
464 * Submits a URB for transfer.
465 * The transfer will do asynchronously if possible.
466 *
467 * @returns VBox status code.
468 * @param pInterface Pointer to this struct.
469 * @param pUrb Pointer to the URB returned by pfnNewUrb.
470 * The URB will be freed in case of failure.
471 * @param pLed Pointer to USB Status LED
472 */
473 DECLR3CALLBACKMEMBER(int, pfnSubmitUrb,(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBURB pUrb, struct PDMLED *pLed));
474
475 /**
476 * Call to service asynchronous URB completions in a polling fashion.
477 *
478 * Reaped URBs will be finished by calling the completion callback,
479 * thus there is no return code or input or anything from this function
480 * except for potential state changes elsewhere.
481 *
482 * @returns VINF_SUCCESS if no URBs are pending upon return.
483 * @returns VERR_TIMEOUT if one or more URBs are still in flight upon returning.
484 * @returns Other VBox status code.
485 *
486 * @param pInterface Pointer to this struct.
487 * @param cMillies Number of milliseconds to poll for completion.
488 */
489 DECLR3CALLBACKMEMBER(void, pfnReapAsyncUrbs,(PVUSBIROOTHUBCONNECTOR pInterface, RTMSINTERVAL cMillies));
490
491 /**
492 * Cancels and completes - with CRC failure - all in-flight async URBs.
493 * This is typically done before saving a state.
494 *
495 * @param pInterface Pointer to this struct.
496 */
497 DECLR3CALLBACKMEMBER(void, pfnCancelAllUrbs,(PVUSBIROOTHUBCONNECTOR pInterface));
498
499 /**
500 * Attach the device to the root hub.
501 * The device must not be attached to any hub for this call to succeed.
502 *
503 * @returns VBox status code.
504 * @param pInterface Pointer to this struct.
505 * @param pDevice Pointer to the device (interface) attach.
506 */
507 DECLR3CALLBACKMEMBER(int, pfnAttachDevice,(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBIDEVICE pDevice));
508
509 /**
510 * Detach the device from the root hub.
511 * The device must already be attached for this call to succeed.
512 *
513 * @returns VBox status code.
514 * @param pInterface Pointer to this struct.
515 * @param pDevice Pointer to the device (interface) to detach.
516 */
517 DECLR3CALLBACKMEMBER(int, pfnDetachDevice,(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBIDEVICE pDevice));
518
519} VUSBIROOTHUBCONNECTOR;
520/** VUSBIROOTHUBCONNECTOR interface ID. */
521#define VUSBIROOTHUBCONNECTOR_IID "d9a90c59-e3ff-4dff-9754-844557c3f7a0"
522
523
524#ifdef IN_RING3
525/** @copydoc VUSBIROOTHUBCONNECTOR::pfnNewUrb */
526DECLINLINE(PVUSBURB) VUSBIRhNewUrb(PVUSBIROOTHUBCONNECTOR pInterface, uint32_t DstAddress, uint32_t cbData, uint32_t cTds)
527{
528 return pInterface->pfnNewUrb(pInterface, DstAddress, cbData, cTds);
529}
530
531/** @copydoc VUSBIROOTHUBCONNECTOR::pfnSubmitUrb */
532DECLINLINE(int) VUSBIRhSubmitUrb(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBURB pUrb, struct PDMLED *pLed)
533{
534 return pInterface->pfnSubmitUrb(pInterface, pUrb, pLed);
535}
536
537/** @copydoc VUSBIROOTHUBCONNECTOR::pfnReapAsyncUrbs */
538DECLINLINE(void) VUSBIRhReapAsyncUrbs(PVUSBIROOTHUBCONNECTOR pInterface, RTMSINTERVAL cMillies)
539{
540 pInterface->pfnReapAsyncUrbs(pInterface, cMillies);
541}
542
543/** @copydoc VUSBIROOTHUBCONNECTOR::pfnCancelAllUrbs */
544DECLINLINE(void) VUSBIRhCancelAllUrbs(PVUSBIROOTHUBCONNECTOR pInterface)
545{
546 pInterface->pfnCancelAllUrbs(pInterface);
547}
548
549/** @copydoc VUSBIROOTHUBCONNECTOR::pfnAttachDevice */
550DECLINLINE(int) VUSBIRhAttachDevice(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBIDEVICE pDevice)
551{
552 return pInterface->pfnAttachDevice(pInterface, pDevice);
553}
554
555/** @copydoc VUSBIROOTHUBCONNECTOR::pfnDetachDevice */
556DECLINLINE(int) VUSBIRhDetachDevice(PVUSBIROOTHUBCONNECTOR pInterface, PVUSBIDEVICE pDevice)
557{
558 return pInterface->pfnDetachDevice(pInterface, pDevice);
559}
560#endif /* IN_RING3 */
561
562
563
564/** Pointer to a Root Hub Configuration Interface. */
565typedef struct VUSBIRHCONFIG *PVUSBIRHCONFIG;
566/**
567 * Root Hub Configuration Interface (intended for MAIN).
568 * No interface pair.
569 */
570typedef struct VUSBIRHCONFIG
571{
572 /**
573 * Creates a USB proxy device and attaches it to the root hub.
574 *
575 * @returns VBox status code.
576 * @param pInterface Pointer to the root hub configuration interface structure.
577 * @param pUuid Pointer to the UUID for the new device.
578 * @param fRemote Whether the device must use the VRDP backend.
579 * @param pszAddress OS specific device address.
580 * @param pvBackend An opaque pointer for the backend. Only used by
581 * the VRDP backend so far.
582 */
583 DECLR3CALLBACKMEMBER(int, pfnCreateProxyDevice,(PVUSBIRHCONFIG pInterface, PCRTUUID pUuid, bool fRemote, const char *pszAddress, void *pvBackend));
584
585 /**
586 * Removes a USB proxy device from the root hub and destroys it.
587 *
588 * @returns VBox status code.
589 * @param pInterface Pointer to the root hub configuration interface structure.
590 * @param pUuid Pointer to the UUID for the device.
591 */
592 DECLR3CALLBACKMEMBER(int, pfnDestroyProxyDevice,(PVUSBIRHCONFIG pInterface, PCRTUUID pUuid));
593
594} VUSBIRHCONFIG;
595/** VUSBIRHCONFIG interface ID. */
596#define VUSBIRHCONFIG_IID "c354cd97-e85f-465e-bc12-b58798465f52"
597
598
599#ifdef IN_RING3
600/** @copydoc VUSBIRHCONFIG::pfnCreateProxyDevice */
601DECLINLINE(int) VUSBIRhCreateProxyDevice(PVUSBIRHCONFIG pInterface, PCRTUUID pUuid, bool fRemote, const char *pszAddress, void *pvBackend)
602{
603 return pInterface->pfnCreateProxyDevice(pInterface, pUuid, fRemote, pszAddress, pvBackend);
604}
605
606/** @copydoc VUSBIRHCONFIG::pfnDestroyProxyDevice */
607DECLINLINE(int) VUSBIRhDestroyProxyDevice(PVUSBIRHCONFIG pInterface, PCRTUUID pUuid)
608{
609 return pInterface->pfnDestroyProxyDevice(pInterface, pUuid);
610}
611#endif /* IN_RING3 */
612
613
614
615/**
616 * VUSB device reset completion callback function.
617 * This is called by the reset thread when the reset has been completed.
618 *
619 * @param pDev Pointer to the virtual USB device core.
620 * @param rc The VBox status code of the reset operation.
621 * @param pvUser User specific argument.
622 *
623 * @thread The reset thread or EMT.
624 */
625typedef DECLCALLBACK(void) FNVUSBRESETDONE(PVUSBIDEVICE pDevice, int rc, void *pvUser);
626/** Pointer to a device reset completion callback function (FNUSBRESETDONE). */
627typedef FNVUSBRESETDONE *PFNVUSBRESETDONE;
628
629/**
630 * The state of a VUSB Device.
631 *
632 * @remark The order of these states is vital.
633 */
634typedef enum VUSBDEVICESTATE
635{
636 VUSB_DEVICE_STATE_INVALID = 0,
637 VUSB_DEVICE_STATE_DETACHED,
638 VUSB_DEVICE_STATE_ATTACHED,
639 VUSB_DEVICE_STATE_POWERED,
640 VUSB_DEVICE_STATE_DEFAULT,
641 VUSB_DEVICE_STATE_ADDRESS,
642 VUSB_DEVICE_STATE_CONFIGURED,
643 VUSB_DEVICE_STATE_SUSPENDED,
644 /** The device is being reset. Don't mess with it.
645 * Next states: VUSB_DEVICE_STATE_DEFAULT, VUSB_DEVICE_STATE_DESTROYED
646 */
647 VUSB_DEVICE_STATE_RESET,
648 /** The device has been destroy. */
649 VUSB_DEVICE_STATE_DESTROYED,
650 /** The usual 32-bit hack. */
651 VUSB_DEVICE_STATE_32BIT_HACK = 0x7fffffff
652} VUSBDEVICESTATE;
653
654
655/**
656 * USB Device Interface (up).
657 * No interface pair.
658 */
659typedef struct VUSBIDEVICE
660{
661 /**
662 * Resets the device.
663 *
664 * Since a device reset shall take at least 10ms from the guest point of view,
665 * it must be performed asynchronously. We create a thread which performs this
666 * operation and ensures it will take at least 10ms.
667 *
668 * At times - like init - a synchronous reset is required, this can be done
669 * by passing NULL for pfnDone.
670 *
671 * -- internal stuff, move it --
672 * While the device is being reset it is in the VUSB_DEVICE_STATE_RESET state.
673 * On completion it will be in the VUSB_DEVICE_STATE_DEFAULT state if successful,
674 * or in the VUSB_DEVICE_STATE_DETACHED state if the rest failed.
675 * -- internal stuff, move it --
676 *
677 * @returns VBox status code.
678 * @param pInterface Pointer to this structure.
679 * @param fResetOnLinux Set if we can permit a real reset and a potential logical
680 * device reconnect on linux hosts.
681 * @param pfnDone Pointer to the completion routine. If NULL a synchronous
682 * reset is preformed not respecting the 10ms.
683 * @param pvUser User argument to the completion routine.
684 * @param pVM Pointer to the VM handle if callback in EMT is required. (optional)
685 */
686 DECLR3CALLBACKMEMBER(int, pfnReset,(PVUSBIDEVICE pInterface, bool fResetOnLinux,
687 PFNVUSBRESETDONE pfnDone, void *pvUser, PVM pVM));
688
689 /**
690 * Powers on the device.
691 *
692 * @returns VBox status code.
693 * @param pInterface Pointer to the device interface structure.
694 */
695 DECLR3CALLBACKMEMBER(int, pfnPowerOn,(PVUSBIDEVICE pInterface));
696
697 /**
698 * Powers off the device.
699 *
700 * @returns VBox status code.
701 * @param pInterface Pointer to the device interface structure.
702 */
703 DECLR3CALLBACKMEMBER(int, pfnPowerOff,(PVUSBIDEVICE pInterface));
704
705 /**
706 * Get the state of the device.
707 *
708 * @returns Device state.
709 * @param pInterface Pointer to the device interface structure.
710 */
711 DECLR3CALLBACKMEMBER(VUSBDEVICESTATE, pfnGetState,(PVUSBIDEVICE pInterface));
712
713} VUSBIDEVICE;
714/** VUSBIDEVICE interface ID. */
715#define VUSBIDEVICE_IID "88732dd3-0ccd-4625-b040-48804ac7a217"
716
717
718#ifdef IN_RING3
719/**
720 * Resets the device.
721 *
722 * Since a device reset shall take at least 10ms from the guest point of view,
723 * it must be performed asynchronously. We create a thread which performs this
724 * operation and ensures it will take at least 10ms.
725 *
726 * At times - like init - a synchronous reset is required, this can be done
727 * by passing NULL for pfnDone.
728 *
729 * -- internal stuff, move it --
730 * While the device is being reset it is in the VUSB_DEVICE_STATE_RESET state.
731 * On completion it will be in the VUSB_DEVICE_STATE_DEFAULT state if successful,
732 * or in the VUSB_DEVICE_STATE_DETACHED state if the rest failed.
733 * -- internal stuff, move it --
734 *
735 * @returns VBox status code.
736 * @param pInterface Pointer to the device interface structure.
737 * @param fResetOnLinux Set if we can permit a real reset and a potential logical
738 * device reconnect on linux hosts.
739 * @param pfnDone Pointer to the completion routine. If NULL a synchronous
740 * reset is preformed not respecting the 10ms.
741 * @param pvUser User argument to the completion routine.
742 * @param pVM Pointer to the VM handle if callback in EMT is required. (optional)
743 */
744DECLINLINE(int) VUSBIDevReset(PVUSBIDEVICE pInterface, bool fResetOnLinux, PFNVUSBRESETDONE pfnDone, void *pvUser, PVM pVM)
745{
746 return pInterface->pfnReset(pInterface, fResetOnLinux, pfnDone, pvUser, pVM);
747}
748
749/**
750 * Powers on the device.
751 *
752 * @returns VBox status code.
753 * @param pInterface Pointer to the device interface structure.
754 */
755DECLINLINE(int) VUSBIDevPowerOn(PVUSBIDEVICE pInterface)
756{
757 return pInterface->pfnPowerOn(pInterface);
758}
759
760/**
761 * Powers off the device.
762 *
763 * @returns VBox status code.
764 * @param pInterface Pointer to the device interface structure.
765 */
766DECLINLINE(int) VUSBIDevPowerOff(PVUSBIDEVICE pInterface)
767{
768 return pInterface->pfnPowerOff(pInterface);
769}
770
771/**
772 * Get the state of the device.
773 *
774 * @returns Device state.
775 * @param pInterface Pointer to the device interface structure.
776 */
777DECLINLINE(VUSBDEVICESTATE) VUSBIDevGetState(PVUSBIDEVICE pInterface)
778{
779 return pInterface->pfnGetState(pInterface);
780}
781#endif /* IN_RING3 */
782
783
784/** @name URB
785 * @{ */
786
787/**
788 * VUSB Transfer status codes.
789 */
790typedef enum VUSBSTATUS
791{
792 /** Transer was ok. */
793 VUSBSTATUS_OK = 0,
794 /** Transfer stalled, endpoint halted. */
795 VUSBSTATUS_STALL,
796 /** Device not responding. */
797 VUSBSTATUS_DNR,
798 /** CRC error. */
799 VUSBSTATUS_CRC,
800 /** Data overrun error. */
801 VUSBSTATUS_DATA_UNDERRUN,
802 /** Data overrun error. */
803 VUSBSTATUS_DATA_OVERRUN,
804 /** The isochronous buffer hasn't been touched. */
805 VUSBSTATUS_NOT_ACCESSED,
806 /** Invalid status. */
807 VUSBSTATUS_INVALID = 0x7f
808} VUSBSTATUS;
809
810
811/**
812 * VUSB Transfer types.
813 */
814typedef enum VUSBXFERTYPE
815{
816 /** Control message. Used to represent a single control transfer. */
817 VUSBXFERTYPE_CTRL = 0,
818 /* Isochronous transfer. */
819 VUSBXFERTYPE_ISOC,
820 /** Bulk transfer. */
821 VUSBXFERTYPE_BULK,
822 /** Interrupt transfer. */
823 VUSBXFERTYPE_INTR,
824 /** Complete control message. Used to represent an entire control message. */
825 VUSBXFERTYPE_MSG,
826 /** Invalid transfer type. */
827 VUSBXFERTYPE_INVALID = 0x7f
828} VUSBXFERTYPE;
829
830
831/**
832 * VUSB transfer direction.
833 */
834typedef enum VUSBDIRECTION
835{
836 /** Setup */
837 VUSBDIRECTION_SETUP = 0,
838#define VUSB_DIRECTION_SETUP VUSBDIRECTION_SETUP
839 /** In - Device to host. */
840 VUSBDIRECTION_IN = 1,
841#define VUSB_DIRECTION_IN VUSBDIRECTION_IN
842 /** Out - Host to device. */
843 VUSBDIRECTION_OUT = 2,
844#define VUSB_DIRECTION_OUT VUSBDIRECTION_OUT
845 /** Invalid direction */
846 VUSBDIRECTION_INVALID = 0x7f
847} VUSBDIRECTION;
848
849/**
850 * The URB states
851 */
852typedef enum VUSBURBSTATE
853{
854 /** The usual invalid state. */
855 VUSBURBSTATE_INVALID = 0,
856 /** The URB is free, i.e. not in use.
857 * Next state: ALLOCATED */
858 VUSBURBSTATE_FREE,
859 /** The URB is allocated, i.e. being prepared for submission.
860 * Next state: FREE, IN_FLIGHT */
861 VUSBURBSTATE_ALLOCATED,
862 /** The URB is in flight.
863 * Next state: REAPED, CANCELLED */
864 VUSBURBSTATE_IN_FLIGHT,
865 /** The URB has been reaped and is being completed.
866 * Next state: FREE */
867 VUSBURBSTATE_REAPED,
868 /** The URB has been cancelled and is awaiting reaping and immediate freeing.
869 * Next state: FREE */
870 VUSBURBSTATE_CANCELLED,
871 /** The end of the valid states (exclusive). */
872 VUSBURBSTATE_END,
873 /** The usual 32-bit blow up. */
874 VUSBURBSTATE_32BIT_HACK = 0x7fffffff
875} VUSBURBSTATE;
876
877
878/**
879 * Information about a isochronous packet.
880 */
881typedef struct VUSBURBISOCPKT
882{
883 /** The size of the packet.
884 * IN: The packet size. I.e. the number of bytes to the next packet or end of buffer.
885 * OUT: The actual size transfered. */
886 uint16_t cb;
887 /** The offset of the packet. (Relative to VUSBURB::abData[0].)
888 * OUT: This can be changed by the USB device if it does some kind of buffer squeezing. */
889 uint16_t off;
890 /** The status of the transfer.
891 * IN: VUSBSTATUS_INVALID
892 * OUT: VUSBSTATUS_INVALID if nothing was done, otherwise the correct status. */
893 VUSBSTATUS enmStatus;
894} VUSBURBISOCPKT;
895/** Pointer to a isochronous packet. */
896typedef VUSBURBISOCPKT *PVUSBURBISOCPTK;
897/** Pointer to a const isochronous packet. */
898typedef const VUSBURBISOCPKT *PCVUSBURBISOCPKT;
899
900/**
901 * Asynchronous USB request descriptor
902 */
903typedef struct VUSBURB
904{
905 /** URB magic value. */
906 uint32_t u32Magic;
907 /** The USR state. */
908 VUSBURBSTATE enmState;
909 /** URB description, can be null. intended for logging. */
910 char *pszDesc;
911
912 /** The VUSB data. */
913 struct VUSBURBVUSB
914 {
915 /** URB chain pointer. */
916 PVUSBURB pNext;
917 /** URB chain pointer. */
918 PVUSBURB *ppPrev;
919 /** Pointer to the original for control messages. */
920 PVUSBURB pCtrlUrb;
921 /** Pointer to the VUSB device.
922 * This may be NULL if the destination address is invalid. */
923 struct VUSBDEV *pDev;
924 /** Sepcific to the pfnFree function. */
925 void *pvFreeCtx;
926 /**
927 * Callback which will free the URB once it's reaped and completed.
928 * @param pUrb The URB.
929 */
930 DECLCALLBACKMEMBER(void, pfnFree)(PVUSBURB pUrb);
931 /** Submit timestamp. (logging only) */
932 uint64_t u64SubmitTS;
933 /** The allocated data length. */
934 uint32_t cbDataAllocated;
935 /** The allocated TD length. */
936 uint32_t cTdsAllocated;
937 } VUsb;
938
939 /** The host controller data. */
940 struct VUSBURBHCI
941 {
942 /** The endpoint descriptor address. */
943 RTGCPHYS32 EdAddr;
944 /** Number of Tds in the array. */
945 uint32_t cTds;
946 /** Pointer to an array of TD info items.*/
947 struct VUSBURBHCITD
948 {
949 /** Type of TD (private) */
950 uint32_t TdType;
951 /** The address of the */
952 RTGCPHYS32 TdAddr;
953 /** A copy of the TD. */
954 uint32_t TdCopy[16];
955 } *paTds;
956 /** URB chain pointer. */
957 PVUSBURB pNext;
958 /** When this URB was created.
959 * (Used for isochronous frames and for logging.) */
960 uint32_t u32FrameNo;
961 /** Flag indicating that the TDs have been unlinked. */
962 bool fUnlinked;
963 } Hci;
964
965 /** The device data. */
966 struct VUSBURBDEV
967 {
968 /** Pointer to private device specific data. */
969 void *pvPrivate;
970 /** Used by the device when linking the URB in some list of its own. */
971 PVUSBURB pNext;
972 } Dev;
973
974 /** The USB device instance this belongs to.
975 * This is NULL if the device address is invalid, in which case this belongs to the hub. */
976 PPDMUSBINS pUsbIns;
977 /** The device address.
978 * This is set at allocation time. */
979 uint8_t DstAddress;
980
981 /** The endpoint.
982 * IN: Must be set before submitting the URB.
983 * @remark This does not have the high bit (direction) set! */
984 uint8_t EndPt;
985 /** The transfer type.
986 * IN: Must be set before submitting the URB. */
987 VUSBXFERTYPE enmType;
988 /** The transfer direction.
989 * IN: Must be set before submitting the URB. */
990 VUSBDIRECTION enmDir;
991 /** Indicates whether it is OK to receive/send less data than requested.
992 * IN: Must be initialized before submitting the URB. */
993 bool fShortNotOk;
994 /** The transfer status.
995 * OUT: This is set when reaping the URB. */
996 VUSBSTATUS enmStatus;
997
998 /** The number of isochronous packets describe in aIsocPkts.
999 * This is ignored when enmType isn't VUSBXFERTYPE_ISOC. */
1000 uint32_t cIsocPkts;
1001 /** The iso packets within abData.
1002 * This is ignored when enmType isn't VUSBXFERTYPE_ISOC. */
1003 VUSBURBISOCPKT aIsocPkts[8];
1004
1005 /** The message length.
1006 * IN: The amount of data to send / receive - set at allocation time.
1007 * OUT: The amount of data sent / received. */
1008 uint32_t cbData;
1009 /** The message data.
1010 * IN: On host to device transfers, the data to send.
1011 * OUT: On device to host transfers, the data to received. */
1012 uint8_t abData[8*_1K];
1013} VUSBURB;
1014
1015/** The magic value of a valid VUSBURB. (Murakami Haruki) */
1016#define VUSBURB_MAGIC UINT32_C(0x19490112)
1017
1018/** @} */
1019
1020
1021/** @} */
1022
1023RT_C_DECLS_END
1024
1025#endif
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