diff options
author | Kim Milo <Milo.Kim@ti.com> | 2013-02-01 13:19:46 -0500 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2013-02-01 17:59:34 -0500 |
commit | a486dc233633156357b5dff0eecbae883aa59353 (patch) | |
tree | c1ab2ce39e9f893444d966dc93aea8e7a78852d2 | |
parent | d58eb6b59f8e3ca99fe16bdb3e784012126a3bb6 (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.c | 21 |
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 |
43 | static struct omap_board_mux board_mux[] __initdata = { | 44 | static 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 | ||
91 | static struct tps65910_board tps65910_pdata = { | ||
92 | .irq = 7 + OMAP_INTC_START, | ||
93 | .en_ck32k_xtal = true, | ||
94 | }; | ||
95 | |||
96 | static struct i2c_board_info __initdata tps65910_board_info[] = { | ||
97 | { | ||
98 | I2C_BOARD_INFO("tps65910", 0x2d), | ||
99 | .platform_data = &tps65910_pdata, | ||
100 | }, | ||
101 | }; | ||
102 | |||
103 | static 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 | |||
89 | static void __init am3517_crane_init(void) | 109 | static 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)) { |