blob: e4d95b4c6bb272a427c5e4d6dae3cb7676b11ae9 [file] [log] [blame]
Mark F. Brown1bbd7082010-09-12 23:51:34 -04001/*
2 * linux/arch/arm/mach-mmp/teton_bga.c
3 *
4 * Support for the Marvell PXA168 Teton BGA Development Platform.
5 *
6 * Author: Mark F. Brown <mark.brown314@gmail.com>
7 *
8 * This code is based on aspenite.c
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * publishhed by the Free Software Foundation.
13 */
14
15#include <linux/init.h>
16#include <linux/kernel.h>
17#include <linux/platform_device.h>
18#include <linux/gpio.h>
Haojian Zhuangb8f649f2013-04-09 18:12:04 +080019#include <linux/gpio-pxa.h>
Mark F. Brownd2ce6972010-09-12 23:51:35 -040020#include <linux/input.h>
Arnd Bergmann293b2da2012-08-24 15:16:48 +020021#include <linux/platform_data/keypad-pxa27x.h>
Mark F. Brown759305c2010-09-12 23:51:36 -040022#include <linux/i2c.h>
Mark F. Brown1bbd7082010-09-12 23:51:34 -040023
24#include <asm/mach-types.h>
25#include <asm/mach/arch.h>
26#include <mach/addr-map.h>
27#include <mach/mfp-pxa168.h>
28#include <mach/pxa168.h>
29#include <mach/teton_bga.h>
Rob Herring8661fb92012-01-03 16:50:40 -060030#include <mach/irqs.h>
Mark F. Brown1bbd7082010-09-12 23:51:34 -040031
32#include "common.h"
33
34static unsigned long teton_bga_pin_config[] __initdata = {
35 /* UART1 */
36 GPIO107_UART1_TXD,
37 GPIO108_UART1_RXD,
Mark F. Brownd2ce6972010-09-12 23:51:35 -040038
39 /* Keypad */
40 GPIO109_KP_MKIN1,
41 GPIO110_KP_MKIN0,
42 GPIO111_KP_MKOUT7,
43 GPIO112_KP_MKOUT6,
Mark F. Brown759305c2010-09-12 23:51:36 -040044
45 /* I2C Bus */
46 GPIO105_CI2C_SDA,
47 GPIO106_CI2C_SCL,
48
49 /* RTC */
50 GPIO78_GPIO,
Mark F. Brownd2ce6972010-09-12 23:51:35 -040051};
52
Haojian Zhuangb8f649f2013-04-09 18:12:04 +080053static struct pxa_gpio_platform_data pxa168_gpio_pdata = {
54 .irq_base = MMP_GPIO_TO_IRQ(0),
55};
56
Mark F. Brownd2ce6972010-09-12 23:51:35 -040057static unsigned int teton_bga_matrix_key_map[] = {
58 KEY(0, 6, KEY_ESC),
59 KEY(0, 7, KEY_ENTER),
60 KEY(1, 6, KEY_LEFT),
61 KEY(1, 7, KEY_RIGHT),
62};
63
64static struct pxa27x_keypad_platform_data teton_bga_keypad_info __initdata = {
65 .matrix_key_rows = 2,
66 .matrix_key_cols = 8,
67 .matrix_key_map = teton_bga_matrix_key_map,
68 .matrix_key_map_size = ARRAY_SIZE(teton_bga_matrix_key_map),
69 .debounce_interval = 30,
Mark F. Brown1bbd7082010-09-12 23:51:34 -040070};
71
Mark F. Brown759305c2010-09-12 23:51:36 -040072static struct i2c_board_info teton_bga_i2c_info[] __initdata = {
73 {
74 I2C_BOARD_INFO("ds1337", 0x68),
Haojian Zhuang4929f5a2011-10-10 16:03:51 +080075 .irq = MMP_GPIO_TO_IRQ(RTC_INT_GPIO)
Mark F. Brown759305c2010-09-12 23:51:36 -040076 },
77};
78
Mark F. Brown1bbd7082010-09-12 23:51:34 -040079static void __init teton_bga_init(void)
80{
81 mfp_config(ARRAY_AND_SIZE(teton_bga_pin_config));
82
83 /* on-chip devices */
84 pxa168_add_uart(1);
Mark F. Brownd2ce6972010-09-12 23:51:35 -040085 pxa168_add_keypad(&teton_bga_keypad_info);
Mark F. Brown759305c2010-09-12 23:51:36 -040086 pxa168_add_twsi(0, NULL, ARRAY_AND_SIZE(teton_bga_i2c_info));
Haojian Zhuangb8f649f2013-04-09 18:12:04 +080087 platform_device_add_data(&pxa168_device_gpio, &pxa168_gpio_pdata,
88 sizeof(struct pxa_gpio_platform_data));
Haojian Zhuang157d2642011-10-17 20:37:52 +080089 platform_device_register(&pxa168_device_gpio);
Mark F. Brown1bbd7082010-09-12 23:51:34 -040090}
91
92MACHINE_START(TETON_BGA, "PXA168-based Teton BGA Development Platform")
Mark F. Brown1bbd7082010-09-12 23:51:34 -040093 .map_io = mmp_map_io,
Rob Herring8661fb92012-01-03 16:50:40 -060094 .nr_irqs = MMP_NR_IRQS,
Mark F. Brown1bbd7082010-09-12 23:51:34 -040095 .init_irq = pxa168_init_irq,
Stephen Warren6bb27d72012-11-08 12:40:59 -070096 .init_time = pxa168_timer_init,
Mark F. Brown1bbd7082010-09-12 23:51:34 -040097 .init_machine = teton_bga_init,
Russell King9854a382011-11-05 15:40:09 +000098 .restart = pxa168_restart,
Mark F. Brown1bbd7082010-09-12 23:51:34 -040099MACHINE_END