source: mainline/uspace/lib/usbvirt/ctrlpipe.c@ 954ea70

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 954ea70 was 954ea70, checked in by Vojtech Horky <vojtechhorky@…>, 15 years ago

usbvirt: standard requests handled better

Also, SET_ADDRESS works according to specification.

  • Property mode set to 100644
File size: 3.0 KB
Line 
1/*
2 * Copyright (c) 2010 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 libusbvirt usb
30 * @{
31 */
32/** @file
33 * @brief Device control pipe.
34 */
35#include <errno.h>
36
37#include "private.h"
38
39#define REQUEST_TYPE_STANDARD 0
40#define REQUEST_TYPE_CLASS 1
41
42#define GET_MIDBITS_MASK(size, shift) \
43 (((1 << size) - 1) << shift)
44#define GET_MIDBITS(value, size, shift) \
45 ((value & GET_MIDBITS_MASK(size, shift)) >> shift)
46
47usb_address_t dev_new_address = -1;
48
49static int request_get_type(uint8_t request_type)
50{
51 return GET_MIDBITS(request_type, 2, 5);
52}
53
54
55
56int control_pipe(void *buffer, size_t size)
57{
58 if (size < sizeof(usb_device_request_setup_packet_t)) {
59 return ENOMEM;
60 }
61
62 usb_device_request_setup_packet_t *request = (usb_device_request_setup_packet_t *) buffer;
63 uint8_t *remaining_data = ((uint8_t *) request) + sizeof(usb_device_request_setup_packet_t);
64
65 int type = request_get_type(request->request_type);
66
67 int rc = EOK;
68
69 switch (type) {
70 case REQUEST_TYPE_STANDARD:
71 rc = handle_std_request(request, remaining_data);
72 break;
73 case REQUEST_TYPE_CLASS:
74 if (DEVICE_HAS_OP(device, on_class_device_request)) {
75 rc = device->ops->on_class_device_request(device,
76 request, remaining_data);
77 }
78 break;
79 default:
80 break;
81 }
82
83 device->send_data(device, 0, NULL, 0);
84
85 if (dev_new_address != -1) {
86 /*
87 * TODO: handle when this request is invalid (e.g.
88 * setting address when in configured state).
89 */
90 if (dev_new_address == 0) {
91 device->state = USBVIRT_STATE_DEFAULT;
92 } else {
93 device->state = USBVIRT_STATE_ADDRESS;
94 }
95 device->address = dev_new_address;
96
97 dev_new_address = -1;
98 }
99
100 return rc;
101}
102
103/**
104 * @}
105 */
Note: See TracBrowser for help on using the repository browser.