diff options
Diffstat (limited to 'arch/arm/mach-kirkwood')
-rw-r--r-- | arch/arm/mach-kirkwood/Kconfig | 23 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/Makefile | 4 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/common.c | 8 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/netspace_v2-setup.c | 59 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/openrd-setup.c | 118 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/openrd_base-setup.c | 96 | ||||
-rw-r--r-- | arch/arm/mach-kirkwood/sheevaplug-setup.c | 50 |
7 files changed, 230 insertions, 128 deletions
diff --git a/arch/arm/mach-kirkwood/Kconfig b/arch/arm/mach-kirkwood/Kconfig index f6c6196a51fa..17879a876be6 100644 --- a/arch/arm/mach-kirkwood/Kconfig +++ b/arch/arm/mach-kirkwood/Kconfig | |||
@@ -32,6 +32,12 @@ config MACH_SHEEVAPLUG | |||
32 | Say 'Y' here if you want your kernel to support the | 32 | Say 'Y' here if you want your kernel to support the |
33 | Marvell SheevaPlug Reference Board. | 33 | Marvell SheevaPlug Reference Board. |
34 | 34 | ||
35 | config MACH_ESATA_SHEEVAPLUG | ||
36 | bool "Marvell eSATA SheevaPlug Reference Board" | ||
37 | help | ||
38 | Say 'Y' here if you want your kernel to support the | ||
39 | Marvell eSATA SheevaPlug Reference Board. | ||
40 | |||
35 | config MACH_TS219 | 41 | config MACH_TS219 |
36 | bool "QNAP TS-110, TS-119, TS-210, TS-219 and TS-219P Turbo NAS" | 42 | bool "QNAP TS-110, TS-119, TS-210, TS-219 and TS-219P Turbo NAS" |
37 | help | 43 | help |
@@ -46,18 +52,35 @@ config MACH_TS41X | |||
46 | QNAP TS-410, TS-410U, TS-419P and TS-419U Turbo NAS | 52 | QNAP TS-410, TS-410U, TS-419P and TS-419U Turbo NAS |
47 | devices. | 53 | devices. |
48 | 54 | ||
55 | config MACH_OPENRD | ||
56 | bool | ||
57 | |||
49 | config MACH_OPENRD_BASE | 58 | config MACH_OPENRD_BASE |
50 | bool "Marvell OpenRD Base Board" | 59 | bool "Marvell OpenRD Base Board" |
60 | select MACH_OPENRD | ||
51 | help | 61 | help |
52 | Say 'Y' here if you want your kernel to support the | 62 | Say 'Y' here if you want your kernel to support the |
53 | Marvell OpenRD Base Board. | 63 | Marvell OpenRD Base Board. |
54 | 64 | ||
65 | config MACH_OPENRD_CLIENT | ||
66 | bool "Marvell OpenRD Client Board" | ||
67 | select MACH_OPENRD | ||
68 | help | ||
69 | Say 'Y' here if you want your kernel to support the | ||
70 | Marvell OpenRD Client Board. | ||
71 | |||
55 | config MACH_NETSPACE_V2 | 72 | config MACH_NETSPACE_V2 |
56 | bool "LaCie Network Space v2 NAS Board" | 73 | bool "LaCie Network Space v2 NAS Board" |
57 | help | 74 | help |
58 | Say 'Y' here if you want your kernel to support the | 75 | Say 'Y' here if you want your kernel to support the |
59 | LaCie Network Space v2 NAS. | 76 | LaCie Network Space v2 NAS. |
60 | 77 | ||
78 | config MACH_INETSPACE_V2 | ||
79 | bool "LaCie Internet Space v2 NAS Board" | ||
80 | help | ||
81 | Say 'Y' here if you want your kernel to support the | ||
82 | LaCie Internet Space v2 NAS. | ||
83 | |||
61 | endmenu | 84 | endmenu |
62 | 85 | ||
63 | endif | 86 | endif |
diff --git a/arch/arm/mach-kirkwood/Makefile b/arch/arm/mach-kirkwood/Makefile index d4d7f53b0fb9..a5530e36ba3e 100644 --- a/arch/arm/mach-kirkwood/Makefile +++ b/arch/arm/mach-kirkwood/Makefile | |||
@@ -5,9 +5,11 @@ obj-$(CONFIG_MACH_RD88F6192_NAS) += rd88f6192-nas-setup.o | |||
5 | obj-$(CONFIG_MACH_RD88F6281) += rd88f6281-setup.o | 5 | obj-$(CONFIG_MACH_RD88F6281) += rd88f6281-setup.o |
6 | obj-$(CONFIG_MACH_MV88F6281GTW_GE) += mv88f6281gtw_ge-setup.o | 6 | obj-$(CONFIG_MACH_MV88F6281GTW_GE) += mv88f6281gtw_ge-setup.o |
7 | obj-$(CONFIG_MACH_SHEEVAPLUG) += sheevaplug-setup.o | 7 | obj-$(CONFIG_MACH_SHEEVAPLUG) += sheevaplug-setup.o |
8 | obj-$(CONFIG_MACH_ESATA_SHEEVAPLUG) += sheevaplug-setup.o | ||
8 | obj-$(CONFIG_MACH_TS219) += ts219-setup.o tsx1x-common.o | 9 | obj-$(CONFIG_MACH_TS219) += ts219-setup.o tsx1x-common.o |
9 | obj-$(CONFIG_MACH_TS41X) += ts41x-setup.o tsx1x-common.o | 10 | obj-$(CONFIG_MACH_TS41X) += ts41x-setup.o tsx1x-common.o |
10 | obj-$(CONFIG_MACH_OPENRD_BASE) += openrd_base-setup.o | 11 | obj-$(CONFIG_MACH_OPENRD) += openrd-setup.o |
11 | obj-$(CONFIG_MACH_NETSPACE_V2) += netspace_v2-setup.o | 12 | obj-$(CONFIG_MACH_NETSPACE_V2) += netspace_v2-setup.o |
13 | obj-$(CONFIG_MACH_INETSPACE_V2) += netspace_v2-setup.o | ||
12 | 14 | ||
13 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o | 15 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o |
diff --git a/arch/arm/mach-kirkwood/common.c b/arch/arm/mach-kirkwood/common.c index 242dd0775343..f759ca243925 100644 --- a/arch/arm/mach-kirkwood/common.c +++ b/arch/arm/mach-kirkwood/common.c | |||
@@ -656,7 +656,7 @@ static struct platform_device kirkwood_xor00_channel = { | |||
656 | .dev = { | 656 | .dev = { |
657 | .dma_mask = &kirkwood_xor_dmamask, | 657 | .dma_mask = &kirkwood_xor_dmamask, |
658 | .coherent_dma_mask = DMA_BIT_MASK(64), | 658 | .coherent_dma_mask = DMA_BIT_MASK(64), |
659 | .platform_data = (void *)&kirkwood_xor00_data, | 659 | .platform_data = &kirkwood_xor00_data, |
660 | }, | 660 | }, |
661 | }; | 661 | }; |
662 | 662 | ||
@@ -682,7 +682,7 @@ static struct platform_device kirkwood_xor01_channel = { | |||
682 | .dev = { | 682 | .dev = { |
683 | .dma_mask = &kirkwood_xor_dmamask, | 683 | .dma_mask = &kirkwood_xor_dmamask, |
684 | .coherent_dma_mask = DMA_BIT_MASK(64), | 684 | .coherent_dma_mask = DMA_BIT_MASK(64), |
685 | .platform_data = (void *)&kirkwood_xor01_data, | 685 | .platform_data = &kirkwood_xor01_data, |
686 | }, | 686 | }, |
687 | }; | 687 | }; |
688 | 688 | ||
@@ -755,7 +755,7 @@ static struct platform_device kirkwood_xor10_channel = { | |||
755 | .dev = { | 755 | .dev = { |
756 | .dma_mask = &kirkwood_xor_dmamask, | 756 | .dma_mask = &kirkwood_xor_dmamask, |
757 | .coherent_dma_mask = DMA_BIT_MASK(64), | 757 | .coherent_dma_mask = DMA_BIT_MASK(64), |
758 | .platform_data = (void *)&kirkwood_xor10_data, | 758 | .platform_data = &kirkwood_xor10_data, |
759 | }, | 759 | }, |
760 | }; | 760 | }; |
761 | 761 | ||
@@ -781,7 +781,7 @@ static struct platform_device kirkwood_xor11_channel = { | |||
781 | .dev = { | 781 | .dev = { |
782 | .dma_mask = &kirkwood_xor_dmamask, | 782 | .dma_mask = &kirkwood_xor_dmamask, |
783 | .coherent_dma_mask = DMA_BIT_MASK(64), | 783 | .coherent_dma_mask = DMA_BIT_MASK(64), |
784 | .platform_data = (void *)&kirkwood_xor11_data, | 784 | .platform_data = &kirkwood_xor11_data, |
785 | }, | 785 | }, |
786 | }; | 786 | }; |
787 | 787 | ||
diff --git a/arch/arm/mach-kirkwood/netspace_v2-setup.c b/arch/arm/mach-kirkwood/netspace_v2-setup.c index 9a064065bebe..3ae158d72681 100644 --- a/arch/arm/mach-kirkwood/netspace_v2-setup.c +++ b/arch/arm/mach-kirkwood/netspace_v2-setup.c | |||
@@ -182,8 +182,14 @@ static struct platform_device netspace_v2_gpio_buttons = { | |||
182 | 182 | ||
183 | static struct gpio_led netspace_v2_gpio_led_pins[] = { | 183 | static struct gpio_led netspace_v2_gpio_led_pins[] = { |
184 | { | 184 | { |
185 | .name = "ns_v2:red:fail", | 185 | .name = "ns_v2:blue:sata", |
186 | .gpio = NETSPACE_V2_GPIO_RED_LED, | 186 | .default_trigger = "default-on", |
187 | .gpio = NETSPACE_V2_GPIO_BLUE_LED_CMD, | ||
188 | .active_low = 1, | ||
189 | }, | ||
190 | { | ||
191 | .name = "ns_v2:red:fail", | ||
192 | .gpio = NETSPACE_V2_GPIO_RED_LED, | ||
187 | }, | 193 | }, |
188 | }; | 194 | }; |
189 | 195 | ||
@@ -202,30 +208,19 @@ static struct platform_device netspace_v2_gpio_leds = { | |||
202 | 208 | ||
203 | static void __init netspace_v2_gpio_leds_init(void) | 209 | static void __init netspace_v2_gpio_leds_init(void) |
204 | { | 210 | { |
205 | platform_device_register(&netspace_v2_gpio_leds); | 211 | int err; |
206 | 212 | ||
207 | /* | 213 | /* Configure register slow_led to allow SATA activity LED blinking */ |
208 | * Configure the front blue LED to blink in relation with the SATA | 214 | err = gpio_request(NETSPACE_V2_GPIO_BLUE_LED_SLOW, "blue LED slow"); |
209 | * activity. | 215 | if (err == 0) { |
210 | */ | 216 | err = gpio_direction_output(NETSPACE_V2_GPIO_BLUE_LED_SLOW, 0); |
211 | if (gpio_request(NETSPACE_V2_GPIO_BLUE_LED_SLOW, | 217 | if (err) |
212 | "SATA blue LED slow") != 0) | 218 | gpio_free(NETSPACE_V2_GPIO_BLUE_LED_SLOW); |
213 | return; | 219 | } |
214 | if (gpio_direction_output(NETSPACE_V2_GPIO_BLUE_LED_SLOW, 0) != 0) | 220 | if (err) |
215 | goto err_free_1; | 221 | pr_err("netspace_v2: failed to configure blue LED slow GPIO\n"); |
216 | if (gpio_request(NETSPACE_V2_GPIO_BLUE_LED_CMD, | 222 | |
217 | "SATA blue LED command") != 0) | 223 | platform_device_register(&netspace_v2_gpio_leds); |
218 | goto err_free_1; | ||
219 | if (gpio_direction_output(NETSPACE_V2_GPIO_BLUE_LED_CMD, 0) != 0) | ||
220 | goto err_free_2; | ||
221 | |||
222 | return; | ||
223 | |||
224 | err_free_2: | ||
225 | gpio_free(NETSPACE_V2_GPIO_BLUE_LED_CMD); | ||
226 | err_free_1: | ||
227 | gpio_free(NETSPACE_V2_GPIO_BLUE_LED_SLOW); | ||
228 | pr_err("netspace_v2: failed to configure SATA blue LED\n"); | ||
229 | } | 224 | } |
230 | 225 | ||
231 | /***************************************************************************** | 226 | /***************************************************************************** |
@@ -314,6 +309,7 @@ static void __init netspace_v2_init(void) | |||
314 | pr_err("netspace_v2: failed to configure power-off GPIO\n"); | 309 | pr_err("netspace_v2: failed to configure power-off GPIO\n"); |
315 | } | 310 | } |
316 | 311 | ||
312 | #ifdef CONFIG_MACH_NETSPACE_V2 | ||
317 | MACHINE_START(NETSPACE_V2, "LaCie Network Space v2") | 313 | MACHINE_START(NETSPACE_V2, "LaCie Network Space v2") |
318 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | 314 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, |
319 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | 315 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, |
@@ -323,3 +319,16 @@ MACHINE_START(NETSPACE_V2, "LaCie Network Space v2") | |||
323 | .init_irq = kirkwood_init_irq, | 319 | .init_irq = kirkwood_init_irq, |
324 | .timer = &netspace_v2_timer, | 320 | .timer = &netspace_v2_timer, |
325 | MACHINE_END | 321 | MACHINE_END |
322 | #endif | ||
323 | |||
324 | #ifdef CONFIG_MACH_INETSPACE_V2 | ||
325 | MACHINE_START(INETSPACE_V2, "LaCie Internet Space v2") | ||
326 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | ||
327 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | ||
328 | .boot_params = 0x00000100, | ||
329 | .init_machine = netspace_v2_init, | ||
330 | .map_io = kirkwood_map_io, | ||
331 | .init_irq = kirkwood_init_irq, | ||
332 | .timer = &netspace_v2_timer, | ||
333 | MACHINE_END | ||
334 | #endif | ||
diff --git a/arch/arm/mach-kirkwood/openrd-setup.c b/arch/arm/mach-kirkwood/openrd-setup.c new file mode 100644 index 000000000000..ad3f1ec33796 --- /dev/null +++ b/arch/arm/mach-kirkwood/openrd-setup.c | |||
@@ -0,0 +1,118 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-kirkwood/openrd-setup.c | ||
3 | * | ||
4 | * Marvell OpenRD (Base|Client) Board Setup | ||
5 | * | ||
6 | * This file is licensed under the terms of the GNU General Public | ||
7 | * License version 2. This program is licensed "as is" without any | ||
8 | * warranty of any kind, whether express or implied. | ||
9 | */ | ||
10 | |||
11 | #include <linux/kernel.h> | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/platform_device.h> | ||
14 | #include <linux/mtd/nand.h> | ||
15 | #include <linux/mtd/partitions.h> | ||
16 | #include <linux/ata_platform.h> | ||
17 | #include <linux/mv643xx_eth.h> | ||
18 | #include <asm/mach-types.h> | ||
19 | #include <asm/mach/arch.h> | ||
20 | #include <mach/kirkwood.h> | ||
21 | #include <plat/mvsdio.h> | ||
22 | #include "common.h" | ||
23 | #include "mpp.h" | ||
24 | |||
25 | static struct mtd_partition openrd_nand_parts[] = { | ||
26 | { | ||
27 | .name = "u-boot", | ||
28 | .offset = 0, | ||
29 | .size = SZ_1M, | ||
30 | .mask_flags = MTD_WRITEABLE | ||
31 | }, { | ||
32 | .name = "uImage", | ||
33 | .offset = MTDPART_OFS_NXTBLK, | ||
34 | .size = SZ_4M | ||
35 | }, { | ||
36 | .name = "root", | ||
37 | .offset = MTDPART_OFS_NXTBLK, | ||
38 | .size = MTDPART_SIZ_FULL | ||
39 | }, | ||
40 | }; | ||
41 | |||
42 | static struct mv643xx_eth_platform_data openrd_ge00_data = { | ||
43 | .phy_addr = MV643XX_ETH_PHY_ADDR(8), | ||
44 | }; | ||
45 | |||
46 | static struct mv643xx_eth_platform_data openrd_ge01_data = { | ||
47 | .phy_addr = MV643XX_ETH_PHY_ADDR(24), | ||
48 | }; | ||
49 | |||
50 | static struct mv_sata_platform_data openrd_sata_data = { | ||
51 | .n_ports = 2, | ||
52 | }; | ||
53 | |||
54 | static struct mvsdio_platform_data openrd_mvsdio_data = { | ||
55 | .gpio_card_detect = 29, /* MPP29 used as SD card detect */ | ||
56 | }; | ||
57 | |||
58 | static unsigned int openrd_mpp_config[] __initdata = { | ||
59 | MPP29_GPIO, | ||
60 | 0 | ||
61 | }; | ||
62 | |||
63 | static void __init openrd_init(void) | ||
64 | { | ||
65 | /* | ||
66 | * Basic setup. Needs to be called early. | ||
67 | */ | ||
68 | kirkwood_init(); | ||
69 | kirkwood_mpp_conf(openrd_mpp_config); | ||
70 | |||
71 | kirkwood_uart0_init(); | ||
72 | kirkwood_nand_init(ARRAY_AND_SIZE(openrd_nand_parts), 25); | ||
73 | |||
74 | kirkwood_ehci_init(); | ||
75 | |||
76 | kirkwood_ge00_init(&openrd_ge00_data); | ||
77 | if (machine_is_openrd_client()) | ||
78 | kirkwood_ge01_init(&openrd_ge01_data); | ||
79 | kirkwood_sata_init(&openrd_sata_data); | ||
80 | kirkwood_sdio_init(&openrd_mvsdio_data); | ||
81 | |||
82 | kirkwood_i2c_init(); | ||
83 | } | ||
84 | |||
85 | static int __init openrd_pci_init(void) | ||
86 | { | ||
87 | if (machine_is_openrd_base() || machine_is_openrd_client()) | ||
88 | kirkwood_pcie_init(); | ||
89 | |||
90 | return 0; | ||
91 | } | ||
92 | subsys_initcall(openrd_pci_init); | ||
93 | |||
94 | #ifdef CONFIG_MACH_OPENRD_BASE | ||
95 | MACHINE_START(OPENRD_BASE, "Marvell OpenRD Base Board") | ||
96 | /* Maintainer: Dhaval Vasa <dhaval.vasa@einfochips.com> */ | ||
97 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | ||
98 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | ||
99 | .boot_params = 0x00000100, | ||
100 | .init_machine = openrd_init, | ||
101 | .map_io = kirkwood_map_io, | ||
102 | .init_irq = kirkwood_init_irq, | ||
103 | .timer = &kirkwood_timer, | ||
104 | MACHINE_END | ||
105 | #endif | ||
106 | |||
107 | #ifdef CONFIG_MACH_OPENRD_CLIENT | ||
108 | MACHINE_START(OPENRD_CLIENT, "Marvell OpenRD Client Board") | ||
109 | /* Maintainer: Dhaval Vasa <dhaval.vasa@einfochips.com> */ | ||
110 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | ||
111 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | ||
112 | .boot_params = 0x00000100, | ||
113 | .init_machine = openrd_init, | ||
114 | .map_io = kirkwood_map_io, | ||
115 | .init_irq = kirkwood_init_irq, | ||
116 | .timer = &kirkwood_timer, | ||
117 | MACHINE_END | ||
118 | #endif | ||
diff --git a/arch/arm/mach-kirkwood/openrd_base-setup.c b/arch/arm/mach-kirkwood/openrd_base-setup.c deleted file mode 100644 index 77617c722299..000000000000 --- a/arch/arm/mach-kirkwood/openrd_base-setup.c +++ /dev/null | |||
@@ -1,96 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-kirkwood/openrd_base-setup.c | ||
3 | * | ||
4 | * Marvell OpenRD Base Board Setup | ||
5 | * | ||
6 | * This file is licensed under the terms of the GNU General Public | ||
7 | * License version 2. This program is licensed "as is" without any | ||
8 | * warranty of any kind, whether express or implied. | ||
9 | */ | ||
10 | |||
11 | #include <linux/kernel.h> | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/platform_device.h> | ||
14 | #include <linux/mtd/partitions.h> | ||
15 | #include <linux/ata_platform.h> | ||
16 | #include <linux/mv643xx_eth.h> | ||
17 | #include <asm/mach-types.h> | ||
18 | #include <asm/mach/arch.h> | ||
19 | #include <mach/kirkwood.h> | ||
20 | #include <plat/mvsdio.h> | ||
21 | #include "common.h" | ||
22 | #include "mpp.h" | ||
23 | |||
24 | static struct mtd_partition openrd_base_nand_parts[] = { | ||
25 | { | ||
26 | .name = "u-boot", | ||
27 | .offset = 0, | ||
28 | .size = SZ_1M | ||
29 | }, { | ||
30 | .name = "uImage", | ||
31 | .offset = MTDPART_OFS_NXTBLK, | ||
32 | .size = SZ_4M | ||
33 | }, { | ||
34 | .name = "root", | ||
35 | .offset = MTDPART_OFS_NXTBLK, | ||
36 | .size = MTDPART_SIZ_FULL | ||
37 | }, | ||
38 | }; | ||
39 | |||
40 | static struct mv643xx_eth_platform_data openrd_base_ge00_data = { | ||
41 | .phy_addr = MV643XX_ETH_PHY_ADDR(8), | ||
42 | }; | ||
43 | |||
44 | static struct mv_sata_platform_data openrd_base_sata_data = { | ||
45 | .n_ports = 2, | ||
46 | }; | ||
47 | |||
48 | static struct mvsdio_platform_data openrd_base_mvsdio_data = { | ||
49 | .gpio_card_detect = 29, /* MPP29 used as SD card detect */ | ||
50 | }; | ||
51 | |||
52 | static unsigned int openrd_base_mpp_config[] __initdata = { | ||
53 | MPP29_GPIO, | ||
54 | 0 | ||
55 | }; | ||
56 | |||
57 | static void __init openrd_base_init(void) | ||
58 | { | ||
59 | /* | ||
60 | * Basic setup. Needs to be called early. | ||
61 | */ | ||
62 | kirkwood_init(); | ||
63 | kirkwood_mpp_conf(openrd_base_mpp_config); | ||
64 | |||
65 | kirkwood_uart0_init(); | ||
66 | kirkwood_nand_init(ARRAY_AND_SIZE(openrd_base_nand_parts), 25); | ||
67 | |||
68 | kirkwood_ehci_init(); | ||
69 | |||
70 | kirkwood_ge00_init(&openrd_base_ge00_data); | ||
71 | kirkwood_sata_init(&openrd_base_sata_data); | ||
72 | kirkwood_sdio_init(&openrd_base_mvsdio_data); | ||
73 | |||
74 | kirkwood_i2c_init(); | ||
75 | } | ||
76 | |||
77 | static int __init openrd_base_pci_init(void) | ||
78 | { | ||
79 | if (machine_is_openrd_base()) | ||
80 | kirkwood_pcie_init(); | ||
81 | |||
82 | return 0; | ||
83 | } | ||
84 | subsys_initcall(openrd_base_pci_init); | ||
85 | |||
86 | |||
87 | MACHINE_START(OPENRD_BASE, "Marvell OpenRD Base Board") | ||
88 | /* Maintainer: Dhaval Vasa <dhaval.vasa@einfochips.com> */ | ||
89 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | ||
90 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | ||
91 | .boot_params = 0x00000100, | ||
92 | .init_machine = openrd_base_init, | ||
93 | .map_io = kirkwood_map_io, | ||
94 | .init_irq = kirkwood_init_irq, | ||
95 | .timer = &kirkwood_timer, | ||
96 | MACHINE_END | ||
diff --git a/arch/arm/mach-kirkwood/sheevaplug-setup.c b/arch/arm/mach-kirkwood/sheevaplug-setup.c index c7319eeac8bb..a00879d34d54 100644 --- a/arch/arm/mach-kirkwood/sheevaplug-setup.c +++ b/arch/arm/mach-kirkwood/sheevaplug-setup.c | |||
@@ -11,6 +11,7 @@ | |||
11 | #include <linux/kernel.h> | 11 | #include <linux/kernel.h> |
12 | #include <linux/init.h> | 12 | #include <linux/init.h> |
13 | #include <linux/platform_device.h> | 13 | #include <linux/platform_device.h> |
14 | #include <linux/ata_platform.h> | ||
14 | #include <linux/mtd/partitions.h> | 15 | #include <linux/mtd/partitions.h> |
15 | #include <linux/mv643xx_eth.h> | 16 | #include <linux/mv643xx_eth.h> |
16 | #include <linux/gpio.h> | 17 | #include <linux/gpio.h> |
@@ -42,10 +43,19 @@ static struct mv643xx_eth_platform_data sheevaplug_ge00_data = { | |||
42 | .phy_addr = MV643XX_ETH_PHY_ADDR(0), | 43 | .phy_addr = MV643XX_ETH_PHY_ADDR(0), |
43 | }; | 44 | }; |
44 | 45 | ||
46 | static struct mv_sata_platform_data sheeva_esata_sata_data = { | ||
47 | .n_ports = 2, | ||
48 | }; | ||
49 | |||
45 | static struct mvsdio_platform_data sheevaplug_mvsdio_data = { | 50 | static struct mvsdio_platform_data sheevaplug_mvsdio_data = { |
46 | /* unfortunately the CD signal has not been connected */ | 51 | /* unfortunately the CD signal has not been connected */ |
47 | }; | 52 | }; |
48 | 53 | ||
54 | static struct mvsdio_platform_data sheeva_esata_mvsdio_data = { | ||
55 | .gpio_write_protect = 44, /* MPP44 used as SD write protect */ | ||
56 | .gpio_card_detect = 47, /* MPP47 used as SD card detect */ | ||
57 | }; | ||
58 | |||
49 | static struct gpio_led sheevaplug_led_pins[] = { | 59 | static struct gpio_led sheevaplug_led_pins[] = { |
50 | { | 60 | { |
51 | .name = "plug:green:health", | 61 | .name = "plug:green:health", |
@@ -74,13 +84,26 @@ static unsigned int sheevaplug_mpp_config[] __initdata = { | |||
74 | 0 | 84 | 0 |
75 | }; | 85 | }; |
76 | 86 | ||
87 | static unsigned int sheeva_esata_mpp_config[] __initdata = { | ||
88 | MPP29_GPIO, /* USB Power Enable */ | ||
89 | MPP44_GPIO, /* SD Write Protect */ | ||
90 | MPP47_GPIO, /* SD Card Detect */ | ||
91 | MPP49_GPIO, /* LED Green */ | ||
92 | 0 | ||
93 | }; | ||
94 | |||
77 | static void __init sheevaplug_init(void) | 95 | static void __init sheevaplug_init(void) |
78 | { | 96 | { |
79 | /* | 97 | /* |
80 | * Basic setup. Needs to be called early. | 98 | * Basic setup. Needs to be called early. |
81 | */ | 99 | */ |
82 | kirkwood_init(); | 100 | kirkwood_init(); |
83 | kirkwood_mpp_conf(sheevaplug_mpp_config); | 101 | |
102 | /* setup gpio pin select */ | ||
103 | if (machine_is_sheeva_esata()) | ||
104 | kirkwood_mpp_conf(sheeva_esata_mpp_config); | ||
105 | else | ||
106 | kirkwood_mpp_conf(sheevaplug_mpp_config); | ||
84 | 107 | ||
85 | kirkwood_uart0_init(); | 108 | kirkwood_uart0_init(); |
86 | kirkwood_nand_init(ARRAY_AND_SIZE(sheevaplug_nand_parts), 25); | 109 | kirkwood_nand_init(ARRAY_AND_SIZE(sheevaplug_nand_parts), 25); |
@@ -91,11 +114,21 @@ static void __init sheevaplug_init(void) | |||
91 | kirkwood_ehci_init(); | 114 | kirkwood_ehci_init(); |
92 | 115 | ||
93 | kirkwood_ge00_init(&sheevaplug_ge00_data); | 116 | kirkwood_ge00_init(&sheevaplug_ge00_data); |
94 | kirkwood_sdio_init(&sheevaplug_mvsdio_data); | 117 | |
118 | /* honor lower power consumption for plugs with out eSATA */ | ||
119 | if (machine_is_sheeva_esata()) | ||
120 | kirkwood_sata_init(&sheeva_esata_sata_data); | ||
121 | |||
122 | /* enable sd wp and sd cd on plugs with esata */ | ||
123 | if (machine_is_sheeva_esata()) | ||
124 | kirkwood_sdio_init(&sheeva_esata_mvsdio_data); | ||
125 | else | ||
126 | kirkwood_sdio_init(&sheevaplug_mvsdio_data); | ||
95 | 127 | ||
96 | platform_device_register(&sheevaplug_leds); | 128 | platform_device_register(&sheevaplug_leds); |
97 | } | 129 | } |
98 | 130 | ||
131 | #ifdef CONFIG_MACH_SHEEVAPLUG | ||
99 | MACHINE_START(SHEEVAPLUG, "Marvell SheevaPlug Reference Board") | 132 | MACHINE_START(SHEEVAPLUG, "Marvell SheevaPlug Reference Board") |
100 | /* Maintainer: shadi Ammouri <shadi@marvell.com> */ | 133 | /* Maintainer: shadi Ammouri <shadi@marvell.com> */ |
101 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | 134 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, |
@@ -106,3 +139,16 @@ MACHINE_START(SHEEVAPLUG, "Marvell SheevaPlug Reference Board") | |||
106 | .init_irq = kirkwood_init_irq, | 139 | .init_irq = kirkwood_init_irq, |
107 | .timer = &kirkwood_timer, | 140 | .timer = &kirkwood_timer, |
108 | MACHINE_END | 141 | MACHINE_END |
142 | #endif | ||
143 | |||
144 | #ifdef CONFIG_MACH_ESATA_SHEEVAPLUG | ||
145 | MACHINE_START(ESATA_SHEEVAPLUG, "Marvell eSATA SheevaPlug Reference Board") | ||
146 | .phys_io = KIRKWOOD_REGS_PHYS_BASE, | ||
147 | .io_pg_offst = ((KIRKWOOD_REGS_VIRT_BASE) >> 18) & 0xfffc, | ||
148 | .boot_params = 0x00000100, | ||
149 | .init_machine = sheevaplug_init, | ||
150 | .map_io = kirkwood_map_io, | ||
151 | .init_irq = kirkwood_init_irq, | ||
152 | .timer = &kirkwood_timer, | ||
153 | MACHINE_END | ||
154 | #endif | ||