com_opb.c revision 1.18 1 1.18 gdamore /* $NetBSD: com_opb.c,v 1.18 2006/07/13 22:56:01 gdamore 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.18 gdamore __KERNEL_RCSID(0, "$NetBSD: com_opb.c,v 1.18 2006/07/13 22:56:01 gdamore 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.1 simonb static int com_opb_probe(struct device *, struct cfdata *, void *);
90 1.1 simonb static void com_opb_attach(struct device *, struct device *, void *);
91 1.1 simonb
92 1.7 thorpej CFATTACH_DECL(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.1 simonb com_opb_probe(struct device *parent, struct cfdata *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.1 simonb com_opb_attach(struct device *parent, struct device *self, void *aux)
109 1.1 simonb {
110 1.1 simonb struct com_opb_softc *msc = (void *)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.9 thorpej /* XXX console check */
117 1.9 thorpej
118 1.18 gdamore bus_space_map(oaa->opb_bt, oaa->opb_addr, COM_NPORTS, 0, &ioh);
119 1.18 gdamore COM_INIT_REGS(sc->sc_regs, oaa->opb_bt, ioh, oaa->opb_addr);
120 1.4 scw
121 1.17 thorpej freq = prop_dictionary_get(device_properties(&sc->sc_dev),
122 1.17 thorpej "clock-frequency");
123 1.15 thorpej if (freq == NULL) {
124 1.17 thorpej printf(": unable to get clock-frequency property\n");
125 1.9 thorpej return;
126 1.9 thorpej }
127 1.15 thorpej KASSERT(prop_object_type(freq) == PROP_TYPE_NUMBER);
128 1.15 thorpej sc->sc_frequency = (int) prop_number_integer_value(freq);
129 1.1 simonb
130 1.1 simonb com_attach_subr(sc);
131 1.1 simonb
132 1.4 scw intr_establish(oaa->opb_irq, IST_LEVEL, IPL_SERIAL, comintr, sc);
133 1.1 simonb }
134 1.12 shige
135 1.12 shige /*
136 1.12 shige * com_opb_cnattach:
137 1.12 shige * Initialize the system console.
138 1.12 shige */
139 1.12 shige void
140 1.12 shige com_opb_cnattach(int com_freq, int conaddr, int conspeed, int conmode)
141 1.12 shige {
142 1.12 shige static int attached = 0;
143 1.12 shige #if (NCOM > 0)
144 1.18 gdamore struct com_regs regs;
145 1.12 shige #endif
146 1.12 shige
147 1.12 shige if (attached)
148 1.12 shige return;
149 1.12 shige attached = 1;
150 1.12 shige
151 1.12 shige #if (NCOM > 0)
152 1.12 shige /* We *know* the com-console attaches to opb */
153 1.18 gdamore regs.cr_iot = opb_get_bus_space_tag();
154 1.18 gdamore regs.cr_iobase = conaddr;
155 1.18 gdamore regs.cr_nports = COM_NPORTS;
156 1.18 gdamore /* regs.ioh is initialized by comcnattach */
157 1.12 shige
158 1.18 gdamore if (comcnattach1(®s, conspeed, com_freq, COM_TYPE_NORMAL, conmode))
159 1.12 shige panic("can't init serial console @%x", conaddr);
160 1.12 shige else
161 1.12 shige return;
162 1.12 shige #endif
163 1.12 shige panic("console device missing -- serial console not in kernel");
164 1.12 shige /* Of course, this is moot if there is no console... */
165 1.12 shige }
166 1.12 shige
167 1.12 shige /*
168 1.12 shige * com_opb_device_register:
169 1.12 shige */
170 1.12 shige void
171 1.12 shige com_opb_device_register(struct device *dev, int frequency)
172 1.12 shige {
173 1.15 thorpej /* Set the frequency of the on-chip UART. */
174 1.15 thorpej prop_number_t pn = prop_number_create_integer(frequency);
175 1.15 thorpej KASSERT(pn != NULL);
176 1.12 shige
177 1.15 thorpej if (prop_dictionary_set(device_properties(dev),
178 1.17 thorpej "clock-frequency", pn) == FALSE) {
179 1.17 thorpej printf("WARNING: unable to set clock-frequency "
180 1.12 shige "property for %s\n", dev->dv_xname);
181 1.15 thorpej }
182 1.15 thorpej prop_object_release(pn);
183 1.12 shige }
184