source: mainline/uspace/drv/root/root.c@ 7329e6a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 7329e6a was 7e752b2, checked in by Martin Decky <martin@…>, 15 years ago
  • correct printf() formatting strings and corresponding arguments
  • minor cstyle changes and other small fixes
  • Property mode set to 100644
File size: 3.8 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>
[7e752b2]47#include <inttypes.h>
[924c75e1]48
[c16cf62]49#include <driver.h>
[729fa2d6]50#include <devman.h>
[924c75e1]51#include <ipc/devman.h>
52
53#define NAME "root"
54
[df747b9c]55static int root_add_device(device_t *dev);
[924c75e1]56
[5291411]57/** The root device driver's standard operations. */
[729fa2d6]58static driver_ops_t root_ops = {
59 .add_device = &root_add_device
60};
61
[5291411]62/** The root device driver structure. */
[729fa2d6]63static driver_t root_driver = {
64 .name = NAME,
65 .driver_ops = &root_ops
66};
67
[df747b9c]68/** Create the device which represents the root of HW device tree.
[5291411]69 *
70 * @param parent Parent of the newly created device.
[df747b9c]71 * @return 0 on success, negative error number otherwise.
[66babbd]72 */
[5291411]73static int add_platform_child(device_t *parent)
74{
[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
[66babbd]122/** Get the root device.
[5291411]123 *
124 * @param dev The device which is root of the whole device tree (both
125 * of HW and pseudo devices).
[66babbd]126 */
[5291411]127static int root_add_device(device_t *dev)
[c16cf62]128{
[7e752b2]129 printf(NAME ": root_add_device, device handle=%" PRIun "\n",
130 dev->handle);
[bda60d9]131
[5291411]132 /* Register root device's children. */
133 int res = add_platform_child(dev);
134 if (EOK != res)
[d347b53]135 printf(NAME ": failed to add child device for platform.\n");
[bda60d9]136
[df747b9c]137 return res;
[c16cf62]138}
139
[924c75e1]140int main(int argc, char *argv[])
141{
[5291411]142 printf(NAME ": HelenOS root device driver\n");
[924c75e1]143 return driver_main(&root_driver);
144}
[c16cf62]145
146/**
147 * @}
[bda60d9]148 */
[5291411]149
Note: See TracBrowser for help on using the repository browser.