source: mainline/uspace/drv/vhc/hub.c@ 774afaae

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

Refactoring of virtual hub

The hub is now divided into two layers (one as a hub and the other
one as a virtual USB device) and separated into more files for better
readability.

  • Property mode set to 100644
File size: 3.1 KB
RevLine 
[b8507a1]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 USB hub.
34 */
[4b4c797]35#include <usb/classes/classes.h>
[b8507a1]36#include <usbvirt/hub.h>
37#include <usbvirt/device.h>
38#include <errno.h>
[0995cd6]39#include <str_error.h>
[b8a3cda]40#include <stdlib.h>
[0995cd6]41#include <driver.h>
[8f8ae1fd]42#include <usb/usbdrv.h>
[b8507a1]43
44#include "hub.h"
[774afaae]45#include "hub/virthub.h"
46#include "vhcd.h"
[b8507a1]47
[774afaae]48usbvirt_device_t virtual_hub_device;
[b8507a1]49
[774afaae]50static int hub_register_in_devman_fibril(void *arg);
[b8507a1]51
[774afaae]52void virtual_hub_device_init(device_t *hc_dev)
53{
54 virthub_init(&virtual_hub_device);
[b8507a1]55
[774afaae]56 /*
57 * We need to register the root hub.
58 * This must be done in separate fibril because the device
59 * we are connecting to are ourselves and we cannot connect
60 * before leaving the add_device() function.
61 */
62 fid_t root_hub_registration
63 = fibril_create(hub_register_in_devman_fibril, hc_dev);
64 if (root_hub_registration == 0) {
65 printf(NAME ": failed to register root hub\n");
66 return;
[b8507a1]67 }
68
[774afaae]69 fibril_add_ready(root_hub_registration);
70}
[b8507a1]71
[8f8ae1fd]72/** Register root hub in devman.
73 *
74 * @param arg Host controller device (type <code>device_t *</code>).
75 * @return Error code.
76 */
[774afaae]77int hub_register_in_devman_fibril(void *arg)
[0995cd6]78{
[8f8ae1fd]79 device_t *hc_dev = (device_t *) arg;
80
81 int hc = usb_drv_hc_connect(hc_dev, IPC_FLAG_BLOCKING);
82 if (hc < 0) {
83 printf(NAME ": failed to register root hub\n");
84 return hc;
[0995cd6]85 }
[8f8ae1fd]86
87 usb_drv_reserve_default_address(hc);
88
89 usb_address_t hub_address = usb_drv_request_address(hc);
90 usb_drv_req_set_address(hc, USB_ADDRESS_DEFAULT, hub_address);
91
92 usb_drv_release_default_address(hc);
93
94 devman_handle_t hub_handle;
95 usb_drv_register_child_in_devman(hc, hc_dev, hub_address, &hub_handle);
96 usb_drv_bind_address(hc, hub_address, hub_handle);
97
98 return EOK;
[0995cd6]99}
[b8507a1]100
101
102/**
103 * @}
104 */
Note: See TracBrowser for help on using the repository browser.