source: mainline/uspace/drv/vhc/hcd.c@ 138a7fd

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

Fixes & improvements in virtual hub

The changes includes:

  • unified (a bit) debugging output
  • port is put into power-off state after SET_CONFIGURATION request
  • less ports on the hub
  • delayed port changes run in separate fibril
  • shorter waiting for transactions in HC scheduling manager
  • 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 usb
30 * @{
31 */
32/** @file
33 * @brief Virtual host controller driver.
34 */
35
36#include <devmap.h>
37#include <ipc/ipc.h>
38#include <async.h>
39#include <unistd.h>
40#include <stdlib.h>
41#include <sysinfo.h>
42#include <stdio.h>
43#include <errno.h>
44#include <str_error.h>
45#include <driver.h>
46
47#include <usb/usb.h>
48#include "vhcd.h"
49#include "hc.h"
50#include "devices.h"
51#include "hub.h"
52#include "conn.h"
53
54static device_ops_t vhc_ops = {
55 .interfaces[USBHC_DEV_IFACE] = &vhc_iface,
56 .default_handler = default_connection_handler
57};
58
59static int vhc_count = 0;
60static int vhc_add_device(device_t *dev)
61{
62 /*
63 * Currently, we know how to simulate only single HC.
64 */
65 if (vhc_count > 0) {
66 return ELIMIT;
67 }
68
69 vhc_count++;
70
71 dev->ops = &vhc_ops;
72
73 /*
74 * Initialize address management.
75 */
76 address_init();
77
78 /*
79 * Initialize our hub and announce its presence.
80 */
81 hub_init(dev);
82
83 printf("%s: virtual USB host controller ready.\n", NAME);
84
85 return EOK;
86}
87
88static driver_ops_t vhc_driver_ops = {
89 .add_device = vhc_add_device,
90};
91
92static driver_t vhc_driver = {
93 .name = NAME,
94 .driver_ops = &vhc_driver_ops
95};
96
97/** Fibril wrapper for HC transaction manager.
98 *
99 * @param arg Not used.
100 * @return Nothing, return argument is unreachable.
101 */
102static int hc_manager_fibril(void *arg)
103{
104 hc_manager();
105 return EOK;
106}
107
108int main(int argc, char * argv[])
109{
110 printf("%s: virtual USB host controller driver.\n", NAME);
111
112 usb_dprintf_enable(NAME, 1);
113
114 fid_t fid = fibril_create(hc_manager_fibril, NULL);
115 if (fid == 0) {
116 printf("%s: failed to start HC manager fibril\n", NAME);
117 return ENOMEM;
118 }
119 fibril_add_ready(fid);
120
121 /*
122 * Temporary workaround. Wait a little bit to be the last driver
123 * in devman output.
124 */
125 sleep(4);
126
127 return driver_main(&vhc_driver);
128}
129
130
131/**
132 * @}
133 */
Note: See TracBrowser for help on using the repository browser.