blob: a6aa4a2432f2d36166f74fcd5f1414b886a39f75 [file] [log] [blame]
Maxim Osipov8ed90592010-09-15 11:54:49 +01001/*
2 * linux/arch/arm/mach-at91/board-flexibity.c
3 *
Maxim Osipov948ce6a2011-05-07 12:47:00 +01004 * Copyright (C) 2010-2011 Flexibity
Maxim Osipov8ed90592010-09-15 11:54:49 +01005 * Copyright (C) 2005 SAN People
6 * Copyright (C) 2006 Atmel
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 */
22
23#include <linux/init.h>
24#include <linux/platform_device.h>
25#include <linux/spi/spi.h>
26#include <linux/input.h>
27#include <linux/gpio.h>
28
29#include <asm/mach-types.h>
30
31#include <asm/mach/arch.h>
32#include <asm/mach/map.h>
33#include <asm/mach/irq.h>
34
35#include <mach/hardware.h>
Maxim Osipov8ed90592010-09-15 11:54:49 +010036
Jean-Christophe PLAGNIOL-VILLARDa510b9b2012-10-30 06:41:28 +080037#include "at91_aic.h"
Jean-Christophe PLAGNIOL-VILLARD43d2f532012-10-30 05:14:17 +080038#include "board.h"
Maxim Osipov8ed90592010-09-15 11:54:49 +010039#include "generic.h"
Linus Walleijcf2e9332014-03-27 14:18:51 +010040#include "gpio.h"
Maxim Osipov8ed90592010-09-15 11:54:49 +010041
Jean-Christophe PLAGNIOL-VILLARD1b021a32011-04-28 20:19:32 +080042static void __init flexibity_init_early(void)
Maxim Osipov8ed90592010-09-15 11:54:49 +010043{
44 /* Initialize processor: 18.432 MHz crystal */
Jean-Christophe PLAGNIOL-VILLARD21d08b92011-04-23 15:28:34 +080045 at91_initialize(18432000);
Maxim Osipov8ed90592010-09-15 11:54:49 +010046}
47
Maxim Osipov8ed90592010-09-15 11:54:49 +010048/* USB Host port */
49static struct at91_usbh_data __initdata flexibity_usbh_data = {
50 .ports = 2,
Jean-Christophe PLAGNIOL-VILLARD63b4c292011-11-25 01:51:06 +080051 .vbus_pin = {-EINVAL, -EINVAL},
52 .overcurrent_pin= {-EINVAL, -EINVAL},
Maxim Osipov8ed90592010-09-15 11:54:49 +010053};
54
55/* USB Device port */
56static struct at91_udc_data __initdata flexibity_udc_data = {
57 .vbus_pin = AT91_PIN_PC5,
Jean-Christophe PLAGNIOL-VILLARD63b4c292011-11-25 01:51:06 +080058 .pullup_pin = -EINVAL, /* pull-up driven by UDC */
Maxim Osipov8ed90592010-09-15 11:54:49 +010059};
60
Maxim Osipov948ce6a2011-05-07 12:47:00 +010061/* I2C devices */
62static struct i2c_board_info __initdata flexibity_i2c_devices[] = {
63 {
64 I2C_BOARD_INFO("ds1307", 0x68),
65 },
66};
67
Maxim Osipov8ed90592010-09-15 11:54:49 +010068/* SPI devices */
69static struct spi_board_info flexibity_spi_devices[] = {
70 { /* DataFlash chip */
71 .modalias = "mtd_dataflash",
72 .chip_select = 1,
73 .max_speed_hz = 15 * 1000 * 1000,
74 .bus_num = 0,
75 },
76};
77
78/* MCI (SD/MMC) */
Ludovic Desroches4cf33262012-05-21 12:23:27 +020079static struct mci_platform_data __initdata flexibity_mci0_data = {
80 .slot[0] = {
81 .bus_width = 4,
82 .detect_pin = AT91_PIN_PC9,
83 .wp_pin = AT91_PIN_PC4,
84 },
Maxim Osipov8ed90592010-09-15 11:54:49 +010085};
86
87/* LEDs */
88static struct gpio_led flexibity_leds[] = {
89 {
90 .name = "usb1:green",
91 .gpio = AT91_PIN_PA12,
92 .active_low = 1,
93 .default_trigger = "default-on",
94 },
95 {
96 .name = "usb1:red",
97 .gpio = AT91_PIN_PA13,
98 .active_low = 1,
99 .default_trigger = "default-on",
100 },
101 {
102 .name = "usb2:green",
103 .gpio = AT91_PIN_PB26,
104 .active_low = 1,
105 .default_trigger = "default-on",
106 },
107 {
108 .name = "usb2:red",
109 .gpio = AT91_PIN_PB27,
110 .active_low = 1,
111 .default_trigger = "default-on",
112 },
113 {
114 .name = "usb3:green",
115 .gpio = AT91_PIN_PC8,
116 .active_low = 1,
117 .default_trigger = "default-on",
118 },
119 {
120 .name = "usb3:red",
121 .gpio = AT91_PIN_PC6,
122 .active_low = 1,
123 .default_trigger = "default-on",
124 },
125 {
126 .name = "usb4:green",
127 .gpio = AT91_PIN_PB4,
128 .active_low = 1,
129 .default_trigger = "default-on",
130 },
131 {
132 .name = "usb4:red",
133 .gpio = AT91_PIN_PB5,
134 .active_low = 1,
135 .default_trigger = "default-on",
136 }
137};
138
139static void __init flexibity_board_init(void)
140{
Maxime Riparde76265c2014-07-03 11:55:33 +0200141 at91_register_devices();
142
Maxim Osipov8ed90592010-09-15 11:54:49 +0100143 /* Serial */
Jean-Christophe PLAGNIOL-VILLARD71b149b2012-04-05 14:14:28 +0800144 /* DBGU on ttyS0. (Rx & Tx only) */
145 at91_register_uart(0, 0, 0);
Maxim Osipov8ed90592010-09-15 11:54:49 +0100146 at91_add_device_serial();
147 /* USB Host */
148 at91_add_device_usbh(&flexibity_usbh_data);
149 /* USB Device */
150 at91_add_device_udc(&flexibity_udc_data);
Maxim Osipov948ce6a2011-05-07 12:47:00 +0100151 /* I2C */
152 at91_add_device_i2c(flexibity_i2c_devices,
153 ARRAY_SIZE(flexibity_i2c_devices));
Maxim Osipov8ed90592010-09-15 11:54:49 +0100154 /* SPI */
155 at91_add_device_spi(flexibity_spi_devices,
156 ARRAY_SIZE(flexibity_spi_devices));
157 /* MMC */
Ludovic Desroches4cf33262012-05-21 12:23:27 +0200158 at91_add_device_mci(0, &flexibity_mci0_data);
Maxim Osipov8ed90592010-09-15 11:54:49 +0100159 /* LEDs */
160 at91_gpio_leds(flexibity_leds, ARRAY_SIZE(flexibity_leds));
161}
162
163MACHINE_START(FLEXIBITY, "Flexibity Connect")
164 /* Maintainer: Maxim Osipov */
Maxime Ripard0f391f12014-07-01 11:33:25 +0200165 .init_time = at91_init_time,
Jean-Christophe PLAGNIOL-VILLARD21d08b92011-04-23 15:28:34 +0800166 .map_io = at91_map_io,
Ludovic Desroches3e135462012-06-11 15:38:03 +0200167 .handle_irq = at91_aic_handle_irq,
Jean-Christophe PLAGNIOL-VILLARD1b021a32011-04-28 20:19:32 +0800168 .init_early = flexibity_init_early,
Jean-Christophe PLAGNIOL-VILLARD92100c12011-04-23 15:28:34 +0800169 .init_irq = at91_init_irq_default,
Maxim Osipov8ed90592010-09-15 11:54:49 +0100170 .init_machine = flexibity_board_init,
171MACHINE_END