source: mainline/uspace/lib/usbhost/include/usb/host/hcd.h@ 8fc61c8

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 8fc61c8 was 4e732f1a, checked in by Jan Vesely <jano.vesely@…>, 12 years ago

usb: Add support for multiple packets per microframe.

  • Property mode set to 100644
File size: 4.2 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>
[4cf5b8e0]40#include <usb/host/usb_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>
46#include <sys/types.h>
[45d105a]47
48typedef struct hcd hcd_t;
49
[f29931c]50typedef int (*schedule_hook_t)(hcd_t *, usb_transfer_batch_t *);
51typedef int (*ep_add_hook_t)(hcd_t *, endpoint_t *);
52typedef void (*ep_remove_hook_t)(hcd_t *, endpoint_t *);
[7191992]53typedef void (*interrupt_hook_t)(hcd_t *, uint32_t);
[e26a9d95]54typedef int (*status_hook_t)(hcd_t *, uint32_t *);
[f29931c]55
[9348862]56typedef struct {
[4dfc905]57 /** Device specific driver data. */
[9348862]58 void *data;
[4dfc905]59 /** Transfer scheduling, implement in device driver. */
[f29931c]60 schedule_hook_t schedule;
[4dfc905]61 /** Hook called upon registering new endpoint. */
[f29931c]62 ep_add_hook_t ep_add_hook;
[4dfc905]63 /** Hook called upon removing of an endpoint. */
[f29931c]64 ep_remove_hook_t ep_remove_hook;
[7191992]65 /** Hook to be called on device interrupt, passes ARG1 */
66 interrupt_hook_t irq_hook;
[e26a9d95]67 /** Periodic polling hook */
68 status_hook_t status_hook;
[9348862]69} hc_driver_t;
70
71/** Generic host controller driver structure. */
72struct hcd {
73 /** Endpoint manager. */
[4cf5b8e0]74 usb_bus_t bus;
[9348862]75
76 /** Driver implementation */
77 hc_driver_t driver;
[3e200736]78
79 /** Interrupt replacement fibril */
80 fid_t polling_fibril;
[45d105a]81};
[77ad86c]82
[21be46a]83void hcd_init(hcd_t *hcd, usb_speed_t max_speed, size_t bandwidth,
84 bw_count_func_t bw_count);
[77ad86c]85
[4daee7a]86static inline void hcd_set_implementation(hcd_t *hcd, void *data,
[7191992]87 schedule_hook_t schedule, ep_add_hook_t add_hook, ep_remove_hook_t rem_hook,
[e26a9d95]88 interrupt_hook_t irq_hook, status_hook_t status_hook)
[4daee7a]89{
90 assert(hcd);
[9348862]91 hcd->driver.data = data;
92 hcd->driver.schedule = schedule;
93 hcd->driver.ep_add_hook = add_hook;
94 hcd->driver.ep_remove_hook = rem_hook;
[7191992]95 hcd->driver.irq_hook = irq_hook;
[e26a9d95]96 hcd->driver.status_hook = status_hook;
[4daee7a]97}
98
[b4c1c95]99usb_address_t hcd_request_address(hcd_t *hcd, usb_speed_t speed);
100
101int hcd_release_address(hcd_t *hcd, usb_address_t address);
102
103int hcd_reserve_default_address(hcd_t *hcd, usb_speed_t speed);
104
[237df2f]105static inline int hcd_release_default_address(hcd_t *hcd)
[b4c1c95]106{
107 return hcd_release_address(hcd, USB_ADDRESS_DEFAULT);
108}
109
[0816c2e]110int hcd_add_ep(hcd_t *hcd, usb_target_t target, usb_direction_t dir,
[4e732f1a]111 usb_transfer_type_t type, size_t max_packet_size, unsigned packets,
112 size_t size, usb_address_t tt_address, unsigned tt_port);
[0816c2e]113
114int hcd_remove_ep(hcd_t *hcd, usb_target_t target, usb_direction_t dir);
115
[3c4663e]116int hcd_send_batch(hcd_t *hcd, usb_target_t target, usb_direction_t direction,
[d9b2c73]117 void *data, size_t size, uint64_t setup_data,
118 usbhc_iface_transfer_in_callback_t in,
119 usbhc_iface_transfer_out_callback_t out, void *arg, const char* name);
[9c7ed9c]120
[237df2f]121ssize_t hcd_send_batch_sync(hcd_t *hcd, usb_target_t target,
122 usb_direction_t dir, void *data, size_t size, uint64_t setup_data,
123 const char* name);
124
[45d105a]125#endif
126/**
127 * @}
128 */
Note: See TracBrowser for help on using the repository browser.