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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since f527f58 was f527f58, checked in by Jakub Jermar <jakub@…>, 9 years ago

Reference-count endpoint_t structures

Track explicit references to USB endpoints. Call endpoint_destroy()
only after the last reference is destroyed. This prevents the scenario
in which removal was attempted on an endpoint while there was a transfer
in progress.

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