diff options
author | Tony Lindgren <tony@atomide.com> | 2009-10-16 12:53:00 -0400 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2009-10-16 12:53:00 -0400 |
commit | 84f90c9cc81d8db172d4f768fc4010f508897366 (patch) | |
tree | 22dc6c2d0ea698e4e16651f14840e409fa7da5d5 /arch/arm/mach-omap2/serial.c | |
parent | a2bb28a0dbcc1370104a543d25eb28aab81d4a91 (diff) |
omap: Change low-level serial init to use ioremap
Change low-level serial init to use ioremap
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap2/serial.c')
-rw-r--r-- | arch/arm/mach-omap2/serial.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/arch/arm/mach-omap2/serial.c b/arch/arm/mach-omap2/serial.c index ae2186892c85..a1949d4262cd 100644 --- a/arch/arm/mach-omap2/serial.c +++ b/arch/arm/mach-omap2/serial.c | |||
@@ -73,7 +73,6 @@ static LIST_HEAD(uart_list); | |||
73 | 73 | ||
74 | static struct plat_serial8250_port serial_platform_data0[] = { | 74 | static struct plat_serial8250_port serial_platform_data0[] = { |
75 | { | 75 | { |
76 | .membase = OMAP2_IO_ADDRESS(OMAP_UART1_BASE), | ||
77 | .mapbase = OMAP_UART1_BASE, | 76 | .mapbase = OMAP_UART1_BASE, |
78 | .irq = 72, | 77 | .irq = 72, |
79 | .flags = UPF_BOOT_AUTOCONF, | 78 | .flags = UPF_BOOT_AUTOCONF, |
@@ -87,7 +86,6 @@ static struct plat_serial8250_port serial_platform_data0[] = { | |||
87 | 86 | ||
88 | static struct plat_serial8250_port serial_platform_data1[] = { | 87 | static struct plat_serial8250_port serial_platform_data1[] = { |
89 | { | 88 | { |
90 | .membase = OMAP2_IO_ADDRESS(OMAP_UART2_BASE), | ||
91 | .mapbase = OMAP_UART2_BASE, | 89 | .mapbase = OMAP_UART2_BASE, |
92 | .irq = 73, | 90 | .irq = 73, |
93 | .flags = UPF_BOOT_AUTOCONF, | 91 | .flags = UPF_BOOT_AUTOCONF, |
@@ -101,7 +99,6 @@ static struct plat_serial8250_port serial_platform_data1[] = { | |||
101 | 99 | ||
102 | static struct plat_serial8250_port serial_platform_data2[] = { | 100 | static struct plat_serial8250_port serial_platform_data2[] = { |
103 | { | 101 | { |
104 | .membase = OMAP2_IO_ADDRESS(OMAP_UART3_BASE), | ||
105 | .mapbase = OMAP_UART3_BASE, | 102 | .mapbase = OMAP_UART3_BASE, |
106 | .irq = 74, | 103 | .irq = 74, |
107 | .flags = UPF_BOOT_AUTOCONF, | 104 | .flags = UPF_BOOT_AUTOCONF, |
@@ -126,7 +123,6 @@ static struct plat_serial8250_port serial_platform_data2[] = { | |||
126 | #ifdef CONFIG_ARCH_OMAP4 | 123 | #ifdef CONFIG_ARCH_OMAP4 |
127 | static struct plat_serial8250_port serial_platform_data3[] = { | 124 | static struct plat_serial8250_port serial_platform_data3[] = { |
128 | { | 125 | { |
129 | .membase = OMAP2_IO_ADDRESS(OMAP_UART4_BASE), | ||
130 | .mapbase = OMAP_UART4_BASE, | 126 | .mapbase = OMAP_UART4_BASE, |
131 | .irq = 70, | 127 | .irq = 70, |
132 | .flags = UPF_BOOT_AUTOCONF, | 128 | .flags = UPF_BOOT_AUTOCONF, |
@@ -605,6 +601,16 @@ void __init omap_serial_early_init(void) | |||
605 | struct device *dev = &pdev->dev; | 601 | struct device *dev = &pdev->dev; |
606 | struct plat_serial8250_port *p = dev->platform_data; | 602 | struct plat_serial8250_port *p = dev->platform_data; |
607 | 603 | ||
604 | /* | ||
605 | * Module 4KB + L4 interconnect 4KB | ||
606 | * Static mapping, never released | ||
607 | */ | ||
608 | p->membase = ioremap(p->mapbase, SZ_8K); | ||
609 | if (!p->membase) { | ||
610 | printk(KERN_ERR "ioremap failed for uart%i\n", i + 1); | ||
611 | continue; | ||
612 | } | ||
613 | |||
608 | sprintf(name, "uart%d_ick", i+1); | 614 | sprintf(name, "uart%d_ick", i+1); |
609 | uart->ick = clk_get(NULL, name); | 615 | uart->ick = clk_get(NULL, name); |
610 | if (IS_ERR(uart->ick)) { | 616 | if (IS_ERR(uart->ick)) { |