source: mainline/uspace/lib/usbhost/include/usb/host/ddf_helpers.h@ e4d7363

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

usbhost: refactor the initialization

Before that, drivers had to setup MMIO range multiple times, or even parse hw
resources themselves again. The former init method was split in half - init and
start. Init shall allocate and initialize inner structures, start shall start
the HC.

In the XHCI it is demonstrated how to isolate inner HC implementation from the
fact this driver is using libusbhost. It adds some boilerplate code, but
I think it leads to cleaner design.

  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2012 Jan Vesely
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 libusbhost
30 * @{
31 */
32/** @file
33 *
34 */
35
36#ifndef LIBUSBHOST_HOST_DDF_HELPERS_H
37#define LIBUSBHOST_HOST_DDF_HELPERS_H
38
39#include <usb/host/hcd.h>
40#include <usb/host/usb_bus.h>
41#include <usb/usb.h>
42
43#include <ddf/driver.h>
44#include <ddf/interrupt.h>
45#include <device/hw_res_parsed.h>
46
47typedef int (*driver_init_t)(hcd_t *, const hw_res_list_parsed_t *);
48typedef int (*irq_code_gen_t)(irq_code_t *, hcd_t *, const hw_res_list_parsed_t *);
49typedef int (*claim_t)(hcd_t *, ddf_dev_t *);
50typedef int (*driver_start_t)(hcd_t *, bool irq);
51
52typedef void (*driver_stop_t)(hcd_t *);
53typedef void (*driver_fini_t)(hcd_t *);
54
55/**
56 * All callbacks are optional.
57 */
58typedef struct {
59 hcd_ops_t ops;
60 usb_speed_t hc_speed;
61 const char *name;
62
63 interrupt_handler_t *irq_handler; /**< Handler of IRQ. Do have generic implementation. */
64
65 /* Initialization sequence: */
66 driver_init_t init; /**< Initialize internal structures, memory */
67 claim_t claim; /**< Claim device from BIOS */
68 irq_code_gen_t irq_code_gen; /**< Generate IRQ handling code */
69 driver_start_t start; /**< Start the HC */
70
71 /* Destruction sequence: */
72 driver_stop_t stop; /**< Stop the HC (counterpart of start) */
73 driver_fini_t fini; /**< Destroy internal structures (counterpart of init) */
74} ddf_hc_driver_t;
75
76int hcd_ddf_add_hc(ddf_dev_t *device, const ddf_hc_driver_t *driver);
77
78int hcd_ddf_setup_hc(ddf_dev_t *device, usb_speed_t max_speed,
79 size_t bw, bw_count_func_t bw_count);
80void hcd_ddf_clean_hc(ddf_dev_t *device);
81int hcd_ddf_setup_root_hub(ddf_dev_t *device);
82
83hcd_t *dev_to_hcd(ddf_dev_t *dev);
84
85int hcd_ddf_enable_interrupts(ddf_dev_t *device);
86int hcd_ddf_get_registers(ddf_dev_t *device, hw_res_list_parsed_t *hw_res);
87int hcd_ddf_setup_interrupts(ddf_dev_t *device,
88 const hw_res_list_parsed_t *hw_res,
89 interrupt_handler_t handler,
90 irq_code_gen_t gen_irq_code);
91void ddf_hcd_gen_irq_handler(ipc_callid_t iid, ipc_call_t *call, ddf_dev_t *dev);
92
93#endif
94
95/**
96 * @}
97 */
Note: See TracBrowser for help on using the repository browser.