source: mainline/uspace/srv/drivers/root/root.c@ eff1a590

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since eff1a590 was eff1a590, checked in by Lenka Trochtova <trochtova.lenka@…>, 15 years ago

parts of code of a dummy root HW device driver for ia32 platform

  • Property mode set to 100644
File size: 3.6 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>
44#include <string.h>
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
[c16cf62]54static bool root_add_device(device_t *dev);
55static bool root_init();
[924c75e1]56
[66babbd]57/** The root device driver's standard operations.
58 */
[729fa2d6]59static driver_ops_t root_ops = {
60 .add_device = &root_add_device
61};
62
[66babbd]63/** The root device driver structure.
64 */
[729fa2d6]65static driver_t root_driver = {
66 .name = NAME,
67 .driver_ops = &root_ops
68};
69
[66babbd]70/** Create the device which represents the root of HW device tree.
71 * @param parent parent of the newly created device.
72 */
[bda60d9]73static bool add_platform_child(device_t *parent) {
74 printf(NAME ": adding new child for platform device.\n");
75
76 device_t *platform = NULL;
77 match_id_t *match_id = NULL;
78
79 // create new device
80 if (NULL == (platform = create_device())) {
81 goto failure;
[eff1a590]82 }
[bda60d9]83
[eff1a590]84 platform->name = "hw";
[bda60d9]85 printf(NAME ": the new device's name is %s.\n", platform->name);
86
87 // initialize match id list
88 if (NULL == (match_id = create_match_id())) {
89 goto failure;
90 }
[eff1a590]91
92 // TODO - replace this with some better solution (sysinfo ?)
93 match_id->id = STRING(UARCH);
[bda60d9]94 match_id->score = 100;
95 add_match_id(&platform->match_ids, match_id);
96
97 // register child device
98 if (!child_device_register(platform, parent)) {
99 goto failure;
100 }
101
102 return true;
103
104failure:
105 if (NULL != match_id) {
106 match_id->id = NULL;
107 }
108
109 if (NULL != platform) {
110 platform->name = NULL;
111 delete_device(platform);
112 }
113
114 return false;
115}
116
[66babbd]117/** Get the root device.
118 * @param dev the device which is root of the whole device tree (both of HW and pseudo devices).
119 */
[c16cf62]120static bool root_add_device(device_t *dev)
121{
[bda60d9]122 printf(NAME ": root_add_device, device handle = %d\n", dev->handle);
123
124 // register root device's children
125 if (!add_platform_child(dev)) {
[d347b53]126 printf(NAME ": failed to add child device for platform.\n");
[bda60d9]127 return false;
128 }
129
[c16cf62]130 return true;
131}
132
[924c75e1]133int main(int argc, char *argv[])
134{
[eff1a590]135 printf(NAME ": HelenOS root device driver\n");
[924c75e1]136 return driver_main(&root_driver);
137}
[c16cf62]138
139/**
140 * @}
[bda60d9]141 */
142
Note: See TracBrowser for help on using the repository browser.