aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Milo <Milo.Kim@ti.com>2013-02-01 13:19:46 -0500
committerTony Lindgren <tony@atomide.com>2013-02-01 17:59:34 -0500
commita486dc233633156357b5dff0eecbae883aa59353 (patch)
treec1ab2ce39e9f893444d966dc93aea8e7a78852d2
parentd58eb6b59f8e3ca99fe16bdb3e784012126a3bb6 (diff)
ARM: OMAP2+: craneboard: support the TPS65910 PMU
This patch supports the TPS65910 PMU function on the AM3517 Craneboard. The IRQ pin, SYS_NIRQ is dedicated connection between the AM3517 and the TPS65910 PMU. To handle the PMU IRQs, mux configuration is required. Platform data configuration: .IRQ number : SYS_NIRQ (M_IRQ_7) .External clock source : external 32KHz clock is connected Signed-off-by: Milo(Woogyom) Kim <milo.kim@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
-rw-r--r--arch/arm/mach-omap2/board-am3517crane.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/board-am3517crane.c b/arch/arm/mach-omap2/board-am3517crane.c
index 37646e557d69..82805de80056 100644
--- a/arch/arm/mach-omap2/board-am3517crane.c
+++ b/arch/arm/mach-omap2/board-am3517crane.c
@@ -20,6 +20,7 @@
20#include <linux/kernel.h> 20#include <linux/kernel.h>
21#include <linux/init.h> 21#include <linux/init.h>
22#include <linux/gpio.h> 22#include <linux/gpio.h>
23#include <linux/mfd/tps65910.h>
23#include <linux/mtd/mtd.h> 24#include <linux/mtd/mtd.h>
24#include <linux/mtd/nand.h> 25#include <linux/mtd/nand.h>
25#include <linux/mtd/partitions.h> 26#include <linux/mtd/partitions.h>
@@ -41,6 +42,7 @@
41 42
42#ifdef CONFIG_OMAP_MUX 43#ifdef CONFIG_OMAP_MUX
43static struct omap_board_mux board_mux[] __initdata = { 44static struct omap_board_mux board_mux[] __initdata = {
45 OMAP3_MUX(SYS_NIRQ, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP),
44 { .reg_offset = OMAP_MUX_TERMINATOR }, 46 { .reg_offset = OMAP_MUX_TERMINATOR },
45}; 47};
46#endif 48#endif
@@ -86,6 +88,24 @@ static struct mtd_partition crane_nand_partitions[] = {
86 }, 88 },
87}; 89};
88 90
91static struct tps65910_board tps65910_pdata = {
92 .irq = 7 + OMAP_INTC_START,
93 .en_ck32k_xtal = true,
94};
95
96static struct i2c_board_info __initdata tps65910_board_info[] = {
97 {
98 I2C_BOARD_INFO("tps65910", 0x2d),
99 .platform_data = &tps65910_pdata,
100 },
101};
102
103static void __init am3517_crane_i2c_init(void)
104{
105 omap_register_i2c_bus(1, 2600, tps65910_board_info,
106 ARRAY_SIZE(tps65910_board_info));
107}
108
89static void __init am3517_crane_init(void) 109static void __init am3517_crane_init(void)
90{ 110{
91 int ret; 111 int ret;
@@ -96,6 +116,7 @@ static void __init am3517_crane_init(void)
96 board_nand_init(crane_nand_partitions, 116 board_nand_init(crane_nand_partitions,
97 ARRAY_SIZE(crane_nand_partitions), 0, 117 ARRAY_SIZE(crane_nand_partitions), 0,
98 NAND_BUSWIDTH_16, NULL); 118 NAND_BUSWIDTH_16, NULL);
119 am3517_crane_i2c_init();
99 120
100 /* Configure GPIO for EHCI port */ 121 /* Configure GPIO for EHCI port */
101 if (omap_mux_init_gpio(GPIO_USB_NRESET, OMAP_PIN_OUTPUT)) { 122 if (omap_mux_init_gpio(GPIO_USB_NRESET, OMAP_PIN_OUTPUT)) {