source: mainline/uspace/drv/bus/usb/xhci/rh.h@ 27b0ea0

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

Refactoring. Renamed device array to better reflect its indexing.

  • Property mode set to 100644
File size: 2.9 KB
RevLine 
[7bd99bf]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
[d32d51d]39#include <usb/host/usb_transfer_batch.h>
[20eaa82]40#include <usb/host/bus.h>
[2cf28b9]41
[816335c]42#include "hw_struct/regs.h"
[2cf28b9]43#include "endpoint.h"
[816335c]44
45typedef struct xhci_hc xhci_hc_t;
[20eaa82]46typedef struct ddf_dev ddf_dev_t;
[d32d51d]47
[816335c]48/**
49 * xHCI lets the controller define speeds of ports it controls.
50 */
51typedef struct xhci_port_speed {
52 char name [4];
53 uint8_t major, minor;
54 uint64_t rx_bps, tx_bps;
[f668d60]55 usb_speed_t usb_speed;
[816335c]56} xhci_port_speed_t;
57
[867b375]58typedef struct hcd_roothub hcd_roothub_t;
[2770b66]59typedef struct xhci_bus xhci_bus_t;
[867b375]60
[d32d51d]61/* XHCI root hub instance */
62typedef struct {
[816335c]63 /** Host controller */
64 xhci_hc_t *hc;
65
[20eaa82]66 /* Root for the device tree */
[2cf28b9]67 xhci_device_t device;
[20eaa82]68
69 /* We need this to attach children to */
70 ddf_dev_t *hc_device;
71
[07c08ea]72 /** Interrupt transfer waiting for an actual interrupt to occur */
73 usb_transfer_batch_t *unfinished_interrupt_transfer;
[9876e34]74
[eaf5e86]75 /* Number of hub ports. */
[9876e34]76 uint8_t max_ports;
[766043c]77
78 /* Device pointers connected to RH ports or NULL. (size is `max_ports`) */
[d33dc780]79 xhci_device_t **devices_by_port;
[d32d51d]80} xhci_rh_t;
81
[0f6b50f]82int xhci_rh_init(xhci_rh_t *, xhci_hc_t *, ddf_dev_t *);
[d32d51d]83int xhci_rh_fini(xhci_rh_t *);
[dcf0597]84const xhci_port_speed_t *xhci_rh_get_port_speed(xhci_rh_t *, uint8_t);
85int xhci_rh_reset_port(xhci_rh_t *, uint8_t);
[7bd99bf]86
[dcf0597]87int xhci_rh_handle_port_status_change_event(xhci_hc_t *, xhci_trb_t *);
88void xhci_rh_handle_port_change(xhci_rh_t *);
[17f24d9]89
[2770b66]90int xhci_rh_address_device(xhci_rh_t *rh, device_t *dev, xhci_bus_t *bus);
[867b375]91
[7bd99bf]92#endif
[c8bb7090]93
94/**
95 * @}
96 */
Note: See TracBrowser for help on using the repository browser.