diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2009-09-02 12:44:17 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2009-09-02 12:44:17 +0000 |
commit | c4385d3282f31e49b2c9d83525ee6a4b838892fd (patch) | |
tree | 419efdda879f38fd33a9e6824481ac881fb1fb1f /target/linux/ramips/files/arch/mips/ralink/common | |
parent | 73b20f81944f4be186f63db39d5c37d733afb8be (diff) | |
download | upstream-c4385d3282f31e49b2c9d83525ee6a4b838892fd.tar.gz upstream-c4385d3282f31e49b2c9d83525ee6a4b838892fd.tar.bz2 upstream-c4385d3282f31e49b2c9d83525ee6a4b838892fd.zip |
use common code for early_serial setup
SVN-Revision: 17467
Diffstat (limited to 'target/linux/ramips/files/arch/mips/ralink/common')
-rw-r--r-- | target/linux/ramips/files/arch/mips/ralink/common/setup.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/target/linux/ramips/files/arch/mips/ralink/common/setup.c b/target/linux/ramips/files/arch/mips/ralink/common/setup.c index 81a1ba4fa4..3030fcd153 100644 --- a/target/linux/ramips/files/arch/mips/ralink/common/setup.c +++ b/target/linux/ramips/files/arch/mips/ralink/common/setup.c @@ -12,6 +12,7 @@ #include <linux/kernel.h> #include <linux/init.h> #include <linux/io.h> +#include <linux/serial_8250.h> #include <asm/bootinfo.h> #include <asm/addrspace.h> @@ -43,6 +44,30 @@ static void __init detect_mem_size(void) add_memory_region(RALINK_SOC_SDRAM_BASE, size, BOOT_MEM_RAM); } +void __init ramips_early_serial_setup(int line, unsigned base, unsigned freq, + unsigned irq) +{ + struct uart_port p; + int err; + + memset(&p, 0, sizeof(p)); + p.flags = UPF_SKIP_TEST; + p.iotype = UPIO_AU; + p.uartclk = freq; + p.regshift = 2; + p.type = PORT_16550A; + + p.mapbase = base; + p.membase = ioremap_nocache(p.mapbase, PAGE_SIZE); + p.line = line; + p.irq = irq; + + err = early_serial_setup(&p); + if (err) + printk(KERN_ERR "early serial%d registration failed %d\n", + line, err); +} + void __init plat_mem_setup(void) { set_io_port_base(KSEG1); |