source: mainline/uspace/lib/usbdev/include/usb/dev/request.h@ 99a1a56

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

libusbdev: Use const on stack structure instead of heap alloc.

  • Property mode set to 100644
File size: 5.4 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
29/** @addtogroup libusbdev
30 * @{
31 */
32/** @file
33 * Standard USB requests.
34 */
35#ifndef LIBUSBDEV_REQUEST_H_
36#define LIBUSBDEV_REQUEST_H_
37
38#include <sys/types.h>
39#include <l18n/langs.h>
40#include <usb/usb.h>
41#include <usb/dev/pipes.h>
42#include <usb/descriptor.h>
43
44/** USB device status - device is self powered (opposed to bus powered). */
45#define USB_DEVICE_STATUS_SELF_POWERED ((uint16_t)(1 << 0))
46
47/** USB device status - remote wake-up signaling is enabled. */
48#define USB_DEVICE_STATUS_REMOTE_WAKEUP ((uint16_t)(1 << 1))
49
50/** USB endpoint status - endpoint is halted (stalled). */
51#define USB_ENDPOINT_STATUS_HALTED ((uint16_t)(1 << 0))
52
53/** USB feature selector - endpoint halt (stall). */
54#define USB_FEATURE_SELECTOR_ENDPOINT_HALT (0)
55
56/** USB feature selector - device remote wake-up. */
57#define USB_FEATURE_SELECTOR_REMOTE_WAKEUP (1)
58
59/** Standard device request. */
60typedef enum {
61 USB_DEVREQ_GET_STATUS = 0,
62 USB_DEVREQ_CLEAR_FEATURE = 1,
63 USB_DEVREQ_SET_FEATURE = 3,
64 USB_DEVREQ_SET_ADDRESS = 5,
65 USB_DEVREQ_GET_DESCRIPTOR = 6,
66 USB_DEVREQ_SET_DESCRIPTOR = 7,
67 USB_DEVREQ_GET_CONFIGURATION = 8,
68 USB_DEVREQ_SET_CONFIGURATION = 9,
69 USB_DEVREQ_GET_INTERFACE = 10,
70 USB_DEVREQ_SET_INTERFACE = 11,
71 USB_DEVREQ_SYNCH_FRAME = 12,
72 USB_DEVREQ_LAST_STD
73} usb_stddevreq_t;
74
75/** Device request setup packet.
76 * The setup packet describes the request.
77 */
78typedef struct {
79 /** Request type.
80 * The type combines transfer direction, request type and
81 * intended recipient.
82 */
83 uint8_t request_type;
84 /** Request identification. */
85 uint8_t request;
86 /** Main parameter to the request. */
87 union {
88 uint16_t value;
89 /* FIXME: add #ifdefs according to host endianness */
90 struct {
91 uint8_t value_low;
92 uint8_t value_high;
93 };
94 };
95 /** Auxiliary parameter to the request.
96 * Typically, it is offset to something.
97 */
98 uint16_t index;
99 /** Length of extra data. */
100 uint16_t length;
101} __attribute__ ((packed)) usb_device_request_setup_packet_t;
102
103int usb_control_request_set(usb_pipe_t *,
104 usb_request_type_t, usb_request_recipient_t, uint8_t,
105 uint16_t, uint16_t, void *, size_t);
106
107int usb_control_request_get(usb_pipe_t *,
108 usb_request_type_t, usb_request_recipient_t, uint8_t,
109 uint16_t, uint16_t, void *, size_t, size_t *);
110
111int usb_request_get_status(usb_pipe_t *, usb_request_recipient_t,
112 uint16_t, uint16_t *);
113int usb_request_clear_feature(usb_pipe_t *, usb_request_type_t,
114 usb_request_recipient_t, uint16_t, uint16_t);
115int usb_request_set_feature(usb_pipe_t *, usb_request_type_t,
116 usb_request_recipient_t, uint16_t, uint16_t);
117int usb_request_get_descriptor(usb_pipe_t *, usb_request_type_t,
118 usb_request_recipient_t, uint8_t, uint8_t, uint16_t, void *, size_t,
119 size_t *);
120int usb_request_get_descriptor_alloc(usb_pipe_t *, usb_request_type_t,
121 usb_request_recipient_t, uint8_t, uint8_t, uint16_t, void **, size_t *);
122int usb_request_get_device_descriptor(usb_pipe_t *,
123 usb_standard_device_descriptor_t *);
124int usb_request_get_bare_configuration_descriptor(usb_pipe_t *, int,
125 usb_standard_configuration_descriptor_t *);
126int usb_request_get_full_configuration_descriptor(usb_pipe_t *, int,
127 void *, size_t, size_t *);
128int usb_request_get_full_configuration_descriptor_alloc(usb_pipe_t *,
129 int, void **, size_t *);
130int usb_request_set_descriptor(usb_pipe_t *, usb_request_type_t,
131 usb_request_recipient_t, uint8_t, uint8_t, uint16_t, void *, size_t);
132
133int usb_request_get_configuration(usb_pipe_t *, uint8_t *);
134int usb_request_set_configuration(usb_pipe_t *, uint8_t);
135int usb_request_get_interface(usb_pipe_t *, uint8_t, uint8_t *);
136int usb_request_set_interface(usb_pipe_t *, uint8_t, uint8_t);
137
138int usb_request_get_supported_languages(usb_pipe_t *,
139 l18_win_locales_t **, size_t *);
140int usb_request_get_string(usb_pipe_t *, size_t, l18_win_locales_t,
141 char **);
142
143int usb_request_clear_endpoint_halt(usb_pipe_t *, uint16_t);
144int usb_pipe_clear_halt(usb_pipe_t *, usb_pipe_t *);
145int usb_request_get_endpoint_status(usb_pipe_t *, usb_pipe_t *, uint16_t *);
146
147#endif
148/**
149 * @}
150 */
Note: See TracBrowser for help on using the repository browser.