source: mainline/uspace/drv/bus/usb/usbhub/port.h@ 4e732f1a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 4e732f1a was 0918382f, checked in by Jan Vesely <jano.vesely@…>, 12 years ago

usb: Switch to using port number as device identifier.

Port number info will be needed for HS SPLIT transactions. Moreover,
it can be used to produce predictable, persistent device names.

Switch port_number from size_t to unsigned. There are max 256 ports so
even short would be enough.

  • Property mode set to 100644
File size: 3.2 KB
Line 
1/*
2 * Copyright (c) 2011 Vojtech Horky
3 * Copyright (c) 2011 Jan Vesely
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * - Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * - The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29/** @addtogroup drvusbhub
30 * @{
31 */
32/** @file
33 * Hub ports related functions.
34 */
35#ifndef DRV_USBHUB_PORT_H
36#define DRV_USBHUB_PORT_H
37
38#include <usb/dev/driver.h>
39#include <usb/classes/hub.h>
40#include <usb_iface.h>
41
42typedef struct usb_hub_dev usb_hub_dev_t;
43
44/** Information about single port on a hub. */
45typedef struct {
46 /** Port number as reported in descriptors. */
47 unsigned port_number;
48 /** Device communication pipe. */
49 usb_pipe_t *control_pipe;
50 /** Mutex needed not only by CV for checking port reset. */
51 fibril_mutex_t mutex;
52 /** CV for waiting to port reset completion. */
53 fibril_condvar_t reset_cv;
54 /** Whether port reset is completed.
55 * Guarded by @c reset_mutex.
56 */
57 bool reset_completed;
58 /** Whether to announce the port reset as successful. */
59 bool reset_okay;
60 /** Device reported to USB bus driver */
61 bool device_attached;
62} usb_hub_port_t;
63
64/** Initialize hub port information.
65 *
66 * @param port Port to be initialized.
67 */
68static inline void usb_hub_port_init(usb_hub_port_t *port, unsigned port_number,
69 usb_pipe_t *control_pipe)
70{
71 assert(port);
72 port->port_number = port_number;
73 port->control_pipe = control_pipe;
74 port->reset_completed = false;
75 port->reset_okay = false;
76 port->device_attached = false;
77 fibril_mutex_initialize(&port->mutex);
78 fibril_condvar_initialize(&port->reset_cv);
79}
80int usb_hub_port_fini(usb_hub_port_t *port, usb_hub_dev_t *hub);
81int usb_hub_port_clear_feature(
82 usb_hub_port_t *port, usb_hub_class_feature_t feature);
83int usb_hub_port_set_feature(
84 usb_hub_port_t *port, usb_hub_class_feature_t feature);
85void usb_hub_port_reset_fail(usb_hub_port_t *port);
86void usb_hub_port_process_interrupt(usb_hub_port_t *port, usb_hub_dev_t *hub);
87
88#endif
89/**
90 * @}
91 */
Note: See TracBrowser for help on using the repository browser.