Commit b94c1823 authored by Olof Johansson's avatar Olof Johansson

Merge tag 'ux500-core-for-arm-soc-2' of...

Merge tag 'ux500-core-for-arm-soc-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-stericsson into late/all

From Linus Walleij:
Ux500 core changes for ARM SoC:
- Cleanup from Julia Lawall
- Clean out old pin definitions
- Fix the I2C devices

* tag 'ux500-core-for-arm-soc-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-stericsson:
  ARM: ux500: fix up the I2C devices
  ARM: ux500: delete oldschool pin defines
  arch/arm/mach-ux500/cpu-db8500.c: Avoid using ARRAY_AND_SIZE(e) as a function argument
  ARM: ux500: set coherent_dma_mask for dma40
  ARM: ux500: remove u8500_secondary_startup from INIT section.
  ARM: ux500: add restart support via prcmu
Signed-off-by: default avatarOlof Johansson <olof@lixom.net>
parents d8dfad38 1e66a3da
...@@ -17,7 +17,6 @@ ...@@ -17,7 +17,6 @@
#include "ste-dma40-db8500.h" #include "ste-dma40-db8500.h"
#include "board-mop500.h" #include "board-mop500.h"
#include "devices-db8500.h" #include "devices-db8500.h"
#include "pins-db8500.h"
static struct stedma40_chan_cfg msp0_dma_rx = { static struct stedma40_chan_cfg msp0_dma_rx = {
.high_priority = true, .high_priority = true,
......
...@@ -14,7 +14,6 @@ ...@@ -14,7 +14,6 @@
#include <asm/mach-types.h> #include <asm/mach-types.h>
#include "pins-db8500.h"
#include "board-mop500.h" #include "board-mop500.h"
enum custom_pin_cfg_t { enum custom_pin_cfg_t {
......
...@@ -42,7 +42,6 @@ ...@@ -42,7 +42,6 @@
#include <linux/platform_data/dma-ste-dma40.h> #include <linux/platform_data/dma-ste-dma40.h>
#include <asm/mach-types.h> #include <asm/mach-types.h>
#include <asm/mach/arch.h>
#include "setup.h" #include "setup.h"
#include "devices.h" #include "devices.h"
...@@ -325,21 +324,19 @@ static struct lp55xx_platform_data __initdata lp5521_sec_data = { ...@@ -325,21 +324,19 @@ static struct lp55xx_platform_data __initdata lp5521_sec_data = {
.clock_mode = LP55XX_CLOCK_EXT, .clock_mode = LP55XX_CLOCK_EXT,
}; };
/* I2C0 devices only available on the first HREF/MOP500 */
static struct i2c_board_info __initdata mop500_i2c0_devices[] = { static struct i2c_board_info __initdata mop500_i2c0_devices[] = {
{ {
I2C_BOARD_INFO("tc3589x", 0x42), I2C_BOARD_INFO("tc3589x", 0x42),
.irq = NOMADIK_GPIO_TO_IRQ(217), .irq = NOMADIK_GPIO_TO_IRQ(217),
.platform_data = &mop500_tc35892_data, .platform_data = &mop500_tc35892_data,
}, },
/* I2C0 devices only available prior to HREFv60 */
{ {
I2C_BOARD_INFO("tps61052", 0x33), I2C_BOARD_INFO("tps61052", 0x33),
.platform_data = &mop500_tps61052_data, .platform_data = &mop500_tps61052_data,
}, },
}; };
#define NUM_PRE_V60_I2C0_DEVICES 1
static struct i2c_board_info __initdata mop500_i2c2_devices[] = { static struct i2c_board_info __initdata mop500_i2c2_devices[] = {
{ {
/* lp5521 LED driver, 1st device */ /* lp5521 LED driver, 1st device */
...@@ -357,6 +354,17 @@ static struct i2c_board_info __initdata mop500_i2c2_devices[] = { ...@@ -357,6 +354,17 @@ static struct i2c_board_info __initdata mop500_i2c2_devices[] = {
}, },
}; };
static int __init mop500_i2c_board_init(void)
{
if (machine_is_u8500())
mop500_uib_i2c_add(0, mop500_i2c0_devices,
ARRAY_SIZE(mop500_i2c0_devices));
mop500_uib_i2c_add(2, mop500_i2c2_devices,
ARRAY_SIZE(mop500_i2c2_devices));
return 0;
}
device_initcall(mop500_i2c_board_init);
static void __init mop500_i2c_init(struct device *parent) static void __init mop500_i2c_init(struct device *parent)
{ {
db8500_add_i2c0(parent, NULL); db8500_add_i2c0(parent, NULL);
...@@ -565,7 +573,6 @@ static struct platform_device *snowball_platform_devs[] __initdata = { ...@@ -565,7 +573,6 @@ static struct platform_device *snowball_platform_devs[] __initdata = {
static void __init mop500_init_machine(void) static void __init mop500_init_machine(void)
{ {
struct device *parent = NULL; struct device *parent = NULL;
int i2c0_devs;
int i; int i;
platform_device_register(&db8500_prcmu_device); platform_device_register(&db8500_prcmu_device);
...@@ -588,19 +595,13 @@ static void __init mop500_init_machine(void) ...@@ -588,19 +595,13 @@ static void __init mop500_init_machine(void)
mop500_spi_init(parent); mop500_spi_init(parent);
mop500_audio_init(parent); mop500_audio_init(parent);
mop500_uart_init(parent); mop500_uart_init(parent);
u8500_cryp1_hash1_init(parent); u8500_cryp1_hash1_init(parent);
i2c0_devs = ARRAY_SIZE(mop500_i2c0_devices);
i2c_register_board_info(0, mop500_i2c0_devices, i2c0_devs);
i2c_register_board_info(2, mop500_i2c2_devices,
ARRAY_SIZE(mop500_i2c2_devices));
/* This board has full regulator constraints */ /* This board has full regulator constraints */
regulator_has_full_constraints(); regulator_has_full_constraints();
} }
static void __init snowball_init_machine(void) static void __init snowball_init_machine(void)
{ {
struct device *parent = NULL; struct device *parent = NULL;
...@@ -635,7 +636,6 @@ static void __init snowball_init_machine(void) ...@@ -635,7 +636,6 @@ static void __init snowball_init_machine(void)
static void __init hrefv60_init_machine(void) static void __init hrefv60_init_machine(void)
{ {
struct device *parent = NULL; struct device *parent = NULL;
int i2c0_devs;
int i; int i;
platform_device_register(&db8500_prcmu_device); platform_device_register(&db8500_prcmu_device);
...@@ -664,14 +664,6 @@ static void __init hrefv60_init_machine(void) ...@@ -664,14 +664,6 @@ static void __init hrefv60_init_machine(void)
mop500_audio_init(parent); mop500_audio_init(parent);
mop500_uart_init(parent); mop500_uart_init(parent);
i2c0_devs = ARRAY_SIZE(mop500_i2c0_devices);
i2c0_devs -= NUM_PRE_V60_I2C0_DEVICES;
i2c_register_board_info(0, mop500_i2c0_devices, i2c0_devs);
i2c_register_board_info(2, mop500_i2c2_devices,
ARRAY_SIZE(mop500_i2c2_devices));
/* This board has full regulator constraints */ /* This board has full regulator constraints */
regulator_has_full_constraints(); regulator_has_full_constraints();
} }
...@@ -686,6 +678,7 @@ MACHINE_START(U8500, "ST-Ericsson MOP500 platform") ...@@ -686,6 +678,7 @@ MACHINE_START(U8500, "ST-Ericsson MOP500 platform")
.init_time = ux500_timer_init, .init_time = ux500_timer_init,
.init_machine = mop500_init_machine, .init_machine = mop500_init_machine,
.init_late = ux500_init_late, .init_late = ux500_init_late,
.restart = ux500_restart,
MACHINE_END MACHINE_END
MACHINE_START(U8520, "ST-Ericsson U8520 Platform HREFP520") MACHINE_START(U8520, "ST-Ericsson U8520 Platform HREFP520")
...@@ -695,6 +688,7 @@ MACHINE_START(U8520, "ST-Ericsson U8520 Platform HREFP520") ...@@ -695,6 +688,7 @@ MACHINE_START(U8520, "ST-Ericsson U8520 Platform HREFP520")
.init_time = ux500_timer_init, .init_time = ux500_timer_init,
.init_machine = mop500_init_machine, .init_machine = mop500_init_machine,
.init_late = ux500_init_late, .init_late = ux500_init_late,
.restart = ux500_restart,
MACHINE_END MACHINE_END
MACHINE_START(HREFV60, "ST-Ericsson U8500 Platform HREFv60+") MACHINE_START(HREFV60, "ST-Ericsson U8500 Platform HREFv60+")
...@@ -705,6 +699,7 @@ MACHINE_START(HREFV60, "ST-Ericsson U8500 Platform HREFv60+") ...@@ -705,6 +699,7 @@ MACHINE_START(HREFV60, "ST-Ericsson U8500 Platform HREFv60+")
.init_time = ux500_timer_init, .init_time = ux500_timer_init,
.init_machine = hrefv60_init_machine, .init_machine = hrefv60_init_machine,
.init_late = ux500_init_late, .init_late = ux500_init_late,
.restart = ux500_restart,
MACHINE_END MACHINE_END
MACHINE_START(SNOWBALL, "Calao Systems Snowball platform") MACHINE_START(SNOWBALL, "Calao Systems Snowball platform")
...@@ -716,4 +711,5 @@ MACHINE_START(SNOWBALL, "Calao Systems Snowball platform") ...@@ -716,4 +711,5 @@ MACHINE_START(SNOWBALL, "Calao Systems Snowball platform")
.init_time = ux500_timer_init, .init_time = ux500_timer_init,
.init_machine = snowball_init_machine, .init_machine = snowball_init_machine,
.init_late = NULL, .init_late = NULL,
.restart = ux500_restart,
MACHINE_END MACHINE_END
...@@ -26,7 +26,6 @@ ...@@ -26,7 +26,6 @@
#include <asm/pmu.h> #include <asm/pmu.h>
#include <asm/mach/map.h> #include <asm/mach/map.h>
#include <asm/mach/arch.h>
#include "setup.h" #include "setup.h"
#include "devices.h" #include "devices.h"
...@@ -157,7 +156,8 @@ static void __init db8500_add_gpios(struct device *parent) ...@@ -157,7 +156,8 @@ static void __init db8500_add_gpios(struct device *parent)
.supports_sleepmode = true, .supports_sleepmode = true,
}; };
dbx500_add_gpios(parent, ARRAY_AND_SIZE(db8500_gpio_base), dbx500_add_gpios(parent, db8500_gpio_base,
ARRAY_SIZE(db8500_gpio_base),
IRQ_DB8500_GPIO0, &pdata); IRQ_DB8500_GPIO0, &pdata);
dbx500_add_pinctrl(parent, "pinctrl-db8500", U8500_PRCMU_BASE); dbx500_add_pinctrl(parent, "pinctrl-db8500", U8500_PRCMU_BASE);
} }
...@@ -325,6 +325,7 @@ DT_MACHINE_START(U8500_DT, "ST-Ericsson Ux5x0 platform (Device Tree Support)") ...@@ -325,6 +325,7 @@ DT_MACHINE_START(U8500_DT, "ST-Ericsson Ux5x0 platform (Device Tree Support)")
.init_machine = u8500_init_machine, .init_machine = u8500_init_machine,
.init_late = NULL, .init_late = NULL,
.dt_compat = stericsson_dt_platform_compat, .dt_compat = stericsson_dt_platform_compat,
.restart = ux500_restart,
MACHINE_END MACHINE_END
#endif #endif
...@@ -31,6 +31,14 @@ ...@@ -31,6 +31,14 @@
#include "db8500-regs.h" #include "db8500-regs.h"
#include "id.h" #include "id.h"
void ux500_restart(enum reboot_mode mode, const char *cmd)
{
local_irq_disable();
local_fiq_disable();
prcmu_system_reset(0);
}
/* /*
* FIXME: Should we set up the GPIO domain here? * FIXME: Should we set up the GPIO domain here?
* *
......
...@@ -49,6 +49,7 @@ struct stedma40_platform_data dma40_plat_data = { ...@@ -49,6 +49,7 @@ struct stedma40_platform_data dma40_plat_data = {
struct platform_device u8500_dma40_device = { struct platform_device u8500_dma40_device = {
.dev = { .dev = {
.platform_data = &dma40_plat_data, .platform_data = &dma40_plat_data,
.coherent_dma_mask = DMA_BIT_MASK(32),
}, },
.name = "dma40", .name = "dma40",
.id = 0, .id = 0,
......
...@@ -11,8 +11,6 @@ ...@@ -11,8 +11,6 @@
#include <linux/linkage.h> #include <linux/linkage.h>
#include <linux/init.h> #include <linux/init.h>
__INIT
/* /*
* U8500 specific entry point for secondary CPUs. * U8500 specific entry point for secondary CPUs.
*/ */
......
This diff is collapsed.
...@@ -11,10 +11,13 @@ ...@@ -11,10 +11,13 @@
#ifndef __ASM_ARCH_SETUP_H #ifndef __ASM_ARCH_SETUP_H
#define __ASM_ARCH_SETUP_H #define __ASM_ARCH_SETUP_H
#include <asm/mach/arch.h>
#include <asm/mach/time.h> #include <asm/mach/time.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/mfd/abx500/ab8500.h> #include <linux/mfd/abx500/ab8500.h>
void ux500_restart(enum reboot_mode mode, const char *cmd);
void __init ux500_map_io(void); void __init ux500_map_io(void);
extern void __init u8500_map_io(void); extern void __init u8500_map_io(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment