blob: 6092226a6d766e07bb4f5bc9ae47a0be341de6e7 [file] [log] [blame]
Maxime Bizone7300d02009-08-18 13:23:37 +01001/*
2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
4 * for more details.
5 *
6 * Copyright (C) 2008 Maxime Bizon <mbizon@freebox.fr>
7 */
8
Maxime Bizone7300d02009-08-18 13:23:37 +01009#include <bcm63xx_io.h>
Florian Fainellie95acd32013-12-05 18:26:08 -080010#include <linux/serial_bcm63xx.h>
Maxime Bizone7300d02009-08-18 13:23:37 +010011
Aaro Koskinenf7be4e72013-02-11 20:51:49 +000012static void wait_xfered(void)
Maxime Bizone7300d02009-08-18 13:23:37 +010013{
14 unsigned int val;
15
16 /* wait for any previous char to be transmitted */
17 do {
18 val = bcm_uart0_readl(UART_IR_REG);
19 if (val & UART_IR_STAT(UART_IR_TXEMPTY))
20 break;
21 } while (1);
22}
23
Aaro Koskinenf7be4e72013-02-11 20:51:49 +000024void prom_putchar(char c)
Maxime Bizone7300d02009-08-18 13:23:37 +010025{
26 wait_xfered();
27 bcm_uart0_writel(c, UART_FIFO_REG);
28 wait_xfered();
29}