mirror of
https://github.com/torvalds/linux.git
synced 2024-12-03 17:41:22 +00:00
ARM: shmobile: convert to twd_local_timer_register() interface
Add support for the new smp_twd runtime registration interface to the shmobile platforms, and remove the old compile-time support. Cc: Magnus Damm <magnus.damm@gmail.com> Cc: Paul Mundt <lethal@linux-sh.org> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
This commit is contained in:
parent
1fcf3a6edd
commit
4200b16d58
@ -16,7 +16,6 @@ obj-$(CONFIG_ARCH_R8A7779) += setup-r8a7779.o clock-r8a7779.o intc-r8a7779.o
|
|||||||
# SMP objects
|
# SMP objects
|
||||||
smp-y := platsmp.o headsmp.o
|
smp-y := platsmp.o headsmp.o
|
||||||
smp-$(CONFIG_HOTPLUG_CPU) += hotplug.o
|
smp-$(CONFIG_HOTPLUG_CPU) += hotplug.o
|
||||||
smp-$(CONFIG_LOCAL_TIMERS) += localtimer.o
|
|
||||||
smp-$(CONFIG_ARCH_SH73A0) += smp-sh73a0.o
|
smp-$(CONFIG_ARCH_SH73A0) += smp-sh73a0.o
|
||||||
smp-$(CONFIG_ARCH_R8A7779) += smp-r8a7779.o
|
smp-$(CONFIG_ARCH_R8A7779) += smp-r8a7779.o
|
||||||
|
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
#define __ARCH_MACH_COMMON_H
|
#define __ARCH_MACH_COMMON_H
|
||||||
|
|
||||||
extern struct sys_timer shmobile_timer;
|
extern struct sys_timer shmobile_timer;
|
||||||
|
struct twd_local_timer;
|
||||||
|
void shmobile_twd_init(struct twd_local_timer *twd_local_timer);
|
||||||
extern void shmobile_setup_console(void);
|
extern void shmobile_setup_console(void);
|
||||||
extern void shmobile_secondary_vector(void);
|
extern void shmobile_secondary_vector(void);
|
||||||
extern int shmobile_platform_cpu_kill(unsigned int cpu);
|
extern int shmobile_platform_cpu_kill(unsigned int cpu);
|
||||||
|
@ -1,26 +0,0 @@
|
|||||||
/*
|
|
||||||
* SMP support for R-Mobile / SH-Mobile - local timer portion
|
|
||||||
*
|
|
||||||
* Copyright (C) 2010 Magnus Damm
|
|
||||||
*
|
|
||||||
* Based on vexpress, Copyright (C) 2002 ARM Ltd, All Rights Reserved
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*/
|
|
||||||
#include <linux/init.h>
|
|
||||||
#include <linux/smp.h>
|
|
||||||
#include <linux/clockchips.h>
|
|
||||||
#include <asm/smp_twd.h>
|
|
||||||
#include <asm/localtimer.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Setup the local clock events for a CPU.
|
|
||||||
*/
|
|
||||||
int __cpuinit local_timer_setup(struct clock_event_device *evt)
|
|
||||||
{
|
|
||||||
evt->irq = 29;
|
|
||||||
twd_timer_setup(evt);
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -17,7 +17,6 @@
|
|||||||
#include <linux/smp.h>
|
#include <linux/smp.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <asm/hardware/gic.h>
|
#include <asm/hardware/gic.h>
|
||||||
#include <asm/localtimer.h>
|
|
||||||
#include <asm/mach-types.h>
|
#include <asm/mach-types.h>
|
||||||
#include <mach/common.h>
|
#include <mach/common.h>
|
||||||
|
|
||||||
|
@ -64,6 +64,8 @@ static void __iomem *scu_base_addr(void)
|
|||||||
static DEFINE_SPINLOCK(scu_lock);
|
static DEFINE_SPINLOCK(scu_lock);
|
||||||
static unsigned long tmp;
|
static unsigned long tmp;
|
||||||
|
|
||||||
|
static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, 0xf0000600, 29);
|
||||||
|
|
||||||
static void modify_scu_cpu_psr(unsigned long set, unsigned long clr)
|
static void modify_scu_cpu_psr(unsigned long set, unsigned long clr)
|
||||||
{
|
{
|
||||||
void __iomem *scu_base = scu_base_addr();
|
void __iomem *scu_base = scu_base_addr();
|
||||||
@ -82,11 +84,7 @@ unsigned int __init r8a7779_get_core_count(void)
|
|||||||
{
|
{
|
||||||
void __iomem *scu_base = scu_base_addr();
|
void __iomem *scu_base = scu_base_addr();
|
||||||
|
|
||||||
#ifdef CONFIG_HAVE_ARM_TWD
|
shmobile_twd_init(&twd_local_timer);
|
||||||
/* twd_base needs to be initialized before percpu_timer_setup() */
|
|
||||||
twd_base = (void __iomem *)0xf0000600;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return scu_get_core_count(scu_base);
|
return scu_get_core_count(scu_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +42,8 @@ static void __iomem *scu_base_addr(void)
|
|||||||
static DEFINE_SPINLOCK(scu_lock);
|
static DEFINE_SPINLOCK(scu_lock);
|
||||||
static unsigned long tmp;
|
static unsigned long tmp;
|
||||||
|
|
||||||
|
static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, 0xf0000600, 29);
|
||||||
|
|
||||||
static void modify_scu_cpu_psr(unsigned long set, unsigned long clr)
|
static void modify_scu_cpu_psr(unsigned long set, unsigned long clr)
|
||||||
{
|
{
|
||||||
void __iomem *scu_base = scu_base_addr();
|
void __iomem *scu_base = scu_base_addr();
|
||||||
@ -60,11 +62,7 @@ unsigned int __init sh73a0_get_core_count(void)
|
|||||||
{
|
{
|
||||||
void __iomem *scu_base = scu_base_addr();
|
void __iomem *scu_base = scu_base_addr();
|
||||||
|
|
||||||
#ifdef CONFIG_HAVE_ARM_TWD
|
shmobile_twd_init(&twd_local_timer);
|
||||||
/* twd_base needs to be initialized before percpu_timer_setup() */
|
|
||||||
twd_base = (void __iomem *)0xf0000600;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return scu_get_core_count(scu_base);
|
return scu_get_core_count(scu_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
*/
|
*/
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
|
#include <asm/smp_twd.h>
|
||||||
|
|
||||||
static void __init shmobile_late_time_init(void)
|
static void __init shmobile_late_time_init(void)
|
||||||
{
|
{
|
||||||
@ -41,6 +42,15 @@ static void __init shmobile_timer_init(void)
|
|||||||
late_time_init = shmobile_late_time_init;
|
late_time_init = shmobile_late_time_init;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __init shmobile_twd_init(struct twd_local_timer *twd_local_timer)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_HAVE_ARM_TWD
|
||||||
|
int err = twd_local_timer_register(twd_local_timer);
|
||||||
|
if (err)
|
||||||
|
pr_err("twd_local_timer_register failed %d\n", err);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
struct sys_timer shmobile_timer = {
|
struct sys_timer shmobile_timer = {
|
||||||
.init = shmobile_timer_init,
|
.init = shmobile_timer_init,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user