Blame view
arch/arm/mach-mx5/board-cpuimx51.c
8.23 KB
ef93f1443 i.MX51: add suppo... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
/* * * Copyright (C) 2010 Eric Bénard <eric@eukrea.com> * * based on board-mx51_babbage.c which is * Copyright 2009 Freescale Semiconductor, Inc. All Rights Reserved. * Copyright (C) 2009-2010 Amit Kucheria <amit.kucheria@canonical.com> * * The code contained herein is licensed under the GNU General Public * License. You may obtain a copy of the GNU General Public License * Version 2 or later at the following locations: * * http://www.opensource.org/licenses/gpl-license.html * http://www.gnu.org/copyleft/gpl.html */ #include <linux/init.h> #include <linux/platform_device.h> #include <linux/serial_8250.h> #include <linux/i2c.h> #include <linux/gpio.h> #include <linux/delay.h> #include <linux/io.h> #include <linux/interrupt.h> |
ef93f1443 i.MX51: add suppo... |
25 26 27 28 |
#include <mach/eukrea-baseboards.h> #include <mach/common.h> #include <mach/hardware.h> |
ef93f1443 i.MX51: add suppo... |
29 |
#include <mach/iomux-mx51.h> |
ef93f1443 i.MX51: add suppo... |
30 |
|
ef93f1443 i.MX51: add suppo... |
31 32 33 34 |
#include <asm/setup.h> #include <asm/mach-types.h> #include <asm/mach/arch.h> #include <asm/mach/time.h> |
04b73b157 ARM: mx51: dynami... |
35 |
#include "devices-imx51.h" |
ef93f1443 i.MX51: add suppo... |
36 |
|
96886c436 iMX51: introduce ... |
37 38 39 40 41 |
#define CPUIMX51_USBH1_STP IMX_GPIO_NR(1, 27) #define CPUIMX51_QUARTA_GPIO IMX_GPIO_NR(3, 28) #define CPUIMX51_QUARTB_GPIO IMX_GPIO_NR(3, 25) #define CPUIMX51_QUARTC_GPIO IMX_GPIO_NR(3, 26) #define CPUIMX51_QUARTD_GPIO IMX_GPIO_NR(3, 27) |
ef93f1443 i.MX51: add suppo... |
42 43 44 45 46 47 48 49 50 51 |
#define CPUIMX51_QUART_XTAL 14745600 #define CPUIMX51_QUART_REGSHIFT 17 /* USB_CTRL_1 */ #define MX51_USB_CTRL_1_OFFSET 0x10 #define MX51_USB_CTRL_UH1_EXT_CLK_EN (1 << 25) #define MX51_USB_PLLDIV_12_MHZ 0x00 #define MX51_USB_PLL_DIV_19_2_MHZ 0x01 #define MX51_USB_PLL_DIV_24_MHZ 0x02 |
ef93f1443 i.MX51: add suppo... |
52 53 54 |
static struct plat_serial8250_port serial_platform_data[] = { { .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x400000), |
e309fb186 arm/mxc: do not u... |
55 |
.irq = IMX_GPIO_TO_IRQ(CPUIMX51_QUARTA_GPIO), |
ef93f1443 i.MX51: add suppo... |
56 57 58 59 60 61 62 |
.irqflags = IRQF_TRIGGER_HIGH, .uartclk = CPUIMX51_QUART_XTAL, .regshift = CPUIMX51_QUART_REGSHIFT, .iotype = UPIO_MEM, .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, }, { .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x800000), |
e309fb186 arm/mxc: do not u... |
63 |
.irq = IMX_GPIO_TO_IRQ(CPUIMX51_QUARTB_GPIO), |
ef93f1443 i.MX51: add suppo... |
64 65 66 67 68 69 70 |
.irqflags = IRQF_TRIGGER_HIGH, .uartclk = CPUIMX51_QUART_XTAL, .regshift = CPUIMX51_QUART_REGSHIFT, .iotype = UPIO_MEM, .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, }, { .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x1000000), |
e309fb186 arm/mxc: do not u... |
71 |
.irq = IMX_GPIO_TO_IRQ(CPUIMX51_QUARTC_GPIO), |
ef93f1443 i.MX51: add suppo... |
72 73 74 75 76 77 78 |
.irqflags = IRQF_TRIGGER_HIGH, .uartclk = CPUIMX51_QUART_XTAL, .regshift = CPUIMX51_QUART_REGSHIFT, .iotype = UPIO_MEM, .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, }, { .mapbase = (unsigned long)(MX51_CS1_BASE_ADDR + 0x2000000), |
e309fb186 arm/mxc: do not u... |
79 |
.irq = IMX_GPIO_TO_IRQ(CPUIMX51_QUARTD_GPIO), |
ef93f1443 i.MX51: add suppo... |
80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |
.irqflags = IRQF_TRIGGER_HIGH, .uartclk = CPUIMX51_QUART_XTAL, .regshift = CPUIMX51_QUART_REGSHIFT, .iotype = UPIO_MEM, .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP, }, { } }; static struct platform_device serial_device = { .name = "serial8250", .id = 0, .dev = { .platform_data = serial_platform_data, }, }; |
ef93f1443 i.MX51: add suppo... |
96 97 |
static struct platform_device *devices[] __initdata = { |
ef93f1443 i.MX51: add suppo... |
98 |
&serial_device, |
ef93f1443 i.MX51: add suppo... |
99 |
}; |
8f5260c8c ARM: i.MX IOMUX-V... |
100 |
static iomux_v3_cfg_t eukrea_cpuimx51_pads[] = { |
ef93f1443 i.MX51: add suppo... |
101 102 103 104 105 106 107 |
/* UART1 */ MX51_PAD_UART1_RXD__UART1_RXD, MX51_PAD_UART1_TXD__UART1_TXD, MX51_PAD_UART1_RTS__UART1_RTS, MX51_PAD_UART1_CTS__UART1_CTS, /* I2C2 */ |
ee1ae4d7b ARM i.MX51: Full ... |
108 109 110 |
MX51_PAD_GPIO1_2__I2C2_SCL, MX51_PAD_GPIO1_3__I2C2_SDA, MX51_PAD_NANDF_D10__GPIO3_30, |
ef93f1443 i.MX51: add suppo... |
111 112 |
/* QUART IRQ */ |
ee1ae4d7b ARM i.MX51: Full ... |
113 114 115 116 |
MX51_PAD_NANDF_D15__GPIO3_25, MX51_PAD_NANDF_D14__GPIO3_26, MX51_PAD_NANDF_D13__GPIO3_27, MX51_PAD_NANDF_D12__GPIO3_28, |
ef93f1443 i.MX51: add suppo... |
117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
/* USB HOST1 */ MX51_PAD_USBH1_CLK__USBH1_CLK, MX51_PAD_USBH1_DIR__USBH1_DIR, MX51_PAD_USBH1_NXT__USBH1_NXT, MX51_PAD_USBH1_DATA0__USBH1_DATA0, MX51_PAD_USBH1_DATA1__USBH1_DATA1, MX51_PAD_USBH1_DATA2__USBH1_DATA2, MX51_PAD_USBH1_DATA3__USBH1_DATA3, MX51_PAD_USBH1_DATA4__USBH1_DATA4, MX51_PAD_USBH1_DATA5__USBH1_DATA5, MX51_PAD_USBH1_DATA6__USBH1_DATA6, MX51_PAD_USBH1_DATA7__USBH1_DATA7, MX51_PAD_USBH1_STP__USBH1_STP, }; |
a3927416b cpuimx51: update ... |
132 133 134 135 136 137 |
static const struct mxc_nand_platform_data eukrea_cpuimx51_nand_board_info __initconst = { .width = 1, .hw_ecc = 1, .flash_bbt = 1, }; |
04b73b157 ARM: mx51: dynami... |
138 |
static const struct imxuart_platform_data uart_pdata __initconst = { |
ef93f1443 i.MX51: add suppo... |
139 140 |
.flags = IMXUART_HAVE_RTSCTS, }; |
44505c076 ARM: mx5: dynamic... |
141 142 |
static const struct imxi2c_platform_data eukrea_cpuimx51_i2c_data __initconst = { |
ef93f1443 i.MX51: add suppo... |
143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 |
.bitrate = 100000, }; static struct i2c_board_info eukrea_cpuimx51_i2c_devices[] = { { I2C_BOARD_INFO("pcf8563", 0x51), }, }; /* This function is board specific as the bit mask for the plldiv will also be different for other Freescale SoCs, thus a common bitmask is not possible and cannot get place in /plat-mxc/ehci.c.*/ static int initialize_otg_port(struct platform_device *pdev) { u32 v; void __iomem *usb_base; void __iomem *usbother_base; |
7d92e8e6c ARM: mx5: dynamic... |
160 |
usb_base = ioremap(MX51_USB_OTG_BASE_ADDR, SZ_4K); |
28a4f908a ARM: mx5: check f... |
161 162 |
if (!usb_base) return -ENOMEM; |
ef93f1443 i.MX51: add suppo... |
163 164 165 166 167 168 169 170 |
usbother_base = usb_base + MX5_USBOTHER_REGS_OFFSET; /* Set the PHY clock to 19.2MHz */ v = __raw_readl(usbother_base + MXC_USB_PHY_CTR_FUNC2_OFFSET); v &= ~MX5_USB_UTMI_PHYCTRL1_PLLDIV_MASK; v |= MX51_USB_PLL_DIV_19_2_MHZ; __raw_writel(v, usbother_base + MXC_USB_PHY_CTR_FUNC2_OFFSET); iounmap(usb_base); |
4bd597b63 ARM i.MX ehci: do... |
171 172 173 174 |
mdelay(10); return mx51_initialize_usb_hw(0, MXC_EHCI_INTERNAL_PHY); |
ef93f1443 i.MX51: add suppo... |
175 176 177 178 179 180 181 |
} static int initialize_usbh1_port(struct platform_device *pdev) { u32 v; void __iomem *usb_base; void __iomem *usbother_base; |
7d92e8e6c ARM: mx5: dynamic... |
182 |
usb_base = ioremap(MX51_USB_OTG_BASE_ADDR, SZ_4K); |
28a4f908a ARM: mx5: check f... |
183 184 |
if (!usb_base) return -ENOMEM; |
ef93f1443 i.MX51: add suppo... |
185 186 187 188 189 190 |
usbother_base = usb_base + MX5_USBOTHER_REGS_OFFSET; /* The clock for the USBH1 ULPI port will come externally from the PHY. */ v = __raw_readl(usbother_base + MX51_USB_CTRL_1_OFFSET); __raw_writel(v | MX51_USB_CTRL_UH1_EXT_CLK_EN, usbother_base + MX51_USB_CTRL_1_OFFSET); iounmap(usb_base); |
4bd597b63 ARM i.MX ehci: do... |
191 192 193 194 195 |
mdelay(10); return mx51_initialize_usb_hw(1, MXC_EHCI_POWER_PINS_ENABLED | MXC_EHCI_ITC_NO_THRESHOLD); |
ef93f1443 i.MX51: add suppo... |
196 |
} |
7d92e8e6c ARM: mx5: dynamic... |
197 |
static const struct mxc_usbh_platform_data dr_utmi_config __initconst = { |
ef93f1443 i.MX51: add suppo... |
198 199 |
.init = initialize_otg_port, .portsc = MXC_EHCI_UTMI_16BIT, |
ef93f1443 i.MX51: add suppo... |
200 |
}; |
6cafe48a6 ARM: mx5: dynamic... |
201 |
static const struct fsl_usb2_platform_data usb_pdata __initconst = { |
ef93f1443 i.MX51: add suppo... |
202 203 204 |
.operating_mode = FSL_USB2_DR_DEVICE, .phy_mode = FSL_USB2_PHY_UTMI_WIDE, }; |
7d92e8e6c ARM: mx5: dynamic... |
205 |
static const struct mxc_usbh_platform_data usbh1_config __initconst = { |
ef93f1443 i.MX51: add suppo... |
206 207 |
.init = initialize_usbh1_port, .portsc = MXC_EHCI_MODE_ULPI, |
ef93f1443 i.MX51: add suppo... |
208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 |
}; static int otg_mode_host; static int __init eukrea_cpuimx51_otg_mode(char *options) { if (!strcmp(options, "host")) otg_mode_host = 1; else if (!strcmp(options, "device")) otg_mode_host = 0; else pr_info("otg_mode neither \"host\" nor \"device\". " "Defaulting to device "); return 0; } __setup("otg_mode=", eukrea_cpuimx51_otg_mode); /* * Board specific initialization. */ static void __init eukrea_cpuimx51_init(void) { |
b78d8e59a gpio/mxc: Change ... |
231 |
imx51_soc_init(); |
ef93f1443 i.MX51: add suppo... |
232 233 |
mxc_iomux_v3_setup_multiple_pads(eukrea_cpuimx51_pads, ARRAY_SIZE(eukrea_cpuimx51_pads)); |
04b73b157 ARM: mx51: dynami... |
234 |
imx51_add_imx_uart(0, &uart_pdata); |
a3927416b cpuimx51: update ... |
235 |
imx51_add_mxc_nand(&eukrea_cpuimx51_nand_board_info); |
ef93f1443 i.MX51: add suppo... |
236 237 238 239 240 241 242 243 244 245 246 247 |
gpio_request(CPUIMX51_QUARTA_GPIO, "quarta_irq"); gpio_direction_input(CPUIMX51_QUARTA_GPIO); gpio_free(CPUIMX51_QUARTA_GPIO); gpio_request(CPUIMX51_QUARTB_GPIO, "quartb_irq"); gpio_direction_input(CPUIMX51_QUARTB_GPIO); gpio_free(CPUIMX51_QUARTB_GPIO); gpio_request(CPUIMX51_QUARTC_GPIO, "quartc_irq"); gpio_direction_input(CPUIMX51_QUARTC_GPIO); gpio_free(CPUIMX51_QUARTC_GPIO); gpio_request(CPUIMX51_QUARTD_GPIO, "quartd_irq"); gpio_direction_input(CPUIMX51_QUARTD_GPIO); gpio_free(CPUIMX51_QUARTD_GPIO); |
6bd96f3c3 ARM: imx: dynamic... |
248 |
imx51_add_fec(NULL); |
ef93f1443 i.MX51: add suppo... |
249 |
platform_add_devices(devices, ARRAY_SIZE(devices)); |
44505c076 ARM: mx5: dynamic... |
250 |
imx51_add_imx_i2c(1, &eukrea_cpuimx51_i2c_data); |
ef93f1443 i.MX51: add suppo... |
251 252 253 254 |
i2c_register_board_info(1, eukrea_cpuimx51_i2c_devices, ARRAY_SIZE(eukrea_cpuimx51_i2c_devices)); if (otg_mode_host) |
7d92e8e6c ARM: mx5: dynamic... |
255 |
imx51_add_mxc_ehci_otg(&dr_utmi_config); |
ef93f1443 i.MX51: add suppo... |
256 257 |
else { initialize_otg_port(NULL); |
6cafe48a6 ARM: mx5: dynamic... |
258 |
imx51_add_fsl_usb2_udc(&usb_pdata); |
ef93f1443 i.MX51: add suppo... |
259 |
} |
7d92e8e6c ARM: mx5: dynamic... |
260 |
imx51_add_mxc_ehci_hs(1, &usbh1_config); |
ef93f1443 i.MX51: add suppo... |
261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 |
#ifdef CONFIG_MACH_EUKREA_MBIMX51_BASEBOARD eukrea_mbimx51_baseboard_init(); #endif } static void __init eukrea_cpuimx51_timer_init(void) { mx51_clocks_init(32768, 24000000, 22579200, 0); } static struct sys_timer mxc_timer = { .init = eukrea_cpuimx51_timer_init, }; MACHINE_START(EUKREA_CPUIMX51, "Eukrea CPUIMX51 Module") /* Maintainer: Eric Bénard <eric@eukrea.com> */ |
6192935c3 ARM: mach-mx5: co... |
278 |
.atag_offset = 0x100, |
ef93f1443 i.MX51: add suppo... |
279 |
.map_io = mx51_map_io, |
ab1304212 ARM: mx5: use .in... |
280 |
.init_early = imx51_init_early, |
ef93f1443 i.MX51: add suppo... |
281 |
.init_irq = mx51_init_irq, |
ffa2ea3f5 ARM i.MX boards: ... |
282 |
.handle_irq = imx51_handle_irq, |
ef93f1443 i.MX51: add suppo... |
283 |
.timer = &mxc_timer, |
ab1304212 ARM: mx5: use .in... |
284 |
.init_machine = eukrea_cpuimx51_init, |
65ea7884b ARM: restart: mxc... |
285 |
.restart = mxc_restart, |
ef93f1443 i.MX51: add suppo... |
286 |
MACHINE_END |