source: mainline/uspace/lib/usbhost/include/usb/host/hcd.h@ 41924f30

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

WIP usbhost refactoring

This commit replaces callbacks with more systematic virtual-like inheritance-like solution. Currently breaks build of HelenOS, but both xhci and usbhost are buildable. More refactoring follows…

  • Property mode set to 100644
File size: 3.9 KB
RevLine 
[45d105a]1/*
2 * Copyright (c) 2011 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 */
[77ad86c]35
[45d105a]36#ifndef LIBUSBHOST_HOST_HCD_H
37#define LIBUSBHOST_HOST_HCD_H
38
[8d2e251]39#include <usb/host/endpoint.h>
[41924f30]40#include <usb/host/bus.h>
[f58ef61]41#include <usb/host/usb_transfer_batch.h>
[8d2e251]42#include <usb/usb.h>
43
44#include <assert.h>
45#include <usbhc_iface.h>
[8d2dd7f2]46#include <stddef.h>
47#include <stdint.h>
[45d105a]48
49typedef struct hcd hcd_t;
50
[f29931c]51typedef int (*schedule_hook_t)(hcd_t *, usb_transfer_batch_t *);
52typedef int (*ep_add_hook_t)(hcd_t *, endpoint_t *);
53typedef void (*ep_remove_hook_t)(hcd_t *, endpoint_t *);
[7191992]54typedef void (*interrupt_hook_t)(hcd_t *, uint32_t);
[e26a9d95]55typedef int (*status_hook_t)(hcd_t *, uint32_t *);
[f29931c]56
[9348862]57typedef struct {
[4dfc905]58 /** Transfer scheduling, implement in device driver. */
[f29931c]59 schedule_hook_t schedule;
[4dfc905]60 /** Hook called upon registering new endpoint. */
[f29931c]61 ep_add_hook_t ep_add_hook;
[4dfc905]62 /** Hook called upon removing of an endpoint. */
[f29931c]63 ep_remove_hook_t ep_remove_hook;
[7191992]64 /** Hook to be called on device interrupt, passes ARG1 */
65 interrupt_hook_t irq_hook;
[e26a9d95]66 /** Periodic polling hook */
67 status_hook_t status_hook;
[b5f813c]68} hcd_ops_t;
[9348862]69
70/** Generic host controller driver structure. */
71struct hcd {
72 /** Endpoint manager. */
[41924f30]73 bus_t *bus;
[9348862]74
[3e200736]75 /** Interrupt replacement fibril */
76 fid_t polling_fibril;
[b5f813c]77
78 /** Driver implementation */
79 hcd_ops_t ops;
[41924f30]80
[b5f813c]81 /** Device specific driver data. */
82 void * driver_data;
[45d105a]83};
[77ad86c]84
[41924f30]85extern void hcd_init(hcd_t *);
[77ad86c]86
[4daee7a]87static inline void hcd_set_implementation(hcd_t *hcd, void *data,
[41924f30]88 const hcd_ops_t *ops, bus_t *bus)
[b5f813c]89{
90 assert(hcd);
91 if (ops) {
92 hcd->driver_data = data;
93 hcd->ops = *ops;
[41924f30]94 hcd->bus = bus;
[b5f813c]95 } else {
96 memset(&hcd->ops, 0, sizeof(hcd->ops));
97 }
98}
99
100static inline void * hcd_get_driver_data(hcd_t *hcd)
[4daee7a]101{
102 assert(hcd);
[b5f813c]103 return hcd->driver_data;
[4daee7a]104}
105
[58563585]106extern usb_address_t hcd_request_address(hcd_t *, usb_speed_t);
[b4c1c95]107
[58563585]108extern int hcd_release_address(hcd_t *, usb_address_t);
[b4c1c95]109
[58563585]110extern int hcd_reserve_default_address(hcd_t *, usb_speed_t);
[b4c1c95]111
[237df2f]112static inline int hcd_release_default_address(hcd_t *hcd)
[b4c1c95]113{
114 return hcd_release_address(hcd, USB_ADDRESS_DEFAULT);
115}
116
[58563585]117extern int hcd_add_ep(hcd_t *, usb_target_t, usb_direction_t,
118 usb_transfer_type_t, size_t, unsigned int, size_t, usb_address_t,
119 unsigned int);
[0816c2e]120
[58563585]121extern int hcd_remove_ep(hcd_t *, usb_target_t, usb_direction_t);
[0816c2e]122
[58563585]123extern int hcd_send_batch(hcd_t *, usb_target_t, usb_direction_t, void *,
124 size_t, uint64_t, usbhc_iface_transfer_in_callback_t,
125 usbhc_iface_transfer_out_callback_t, void *, const char *);
[9c7ed9c]126
[58563585]127extern ssize_t hcd_send_batch_sync(hcd_t *, usb_target_t, usb_direction_t,
128 void *, size_t, uint64_t, const char *);
[237df2f]129
[45d105a]130#endif
[58563585]131
[45d105a]132/**
133 * @}
134 */
Note: See TracBrowser for help on using the repository browser.