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
Line 
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/**
30 * @defgroup root Root device driver.
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>
44#include <str.h>
45#include <ctype.h>
46#include <macros.h>
47
48#include <driver.h>
49#include <devman.h>
50#include <ipc/devman.h>
51
52#define NAME "root"
53
54static int root_add_device(device_t *dev);
55
56/** The root device driver's standard operations. */
57static driver_ops_t root_ops = {
58 .add_device = &root_add_device
59};
60
61/** The root device driver structure. */
62static driver_t root_driver = {
63 .name = NAME,
64 .driver_ops = &root_ops
65};
66
67/** Create the device which represents the root of HW device tree.
68 *
69 * @param parent Parent of the newly created device.
70 * @return 0 on success, negative error number otherwise.
71 */
72static int add_platform_child(device_t *parent)
73{
74 return EOK;
75 printf(NAME ": adding new child for platform device.\n");
76
77 int res = EOK;
78 device_t *platform = NULL;
79 match_id_t *match_id = NULL;
80
81 /* Create new device. */
82 platform = create_device();
83 if (NULL == platform) {
84 res = ENOMEM;
85 goto failure;
86 }
87
88 platform->name = "hw";
89 printf(NAME ": the new device's name is %s.\n", platform->name);
90
91 /* Initialize match id list. */
92 match_id = create_match_id();
93 if (NULL == match_id) {
94 res = ENOMEM;
95 goto failure;
96 }
97
98 /* TODO - replace this with some better solution (sysinfo ?) */
99 match_id->id = STRING(UARCH);
100 match_id->score = 100;
101 add_match_id(&platform->match_ids, match_id);
102
103 /* Register child device. */
104 res = child_device_register(platform, parent);
105 if (EOK != res)
106 goto failure;
107
108 return res;
109
110failure:
111 if (NULL != match_id)
112 match_id->id = NULL;
113
114 if (NULL != platform) {
115 platform->name = NULL;
116 delete_device(platform);
117 }
118
119 return res;
120}
121
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
176/** Get the root device.
177 *
178 * @param dev The device which is root of the whole device tree (both
179 * of HW and pseudo devices).
180 */
181static int root_add_device(device_t *dev)
182{
183 printf(NAME ": root_add_device, device handle = %d\n", dev->handle);
184
185 /* Register root device's children. */
186 int res = add_platform_child(dev);
187 if (EOK != res)
188 printf(NAME ": failed to add child device for platform.\n");
189
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
196 return res;
197}
198
199int main(int argc, char *argv[])
200{
201 printf(NAME ": HelenOS root device driver\n");
202 return driver_main(&root_driver);
203}
204
205/**
206 * @}
207 */
208
Note: See TracBrowser for help on using the repository browser.