1 /* $NetBSD: pxa2x0_com.c,v 1.11 2009/08/04 12:11:33 kiyohara Exp $ */
4 * Copyright 2003 Wasabi Systems, Inc.
7 * Written by Steve C. Woodford for Wasabi Systems, Inc.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software developed for the NetBSD Project by
20 * Wasabi Systems, Inc.
21 * 4. The name of Wasabi Systems, Inc. may not be used to endorse
22 * or promote products derived from this software without specific prior
25 * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC
29 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 * POSSIBILITY OF SUCH DAMAGE.
38 #include <sys/cdefs.h>
39 __KERNEL_RCSID(0, "$NetBSD: pxa2x0_com.c,v 1.11 2009/08/04 12:11:33 kiyohara Exp $");
44 #error "You must use options COM_PXA2X0 to get PXA2x0 serial port support"
47 #include <sys/param.h>
48 #include <sys/systm.h>
49 #include <sys/device.h>
50 #include <sys/termios.h>
52 #include <machine/intr.h>
53 #include <machine/bus.h>
55 #include <dev/ic/comreg.h>
56 #include <dev/ic/comvar.h>
58 #include <arm/xscale/pxa2x0cpu.h>
59 #include <arm/xscale/pxa2x0reg.h>
60 #include <arm/xscale/pxa2x0var.h>
61 #include <arm/xscale/pxa2x0_gpio.h>
65 static int pxauart_match(device_t
, cfdata_t
, void *);
66 static void pxauart_attach(device_t
, device_t
, void *);
68 CFATTACH_DECL_NEW(pxauart
, sizeof(struct com_softc
),
69 pxauart_match
, pxauart_attach
, NULL
, NULL
);
72 pxauart_match(device_t parent
, cfdata_t cf
, void *aux
)
74 struct pxaip_attach_args
*pxa
= aux
;
75 bus_space_tag_t bt
= &pxa2x0_a4x_bs_tag
; /* XXX: This sucks */
76 bus_space_handle_t bh
;
77 struct pxa2x0_gpioconf
*gpioconf
;
81 switch (pxa
->pxa_addr
) {
82 case PXA2X0_FFUART_BASE
:
83 if (pxa
->pxa_intr
!= PXA2X0_INT_FFUART
)
85 gpioconf
= CPU_IS_PXA250
? pxa25x_com_ffuart_gpioconf
:
86 pxa27x_com_ffuart_gpioconf
;
89 case PXA2X0_STUART_BASE
:
90 if (pxa
->pxa_intr
!= PXA2X0_INT_STUART
)
92 gpioconf
= CPU_IS_PXA250
? pxa25x_com_stuart_gpioconf
:
93 pxa27x_com_stuart_gpioconf
;
96 case PXA2X0_BTUART_BASE
: /* XXX: Config file option ... */
97 if (pxa
->pxa_intr
!= PXA2X0_INT_BTUART
)
99 gpioconf
= CPU_IS_PXA250
? pxa25x_com_btuart_gpioconf
:
100 pxa27x_com_btuart_gpioconf
;
103 case PXA2X0_HWUART_BASE
:
104 if (pxa
->pxa_intr
!= PXA2X0_INT_HWUART
)
108 gpioconf
= pxa25x_com_hwuart_gpioconf
;
114 for (i
= 0; gpioconf
[i
].pin
!= -1; i
++) {
115 gpio
= pxa2x0_gpio_get_function(gpioconf
[i
].pin
);
116 if (GPIO_FN(gpio
) != GPIO_FN(gpioconf
[i
].value
) ||
117 GPIO_FN_IS_OUT(gpio
) != GPIO_FN_IS_OUT(gpioconf
[i
].value
))
121 pxa
->pxa_size
= 0x20;
123 if (com_is_console(bt
, pxa
->pxa_addr
, NULL
))
126 if (bus_space_map(bt
, pxa
->pxa_addr
, pxa
->pxa_size
, 0, &bh
))
129 /* Make sure the UART is enabled */
130 bus_space_write_1(bt
, bh
, com_ier
, IER_EUART
);
132 rv
= comprobe1(bt
, bh
);
133 bus_space_unmap(bt
, bh
, pxa
->pxa_size
);
139 pxauart_attach(device_t parent
, device_t self
, void *aux
)
141 struct com_softc
*sc
= device_private(self
);
142 struct pxaip_attach_args
*pxa
= aux
;
144 bus_space_handle_t ioh
;
149 iot
= &pxa2x0_a4x_bs_tag
; /* XXX: This sucks */
150 iobase
= pxa
->pxa_addr
;
151 sc
->sc_frequency
= PXA2X0_COM_FREQ
;
152 sc
->sc_type
= COM_TYPE_PXA2x0
;
154 if (com_is_console(iot
, iobase
, &ioh
) == 0 &&
155 bus_space_map(iot
, iobase
, pxa
->pxa_size
, 0, &ioh
)) {
156 aprint_error(": can't map registers\n");
159 COM_INIT_REGS(sc
->sc_regs
, iot
, ioh
, iobase
);
161 switch (pxa
->pxa_addr
) {
162 case PXA2X0_FFUART_BASE
: cken
= CKEN_FFUART
; break;
163 case PXA2X0_STUART_BASE
: cken
= CKEN_STUART
; break;
164 case PXA2X0_BTUART_BASE
: cken
= CKEN_BTUART
; break;
165 case PXA2X0_HWUART_BASE
: cken
= CKEN_HWUART
; break;
167 pxa2x0_clkman_config(cken
, 1);
171 pxa2x0_intr_establish(pxa
->pxa_intr
, IPL_SERIAL
, comintr
, sc
);