source: mainline/uspace/lib/usb/src/hcdrv.c@ fe5e00d6

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

Remote interface can handle interrupt transfers

The HC framework can handle interrupt transfers from USB device drivers.

  • Property mode set to 100644
File size: 3.2 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 libusb usb
30 * @{
31 */
32/** @file
33 * @brief HC driver.
34 */
35#include <usb/hcdhubd.h>
36#include <usb/devreq.h>
37#include <usbhc_iface.h>
38#include <usb/descriptor.h>
39#include <driver.h>
40#include <bool.h>
41#include <errno.h>
42#include <usb/classes/hub.h>
43
44#include "hcdhubd_private.h"
45
46/** List of handled host controllers. */
47LIST_INITIALIZE(hc_list);
48
49/** Our HC driver. */
50usb_hc_driver_t *hc_driver = NULL;
51
52static device_ops_t usb_device_ops = {
53 .interfaces[USBHC_DEV_IFACE] = &usbhc_interface
54};
55
56int usb_add_hc_device(device_t *dev)
57{
58 usb_hc_device_t *hc_dev = malloc(sizeof (usb_hc_device_t));
59 list_initialize(&hc_dev->link);
60 hc_dev->transfer_ops = NULL;
61
62 hc_dev->generic = dev;
63 dev->ops = &usb_device_ops;
64 hc_dev->generic->driver_data = hc_dev;
65
66 int rc = hc_driver->add_hc(hc_dev);
67 if (rc != EOK) {
68 free(hc_dev);
69 return rc;
70 }
71
72 /*
73 * FIXME: The following line causes devman to hang.
74 * Will investigate later why.
75 */
76 // add_device_to_class(dev, "usbhc");
77
78 list_append(&hc_dev->link, &hc_list);
79
80 //add keyboard
81 /// @TODO this is not correct code
82
83 /*
84 * Announce presence of child device.
85 */
86 device_t *kbd = NULL;
87 match_id_t *match_id = NULL;
88
89 kbd = create_device();
90 if (kbd == NULL) {
91 printf("ERROR: enomem\n");
92 }
93 kbd->name = USB_KBD_DEVICE_NAME;
94
95 match_id = create_match_id();
96 if (match_id == NULL) {
97 printf("ERROR: enomem\n");
98 }
99
100 char *id;
101 rc = asprintf(&id, USB_KBD_DEVICE_NAME);
102 if (rc <= 0) {
103 printf("ERROR: enomem\n");
104 return rc;
105 }
106
107 match_id->id = id;
108 match_id->score = 30;
109
110 add_match_id(&kbd->match_ids, match_id);
111
112 rc = child_device_register(kbd, dev);
113 if (rc != EOK) {
114 printf("ERROR: cannot register kbd\n");
115 return rc;
116 }
117
118 printf("%s: registered root hub\n", dev->name);
119 return EOK;
120}
121
122/**
123 * @}
124 */
Note: See TracBrowser for help on using the repository browser.