source: mainline/uspace/drv/bus/usb/xhci/rh.h@ 816f5f4

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 816f5f4 was 2770b66, checked in by Petr Manek <petr.manek@…>, 8 years ago

Fixed few bugs related to control transfers and some deadlocks. Registering control endpoint with HelenOS. Can read out device descriptors through MID and initialize mouse driver!

  • Property mode set to 100644
File size: 2.8 KB
Line 
1/*
2 * Copyright (c) 2017 Michal Staruch
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup drvusbxhci
30 * @{
31 */
32/** @file
33 * @brief The roothub structures abstraction.
34 */
35
36#ifndef XHCI_RH_H
37#define XHCI_RH_H
38
39#include <usb/host/usb_transfer_batch.h>
40#include <usb/host/bus.h>
41#include "hw_struct/regs.h"
42
43typedef struct xhci_hc xhci_hc_t;
44typedef struct ddf_dev ddf_dev_t;
45
46/**
47 * xHCI lets the controller define speeds of ports it controls.
48 */
49typedef struct xhci_port_speed {
50 char name [4];
51 uint8_t major, minor;
52 uint64_t rx_bps, tx_bps;
53} xhci_port_speed_t;
54
55typedef struct hcd_roothub hcd_roothub_t;
56typedef struct xhci_bus xhci_bus_t;
57
58/* XHCI root hub instance */
59typedef struct {
60 /** Host controller */
61 xhci_hc_t *hc;
62
63 /* Root for the device tree */
64 device_t device;
65
66 /* We need this to attach children to */
67 ddf_dev_t *hc_device;
68
69 /** Port speeds reported from HC */
70 xhci_port_speed_t speeds [16];
71
72 /** Interrupt transfer waiting for an actual interrupt to occur */
73 usb_transfer_batch_t *unfinished_interrupt_transfer;
74
75 /* Number of hub ports. */
76 uint8_t max_ports;
77} xhci_rh_t;
78
79int xhci_rh_init(xhci_rh_t *, xhci_hc_t *);
80int xhci_rh_fini(xhci_rh_t *);
81const xhci_port_speed_t *xhci_rh_get_port_speed(xhci_rh_t *, uint8_t);
82int xhci_rh_reset_port(xhci_rh_t *, uint8_t);
83
84int xhci_rh_handle_port_status_change_event(xhci_hc_t *, xhci_trb_t *);
85void xhci_rh_handle_port_change(xhci_rh_t *);
86
87int xhci_rh_address_device(xhci_rh_t *rh, device_t *dev, xhci_bus_t *bus);
88
89#endif
90
91/**
92 * @}
93 */
Note: See TracBrowser for help on using the repository browser.