source: mainline/uspace/lib/usbhost/include/usb/host/endpoint.h@ 4e732f1a

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

usb: Add support for multiple packets per microframe.

  • Property mode set to 100644
File size: 3.8 KB
Line 
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 */
35#ifndef LIBUSBHOST_HOST_ENDPOINT_H
36#define LIBUSBHOST_HOST_ENDPOINT_H
37
38#include <stdbool.h>
39#include <adt/list.h>
40#include <fibril_synch.h>
41#include <usb/usb.h>
42
43/** Host controller side endpoint structure. */
44typedef struct endpoint {
45 /** Part of linked list. */
46 link_t link;
47 /** USB address. */
48 usb_address_t address;
49 /** USB endpoint number. */
50 usb_endpoint_t endpoint;
51 /** Communication direction. */
52 usb_direction_t direction;
53 /** USB transfer type. */
54 usb_transfer_type_t transfer_type;
55 /** Communication speed. */
56 usb_speed_t speed;
57 /** Maximum size of data packets. */
58 size_t max_packet_size;
59 /** Additional opportunities per uframe */
60 unsigned packets;
61 /** Necessary bandwidth. */
62 size_t bandwidth;
63 /** Value of the toggle bit. */
64 unsigned toggle:1;
65 /** True if there is a batch using this scheduled for this endpoint. */
66 volatile bool active;
67 /** Protects resources and active status changes. */
68 fibril_mutex_t guard;
69 /** Signals change of active status. */
70 fibril_condvar_t avail;
71 /** High speed TT data */
72 struct {
73 usb_address_t address;
74 unsigned port;
75 } tt;
76 /** Optional device specific data. */
77 struct {
78 /** Device specific data. */
79 void *data;
80 /** Callback to get the value of toggle bit. */
81 int (*toggle_get)(void *);
82 /** Callback to set the value of toggle bit. */
83 void (*toggle_set)(void *, int);
84 } hc_data;
85} endpoint_t;
86
87endpoint_t * endpoint_create(usb_address_t address, usb_endpoint_t endpoint,
88 usb_direction_t direction, usb_transfer_type_t type, usb_speed_t speed,
89 size_t max_packet_size, unsigned packets, size_t bw,
90 usb_address_t tt_address, unsigned tt_port);
91void endpoint_destroy(endpoint_t *instance);
92
93void endpoint_set_hc_data(endpoint_t *instance,
94 void *data, int (*toggle_get)(void *), void (*toggle_set)(void *, int));
95void endpoint_clear_hc_data(endpoint_t *instance);
96
97void endpoint_use(endpoint_t *instance);
98void endpoint_release(endpoint_t *instance);
99
100int endpoint_toggle_get(endpoint_t *instance);
101void endpoint_toggle_set(endpoint_t *instance, int toggle);
102
103/** list_get_instance wrapper.
104 * @param item Pointer to link member.
105 * @return Pointer to endpoint_t structure.
106 */
107static inline endpoint_t * endpoint_get_instance(link_t *item)
108{
109 return item ? list_get_instance(item, endpoint_t, link) : NULL;
110}
111#endif
112/**
113 * @}
114 */
Note: See TracBrowser for help on using the repository browser.