com_opb.c revision 1.12 1 1.12 shige /* $NetBSD: com_opb.c,v 1.12 2004/12/24 14:55:50 shige 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.12 shige __KERNEL_RCSID(0, "$NetBSD: com_opb.c,v 1.12 2004/12/24 14:55:50 shige 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.4 scw
114 1.1 simonb sc->sc_iot = oaa->opb_bt;
115 1.4 scw sc->sc_iobase = oaa->opb_addr;
116 1.4 scw
117 1.9 thorpej /* XXX console check */
118 1.9 thorpej
119 1.4 scw bus_space_map(sc->sc_iot, oaa->opb_addr, COM_NPORTS, 0,
120 1.4 scw &sc->sc_ioh);
121 1.4 scw
122 1.9 thorpej if (prop_get(dev_propdb, &sc->sc_dev, "frequency",
123 1.10 simonb &sc->sc_frequency, sizeof(sc->sc_frequency), NULL) == -1) {
124 1.9 thorpej printf(": unable to get frequency property\n");
125 1.9 thorpej return;
126 1.9 thorpej }
127 1.1 simonb
128 1.1 simonb com_attach_subr(sc);
129 1.1 simonb
130 1.4 scw intr_establish(oaa->opb_irq, IST_LEVEL, IPL_SERIAL, comintr, sc);
131 1.1 simonb }
132 1.12 shige
133 1.12 shige /*
134 1.12 shige * com_opb_cnattach:
135 1.12 shige * Initialize the system console.
136 1.12 shige */
137 1.12 shige void
138 1.12 shige com_opb_cnattach(int com_freq, int conaddr, int conspeed, int conmode)
139 1.12 shige {
140 1.12 shige static int attached = 0;
141 1.12 shige #if (NCOM > 0)
142 1.12 shige bus_space_tag_t tag;
143 1.12 shige #endif
144 1.12 shige
145 1.12 shige if (attached)
146 1.12 shige return;
147 1.12 shige attached = 1;
148 1.12 shige
149 1.12 shige #if (NCOM > 0)
150 1.12 shige /* We *know* the com-console attaches to opb */
151 1.12 shige tag = opb_get_bus_space_tag();
152 1.12 shige
153 1.12 shige if (comcnattach(tag,
154 1.12 shige conaddr, conspeed, com_freq, COM_TYPE_NORMAL, conmode))
155 1.12 shige panic("can't init serial console @%x", conaddr);
156 1.12 shige else
157 1.12 shige return;
158 1.12 shige #endif
159 1.12 shige panic("console device missing -- serial console not in kernel");
160 1.12 shige /* Of course, this is moot if there is no console... */
161 1.12 shige }
162 1.12 shige
163 1.12 shige /*
164 1.12 shige * com_opb_device_register:
165 1.12 shige */
166 1.12 shige void
167 1.12 shige com_opb_device_register(struct device *dev, int frequency)
168 1.12 shige {
169 1.12 shige int com_freq = frequency;
170 1.12 shige
171 1.12 shige /* Set the frequency of the on-chip UART. */
172 1.12 shige if (prop_set(dev_propdb, dev, "frequency",
173 1.12 shige &com_freq, sizeof(com_freq), PROP_INT, 0) != 0)
174 1.12 shige printf("WARNING: unable to set frequency "
175 1.12 shige "property for %s\n", dev->dv_xname);
176 1.12 shige return;
177 1.12 shige }
178