ARM: integrator: add Integrator/CP sched_clock support
Integrator/CP has the 24MHz counter which Versatile and later platforms also have, which we use for sched_clock support. Allow this counter to be used when building a kernel targetting Integrator/CP alone. Integrator/AP does not have this counter, so we must exclude support for the Integrator family when this is enabled. Acked-by: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
0462b4477e
commit
d77e270c53
@ -44,6 +44,7 @@
|
|||||||
|
|
||||||
#include <plat/clcd.h>
|
#include <plat/clcd.h>
|
||||||
#include <plat/fpga-irq.h>
|
#include <plat/fpga-irq.h>
|
||||||
|
#include <plat/sched_clock.h>
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
@ -440,11 +441,17 @@ static struct amba_device *amba_devs[] __initdata = {
|
|||||||
&clcd_device,
|
&clcd_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define REFCOUNTER (__io_address(INTEGRATOR_HDR_BASE) + 0x28)
|
||||||
|
|
||||||
static void __init intcp_init_early(void)
|
static void __init intcp_init_early(void)
|
||||||
{
|
{
|
||||||
clkdev_add_table(cp_lookups, ARRAY_SIZE(cp_lookups));
|
clkdev_add_table(cp_lookups, ARRAY_SIZE(cp_lookups));
|
||||||
|
|
||||||
integrator_init_early();
|
integrator_init_early();
|
||||||
|
|
||||||
|
#ifdef CONFIG_PLAT_VERSATILE_SCHED_CLOCK
|
||||||
|
versatile_sched_clock_init(REFCOUNTER, 24000000);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init intcp_init(void)
|
static void __init intcp_init(void)
|
||||||
|
@ -11,7 +11,7 @@ config PLAT_VERSATILE_LEDS
|
|||||||
depends on ARCH_REALVIEW || ARCH_VERSATILE
|
depends on ARCH_REALVIEW || ARCH_VERSATILE
|
||||||
|
|
||||||
config PLAT_VERSATILE_SCHED_CLOCK
|
config PLAT_VERSATILE_SCHED_CLOCK
|
||||||
def_bool y if !ARCH_INTEGRATOR
|
def_bool y if !ARCH_INTEGRATOR_AP
|
||||||
select HAVE_SCHED_CLOCK
|
select HAVE_SCHED_CLOCK
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
Loading…
Reference in New Issue
Block a user