source: mainline/uspace/lib/usbdev/include/usb/dev/pipes.h@ 1a38701

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

libusb, libusbdev: Move usb_device_connection to separate header in libusbdev.

  • Property mode set to 100644
File size: 4.9 KB
Line 
1/*
2 * Copyright (c) 2011 Vojtech Horky
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/** @addtogroup libusbdev
29 * @{
30 */
31/** @file
32 * USB pipes representation.
33 */
34#ifndef LIBUSBDEV_PIPES_H_
35#define LIBUSBDEV_PIPES_H_
36
37#include <sys/types.h>
38#include <ipc/devman.h>
39#include <ddf/driver.h>
40#include <fibril_synch.h>
41#include <async.h>
42#include <usb/usb.h>
43#include <usb/descriptor.h>
44#include <usb/dev/usb_device_connection.h>
45
46/** Abstraction of a logical connection to USB device endpoint.
47 * It encapsulates endpoint attributes (transfer type etc.) as well
48 * as information about currently running sessions.
49 * This endpoint must be bound with existing usb_device_connection_t
50 * (i.e. the wire to send data over).
51 *
52 * Locking order: if you want to lock both mutexes
53 * (@c guard and @c hc_sess_mutex), lock @c guard first.
54 * It is not necessary to lock @c guard if you want to lock @c hc_sess_mutex
55 * only.
56 */
57typedef struct {
58 /** Guard of the whole pipe. */
59 fibril_mutex_t guard;
60
61 /** The connection used for sending the data. */
62 usb_device_connection_t *wire;
63
64 /** Endpoint number. */
65 usb_endpoint_t endpoint_no;
66
67 /** Endpoint transfer type. */
68 usb_transfer_type_t transfer_type;
69
70 /** Endpoint direction. */
71 usb_direction_t direction;
72
73 /** Maximum packet size for the endpoint. */
74 size_t max_packet_size;
75
76 /** Whether to automatically reset halt on the endpoint.
77 * Valid only for control endpoint zero.
78 */
79 bool auto_reset_halt;
80} usb_pipe_t;
81
82
83/** Description of endpoint characteristics. */
84typedef struct {
85 /** Transfer type (e.g. control or interrupt). */
86 usb_transfer_type_t transfer_type;
87 /** Transfer direction (to or from a device). */
88 usb_direction_t direction;
89 /** Interface class this endpoint belongs to (-1 for any). */
90 int interface_class;
91 /** Interface subclass this endpoint belongs to (-1 for any). */
92 int interface_subclass;
93 /** Interface protocol this endpoint belongs to (-1 for any). */
94 int interface_protocol;
95 /** Extra endpoint flags. */
96 unsigned int flags;
97} usb_endpoint_description_t;
98
99/** Mapping of endpoint pipes and endpoint descriptions. */
100typedef struct {
101 /** Endpoint pipe. */
102 usb_pipe_t pipe;
103 /** Endpoint description. */
104 const usb_endpoint_description_t *description;
105 /** Interface number the endpoint must belong to (-1 for any). */
106 int interface_no;
107 /** Alternate interface setting to choose. */
108 int interface_setting;
109 /** Found descriptor fitting the description. */
110 const usb_standard_endpoint_descriptor_t *descriptor;
111 /** Interface descriptor the endpoint belongs to. */
112 const usb_standard_interface_descriptor_t *interface;
113 /** Whether the endpoint was actually found. */
114 bool present;
115} usb_endpoint_mapping_t;
116
117
118int usb_device_get_assigned_interface(const ddf_dev_t *);
119
120int usb_pipe_initialize(usb_pipe_t *, usb_device_connection_t *,
121 usb_endpoint_t, usb_transfer_type_t, size_t, usb_direction_t);
122int usb_pipe_initialize_default_control(usb_pipe_t *,
123 usb_device_connection_t *);
124
125int usb_pipe_probe_default_control(usb_pipe_t *);
126int usb_pipe_initialize_from_configuration(usb_endpoint_mapping_t *,
127 size_t, const uint8_t *, size_t, usb_device_connection_t *);
128int usb_pipe_register(usb_pipe_t *, unsigned);
129int usb_pipe_unregister(usb_pipe_t *);
130
131int usb_pipe_start_long_transfer(usb_pipe_t *);
132int usb_pipe_end_long_transfer(usb_pipe_t *);
133
134int usb_pipe_read(usb_pipe_t *, void *, size_t, size_t *);
135int usb_pipe_write(usb_pipe_t *, const void *, size_t);
136
137int usb_pipe_control_read(usb_pipe_t *, const void *, size_t,
138 void *, size_t, size_t *);
139int usb_pipe_control_write(usb_pipe_t *, const void *, size_t,
140 const void *, size_t);
141
142#endif
143/**
144 * @}
145 */
Note: See TracBrowser for help on using the repository browser.