source: mainline/uspace/drv/root/root.c@ 7034be15

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

Various changes to HC driver framework API

Also, the root driver only registers VHC as its only child to clean-up
debug output from devman.

  • Property mode set to 100644
File size: 4.9 KB
RevLine 
[924c75e1]1/*
2 * Copyright (c) 2010 Lenka Trochtova
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/**
[c16cf62]30 * @defgroup root Root device driver.
[924c75e1]31 * @brief HelenOS root device driver.
32 * @{
33 */
34
35/** @file
36 */
37
38#include <assert.h>
39#include <stdio.h>
40#include <errno.h>
41#include <bool.h>
42#include <fibril_synch.h>
43#include <stdlib.h>
[c47e1a8]44#include <str.h>
[924c75e1]45#include <ctype.h>
[bda60d9]46#include <macros.h>
[924c75e1]47
[c16cf62]48#include <driver.h>
[729fa2d6]49#include <devman.h>
[924c75e1]50#include <ipc/devman.h>
51
52#define NAME "root"
53
[df747b9c]54static int root_add_device(device_t *dev);
[924c75e1]55
[5291411]56/** The root device driver's standard operations. */
[729fa2d6]57static driver_ops_t root_ops = {
58 .add_device = &root_add_device
59};
60
[5291411]61/** The root device driver structure. */
[729fa2d6]62static driver_t root_driver = {
63 .name = NAME,
64 .driver_ops = &root_ops
65};
66
[df747b9c]67/** Create the device which represents the root of HW device tree.
[5291411]68 *
69 * @param parent Parent of the newly created device.
[df747b9c]70 * @return 0 on success, negative error number otherwise.
[66babbd]71 */
[5291411]72static int add_platform_child(device_t *parent)
73{
[7034be15]74 return EOK;
[bda60d9]75 printf(NAME ": adding new child for platform device.\n");
76
[df747b9c]77 int res = EOK;
[bda60d9]78 device_t *platform = NULL;
[5291411]79 match_id_t *match_id = NULL;
[bda60d9]80
[5291411]81 /* Create new device. */
82 platform = create_device();
83 if (NULL == platform) {
[df747b9c]84 res = ENOMEM;
[bda60d9]85 goto failure;
[eff1a590]86 }
[bda60d9]87
[eff1a590]88 platform->name = "hw";
[bda60d9]89 printf(NAME ": the new device's name is %s.\n", platform->name);
90
[5291411]91 /* Initialize match id list. */
92 match_id = create_match_id();
93 if (NULL == match_id) {
[df747b9c]94 res = ENOMEM;
[bda60d9]95 goto failure;
96 }
[eff1a590]97
[5291411]98 /* TODO - replace this with some better solution (sysinfo ?) */
[eff1a590]99 match_id->id = STRING(UARCH);
[bda60d9]100 match_id->score = 100;
[5291411]101 add_match_id(&platform->match_ids, match_id);
[bda60d9]102
[5291411]103 /* Register child device. */
[df747b9c]104 res = child_device_register(platform, parent);
[5291411]105 if (EOK != res)
[bda60d9]106 goto failure;
107
[df747b9c]108 return res;
[bda60d9]109
110failure:
[5291411]111 if (NULL != match_id)
[bda60d9]112 match_id->id = NULL;
113
114 if (NULL != platform) {
115 platform->name = NULL;
[5291411]116 delete_device(platform);
[bda60d9]117 }
118
[5291411]119 return res;
[bda60d9]120}
121
[63b4f90]122/** Create virtual USB host controller device.
123 * Note that the virtual HC is actually device and driver in one
124 * task.
125 *
126 * @param parent Parent device.
127 * @return Error code.
128 */
129static int add_virtual_usb_host_controller(device_t *parent)
130{
131 printf(NAME ": adding virtual host contoller.\n");
132
133 int rc;
134 device_t *vhc = NULL;
135 match_id_t *match_id = NULL;
136
137 vhc = create_device();
138 if (vhc == NULL) {
139 rc = ENOMEM;
140 goto failure;
141 }
142
143 vhc->name = "vhc";
144 printf(NAME ": the new device's name is %s.\n", vhc->name);
145
146 /* Initialize match id list. */
147 match_id = create_match_id();
148 if (match_id == NULL) {
149 rc = ENOMEM;
150 goto failure;
151 }
152
153 match_id->id = "usb&hc=vhc";
154 match_id->score = 100;
155 add_match_id(&vhc->match_ids, match_id);
156
157 /* Register child device. */
158 rc = child_device_register(vhc, parent);
159 if (rc != EOK)
160 goto failure;
161
162 return EOK;
163
164failure:
165 if (match_id != NULL)
166 match_id->id = NULL;
167
168 if (vhc != NULL) {
169 vhc->name = NULL;
170 delete_device(vhc);
171 }
172
173 return rc;
174}
175
[66babbd]176/** Get the root device.
[5291411]177 *
178 * @param dev The device which is root of the whole device tree (both
179 * of HW and pseudo devices).
[66babbd]180 */
[5291411]181static int root_add_device(device_t *dev)
[c16cf62]182{
[bda60d9]183 printf(NAME ": root_add_device, device handle = %d\n", dev->handle);
184
[5291411]185 /* Register root device's children. */
186 int res = add_platform_child(dev);
187 if (EOK != res)
[d347b53]188 printf(NAME ": failed to add child device for platform.\n");
[bda60d9]189
[63b4f90]190 /* Register virtual USB host controller. */
191 int rc = add_virtual_usb_host_controller(dev);
192 if (EOK != rc) {
193 printf(NAME ": failed to add child device - virtual USB HC.\n");
194 }
195
[df747b9c]196 return res;
[c16cf62]197}
198
[924c75e1]199int main(int argc, char *argv[])
200{
[5291411]201 printf(NAME ": HelenOS root device driver\n");
[924c75e1]202 return driver_main(&root_driver);
203}
[c16cf62]204
205/**
206 * @}
[bda60d9]207 */
[5291411]208
Note: See TracBrowser for help on using the repository browser.