diff options
author | cognet <cognet@FreeBSD.org> | 2006-04-06 20:47:54 +0000 |
---|---|---|
committer | cognet <cognet@FreeBSD.org> | 2006-04-06 20:47:54 +0000 |
commit | 8b8bb58f45b6341b27108020661cbad7d90abb3b (patch) | |
tree | 92ca8a54f54a11e201fbaeabf3702b0935af1cb6 /sys | |
parent | a29f457114ce2ace6c1e5ca9ab7b2df898f96da3 (diff) | |
download | FreeBSD-src-8b8bb58f45b6341b27108020661cbad7d90abb3b.zip FreeBSD-src-8b8bb58f45b6341b27108020661cbad7d90abb3b.tar.gz |
MFp4: Catchup with recent UART changes.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arm/at91/uart_dev_at91usart.c | 26 | ||||
-rw-r--r-- | sys/arm/sa11x0/uart_dev_sa1110.c | 4 |
2 files changed, 15 insertions, 15 deletions
diff --git a/sys/arm/at91/uart_dev_at91usart.c b/sys/arm/at91/uart_dev_at91usart.c index 1ac8ba0..43905b2 100644 --- a/sys/arm/at91/uart_dev_at91usart.c +++ b/sys/arm/at91/uart_dev_at91usart.c @@ -80,7 +80,7 @@ static void at91_usart_init(struct uart_bas *bas, int, int, int, int); static void at91_usart_term(struct uart_bas *bas); static void at91_usart_putc(struct uart_bas *bas, int); static int at91_usart_poll(struct uart_bas *bas); -static int at91_usart_getc(struct uart_bas *bas); +static int at91_usart_getc(struct uart_bas *bas, struct mtx *mtx); extern SLIST_HEAD(uart_devinfo_list, uart_devinfo) uart_sysdevs; @@ -248,7 +248,7 @@ at91_usart_poll(struct uart_bas *bas) * Block waiting for a character. */ static int -at91_usart_getc(struct uart_bas *bas) +at91_usart_getc(struct uart_bas *bas, struct mtx *mtx) { int c; @@ -343,7 +343,7 @@ at91_usart_bus_transmit(struct uart_softc *sc) return (EAGAIN); bus_dmamap_sync(atsc->dmatag, atsc->tx_map, BUS_DMASYNC_PREWRITE); - mtx_lock_spin(&sc->sc_hwmtx); + uart_lock(sc->sc_hwmtx); sc->sc_txbusy = 1; /* * Setup the PDC to transfer the data and interrupt us when it @@ -352,7 +352,7 @@ at91_usart_bus_transmit(struct uart_softc *sc) WR4(&sc->sc_bas, PDC_TPR, addr); WR4(&sc->sc_bas, PDC_TCR, sc->sc_txdatasz); WR4(&sc->sc_bas, PDC_PTCR, PDC_PTCR_TXTEN); - mtx_unlock_spin(&sc->sc_hwmtx); + uart_unlock(sc->sc_hwmtx); #ifdef USART0_CONSOLE /* * XXX: Gross hack : Skyeye doesn't raise an interrupt once the @@ -377,7 +377,7 @@ at91_usart_bus_setsig(struct uart_softc *sc, int sig) SIGCHG(sig & SER_RTS, new, SER_RTS, SER_DRTS); } while (!atomic_cmpset_32(&sc->sc_hwsig, old, new)); bas = &sc->sc_bas; - mtx_lock_spin(&sc->sc_hwmtx); + uart_lock(sc->sc_hwmtx); cr = RD4(bas, USART_CR); cr &= ~(USART_CR_DTREN | USART_CR_DTRDIS | USART_CR_RTSEN | USART_CR_RTSDIS); @@ -390,16 +390,16 @@ at91_usart_bus_setsig(struct uart_softc *sc, int sig) else cr |= USART_CR_RTSDIS; WR4(bas, USART_CR, cr); - mtx_unlock_spin(&sc->sc_hwmtx); + uart_unlock(sc->sc_hwmtx); return (0); } static int at91_usart_bus_receive(struct uart_softc *sc) { - mtx_lock_spin(&sc->sc_hwmtx); - uart_rx_put(sc, at91_usart_getc(&sc->sc_bas)); - mtx_unlock_spin(&sc->sc_hwmtx); + uart_lock(sc->sc_hwmtx); + uart_rx_put(sc, at91_usart_getc(&sc->sc_bas, NULL)); + uart_unlock(sc->sc_hwmtx); return (0); } static int @@ -431,7 +431,7 @@ at91_usart_bus_ipend(struct uart_softc *sc) BUS_DMASYNC_POSTWRITE); bus_dmamap_unload(atsc->dmatag, atsc->tx_map); } - mtx_lock_spin(&sc->sc_hwmtx); + uart_lock(sc->sc_hwmtx); if (csr & USART_CSR_TXRDY && sc->sc_txbusy) ipend |= SER_INT_TXIDLE; if (csr & USART_CSR_ENDTX && sc->sc_txbusy) @@ -444,7 +444,7 @@ at91_usart_bus_ipend(struct uart_softc *sc) ipend |= SER_INT_BREAK; WR4(&sc->sc_bas, USART_CR, cr); } - mtx_unlock_spin(&sc->sc_hwmtx); + uart_unlock(sc->sc_hwmtx); return (ipend); } static int @@ -459,7 +459,7 @@ at91_usart_bus_getsig(struct uart_softc *sc) uint32_t new, sig; uint8_t csr; - mtx_lock_spin(&sc->sc_hwmtx); + uart_lock(sc->sc_hwmtx); csr = RD4(&sc->sc_bas, USART_CSR); sig = 0; if (csr & USART_CSR_CTS) @@ -472,7 +472,7 @@ at91_usart_bus_getsig(struct uart_softc *sc) sig |= SER_RI; new = sig & ~SER_MASK_DELTA; sc->sc_hwsig = new; - mtx_unlock_spin(&sc->sc_hwmtx); + uart_unlock(sc->sc_hwmtx); return (sig); } diff --git a/sys/arm/sa11x0/uart_dev_sa1110.c b/sys/arm/sa11x0/uart_dev_sa1110.c index e1ba5fe..0bf8add 100644 --- a/sys/arm/sa11x0/uart_dev_sa1110.c +++ b/sys/arm/sa11x0/uart_dev_sa1110.c @@ -54,7 +54,7 @@ static void sa1110_init(struct uart_bas *bas, int, int, int, int); static void sa1110_term(struct uart_bas *bas); static void sa1110_putc(struct uart_bas *bas, int); static int sa1110_poll(struct uart_bas *bas); -static int sa1110_getc(struct uart_bas *bas); +static int sa1110_getc(struct uart_bas *bas, struct mtx *mtx); int did_mmu = 0; @@ -132,7 +132,7 @@ sa1110_poll(struct uart_bas *bas) } static int -sa1110_getc(struct uart_bas *bas) +sa1110_getc(struct uart_bas *bas, struct mtx *mtx) { int c; /* XXX: sigh. */ |