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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 5fe3f954 was 45457265, checked in by Jenda <jenda.jzqk73@…>, 8 years ago

errno_t all the things!

  • Property mode set to 100644
File size: 2.9 KB
RevLine 
[a5976973]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
[682c9354]32 * xHCI bus interface.
[a5976973]33 */
34
[17c5e62]35#include <usb/descriptor.h>
[a5976973]36
[2cf28b9]37#include "hc.h"
[682c9354]38#include "device.h"
[a5976973]39#include "endpoint.h"
[5fd9c30]40#include "transfers.h"
[a5976973]41
[682c9354]42#include "bus.h"
[0206d35]43
[5fd9c30]44
[a5976973]45static const bus_ops_t xhci_bus_ops = {
[32fb6bce]46 .interrupt = hc_interrupt,
47 .status = hc_status,
[eb928c4]48
[682c9354]49 .device_enumerate = xhci_device_enumerate,
50 .device_gone = xhci_device_gone,
51 .device_online = xhci_device_online,
52 .device_offline = xhci_device_offline,
[eb928c4]53
[682c9354]54 .endpoint_create = xhci_endpoint_create,
55 .endpoint_destroy = xhci_endpoint_destroy,
56 .endpoint_register = xhci_endpoint_register,
57 .endpoint_unregister = xhci_endpoint_unregister,
[eb928c4]58
[682c9354]59 .batch_schedule = xhci_transfer_schedule,
[eb928c4]60 .batch_create = xhci_transfer_create,
61 .batch_destroy = xhci_transfer_destroy,
[a5976973]62};
63
[95a62dc]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 */
[45457265]70errno_t xhci_bus_init(xhci_bus_t *bus, xhci_hc_t *hc)
[a5976973]71{
72 assert(bus);
73
[32fb6bce]74 bus_init(&bus->base, sizeof(xhci_device_t));
[2b61945]75
76 bus->devices_by_slot = calloc(hc->max_slots, sizeof(xhci_device_t *));
77 if (!bus->devices_by_slot)
78 return ENOMEM;
[a5976973]79
[25251bb]80 bus->hc = hc;
[6832245]81 bus->base.ops = &xhci_bus_ops;
[a5976973]82 return EOK;
83}
[a8435eb5]84
[95a62dc]85/** Finalize XHCI bus.
86 * @param[in] bus XHCI bus to finalize.
87 */
[a8435eb5]88void xhci_bus_fini(xhci_bus_t *bus)
89{
[eb928c4]90 // FIXME: Ensure there are no more devices?
91 free(bus->devices_by_slot);
[95a62dc]92 // FIXME: Something else we forgot?
[a8435eb5]93}
[20eaa82]94
[a5976973]95/**
96 * @}
97 */
Note: See TracBrowser for help on using the repository browser.