2 * Copyright (C) 2009 Texas Instruments Inc.
3 * Mikkel Christensen <mlc@ti.com>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
10 #include <linux/kernel.h>
11 #include <linux/init.h>
12 #include <linux/gpio.h>
13 #include <linux/serial_8250.h>
14 #include <linux/smsc911x.h>
15 #include <linux/interrupt.h>
17 #include <plat/gpmc.h>
19 #define ZOOM_SMSC911X_CS 7
20 #define ZOOM_SMSC911X_GPIO 158
21 #define ZOOM_QUADUART_CS 3
22 #define ZOOM_QUADUART_GPIO 102
23 #define QUART_CLK 1843200
24 #define DEBUG_BASE 0x08000000
25 #define ZOOM_ETHR_START DEBUG_BASE
27 static struct resource zoom_smsc911x_resources
[] = {
29 .start
= ZOOM_ETHR_START
,
30 .end
= ZOOM_ETHR_START
+ SZ_4K
,
31 .flags
= IORESOURCE_MEM
,
34 .flags
= IORESOURCE_IRQ
| IORESOURCE_IRQ_LOWLEVEL
,
38 static struct smsc911x_platform_config zoom_smsc911x_config
= {
39 .irq_polarity
= SMSC911X_IRQ_POLARITY_ACTIVE_LOW
,
40 .irq_type
= SMSC911X_IRQ_TYPE_OPEN_DRAIN
,
41 .flags
= SMSC911X_USE_32BIT
,
42 .phy_interface
= PHY_INTERFACE_MODE_MII
,
45 static struct platform_device zoom_smsc911x_device
= {
48 .num_resources
= ARRAY_SIZE(zoom_smsc911x_resources
),
49 .resource
= zoom_smsc911x_resources
,
51 .platform_data
= &zoom_smsc911x_config
,
55 static inline void __init
zoom_init_smsc911x(void)
58 unsigned long cs_mem_base
;
61 eth_cs
= ZOOM_SMSC911X_CS
;
63 if (gpmc_cs_request(eth_cs
, SZ_16M
, &cs_mem_base
) < 0) {
64 printk(KERN_ERR
"Failed to request GPMC mem for smsc911x\n");
68 zoom_smsc911x_resources
[0].start
= cs_mem_base
+ 0x0;
69 zoom_smsc911x_resources
[0].end
= cs_mem_base
+ 0xff;
71 eth_gpio
= ZOOM_SMSC911X_GPIO
;
73 zoom_smsc911x_resources
[1].start
= OMAP_GPIO_IRQ(eth_gpio
);
75 if (gpio_request(eth_gpio
, "smsc911x irq") < 0) {
76 printk(KERN_ERR
"Failed to request GPIO%d for smsc911x IRQ\n",
80 gpio_direction_input(eth_gpio
);
83 static struct plat_serial8250_port serial_platform_data
[] = {
85 .mapbase
= 0x10000000,
86 .irq
= OMAP_GPIO_IRQ(102),
87 .flags
= UPF_BOOT_AUTOCONF
|UPF_IOREMAP
|UPF_SHARE_IRQ
,
88 .irqflags
= IRQF_SHARED
| IRQF_TRIGGER_RISING
,
97 static struct platform_device zoom_debugboard_serial_device
= {
99 .id
= PLAT8250_DEV_PLATFORM
,
101 .platform_data
= serial_platform_data
,
105 static inline void __init
zoom_init_quaduart(void)
108 unsigned long cs_mem_base
;
111 quart_cs
= ZOOM_QUADUART_CS
;
113 if (gpmc_cs_request(quart_cs
, SZ_1M
, &cs_mem_base
) < 0) {
114 printk(KERN_ERR
"Failed to request GPMC mem"
115 "for Quad UART(TL16CP754C)\n");
119 quart_gpio
= ZOOM_QUADUART_GPIO
;
121 if (gpio_request(quart_gpio
, "TL16CP754C GPIO") < 0) {
122 printk(KERN_ERR
"Failed to request GPIO%d for TL16CP754C\n",
126 gpio_direction_input(quart_gpio
);
129 static inline int omap_zoom_debugboard_detect(void)
131 int debug_board_detect
= 0;
134 debug_board_detect
= ZOOM_SMSC911X_GPIO
;
136 if (gpio_request(debug_board_detect
, "Zoom debug board detect") < 0) {
137 printk(KERN_ERR
"Failed to request GPIO%d for Zoom debug"
138 "board detect\n", debug_board_detect
);
141 gpio_direction_input(debug_board_detect
);
143 if (!gpio_get_value(debug_board_detect
)) {
146 gpio_free(debug_board_detect
);
150 static struct platform_device
*zoom_devices
[] __initdata
= {
151 &zoom_smsc911x_device
,
152 &zoom_debugboard_serial_device
,
155 int __init
zoom_debugboard_init(void)
157 if (!omap_zoom_debugboard_detect())
160 zoom_init_smsc911x();
161 zoom_init_quaduart();
162 return platform_add_devices(zoom_devices
, ARRAY_SIZE(zoom_devices
));