blob: 85e2877572b56c64f74d0f022fb1270056accea3 [file] [log] [blame]
Paulius Zaleckascfca8b52008-11-14 11:01:38 +01001/*
Uwe Kleine-König95c00462009-12-09 20:12:07 +01002 * arch/arm/mach-imx/mach-mx1ads.c
Paulius Zaleckascfca8b52008-11-14 11:01:38 +01003 *
4 * Initially based on:
5 * linux-2.6.7-imx/arch/arm/mach-imx/scb9328.c
6 * Copyright (c) 2004 Sascha Hauer <sascha@saschahauer.de>
7 *
8 * 2004 (c) MontaVista Software, Inc.
9 *
10 * This file is licensed under the terms of the GNU General Public
11 * License version 2. This program is licensed "as is" without any
12 * warranty of any kind, whether express or implied.
13 */
14
Sascha Hauerb8b19b02009-01-28 14:06:20 +010015#include <linux/i2c.h>
16#include <linux/i2c/pcf857x.h>
Sascha Hauer5b684212009-04-29 13:14:19 +020017#include <linux/init.h>
18#include <linux/kernel.h>
19#include <linux/platform_device.h>
20#include <linux/mtd/physmap.h>
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010021
22#include <asm/mach-types.h>
23#include <asm/mach/arch.h>
24#include <asm/mach/time.h>
25
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010026#include <mach/common.h>
Sascha Hauer5b684212009-04-29 13:14:19 +020027#include <mach/hardware.h>
Sascha Hauerb8b19b02009-01-28 14:06:20 +010028#include <mach/i2c.h>
Uwe Kleine-Könige835d882010-02-16 11:07:49 +010029#include <mach/iomux-mx1.h>
Sascha Hauer5b684212009-04-29 13:14:19 +020030#include <mach/irqs.h>
31
Uwe Kleine-König6348e6b2010-06-16 15:26:07 +020032#include "devices-imx1.h"
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010033#include "devices.h"
34
Uwe Kleine-König6c80ee52010-09-28 21:53:31 +020035static const int mx1ads_pins[] __initconst = {
Sascha Hauer5ae07da2009-04-29 13:17:21 +020036 /* UART1 */
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010037 PC9_PF_UART1_CTS,
38 PC10_PF_UART1_RTS,
39 PC11_PF_UART1_TXD,
40 PC12_PF_UART1_RXD,
Sascha Hauer5ae07da2009-04-29 13:17:21 +020041 /* UART2 */
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010042 PB28_PF_UART2_CTS,
43 PB29_PF_UART2_RTS,
44 PB30_PF_UART2_TXD,
45 PB31_PF_UART2_RXD,
Sascha Hauer5ae07da2009-04-29 13:17:21 +020046 /* I2C */
47 PA15_PF_I2C_SDA,
48 PA16_PF_I2C_SCL,
49 /* SPI */
50 PC13_PF_SPI1_SPI_RDY,
51 PC14_PF_SPI1_SCLK,
52 PC15_PF_SPI1_SS,
53 PC16_PF_SPI1_MISO,
54 PC17_PF_SPI1_MOSI,
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010055};
56
Sascha Hauer5ae07da2009-04-29 13:17:21 +020057/*
58 * UARTs platform data
59 */
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010060
Uwe Kleine-Königd112f4e2010-06-22 14:50:59 +020061static const struct imxuart_platform_data uart0_pdata __initconst = {
62 .flags = IMXUART_HAVE_RTSCTS,
63};
64
65static const struct imxuart_platform_data uart1_pdata __initconst = {
66 .flags = IMXUART_HAVE_RTSCTS,
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010067};
68
69/*
70 * Physmap flash
71 */
72
73static struct physmap_flash_data mx1ads_flash_data = {
74 .width = 4, /* bankwidth in bytes */
75};
76
77static struct resource flash_resource = {
Uwe Kleine-König05a31852010-03-04 21:02:41 +010078 .start = MX1_CS0_PHYS,
79 .end = MX1_CS0_PHYS + SZ_32M - 1,
Paulius Zaleckascfca8b52008-11-14 11:01:38 +010080 .flags = IORESOURCE_MEM,
81};
82
83static struct platform_device flash_device = {
84 .name = "physmap-flash",
85 .id = 0,
86 .resource = &flash_resource,
87 .num_resources = 1,
88};
89
90/*
Sascha Hauerb8b19b02009-01-28 14:06:20 +010091 * I2C
92 */
Sascha Hauerb8b19b02009-01-28 14:06:20 +010093static struct pcf857x_platform_data pcf857x_data[] = {
94 {
95 .gpio_base = 4 * 32,
96 }, {
97 .gpio_base = 4 * 32 + 16,
98 }
99};
100
Uwe Kleine-König6348e6b2010-06-16 15:26:07 +0200101static const struct imxi2c_platform_data mx1ads_i2c_data __initconst = {
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100102 .bitrate = 100000,
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100103};
104
105static struct i2c_board_info mx1ads_i2c_devices[] = {
106 {
Sascha Hauercf87a6e2009-07-20 08:18:47 +0200107 I2C_BOARD_INFO("pcf8575", 0x22),
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100108 .platform_data = &pcf857x_data[0],
109 }, {
Sascha Hauercf87a6e2009-07-20 08:18:47 +0200110 I2C_BOARD_INFO("pcf8575", 0x24),
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100111 .platform_data = &pcf857x_data[1],
112 },
113};
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100114
115/*
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100116 * Board init
117 */
118static void __init mx1ads_init(void)
119{
Sascha Hauer5ae07da2009-04-29 13:17:21 +0200120 mxc_gpio_setup_multiple_pins(mx1ads_pins,
121 ARRAY_SIZE(mx1ads_pins), "mx1ads");
122
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100123 /* UART */
Uwe Kleine-Königd112f4e2010-06-22 14:50:59 +0200124 imx1_add_imx_uart0(&uart0_pdata);
125 imx1_add_imx_uart1(&uart1_pdata);
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100126
127 /* Physmap flash */
128 mxc_register_device(&flash_device, &mx1ads_flash_data);
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100129
130 /* I2C */
Sascha Hauerb8b19b02009-01-28 14:06:20 +0100131 i2c_register_board_info(0, mx1ads_i2c_devices,
132 ARRAY_SIZE(mx1ads_i2c_devices));
133
Uwe Kleine-König77a406d2010-08-25 12:19:50 +0200134 imx1_add_imx_i2c(&mx1ads_i2c_data);
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100135}
136
137static void __init mx1ads_timer_init(void)
138{
Sascha Hauer30c730f2009-02-16 14:36:49 +0100139 mx1_clocks_init(32000);
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100140}
141
142struct sys_timer mx1ads_timer = {
143 .init = mx1ads_timer_init,
144};
145
146MACHINE_START(MX1ADS, "Freescale MX1ADS")
147 /* Maintainer: Sascha Hauer, Pengutronix */
Uwe Kleine-König05a31852010-03-04 21:02:41 +0100148 .phys_io = MX1_IO_BASE_ADDR,
149 .io_pg_offst = (MX1_IO_BASE_ADDR_VIRT >> 18) & 0xfffc,
Uwe Kleine-König34101232010-01-29 17:36:05 +0100150 .boot_params = MX1_PHYS_OFFSET + 0x100,
Sascha Hauer74fe030e2009-04-29 13:41:40 +0200151 .map_io = mx1_map_io,
Sascha Hauerc5aa0ad2009-05-25 17:36:19 +0200152 .init_irq = mx1_init_irq,
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100153 .timer = &mx1ads_timer,
154 .init_machine = mx1ads_init,
155MACHINE_END
156
157MACHINE_START(MXLADS, "Freescale MXLADS")
Uwe Kleine-König05a31852010-03-04 21:02:41 +0100158 .phys_io = MX1_IO_BASE_ADDR,
159 .io_pg_offst = (MX1_IO_BASE_ADDR_VIRT >> 18) & 0xfffc,
Uwe Kleine-König34101232010-01-29 17:36:05 +0100160 .boot_params = MX1_PHYS_OFFSET + 0x100,
Sascha Hauercd4a05f2009-04-02 22:32:10 +0200161 .map_io = mx1_map_io,
Sascha Hauerc5aa0ad2009-05-25 17:36:19 +0200162 .init_irq = mx1_init_irq,
Paulius Zaleckascfca8b52008-11-14 11:01:38 +0100163 .timer = &mx1ads_timer,
164 .init_machine = mx1ads_init,
165MACHINE_END