com_opb.c revision 1.20 1 1.20 cube /* $NetBSD: com_opb.c,v 1.20 2008/03/14 15:09:10 cube Exp $ */
2 1.1 simonb
3 1.1 simonb /*
4 1.1 simonb * Copyright 2001 Wasabi Systems, Inc.
5 1.1 simonb * All rights reserved.
6 1.1 simonb *
7 1.1 simonb * Written by Eduardo Horvath and Simon Burge for Wasabi Systems, Inc.
8 1.1 simonb *
9 1.1 simonb * Redistribution and use in source and binary forms, with or without
10 1.1 simonb * modification, are permitted provided that the following conditions
11 1.1 simonb * are met:
12 1.1 simonb * 1. Redistributions of source code must retain the above copyright
13 1.1 simonb * notice, this list of conditions and the following disclaimer.
14 1.1 simonb * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 simonb * notice, this list of conditions and the following disclaimer in the
16 1.1 simonb * documentation and/or other materials provided with the distribution.
17 1.1 simonb * 3. All advertising materials mentioning features or use of this software
18 1.1 simonb * must display the following acknowledgement:
19 1.1 simonb * This product includes software developed for the NetBSD Project by
20 1.1 simonb * Wasabi Systems, Inc.
21 1.1 simonb * 4. The name of Wasabi Systems, Inc. may not be used to endorse
22 1.1 simonb * or promote products derived from this software without specific prior
23 1.1 simonb * written permission.
24 1.1 simonb *
25 1.1 simonb * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
26 1.1 simonb * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 1.1 simonb * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 1.1 simonb * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC
29 1.1 simonb * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 1.1 simonb * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 1.1 simonb * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 1.1 simonb * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 1.1 simonb * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 1.1 simonb * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 1.1 simonb * POSSIBILITY OF SUCH DAMAGE.
36 1.1 simonb */
37 1.11 lukem
38 1.12 shige /*
39 1.12 shige * Copyright (c) 1998
40 1.12 shige * Matthias Drochner. All rights reserved.
41 1.12 shige *
42 1.12 shige * Redistribution and use in source and binary forms, with or without
43 1.12 shige * modification, are permitted provided that the following conditions
44 1.12 shige * are met:
45 1.12 shige * 1. Redistributions of source code must retain the above copyright
46 1.12 shige * notice, this list of conditions and the following disclaimer.
47 1.12 shige * 2. Redistributions in binary form must reproduce the above copyright
48 1.12 shige * notice, this list of conditions and the following disclaimer in the
49 1.12 shige * documentation and/or other materials provided with the distribution.
50 1.12 shige *
51 1.12 shige * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
52 1.12 shige * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
53 1.12 shige * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
54 1.12 shige * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
55 1.12 shige * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
56 1.12 shige * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
57 1.12 shige * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
58 1.12 shige * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
59 1.12 shige * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
60 1.12 shige * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
61 1.12 shige */
62 1.12 shige
63 1.11 lukem #include <sys/cdefs.h>
64 1.20 cube __KERNEL_RCSID(0, "$NetBSD: com_opb.c,v 1.20 2008/03/14 15:09:10 cube Exp $");
65 1.1 simonb
66 1.1 simonb #include <sys/param.h>
67 1.1 simonb #include <sys/device.h>
68 1.1 simonb #include <sys/tty.h>
69 1.1 simonb #include <sys/systm.h>
70 1.1 simonb
71 1.1 simonb #include <lib/libkern/libkern.h>
72 1.1 simonb
73 1.4 scw #include <machine/cpu.h>
74 1.4 scw
75 1.1 simonb #include <powerpc/ibm4xx/dev/opbvar.h>
76 1.12 shige #include <powerpc/ibm4xx/dev/comopbvar.h>
77 1.1 simonb
78 1.12 shige #include "com.h"
79 1.12 shige #if (NCOM > 0)
80 1.1 simonb #include <dev/ic/comreg.h>
81 1.1 simonb #include <dev/ic/comvar.h>
82 1.12 shige #endif
83 1.1 simonb
84 1.1 simonb struct com_opb_softc {
85 1.1 simonb struct com_softc sc_com;
86 1.1 simonb void *sc_ih;
87 1.1 simonb };
88 1.1 simonb
89 1.20 cube static int com_opb_probe(device_t, cfdata_t , void *);
90 1.20 cube static void com_opb_attach(device_t, device_t, void *);
91 1.1 simonb
92 1.20 cube CFATTACH_DECL_NEW(com_opb, sizeof(struct com_opb_softc),
93 1.8 thorpej com_opb_probe, com_opb_attach, NULL, NULL);
94 1.1 simonb
95 1.1 simonb int
96 1.20 cube com_opb_probe(device_t parent, cfdata_t cf, void *aux)
97 1.1 simonb {
98 1.1 simonb struct opb_attach_args *oaa = aux;
99 1.1 simonb
100 1.1 simonb /* match only com devices */
101 1.5 thorpej if (strcmp(oaa->opb_name, cf->cf_name) != 0)
102 1.1 simonb return 0;
103 1.1 simonb
104 1.3 simonb return (1);
105 1.1 simonb }
106 1.1 simonb
107 1.1 simonb void
108 1.20 cube com_opb_attach(device_t parent, device_t self, void *aux)
109 1.1 simonb {
110 1.20 cube struct com_opb_softc *msc = device_private(self);
111 1.1 simonb struct com_softc *sc = &msc->sc_com;
112 1.1 simonb struct opb_attach_args *oaa = aux;
113 1.15 thorpej prop_number_t freq;
114 1.18 gdamore bus_space_handle_t ioh;
115 1.4 scw
116 1.20 cube sc->sc_dev = self;
117 1.20 cube
118 1.9 thorpej /* XXX console check */
119 1.9 thorpej
120 1.18 gdamore bus_space_map(oaa->opb_bt, oaa->opb_addr, COM_NPORTS, 0, &ioh);
121 1.18 gdamore COM_INIT_REGS(sc->sc_regs, oaa->opb_bt, ioh, oaa->opb_addr);
122 1.4 scw
123 1.20 cube freq = prop_dictionary_get(device_properties(sc->sc_dev),
124 1.17 thorpej "clock-frequency");
125 1.15 thorpej if (freq == NULL) {
126 1.20 cube aprint_error(": unable to get clock-frequency property\n");
127 1.9 thorpej return;
128 1.9 thorpej }
129 1.15 thorpej KASSERT(prop_object_type(freq) == PROP_TYPE_NUMBER);
130 1.15 thorpej sc->sc_frequency = (int) prop_number_integer_value(freq);
131 1.1 simonb
132 1.1 simonb com_attach_subr(sc);
133 1.1 simonb
134 1.4 scw intr_establish(oaa->opb_irq, IST_LEVEL, IPL_SERIAL, comintr, sc);
135 1.1 simonb }
136 1.12 shige
137 1.12 shige /*
138 1.12 shige * com_opb_cnattach:
139 1.12 shige * Initialize the system console.
140 1.12 shige */
141 1.12 shige void
142 1.12 shige com_opb_cnattach(int com_freq, int conaddr, int conspeed, int conmode)
143 1.12 shige {
144 1.12 shige static int attached = 0;
145 1.12 shige #if (NCOM > 0)
146 1.18 gdamore struct com_regs regs;
147 1.12 shige #endif
148 1.12 shige
149 1.12 shige if (attached)
150 1.12 shige return;
151 1.12 shige attached = 1;
152 1.12 shige
153 1.12 shige #if (NCOM > 0)
154 1.12 shige /* We *know* the com-console attaches to opb */
155 1.18 gdamore regs.cr_iot = opb_get_bus_space_tag();
156 1.18 gdamore regs.cr_iobase = conaddr;
157 1.18 gdamore regs.cr_nports = COM_NPORTS;
158 1.18 gdamore /* regs.ioh is initialized by comcnattach */
159 1.12 shige
160 1.18 gdamore if (comcnattach1(®s, conspeed, com_freq, COM_TYPE_NORMAL, conmode))
161 1.12 shige panic("can't init serial console @%x", conaddr);
162 1.12 shige else
163 1.12 shige return;
164 1.12 shige #endif
165 1.12 shige panic("console device missing -- serial console not in kernel");
166 1.12 shige /* Of course, this is moot if there is no console... */
167 1.12 shige }
168 1.12 shige
169 1.12 shige /*
170 1.12 shige * com_opb_device_register:
171 1.12 shige */
172 1.12 shige void
173 1.20 cube com_opb_device_register(device_t dev, int frequency)
174 1.12 shige {
175 1.15 thorpej /* Set the frequency of the on-chip UART. */
176 1.15 thorpej prop_number_t pn = prop_number_create_integer(frequency);
177 1.15 thorpej KASSERT(pn != NULL);
178 1.12 shige
179 1.15 thorpej if (prop_dictionary_set(device_properties(dev),
180 1.19 thorpej "clock-frequency", pn) == false) {
181 1.17 thorpej printf("WARNING: unable to set clock-frequency "
182 1.20 cube "property for %s\n", device_xname(dev));
183 1.15 thorpej }
184 1.15 thorpej prop_object_release(pn);
185 1.12 shige }
186