The UART divider should be calculated based on the base frequency
[coreboot.git] / src / console / uart8250_console.c
index 6eeeb6aa552db68bc1a68e05c37e956bf75dd01b..03db400319f89c30ffd3f2bef4d90ebaceb23806 100644 (file)
@@ -1,49 +1,62 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2003 Eric Biederman
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; version 2 of the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
 #include <console/console.h>
 #include <uart8250.h>
 #include <pc80/mc146818rtc.h>
 
-/* Base Address */
-#ifndef TTYS0_BASE
-#define TTYS0_BASE 0x3f8
-#endif
-
-#ifndef TTYS0_BAUD
-#define TTYS0_BAUD 115200
-#endif
-
-#if ((115200%TTYS0_BAUD) != 0)
-#error Bad ttys0 baud rate
-#endif
-
-#define TTYS0_DIV      (115200/TTYS0_BAUD)
-
-/* Line Control Settings */
-#ifndef TTYS0_LCS
-/* Set 8bit, 1 stop bit, no parity */
-#define TTYS0_LCS      0x3
-#endif
-
-#define UART_LCS       TTYS0_LCS
+static void ttyS0_init(void)
+{
+       static const unsigned char div[8] = { 1, 2, 3, 6, 12, 24, 48, 96 };
+       int b_index = 0;
+       /* TODO the divisor calculation is hard coded to standard UARTs. Some
+        * UARTs won't work with these values. This should be a property of the
+        * UART used, worst case a Kconfig variable. For now live with hard
+        * codes as the only devices that might be different are the iWave
+        * iRainbowG6 and the OXPCIe952 card (and the latter is memory mapped)
+        */
+       unsigned int divisor = 115200 / CONFIG_TTYS0_BAUD;
+
+       if (get_option(&b_index, "baud_rate") == 0) {
+               divisor = div[b_index];
+       }
+       uart8250_init(CONFIG_TTYS0_BASE, divisor);
+}
 
-void ttyS0_init(void)
+static void ttyS0_tx_byte(unsigned char data)
 {
-       static unsigned char div[8]={1,2,3,6,12,24,48,96};
-       int b_index=0;
-       unsigned int divisor=TTYS0_DIV;
+       uart8250_tx_byte(CONFIG_TTYS0_BASE, data);
+}
 
-       if(get_option(&b_index,"baud_rate")==0) {
-               divisor=div[b_index];
-       }
-       uart8250_init(TTYS0_BASE, divisor, TTYS0_LCS);
+static unsigned char ttyS0_rx_byte(void)
+{
+       return uart8250_rx_byte(CONFIG_TTYS0_BASE);
 }
 
-void ttyS0_tx_byte(unsigned char data) 
+static int ttyS0_tst_byte(void)
 {
-       uart8250_tx_byte(TTYS0_BASE, data);
+       return uart8250_can_rx_byte(CONFIG_TTYS0_BASE);
 }
 
-static struct console_driver uart8250_console __console = {
-       .init    = ttyS0_init,
-       .tx_byte = ttyS0_tx_byte,
+static const struct console_driver uart8250_console __console = {
+       .init     = ttyS0_init,
+       .tx_byte  = ttyS0_tx_byte,
+       .rx_byte  = ttyS0_rx_byte,
+       .tst_byte = ttyS0_tst_byte,
 };
-