summaryrefslogtreecommitdiff
path: root/arch/arm/mach-spear3xx
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-spear3xx')
-rw-r--r--arch/arm/mach-spear3xx/Kconfig26
-rw-r--r--arch/arm/mach-spear3xx/Makefile15
-rw-r--r--arch/arm/mach-spear3xx/Makefile.boot3
-rw-r--r--arch/arm/mach-spear3xx/include/mach/debug-macro.S14
-rw-r--r--arch/arm/mach-spear3xx/include/mach/generic.h37
-rw-r--r--arch/arm/mach-spear3xx/include/mach/hardware.h1
-rw-r--r--arch/arm/mach-spear3xx/include/mach/irqs.h19
-rw-r--r--arch/arm/mach-spear3xx/include/mach/misc_regs.h22
-rw-r--r--arch/arm/mach-spear3xx/include/mach/spear.h60
-rw-r--r--arch/arm/mach-spear3xx/include/mach/timex.h19
-rw-r--r--arch/arm/mach-spear3xx/include/mach/uncompress.h19
-rw-r--r--arch/arm/mach-spear3xx/spear300.c221
-rw-r--r--arch/arm/mach-spear3xx/spear310.c263
-rw-r--r--arch/arm/mach-spear3xx/spear320.c277
-rw-r--r--arch/arm/mach-spear3xx/spear3xx.c134
15 files changed, 0 insertions, 1130 deletions
diff --git a/arch/arm/mach-spear3xx/Kconfig b/arch/arm/mach-spear3xx/Kconfig
deleted file mode 100644
index 8bd37291fa4f..000000000000
--- a/arch/arm/mach-spear3xx/Kconfig
+++ /dev/null
@@ -1,26 +0,0 @@
-#
-# SPEAr3XX Machine configuration file
-#
-
-if ARCH_SPEAR3XX
-
-menu "SPEAr3xx Implementations"
-config MACH_SPEAR300
- bool "SPEAr300 Machine support with Device Tree"
- select PINCTRL_SPEAR300
- help
- Supports ST SPEAr300 machine configured via the device-tree
-
-config MACH_SPEAR310
- bool "SPEAr310 Machine support with Device Tree"
- select PINCTRL_SPEAR310
- help
- Supports ST SPEAr310 machine configured via the device-tree
-
-config MACH_SPEAR320
- bool "SPEAr320 Machine support with Device Tree"
- select PINCTRL_SPEAR320
- help
- Supports ST SPEAr320 machine configured via the device-tree
-endmenu
-endif #ARCH_SPEAR3XX
diff --git a/arch/arm/mach-spear3xx/Makefile b/arch/arm/mach-spear3xx/Makefile
deleted file mode 100644
index 8d12faa178fd..000000000000
--- a/arch/arm/mach-spear3xx/Makefile
+++ /dev/null
@@ -1,15 +0,0 @@
-#
-# Makefile for SPEAr3XX machine series
-#
-
-# common files
-obj-$(CONFIG_ARCH_SPEAR3XX) += spear3xx.o
-
-# spear300 specific files
-obj-$(CONFIG_MACH_SPEAR300) += spear300.o
-
-# spear310 specific files
-obj-$(CONFIG_MACH_SPEAR310) += spear310.o
-
-# spear320 specific files
-obj-$(CONFIG_MACH_SPEAR320) += spear320.o
diff --git a/arch/arm/mach-spear3xx/Makefile.boot b/arch/arm/mach-spear3xx/Makefile.boot
deleted file mode 100644
index 4674a4c221db..000000000000
--- a/arch/arm/mach-spear3xx/Makefile.boot
+++ /dev/null
@@ -1,3 +0,0 @@
-zreladdr-y += 0x00008000
-params_phys-y := 0x00000100
-initrd_phys-y := 0x00800000
diff --git a/arch/arm/mach-spear3xx/include/mach/debug-macro.S b/arch/arm/mach-spear3xx/include/mach/debug-macro.S
deleted file mode 100644
index 0a6381fad5d9..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/debug-macro.S
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/debug-macro.S
- *
- * Debugging macro include header spear3xx machine family
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar<viresh.linux@gmail.com>
- *
- * 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 <plat/debug-macro.S>
diff --git a/arch/arm/mach-spear3xx/include/mach/generic.h b/arch/arm/mach-spear3xx/include/mach/generic.h
deleted file mode 100644
index ce19113ca791..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/generic.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/generic.h
- *
- * SPEAr3XX machine family generic header file
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar<viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_GENERIC_H
-#define __MACH_GENERIC_H
-
-#include <linux/amba/pl08x.h>
-#include <linux/init.h>
-#include <linux/platform_device.h>
-#include <linux/amba/bus.h>
-#include <asm/mach/time.h>
-#include <asm/mach/map.h>
-
-/* Add spear3xx family device structure declarations here */
-extern struct sys_timer spear3xx_timer;
-extern struct pl022_ssp_controller pl022_plat_data;
-extern struct pl08x_platform_data pl080_plat_data;
-
-/* Add spear3xx family function declarations here */
-void __init spear_setup_of_timer(void);
-void __init spear3xx_clk_init(void);
-void __init spear3xx_map_io(void);
-void __init spear3xx_dt_init_irq(void);
-
-void spear_restart(char, const char *);
-
-#endif /* __MACH_GENERIC_H */
diff --git a/arch/arm/mach-spear3xx/include/mach/hardware.h b/arch/arm/mach-spear3xx/include/mach/hardware.h
deleted file mode 100644
index 40a8c178f10d..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/hardware.h
+++ /dev/null
@@ -1 +0,0 @@
-/* empty */
diff --git a/arch/arm/mach-spear3xx/include/mach/irqs.h b/arch/arm/mach-spear3xx/include/mach/irqs.h
deleted file mode 100644
index f95e5b2b6686..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/irqs.h
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/irqs.h
- *
- * IRQ helper macros for SPEAr3xx machine family
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_IRQS_H
-#define __MACH_IRQS_H
-
-#define NR_IRQS 256
-
-#endif /* __MACH_IRQS_H */
diff --git a/arch/arm/mach-spear3xx/include/mach/misc_regs.h b/arch/arm/mach-spear3xx/include/mach/misc_regs.h
deleted file mode 100644
index 6309bf68d6f8..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/misc_regs.h
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/misc_regs.h
- *
- * Miscellaneous registers definitions for SPEAr3xx machine family
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_MISC_REGS_H
-#define __MACH_MISC_REGS_H
-
-#include <mach/spear.h>
-
-#define MISC_BASE IOMEM(VA_SPEAR3XX_ICM3_MISC_REG_BASE)
-#define DMA_CHN_CFG (MISC_BASE + 0x0A0)
-
-#endif /* __MACH_MISC_REGS_H */
diff --git a/arch/arm/mach-spear3xx/include/mach/spear.h b/arch/arm/mach-spear3xx/include/mach/spear.h
deleted file mode 100644
index 8cca95193d4d..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/spear.h
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/spear.h
- *
- * SPEAr3xx Machine family specific definition
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_SPEAR3XX_H
-#define __MACH_SPEAR3XX_H
-
-#include <asm/memory.h>
-
-/* ICM1 - Low speed connection */
-#define SPEAR3XX_ICM1_2_BASE UL(0xD0000000)
-#define VA_SPEAR3XX_ICM1_2_BASE UL(0xFD000000)
-#define SPEAR3XX_ICM1_UART_BASE UL(0xD0000000)
-#define VA_SPEAR3XX_ICM1_UART_BASE (VA_SPEAR3XX_ICM1_2_BASE | SPEAR3XX_ICM1_UART_BASE)
-#define SPEAR3XX_ICM1_SSP_BASE UL(0xD0100000)
-
-/* ML1 - Multi Layer CPU Subsystem */
-#define SPEAR3XX_ICM3_ML1_2_BASE UL(0xF0000000)
-#define VA_SPEAR6XX_ML_CPU_BASE UL(0xF0000000)
-
-/* ICM3 - Basic Subsystem */
-#define SPEAR3XX_ICM3_SMI_CTRL_BASE UL(0xFC000000)
-#define VA_SPEAR3XX_ICM3_SMI_CTRL_BASE UL(0xFC000000)
-#define SPEAR3XX_ICM3_DMA_BASE UL(0xFC400000)
-#define SPEAR3XX_ICM3_SYS_CTRL_BASE UL(0xFCA00000)
-#define VA_SPEAR3XX_ICM3_SYS_CTRL_BASE (VA_SPEAR3XX_ICM3_SMI_CTRL_BASE | SPEAR3XX_ICM3_SYS_CTRL_BASE)
-#define SPEAR3XX_ICM3_MISC_REG_BASE UL(0xFCA80000)
-#define VA_SPEAR3XX_ICM3_MISC_REG_BASE (VA_SPEAR3XX_ICM3_SMI_CTRL_BASE | SPEAR3XX_ICM3_MISC_REG_BASE)
-
-/* Debug uart for linux, will be used for debug and uncompress messages */
-#define SPEAR_DBG_UART_BASE SPEAR3XX_ICM1_UART_BASE
-#define VA_SPEAR_DBG_UART_BASE VA_SPEAR3XX_ICM1_UART_BASE
-
-/* Sysctl base for spear platform */
-#define SPEAR_SYS_CTRL_BASE SPEAR3XX_ICM3_SYS_CTRL_BASE
-#define VA_SPEAR_SYS_CTRL_BASE VA_SPEAR3XX_ICM3_SYS_CTRL_BASE
-
-/* SPEAr320 Macros */
-#define SPEAR320_SOC_CONFIG_BASE UL(0xB3000000)
-#define VA_SPEAR320_SOC_CONFIG_BASE UL(0xFE000000)
-#define SPEAR320_CONTROL_REG IOMEM(VA_SPEAR320_SOC_CONFIG_BASE)
-#define SPEAR320_EXT_CTRL_REG IOMEM(VA_SPEAR320_SOC_CONFIG_BASE + 0x0018)
- #define SPEAR320_UARTX_PCLK_MASK 0x1
- #define SPEAR320_UART2_PCLK_SHIFT 8
- #define SPEAR320_UART3_PCLK_SHIFT 9
- #define SPEAR320_UART4_PCLK_SHIFT 10
- #define SPEAR320_UART5_PCLK_SHIFT 11
- #define SPEAR320_UART6_PCLK_SHIFT 12
- #define SPEAR320_RS485_PCLK_SHIFT 13
-
-#endif /* __MACH_SPEAR3XX_H */
diff --git a/arch/arm/mach-spear3xx/include/mach/timex.h b/arch/arm/mach-spear3xx/include/mach/timex.h
deleted file mode 100644
index 9f5d08bd0c44..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/timex.h
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/timex.h
- *
- * SPEAr3XX machine family specific timex definitions
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_TIMEX_H
-#define __MACH_TIMEX_H
-
-#include <plat/timex.h>
-
-#endif /* __MACH_TIMEX_H */
diff --git a/arch/arm/mach-spear3xx/include/mach/uncompress.h b/arch/arm/mach-spear3xx/include/mach/uncompress.h
deleted file mode 100644
index b909b011f7c8..000000000000
--- a/arch/arm/mach-spear3xx/include/mach/uncompress.h
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/include/mach/uncompress.h
- *
- * Serial port stubs for kernel decompress status messages
- *
- * Copyright (C) 2009 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#ifndef __MACH_UNCOMPRESS_H
-#define __MACH_UNCOMPRESS_H
-
-#include <plat/uncompress.h>
-
-#endif /* __MACH_UNCOMPRESS_H */
diff --git a/arch/arm/mach-spear3xx/spear300.c b/arch/arm/mach-spear3xx/spear300.c
deleted file mode 100644
index a69cbfdb07ee..000000000000
--- a/arch/arm/mach-spear3xx/spear300.c
+++ /dev/null
@@ -1,221 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/spear300.c
- *
- * SPEAr300 machine source file
- *
- * Copyright (C) 2009-2012 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#define pr_fmt(fmt) "SPEAr300: " fmt
-
-#include <linux/amba/pl08x.h>
-#include <linux/of_platform.h>
-#include <asm/hardware/vic.h>
-#include <asm/mach/arch.h>
-#include <mach/generic.h>
-#include <mach/spear.h>
-
-/* DMAC platform data's slave info */
-struct pl08x_channel_data spear300_dma_info[] = {
- {
- .bus_id = "uart0_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart0_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "irda",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "adc",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "to_jpeg",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "from_jpeg",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras0_rx",
- .min_signal = 0,
- .max_signal = 0,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras0_tx",
- .min_signal = 1,
- .max_signal = 1,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras1_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras1_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras2_rx",
- .min_signal = 4,
- .max_signal = 4,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras2_tx",
- .min_signal = 5,
- .max_signal = 5,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras3_rx",
- .min_signal = 6,
- .max_signal = 6,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras3_tx",
- .min_signal = 7,
- .max_signal = 7,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras4_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras4_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras5_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras5_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras6_rx",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras6_tx",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras7_rx",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras7_tx",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- },
-};
-
-/* Add SPEAr300 auxdata to pass platform data */
-static struct of_dev_auxdata spear300_auxdata_lookup[] __initdata = {
- OF_DEV_AUXDATA("arm,pl022", SPEAR3XX_ICM1_SSP_BASE, NULL,
- &pl022_plat_data),
- OF_DEV_AUXDATA("arm,pl080", SPEAR3XX_ICM3_DMA_BASE, NULL,
- &pl080_plat_data),
- {}
-};
-
-static void __init spear300_dt_init(void)
-{
- pl080_plat_data.slave_channels = spear300_dma_info;
- pl080_plat_data.num_slave_channels = ARRAY_SIZE(spear300_dma_info);
-
- of_platform_populate(NULL, of_default_bus_match_table,
- spear300_auxdata_lookup, NULL);
-}
-
-static const char * const spear300_dt_board_compat[] = {
- "st,spear300",
- "st,spear300-evb",
- NULL,
-};
-
-static void __init spear300_map_io(void)
-{
- spear3xx_map_io();
-}
-
-DT_MACHINE_START(SPEAR300_DT, "ST SPEAr300 SoC with Flattened Device Tree")
- .map_io = spear300_map_io,
- .init_irq = spear3xx_dt_init_irq,
- .handle_irq = vic_handle_irq,
- .timer = &spear3xx_timer,
- .init_machine = spear300_dt_init,
- .restart = spear_restart,
- .dt_compat = spear300_dt_board_compat,
-MACHINE_END
diff --git a/arch/arm/mach-spear3xx/spear310.c b/arch/arm/mach-spear3xx/spear310.c
deleted file mode 100644
index b963ebb10b56..000000000000
--- a/arch/arm/mach-spear3xx/spear310.c
+++ /dev/null
@@ -1,263 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/spear310.c
- *
- * SPEAr310 machine source file
- *
- * Copyright (C) 2009-2012 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#define pr_fmt(fmt) "SPEAr310: " fmt
-
-#include <linux/amba/pl08x.h>
-#include <linux/amba/serial.h>
-#include <linux/of_platform.h>
-#include <asm/hardware/vic.h>
-#include <asm/mach/arch.h>
-#include <mach/generic.h>
-#include <mach/spear.h>
-
-#define SPEAR310_UART1_BASE UL(0xB2000000)
-#define SPEAR310_UART2_BASE UL(0xB2080000)
-#define SPEAR310_UART3_BASE UL(0xB2100000)
-#define SPEAR310_UART4_BASE UL(0xB2180000)
-#define SPEAR310_UART5_BASE UL(0xB2200000)
-
-/* DMAC platform data's slave info */
-struct pl08x_channel_data spear310_dma_info[] = {
- {
- .bus_id = "uart0_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart0_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "irda",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "adc",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "to_jpeg",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "from_jpeg",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart1_rx",
- .min_signal = 0,
- .max_signal = 0,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart1_tx",
- .min_signal = 1,
- .max_signal = 1,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart2_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart2_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart3_rx",
- .min_signal = 4,
- .max_signal = 4,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart3_tx",
- .min_signal = 5,
- .max_signal = 5,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart4_rx",
- .min_signal = 6,
- .max_signal = 6,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart4_tx",
- .min_signal = 7,
- .max_signal = 7,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart5_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart5_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras5_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras5_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras6_rx",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras6_tx",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras7_rx",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ras7_tx",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 1,
- .periph_buses = PL08X_AHB1,
- },
-};
-
-/* uart devices plat data */
-static struct amba_pl011_data spear310_uart_data[] = {
- {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart1_tx",
- .dma_rx_param = "uart1_rx",
- }, {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart2_tx",
- .dma_rx_param = "uart2_rx",
- }, {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart3_tx",
- .dma_rx_param = "uart3_rx",
- }, {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart4_tx",
- .dma_rx_param = "uart4_rx",
- }, {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart5_tx",
- .dma_rx_param = "uart5_rx",
- },
-};
-
-/* Add SPEAr310 auxdata to pass platform data */
-static struct of_dev_auxdata spear310_auxdata_lookup[] __initdata = {
- OF_DEV_AUXDATA("arm,pl022", SPEAR3XX_ICM1_SSP_BASE, NULL,
- &pl022_plat_data),
- OF_DEV_AUXDATA("arm,pl080", SPEAR3XX_ICM3_DMA_BASE, NULL,
- &pl080_plat_data),
- OF_DEV_AUXDATA("arm,pl011", SPEAR310_UART1_BASE, NULL,
- &spear310_uart_data[0]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR310_UART2_BASE, NULL,
- &spear310_uart_data[1]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR310_UART3_BASE, NULL,
- &spear310_uart_data[2]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR310_UART4_BASE, NULL,
- &spear310_uart_data[3]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR310_UART5_BASE, NULL,
- &spear310_uart_data[4]),
- {}
-};
-
-static void __init spear310_dt_init(void)
-{
- pl080_plat_data.slave_channels = spear310_dma_info;
- pl080_plat_data.num_slave_channels = ARRAY_SIZE(spear310_dma_info);
-
- of_platform_populate(NULL, of_default_bus_match_table,
- spear310_auxdata_lookup, NULL);
-}
-
-static const char * const spear310_dt_board_compat[] = {
- "st,spear310",
- "st,spear310-evb",
- NULL,
-};
-
-static void __init spear310_map_io(void)
-{
- spear3xx_map_io();
-}
-
-DT_MACHINE_START(SPEAR310_DT, "ST SPEAr310 SoC with Flattened Device Tree")
- .map_io = spear310_map_io,
- .init_irq = spear3xx_dt_init_irq,
- .handle_irq = vic_handle_irq,
- .timer = &spear3xx_timer,
- .init_machine = spear310_dt_init,
- .restart = spear_restart,
- .dt_compat = spear310_dt_board_compat,
-MACHINE_END
diff --git a/arch/arm/mach-spear3xx/spear320.c b/arch/arm/mach-spear3xx/spear320.c
deleted file mode 100644
index 66e3a0c33e75..000000000000
--- a/arch/arm/mach-spear3xx/spear320.c
+++ /dev/null
@@ -1,277 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/spear320.c
- *
- * SPEAr320 machine source file
- *
- * Copyright (C) 2009-2012 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#define pr_fmt(fmt) "SPEAr320: " fmt
-
-#include <linux/amba/pl022.h>
-#include <linux/amba/pl08x.h>
-#include <linux/amba/serial.h>
-#include <linux/of_platform.h>
-#include <asm/hardware/vic.h>
-#include <asm/mach/arch.h>
-#include <mach/generic.h>
-#include <mach/spear.h>
-
-#define SPEAR320_UART1_BASE UL(0xA3000000)
-#define SPEAR320_UART2_BASE UL(0xA4000000)
-#define SPEAR320_SSP0_BASE UL(0xA5000000)
-#define SPEAR320_SSP1_BASE UL(0xA6000000)
-
-/* DMAC platform data's slave info */
-struct pl08x_channel_data spear320_dma_info[] = {
- {
- .bus_id = "uart0_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "uart0_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp0_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c0_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "i2c0_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "irda",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "adc",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "to_jpeg",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "from_jpeg",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 0,
- .periph_buses = PL08X_AHB1,
- }, {
- .bus_id = "ssp1_rx",
- .min_signal = 0,
- .max_signal = 0,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "ssp1_tx",
- .min_signal = 1,
- .max_signal = 1,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "ssp2_rx",
- .min_signal = 2,
- .max_signal = 2,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "ssp2_tx",
- .min_signal = 3,
- .max_signal = 3,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "uart1_rx",
- .min_signal = 4,
- .max_signal = 4,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "uart1_tx",
- .min_signal = 5,
- .max_signal = 5,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "uart2_rx",
- .min_signal = 6,
- .max_signal = 6,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "uart2_tx",
- .min_signal = 7,
- .max_signal = 7,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2c1_rx",
- .min_signal = 8,
- .max_signal = 8,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2c1_tx",
- .min_signal = 9,
- .max_signal = 9,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2c2_rx",
- .min_signal = 10,
- .max_signal = 10,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2c2_tx",
- .min_signal = 11,
- .max_signal = 11,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2s_rx",
- .min_signal = 12,
- .max_signal = 12,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "i2s_tx",
- .min_signal = 13,
- .max_signal = 13,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "rs485_rx",
- .min_signal = 14,
- .max_signal = 14,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- }, {
- .bus_id = "rs485_tx",
- .min_signal = 15,
- .max_signal = 15,
- .muxval = 1,
- .periph_buses = PL08X_AHB2,
- },
-};
-
-static struct pl022_ssp_controller spear320_ssp_data[] = {
- {
- .bus_id = 1,
- .enable_dma = 1,
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "ssp1_tx",
- .dma_rx_param = "ssp1_rx",
- .num_chipselect = 2,
- }, {
- .bus_id = 2,
- .enable_dma = 1,
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "ssp2_tx",
- .dma_rx_param = "ssp2_rx",
- .num_chipselect = 2,
- }
-};
-
-static struct amba_pl011_data spear320_uart_data[] = {
- {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart1_tx",
- .dma_rx_param = "uart1_rx",
- }, {
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "uart2_tx",
- .dma_rx_param = "uart2_rx",
- },
-};
-
-/* Add SPEAr310 auxdata to pass platform data */
-static struct of_dev_auxdata spear320_auxdata_lookup[] __initdata = {
- OF_DEV_AUXDATA("arm,pl022", SPEAR3XX_ICM1_SSP_BASE, NULL,
- &pl022_plat_data),
- OF_DEV_AUXDATA("arm,pl080", SPEAR3XX_ICM3_DMA_BASE, NULL,
- &pl080_plat_data),
- OF_DEV_AUXDATA("arm,pl022", SPEAR320_SSP0_BASE, NULL,
- &spear320_ssp_data[0]),
- OF_DEV_AUXDATA("arm,pl022", SPEAR320_SSP1_BASE, NULL,
- &spear320_ssp_data[1]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR320_UART1_BASE, NULL,
- &spear320_uart_data[0]),
- OF_DEV_AUXDATA("arm,pl011", SPEAR320_UART2_BASE, NULL,
- &spear320_uart_data[1]),
- {}
-};
-
-static void __init spear320_dt_init(void)
-{
- pl080_plat_data.slave_channels = spear320_dma_info;
- pl080_plat_data.num_slave_channels = ARRAY_SIZE(spear320_dma_info);
-
- of_platform_populate(NULL, of_default_bus_match_table,
- spear320_auxdata_lookup, NULL);
-}
-
-static const char * const spear320_dt_board_compat[] = {
- "st,spear320",
- "st,spear320-evb",
- "st,spear320-hmi",
- NULL,
-};
-
-struct map_desc spear320_io_desc[] __initdata = {
- {
- .virtual = VA_SPEAR320_SOC_CONFIG_BASE,
- .pfn = __phys_to_pfn(SPEAR320_SOC_CONFIG_BASE),
- .length = SZ_16M,
- .type = MT_DEVICE
- },
-};
-
-static void __init spear320_map_io(void)
-{
- iotable_init(spear320_io_desc, ARRAY_SIZE(spear320_io_desc));
- spear3xx_map_io();
-}
-
-DT_MACHINE_START(SPEAR320_DT, "ST SPEAr320 SoC with Flattened Device Tree")
- .map_io = spear320_map_io,
- .init_irq = spear3xx_dt_init_irq,
- .handle_irq = vic_handle_irq,
- .timer = &spear3xx_timer,
- .init_machine = spear320_dt_init,
- .restart = spear_restart,
- .dt_compat = spear320_dt_board_compat,
-MACHINE_END
diff --git a/arch/arm/mach-spear3xx/spear3xx.c b/arch/arm/mach-spear3xx/spear3xx.c
deleted file mode 100644
index 38fe95db31a7..000000000000
--- a/arch/arm/mach-spear3xx/spear3xx.c
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * arch/arm/mach-spear3xx/spear3xx.c
- *
- * SPEAr3XX machines common source file
- *
- * Copyright (C) 2009-2012 ST Microelectronics
- * Viresh Kumar <viresh.linux@gmail.com>
- *
- * 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.
- */
-
-#define pr_fmt(fmt) "SPEAr3xx: " fmt
-
-#include <linux/amba/pl022.h>
-#include <linux/amba/pl08x.h>
-#include <linux/irqchip/spear-shirq.h>
-#include <linux/of_irq.h>
-#include <linux/io.h>
-#include <asm/hardware/pl080.h>
-#include <asm/hardware/vic.h>
-#include <plat/pl080.h>
-#include <mach/generic.h>
-#include <mach/spear.h>
-
-/* ssp device registration */
-struct pl022_ssp_controller pl022_plat_data = {
- .bus_id = 0,
- .enable_dma = 1,
- .dma_filter = pl08x_filter_id,
- .dma_tx_param = "ssp0_tx",
- .dma_rx_param = "ssp0_rx",
- /*
- * This is number of spi devices that can be connected to spi. There are
- * two type of chipselects on which slave devices can work. One is chip
- * select provided by spi masters other is controlled through external
- * gpio's. We can't use chipselect provided from spi master (because as
- * soon as FIFO becomes empty, CS is disabled and transfer ends). So
- * this number now depends on number of gpios available for spi. each
- * slave on each master requires a separate gpio pin.
- */
- .num_chipselect = 2,
-};
-
-/* dmac device registration */
-struct pl08x_platform_data pl080_plat_data = {
- .memcpy_channel = {
- .bus_id = "memcpy",
- .cctl_memcpy =
- (PL080_BSIZE_16 << PL080_CONTROL_SB_SIZE_SHIFT | \
- PL080_BSIZE_16 << PL080_CONTROL_DB_SIZE_SHIFT | \
- PL080_WIDTH_32BIT << PL080_CONTROL_SWIDTH_SHIFT | \
- PL080_WIDTH_32BIT << PL080_CONTROL_DWIDTH_SHIFT | \
- PL080_CONTROL_PROT_BUFF | PL080_CONTROL_PROT_CACHE | \
- PL080_CONTROL_PROT_SYS),
- },
- .lli_buses = PL08X_AHB1,
- .mem_buses = PL08X_AHB1,
- .get_signal = pl080_get_signal,
- .put_signal = pl080_put_signal,
-};
-
-/*
- * Following will create 16MB static virtual/physical mappings
- * PHYSICAL VIRTUAL
- * 0xD0000000 0xFD000000
- * 0xFC000000 0xFC000000
- */
-struct map_desc spear3xx_io_desc[] __initdata = {
- {
- .virtual = VA_SPEAR3XX_ICM1_2_BASE,
- .pfn = __phys_to_pfn(SPEAR3XX_ICM1_2_BASE),
- .length = SZ_16M,
- .type = MT_DEVICE
- }, {
- .virtual = VA_SPEAR3XX_ICM3_SMI_CTRL_BASE,
- .pfn = __phys_to_pfn(SPEAR3XX_ICM3_SMI_CTRL_BASE),
- .length = SZ_16M,
- .type = MT_DEVICE
- },
-};
-
-/* This will create static memory mapping for selected devices */
-void __init spear3xx_map_io(void)
-{
- iotable_init(spear3xx_io_desc, ARRAY_SIZE(spear3xx_io_desc));
-}
-
-static void __init spear3xx_timer_init(void)
-{
- char pclk_name[] = "pll3_clk";
- struct clk *gpt_clk, *pclk;
-
- spear3xx_clk_init();
-
- /* get the system timer clock */
- gpt_clk = clk_get_sys("gpt0", NULL);
- if (IS_ERR(gpt_clk)) {
- pr_err("%s:couldn't get clk for gpt\n", __func__);
- BUG();
- }
-
- /* get the suitable parent clock for timer*/
- pclk = clk_get(NULL, pclk_name);
- if (IS_ERR(pclk)) {
- pr_err("%s:couldn't get %s as parent for gpt\n",
- __func__, pclk_name);
- BUG();
- }
-
- clk_set_parent(gpt_clk, pclk);
- clk_put(gpt_clk);
- clk_put(pclk);
-
- spear_setup_of_timer();
-}
-
-struct sys_timer spear3xx_timer = {
- .init = spear3xx_timer_init,
-};
-
-static const struct of_device_id vic_of_match[] __initconst = {
- { .compatible = "arm,pl190-vic", .data = vic_of_init, },
- { .compatible = "st,spear300-shirq", .data = spear300_shirq_of_init, },
- { .compatible = "st,spear310-shirq", .data = spear310_shirq_of_init, },
- { .compatible = "st,spear320-shirq", .data = spear320_shirq_of_init, },
- { /* Sentinel */ }
-};
-
-void __init spear3xx_dt_init_irq(void)
-{
- of_irq_init(vic_of_match);
-}