source: mainline/uspace/drv/bus/usb/xhci/bus.c@ e454d9c

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since e454d9c was 682c9354, checked in by Ondřej Hlavatý <aearsis@…>, 8 years ago

xhci: move all real functionality from bus to device/endpoint/transfers

  • Property mode set to 100644
File size: 2.9 KB
Line 
1/*
2 * Copyright (c) 2017 Ondrej Hlavaty <aearsis@eideo.cz>
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/** @addtogroup libusbhost
29 * @{
30 */
31/** @file
32 * xHCI bus interface.
33 */
34
35#include <usb/descriptor.h>
36
37#include "hc.h"
38#include "device.h"
39#include "endpoint.h"
40#include "transfers.h"
41
42#include "bus.h"
43
44
45static const bus_ops_t xhci_bus_ops = {
46 .interrupt = hc_interrupt,
47 .status = hc_status,
48
49 .device_enumerate = xhci_device_enumerate,
50 .device_gone = xhci_device_gone,
51 .device_online = xhci_device_online,
52 .device_offline = xhci_device_offline,
53
54 .endpoint_create = xhci_endpoint_create,
55 .endpoint_destroy = xhci_endpoint_destroy,
56 .endpoint_register = xhci_endpoint_register,
57 .endpoint_unregister = xhci_endpoint_unregister,
58
59 .batch_schedule = xhci_transfer_schedule,
60 .batch_create = xhci_transfer_create,
61 .batch_destroy = xhci_transfer_destroy,
62};
63
64/** Initialize XHCI bus.
65 * @param[in] bus Allocated XHCI bus to initialize.
66 * @param[in] hc Associated host controller, which manages the bus.
67 *
68 * @return Error code.
69 */
70int xhci_bus_init(xhci_bus_t *bus, xhci_hc_t *hc)
71{
72 assert(bus);
73
74 bus_init(&bus->base, sizeof(xhci_device_t));
75
76 bus->devices_by_slot = calloc(hc->max_slots, sizeof(xhci_device_t *));
77 if (!bus->devices_by_slot)
78 return ENOMEM;
79
80 bus->hc = hc;
81 bus->base.ops = &xhci_bus_ops;
82 return EOK;
83}
84
85/** Finalize XHCI bus.
86 * @param[in] bus XHCI bus to finalize.
87 */
88void xhci_bus_fini(xhci_bus_t *bus)
89{
90 // FIXME: Ensure there are no more devices?
91 free(bus->devices_by_slot);
92 // FIXME: Something else we forgot?
93}
94
95/**
96 * @}
97 */
Note: See TracBrowser for help on using the repository browser.