Changes in uspace/lib/usbhost/include/usb/host/endpoint.h [20eaa82:58563585] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/usbhost/include/usb/host/endpoint.h
r20eaa82 r58563585 32 32 /** @file 33 33 * 34 * Endpoint structure is tightly coupled to the bus. The bus controls the35 * life-cycle of endpoint. In order to keep endpoints lightweight, operations36 * on endpoints are part of the bus structure.37 *38 34 */ 39 35 #ifndef LIBUSBHOST_HOST_ENDPOINT_H … … 46 42 #include <atomic.h> 47 43 48 typedef struct bus bus_t;49 typedef struct device device_t;50 51 44 /** Host controller side endpoint structure. */ 52 45 typedef struct endpoint { 53 /** Managing bus */54 bus_t *bus;55 46 /** Reference count. */ 56 atomic_t refcnt; 47 atomic_t refcnt; 57 48 /** Part of linked list. */ 58 49 link_t link; 59 /** USB device */60 device_t *device;61 50 /** USB address. */ 62 usb_target_t target; 51 usb_address_t address; 52 /** USB endpoint number. */ 53 usb_endpoint_t endpoint; 63 54 /** Communication direction. */ 64 55 usb_direction_t direction; … … 71 62 /** Additional opportunities per uframe */ 72 63 unsigned packets; 73 /** Reservedbandwidth. */64 /** Necessary bandwidth. */ 74 65 size_t bandwidth; 75 66 /** Value of the toggle bit. */ 76 67 unsigned toggle:1; 77 68 /** True if there is a batch using this scheduled for this endpoint. */ 78 bool active;69 volatile bool active; 79 70 /** Protects resources and active status changes. */ 80 71 fibril_mutex_t guard; 81 72 /** Signals change of active status. */ 82 73 fibril_condvar_t avail; 83 84 /* This structure is meant to be extended by overriding. */ 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; 85 88 } endpoint_t; 86 89 87 extern void endpoint_init(endpoint_t *, bus_t *); 90 extern endpoint_t *endpoint_create(usb_address_t, usb_endpoint_t, 91 usb_direction_t, usb_transfer_type_t, usb_speed_t, size_t, unsigned int, 92 size_t, usb_address_t, unsigned int); 93 extern void endpoint_destroy(endpoint_t *); 88 94 89 95 extern void endpoint_add_ref(endpoint_t *); 90 96 extern void endpoint_del_ref(endpoint_t *); 97 98 extern void endpoint_set_hc_data(endpoint_t *, void *, int (*)(void *), 99 void (*)(void *, int)); 100 extern void endpoint_clear_hc_data(endpoint_t *); 91 101 92 102 extern void endpoint_use(endpoint_t *); … … 94 104 95 105 extern int endpoint_toggle_get(endpoint_t *); 96 extern void endpoint_toggle_set(endpoint_t *, unsigned);106 extern void endpoint_toggle_set(endpoint_t *, int); 97 107 98 108 /** list_get_instance wrapper.
Note:
See TracChangeset
for help on using the changeset viewer.