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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 96ef672 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
RevLine 
[6ce42e85]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
[160b75e]29/** @addtogroup libusbhost
[6ce42e85]30 * @{
31 */
32/** @file
[8dc762e0]33 *
[6ce42e85]34 */
[160b75e]35#ifndef LIBUSBHOST_HOST_ENDPOINT_H
36#define LIBUSBHOST_HOST_ENDPOINT_H
[6ce42e85]37
[3e6a98c5]38#include <stdbool.h>
[6ce42e85]39#include <adt/list.h>
[6a32665d]40#include <fibril_synch.h>
[6ce42e85]41#include <usb/usb.h>
[f527f58]42#include <atomic.h>
[6ce42e85]43
[17412546]44/** Host controller side endpoint structure. */
[6ce42e85]45typedef struct endpoint {
[f527f58]46 /** Reference count. */
47 atomic_t refcnt;
[17412546]48 /** Part of linked list. */
[83c3123]49 link_t link;
[17412546]50 /** USB address. */
[0aae4a6a]51 usb_address_t address;
[17412546]52 /** USB endpoint number. */
[0aae4a6a]53 usb_endpoint_t endpoint;
[17412546]54 /** Communication direction. */
[0aae4a6a]55 usb_direction_t direction;
[17412546]56 /** USB transfer type. */
[6ce42e85]57 usb_transfer_type_t transfer_type;
[17412546]58 /** Communication speed. */
[6ce42e85]59 usb_speed_t speed;
[17412546]60 /** Maximum size of data packets. */
[6ce42e85]61 size_t max_packet_size;
[4e732f1a]62 /** Additional opportunities per uframe */
63 unsigned packets;
[17412546]64 /** Necessary bandwidth. */
[83c3123]65 size_t bandwidth;
[17412546]66 /** Value of the toggle bit. */
[f567bcf]67 unsigned toggle:1;
[17412546]68 /** True if there is a batch using this scheduled for this endpoint. */
69 volatile bool active;
70 /** Protects resources and active status changes. */
[6a32665d]71 fibril_mutex_t guard;
[17412546]72 /** Signals change of active status. */
[6a32665d]73 fibril_condvar_t avail;
[0ee999d]74 /** High speed TT data */
75 struct {
76 usb_address_t address;
77 unsigned port;
78 } tt;
[17412546]79 /** Optional device specific data. */
[3d932af6]80 struct {
[17412546]81 /** Device specific data. */
[3d932af6]82 void *data;
[17412546]83 /** Callback to get the value of toggle bit. */
[3d932af6]84 int (*toggle_get)(void *);
[17412546]85 /** Callback to set the value of toggle bit. */
[3d932af6]86 void (*toggle_set)(void *, int);
87 } hc_data;
[6ce42e85]88} endpoint_t;
89
[83c3123]90endpoint_t * endpoint_create(usb_address_t address, usb_endpoint_t endpoint,
[aa81adc]91 usb_direction_t direction, usb_transfer_type_t type, usb_speed_t speed,
[4e732f1a]92 size_t max_packet_size, unsigned packets, size_t bw,
93 usb_address_t tt_address, unsigned tt_port);
[8dc762e0]94void endpoint_destroy(endpoint_t *instance);
[1e70157]95
[f527f58]96void endpoint_add_ref(endpoint_t *instance);
97void endpoint_del_ref(endpoint_t *instance);
98
[3d932af6]99void endpoint_set_hc_data(endpoint_t *instance,
[48ae3ef]100 void *data, int (*toggle_get)(void *), void (*toggle_set)(void *, int));
[3d932af6]101void endpoint_clear_hc_data(endpoint_t *instance);
102
[6a32665d]103void endpoint_use(endpoint_t *instance);
104void endpoint_release(endpoint_t *instance);
105
[f567bcf]106int endpoint_toggle_get(endpoint_t *instance);
107void endpoint_toggle_set(endpoint_t *instance, int toggle);
[7265558]108
[17412546]109/** list_get_instance wrapper.
110 * @param item Pointer to link member.
[c59dbdd5]111 * @return Pointer to endpoint_t structure.
[17412546]112 */
[7265558]113static inline endpoint_t * endpoint_get_instance(link_t *item)
114{
[c59dbdd5]115 return item ? list_get_instance(item, endpoint_t, link) : NULL;
[7265558]116}
[6ce42e85]117#endif
118/**
119 * @}
120 */
Note: See TracBrowser for help on using the repository browser.