]> git.karo-electronics.de Git - linux-beck.git/commitdiff
[ARM] Dove: add support for CM-A510 machine.
authorKonstantin Sinyuk <kostyas@compulab.co.il>
Tue, 16 Nov 2010 06:55:03 +0000 (08:55 +0200)
committerNicolas Pitre <nico@fluxnic.net>
Mon, 29 Nov 2010 15:43:25 +0000 (10:43 -0500)
This patch adds support for CM-A510 machine

Signed-off-by: Konstantin Sinyuk <kostyas@compulab.co.il>
Signed-off-by: Mike Rapoport <mike@compulab.co.il>
Reviewed-by: Saeed Bishara <saeed@marvell.com>
Signed-off-by: Nicolas Pitre <nico@fluxnic.net>
arch/arm/mach-dove/Kconfig
arch/arm/mach-dove/Makefile
arch/arm/mach-dove/cm-a510.c [new file with mode: 0644]

index 3b9a32ace90958562547b46d490a1f7b86674d3a..a4ed3900912af08130001a3a5cbc4169f4a96b63 100644 (file)
@@ -9,6 +9,12 @@ config MACH_DOVE_DB
          Say 'Y' here if you want your kernel to support the
          Marvell DB-MV88AP510 Development Board.
 
+ config MACH_CM_A510
+       bool "CompuLab CM-A510 Board"
+       help
+         Say 'Y' here if you want your kernel to support the
+         CompuLab CM-A510 Board.
+
 endmenu
 
 endif
index 7ab3be53f642b98d1a8ac9947f5b463372e4b451..f74f5495425ecb1396e507a8f3c880e069250a9c 100644 (file)
@@ -1,3 +1,4 @@
 obj-y                          += common.o addr-map.o irq.o pcie.o
 
 obj-$(CONFIG_MACH_DOVE_DB)     += dove-db-setup.o
+obj-$(CONFIG_MACH_CM_A510)     += cm-a510.o
diff --git a/arch/arm/mach-dove/cm-a510.c b/arch/arm/mach-dove/cm-a510.c
new file mode 100644 (file)
index 0000000..96e0e94
--- /dev/null
@@ -0,0 +1,95 @@
+/*
+ * arch/arm/mach-dove/cm-a510.c
+ *
+ * Copyright (C) 2010 CompuLab, Ltd.
+ * Konstantin Sinyuk <kostyas@compulab.co.il>
+ *
+ * Based on Marvell DB-MV88AP510-BP Development Board Setup
+ *
+ * This file is licensed under the terms of the GNU General Public
+ * License version 2.  This program is licensed "as is" without any
+ * warranty of any kind, whether express or implied.
+ */
+
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/platform_device.h>
+#include <linux/ata_platform.h>
+#include <linux/mv643xx_eth.h>
+#include <linux/spi/spi.h>
+#include <linux/spi/flash.h>
+
+#include <asm/mach-types.h>
+#include <asm/mach/arch.h>
+
+#include <mach/dove.h>
+
+#include "common.h"
+
+static struct mv643xx_eth_platform_data cm_a510_ge00_data = {
+       .phy_addr       = MV643XX_ETH_PHY_ADDR_DEFAULT,
+};
+
+static struct mv_sata_platform_data cm_a510_sata_data = {
+       .n_ports        = 1,
+};
+
+/*
+ * SPI Devices:
+ * SPI0: 1M Flash Winbond w25q32bv
+ */
+static const struct flash_platform_data cm_a510_spi_flash_data = {
+       .type           = "w25q32bv",
+};
+
+static struct spi_board_info __initdata cm_a510_spi_flash_info[] = {
+       {
+               .modalias       = "m25p80",
+               .platform_data  = &cm_a510_spi_flash_data,
+               .irq            = -1,
+               .max_speed_hz   = 20000000,
+               .bus_num        = 0,
+               .chip_select    = 0,
+       },
+};
+
+static int __init cm_a510_pci_init(void)
+{
+       if (machine_is_cm_a510())
+               dove_pcie_init(1, 1);
+
+       return 0;
+}
+
+subsys_initcall(cm_a510_pci_init);
+
+/* Board Init */
+static void __init cm_a510_init(void)
+{
+       /*
+        * Basic Dove setup. Needs to be called early.
+        */
+       dove_init();
+
+       dove_ge00_init(&cm_a510_ge00_data);
+       dove_ehci0_init();
+       dove_ehci1_init();
+       dove_sata_init(&cm_a510_sata_data);
+       dove_sdio0_init();
+       dove_sdio1_init();
+       dove_spi0_init();
+       dove_spi1_init();
+       dove_uart0_init();
+       dove_uart1_init();
+       dove_i2c_init();
+       spi_register_board_info(cm_a510_spi_flash_info,
+                               ARRAY_SIZE(cm_a510_spi_flash_info));
+}
+
+MACHINE_START(CM_A510, "Compulab CM-A510 Board")
+       .boot_params    = 0x00000100,
+       .init_machine   = cm_a510_init,
+       .map_io         = dove_map_io,
+       .init_irq       = dove_init_irq,
+       .timer          = &dove_timer,
+MACHINE_END