mainbus.c revision 1.9 1 1.9 jmcneill /* $NetBSD: mainbus.c,v 1.9 2012/01/07 18:10:18 jmcneill Exp $ */
2 1.1 jmcneill
3 1.1 jmcneill /*-
4 1.1 jmcneill * Copyright (c) 2007 Jared D. McNeill <jmcneill (at) invisible.ca>
5 1.1 jmcneill * All rights reserved.
6 1.1 jmcneill *
7 1.1 jmcneill * Redistribution and use in source and binary forms, with or without
8 1.1 jmcneill * modification, are permitted provided that the following conditions
9 1.1 jmcneill * are met:
10 1.1 jmcneill * 1. Redistributions of source code must retain the above copyright
11 1.1 jmcneill * notice, this list of conditions and the following disclaimer.
12 1.1 jmcneill * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 jmcneill * notice, this list of conditions and the following disclaimer in the
14 1.1 jmcneill * documentation and/or other materials provided with the distribution.
15 1.1 jmcneill *
16 1.1 jmcneill * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 jmcneill * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 jmcneill * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 jmcneill * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 jmcneill * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 jmcneill * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 jmcneill * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 jmcneill * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 jmcneill * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 jmcneill * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 jmcneill * POSSIBILITY OF SUCH DAMAGE.
27 1.1 jmcneill */
28 1.1 jmcneill
29 1.1 jmcneill #include <sys/cdefs.h>
30 1.9 jmcneill __KERNEL_RCSID(0, "$NetBSD: mainbus.c,v 1.9 2012/01/07 18:10:18 jmcneill Exp $");
31 1.1 jmcneill
32 1.1 jmcneill #include <sys/param.h>
33 1.1 jmcneill #include <sys/proc.h>
34 1.1 jmcneill #include <sys/systm.h>
35 1.1 jmcneill #include <sys/device.h>
36 1.1 jmcneill
37 1.1 jmcneill #include <dev/cons.h>
38 1.1 jmcneill
39 1.1 jmcneill #include <machine/mainbus.h>
40 1.1 jmcneill
41 1.1 jmcneill static int mainbus_match(device_t, cfdata_t, void *);
42 1.1 jmcneill static void mainbus_attach(device_t, device_t, void *);
43 1.1 jmcneill
44 1.1 jmcneill static int mainbus_print(void *, const char *);
45 1.1 jmcneill
46 1.1 jmcneill typedef struct mainbus_softc {
47 1.1 jmcneill device_t sc_dev;
48 1.1 jmcneill } mainbus_softc_t;
49 1.1 jmcneill
50 1.1 jmcneill CFATTACH_DECL_NEW(mainbus, sizeof(mainbus_softc_t),
51 1.1 jmcneill mainbus_match, mainbus_attach, NULL, NULL);
52 1.1 jmcneill
53 1.9 jmcneill extern char *usermode_disk_image_path[];
54 1.9 jmcneill extern int usermode_disk_image_path_count;
55 1.6 jmcneill extern char *usermode_tap_device;
56 1.6 jmcneill extern char *usermode_tap_eaddr;
57 1.7 jmcneill extern char *usermode_audio_device;
58 1.8 jmcneill extern int usermode_vnc_width, usermode_vnc_height, usermode_vnc_port;
59 1.4 jmcneill
60 1.1 jmcneill static int
61 1.1 jmcneill mainbus_match(device_t parent, cfdata_t match, void *opaque)
62 1.1 jmcneill {
63 1.1 jmcneill
64 1.1 jmcneill return 1;
65 1.1 jmcneill }
66 1.1 jmcneill
67 1.1 jmcneill static void
68 1.1 jmcneill mainbus_attach(device_t parent, device_t self, void *opaque)
69 1.1 jmcneill {
70 1.1 jmcneill mainbus_softc_t *sc = device_private(self);
71 1.1 jmcneill struct thunkbus_attach_args taa;
72 1.9 jmcneill int i;
73 1.1 jmcneill
74 1.1 jmcneill aprint_naive("\n");
75 1.1 jmcneill aprint_normal("\n");
76 1.1 jmcneill
77 1.1 jmcneill sc->sc_dev = self;
78 1.1 jmcneill
79 1.1 jmcneill taa.taa_type = THUNKBUS_TYPE_CPU;
80 1.1 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
81 1.5 jmcneill
82 1.8 jmcneill taa.taa_type = THUNKBUS_TYPE_TTYCONS;
83 1.5 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
84 1.8 jmcneill
85 1.8 jmcneill if (usermode_vnc_port > 0 && usermode_vnc_port < 65536) {
86 1.8 jmcneill taa.taa_type = THUNKBUS_TYPE_VNCFB;
87 1.8 jmcneill taa.u.vnc.width = usermode_vnc_width;
88 1.8 jmcneill taa.u.vnc.height = usermode_vnc_height;
89 1.8 jmcneill taa.u.vnc.port = usermode_vnc_port;
90 1.8 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
91 1.8 jmcneill }
92 1.5 jmcneill
93 1.1 jmcneill taa.taa_type = THUNKBUS_TYPE_CLOCK;
94 1.1 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
95 1.5 jmcneill
96 1.6 jmcneill if (usermode_tap_device) {
97 1.6 jmcneill taa.taa_type = THUNKBUS_TYPE_VETH;
98 1.6 jmcneill taa.u.veth.device = usermode_tap_device;
99 1.6 jmcneill taa.u.veth.eaddr = usermode_tap_eaddr;
100 1.6 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
101 1.6 jmcneill }
102 1.6 jmcneill
103 1.7 jmcneill if (usermode_audio_device) {
104 1.7 jmcneill taa.taa_type = THUNKBUS_TYPE_VAUDIO;
105 1.7 jmcneill taa.u.vaudio.device = usermode_audio_device;
106 1.7 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
107 1.7 jmcneill }
108 1.7 jmcneill
109 1.9 jmcneill for (i = 0; i < usermode_disk_image_path_count; i++) {
110 1.4 jmcneill taa.taa_type = THUNKBUS_TYPE_DISKIMAGE;
111 1.9 jmcneill taa.u.diskimage.path = usermode_disk_image_path[i];
112 1.4 jmcneill config_found_ia(self, "thunkbus", &taa, mainbus_print);
113 1.4 jmcneill }
114 1.1 jmcneill }
115 1.1 jmcneill
116 1.1 jmcneill static int
117 1.1 jmcneill mainbus_print(void *opaque, const char *pnp)
118 1.1 jmcneill {
119 1.1 jmcneill if (pnp)
120 1.1 jmcneill aprint_normal("%s", pnp);
121 1.1 jmcneill return UNCONF;
122 1.1 jmcneill }
123