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