Commit 7e10cf74 authored by Jon Hunter's avatar Jon Hunter Committed by Thierry Reding

soc/tegra: Move Tegra flowctrl driver

The flowctrl driver is required for both ARM and ARM64 Tegra devices
and in order to enable support for it for ARM64, move the Tegra flowctrl
driver into drivers/soc/tegra.

By moving the flowctrl driver, tegra_flowctrl_init() is now called by
via an early initcall and to prevent this function from attempting to
mapping IO space for a non-Tegra device, a test for 'soc_is_tegra()'
is also added.
Signed-off-by: default avatarJon Hunter <jonathanh@nvidia.com>
Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
parent 07d76e95
...@@ -2,7 +2,6 @@ asflags-y += -march=armv7-a ...@@ -2,7 +2,6 @@ asflags-y += -march=armv7-a
obj-y += io.o obj-y += io.o
obj-y += irq.o obj-y += irq.o
obj-y += flowctrl.o
obj-y += pm.o obj-y += pm.o
obj-y += reset.o obj-y += reset.o
obj-y += reset-handler.o obj-y += reset-handler.o
......
...@@ -26,12 +26,13 @@ ...@@ -26,12 +26,13 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/module.h> #include <linux/module.h>
#include <soc/tegra/flowctrl.h>
#include <asm/cpuidle.h> #include <asm/cpuidle.h>
#include <asm/smp_plat.h> #include <asm/smp_plat.h>
#include <asm/suspend.h> #include <asm/suspend.h>
#include "cpuidle.h" #include "cpuidle.h"
#include "flowctrl.h"
#include "iomap.h" #include "iomap.h"
#include "irq.h" #include "irq.h"
#include "pm.h" #include "pm.h"
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/jiffies.h> #include <linux/jiffies.h>
#include <linux/smp.h> #include <linux/smp.h>
#include <soc/tegra/flowctrl.h>
#include <soc/tegra/fuse.h> #include <soc/tegra/fuse.h>
#include <soc/tegra/pmc.h> #include <soc/tegra/pmc.h>
...@@ -30,7 +31,6 @@ ...@@ -30,7 +31,6 @@
#include <asm/smp_scu.h> #include <asm/smp_scu.h>
#include "common.h" #include "common.h"
#include "flowctrl.h"
#include "iomap.h" #include "iomap.h"
#include "reset.h" #include "reset.h"
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/suspend.h> #include <linux/suspend.h>
#include <soc/tegra/flowctrl.h>
#include <soc/tegra/fuse.h> #include <soc/tegra/fuse.h>
#include <soc/tegra/pm.h> #include <soc/tegra/pm.h>
#include <soc/tegra/pmc.h> #include <soc/tegra/pmc.h>
...@@ -38,7 +39,6 @@ ...@@ -38,7 +39,6 @@
#include <asm/suspend.h> #include <asm/suspend.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#include "flowctrl.h"
#include "iomap.h" #include "iomap.h"
#include "pm.h" #include "pm.h"
#include "reset.h" #include "reset.h"
......
...@@ -17,12 +17,12 @@ ...@@ -17,12 +17,12 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/linkage.h> #include <linux/linkage.h>
#include <soc/tegra/flowctrl.h>
#include <soc/tegra/fuse.h> #include <soc/tegra/fuse.h>
#include <asm/asm-offsets.h> #include <asm/asm-offsets.h>
#include <asm/cache.h> #include <asm/cache.h>
#include "flowctrl.h"
#include "iomap.h" #include "iomap.h"
#include "reset.h" #include "reset.h"
#include "sleep.h" #include "sleep.h"
......
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
#include <linux/linkage.h> #include <linux/linkage.h>
#include <soc/tegra/flowctrl.h>
#include <asm/assembler.h> #include <asm/assembler.h>
#include <asm/proc-fns.h> #include <asm/proc-fns.h>
#include <asm/cp15.h> #include <asm/cp15.h>
...@@ -27,7 +29,6 @@ ...@@ -27,7 +29,6 @@
#include "irammap.h" #include "irammap.h"
#include "sleep.h" #include "sleep.h"
#include "flowctrl.h"
#define EMC_CFG 0xc #define EMC_CFG 0xc
#define EMC_ADR_CFG 0x10 #define EMC_ADR_CFG 0x10
......
...@@ -16,13 +16,13 @@ ...@@ -16,13 +16,13 @@
#include <linux/linkage.h> #include <linux/linkage.h>
#include <soc/tegra/flowctrl.h>
#include <soc/tegra/fuse.h> #include <soc/tegra/fuse.h>
#include <asm/asm-offsets.h> #include <asm/asm-offsets.h>
#include <asm/assembler.h> #include <asm/assembler.h>
#include <asm/cache.h> #include <asm/cache.h>
#include "flowctrl.h"
#include "irammap.h" #include "irammap.h"
#include "sleep.h" #include "sleep.h"
......
...@@ -48,7 +48,6 @@ ...@@ -48,7 +48,6 @@
#include "board.h" #include "board.h"
#include "common.h" #include "common.h"
#include "cpuidle.h" #include "cpuidle.h"
#include "flowctrl.h"
#include "iomap.h" #include "iomap.h"
#include "irq.h" #include "irq.h"
#include "pm.h" #include "pm.h"
...@@ -75,7 +74,6 @@ static void __init tegra_init_early(void) ...@@ -75,7 +74,6 @@ static void __init tegra_init_early(void)
{ {
of_register_trusted_foundations(); of_register_trusted_foundations();
tegra_cpu_reset_handler_init(); tegra_cpu_reset_handler_init();
tegra_flowctrl_init();
} }
static void __init tegra_dt_init_irq(void) static void __init tegra_dt_init_irq(void)
......
...@@ -12,6 +12,7 @@ config ARCH_TEGRA_2x_SOC ...@@ -12,6 +12,7 @@ config ARCH_TEGRA_2x_SOC
select PINCTRL_TEGRA20 select PINCTRL_TEGRA20
select PL310_ERRATA_727915 if CACHE_L2X0 select PL310_ERRATA_727915 if CACHE_L2X0
select PL310_ERRATA_769419 if CACHE_L2X0 select PL310_ERRATA_769419 if CACHE_L2X0
select SOC_TEGRA_FLOWCTRL
select SOC_TEGRA_PMC select SOC_TEGRA_PMC
select TEGRA_TIMER select TEGRA_TIMER
help help
...@@ -24,6 +25,7 @@ config ARCH_TEGRA_3x_SOC ...@@ -24,6 +25,7 @@ config ARCH_TEGRA_3x_SOC
select ARM_ERRATA_764369 if SMP select ARM_ERRATA_764369 if SMP
select PINCTRL_TEGRA30 select PINCTRL_TEGRA30
select PL310_ERRATA_769419 if CACHE_L2X0 select PL310_ERRATA_769419 if CACHE_L2X0
select SOC_TEGRA_FLOWCTRL
select SOC_TEGRA_PMC select SOC_TEGRA_PMC
select TEGRA_TIMER select TEGRA_TIMER
help help
...@@ -35,6 +37,7 @@ config ARCH_TEGRA_114_SOC ...@@ -35,6 +37,7 @@ config ARCH_TEGRA_114_SOC
select ARM_ERRATA_798181 if SMP select ARM_ERRATA_798181 if SMP
select HAVE_ARM_ARCH_TIMER select HAVE_ARM_ARCH_TIMER
select PINCTRL_TEGRA114 select PINCTRL_TEGRA114
select SOC_TEGRA_FLOWCTRL
select SOC_TEGRA_PMC select SOC_TEGRA_PMC
select TEGRA_TIMER select TEGRA_TIMER
help help
...@@ -45,6 +48,7 @@ config ARCH_TEGRA_124_SOC ...@@ -45,6 +48,7 @@ config ARCH_TEGRA_124_SOC
bool "Enable support for Tegra124 family" bool "Enable support for Tegra124 family"
select HAVE_ARM_ARCH_TIMER select HAVE_ARM_ARCH_TIMER
select PINCTRL_TEGRA124 select PINCTRL_TEGRA124
select SOC_TEGRA_FLOWCTRL
select SOC_TEGRA_PMC select SOC_TEGRA_PMC
select TEGRA_TIMER select TEGRA_TIMER
help help
...@@ -101,6 +105,9 @@ config ARCH_TEGRA_186_SOC ...@@ -101,6 +105,9 @@ config ARCH_TEGRA_186_SOC
endif endif
endif endif
config SOC_TEGRA_FLOWCTRL
bool
config SOC_TEGRA_PMC config SOC_TEGRA_PMC
bool bool
......
obj-y += fuse/ obj-y += fuse/
obj-y += common.o obj-y += common.o
obj-$(CONFIG_SOC_TEGRA_FLOWCTRL) += flowctrl.o
obj-$(CONFIG_SOC_TEGRA_PMC) += pmc.o obj-$(CONFIG_SOC_TEGRA_PMC) += pmc.o
obj-$(CONFIG_SOC_TEGRA_PMC_TEGRA186) += pmc-tegra186.o obj-$(CONFIG_SOC_TEGRA_PMC_TEGRA186) += pmc-tegra186.o
/* /*
* arch/arm/mach-tegra/flowctrl.c * drivers/soc/tegra/flowctrl.c
* *
* functions and macros to control the flowcontroller * Functions and macros to control the flowcontroller
* *
* Copyright (c) 2010-2012, NVIDIA Corporation. All rights reserved. * Copyright (c) 2010-2012, NVIDIA Corporation. All rights reserved.
* *
...@@ -25,10 +25,10 @@ ...@@ -25,10 +25,10 @@
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <soc/tegra/common.h>
#include <soc/tegra/flowctrl.h>
#include <soc/tegra/fuse.h> #include <soc/tegra/fuse.h>
#include "flowctrl.h"
static u8 flowctrl_offset_halt_cpu[] = { static u8 flowctrl_offset_halt_cpu[] = {
FLOW_CTRL_HALT_CPU0_EVENTS, FLOW_CTRL_HALT_CPU0_EVENTS,
FLOW_CTRL_HALT_CPU1_EVENTS, FLOW_CTRL_HALT_CPU1_EVENTS,
...@@ -47,6 +47,10 @@ static void __iomem *tegra_flowctrl_base; ...@@ -47,6 +47,10 @@ static void __iomem *tegra_flowctrl_base;
static void flowctrl_update(u8 offset, u32 value) static void flowctrl_update(u8 offset, u32 value)
{ {
if (WARN_ONCE(!tegra_flowctrl_base,
"Tegra flowctrl not initialised!\n"))
return;
writel(value, tegra_flowctrl_base + offset); writel(value, tegra_flowctrl_base + offset);
/* ensure the update has reached the flow controller */ /* ensure the update has reached the flow controller */
...@@ -58,6 +62,10 @@ u32 flowctrl_read_cpu_csr(unsigned int cpuid) ...@@ -58,6 +62,10 @@ u32 flowctrl_read_cpu_csr(unsigned int cpuid)
{ {
u8 offset = flowctrl_offset_cpu_csr[cpuid]; u8 offset = flowctrl_offset_cpu_csr[cpuid];
if (WARN_ONCE(!tegra_flowctrl_base,
"Tegra flowctrl not initialised!\n"))
return 0;
return readl(tegra_flowctrl_base + offset); return readl(tegra_flowctrl_base + offset);
} }
...@@ -148,13 +156,16 @@ static const struct of_device_id matches[] __initconst = { ...@@ -148,13 +156,16 @@ static const struct of_device_id matches[] __initconst = {
{ } { }
}; };
void __init tegra_flowctrl_init(void) static int __init tegra_flowctrl_init(void)
{ {
/* hardcoded fallback if device tree node is missing */ /* hardcoded fallback if device tree node is missing */
unsigned long base = 0x60007000; unsigned long base = 0x60007000;
unsigned long size = SZ_4K; unsigned long size = SZ_4K;
struct device_node *np; struct device_node *np;
if (!soc_is_tegra())
return 0;
np = of_find_matching_node(NULL, matches); np = of_find_matching_node(NULL, matches);
if (np) { if (np) {
struct resource res; struct resource res;
...@@ -168,4 +179,9 @@ void __init tegra_flowctrl_init(void) ...@@ -168,4 +179,9 @@ void __init tegra_flowctrl_init(void)
} }
tegra_flowctrl_base = ioremap_nocache(base, size); tegra_flowctrl_base = ioremap_nocache(base, size);
if (!tegra_flowctrl_base)
return -ENXIO;
return 0;
} }
early_initcall(tegra_flowctrl_init);
/* /*
* arch/arm/mach-tegra/flowctrl.h * Functions and macros to control the flowcontroller
*
* functions and macros to control the flowcontroller
* *
* Copyright (c) 2010-2012, NVIDIA Corporation. All rights reserved. * Copyright (c) 2010-2012, NVIDIA Corporation. All rights reserved.
* *
...@@ -18,8 +16,8 @@ ...@@ -18,8 +16,8 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#ifndef __MACH_TEGRA_FLOWCTRL_H #ifndef __SOC_TEGRA_FLOWCTRL_H__
#define __MACH_TEGRA_FLOWCTRL_H #define __SOC_TEGRA_FLOWCTRL_H__
#define FLOW_CTRL_HALT_CPU0_EVENTS 0x0 #define FLOW_CTRL_HALT_CPU0_EVENTS 0x0
#define FLOW_CTRL_WAITEVENT (2 << 29) #define FLOW_CTRL_WAITEVENT (2 << 29)
...@@ -53,14 +51,32 @@ ...@@ -53,14 +51,32 @@
#define TEGRA30_FLOW_CTRL_CSR_WFI_BITMAP (0xF << 8) #define TEGRA30_FLOW_CTRL_CSR_WFI_BITMAP (0xF << 8)
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
#ifdef CONFIG_SOC_TEGRA_FLOWCTRL
u32 flowctrl_read_cpu_csr(unsigned int cpuid); u32 flowctrl_read_cpu_csr(unsigned int cpuid);
void flowctrl_write_cpu_csr(unsigned int cpuid, u32 value); void flowctrl_write_cpu_csr(unsigned int cpuid, u32 value);
void flowctrl_write_cpu_halt(unsigned int cpuid, u32 value); void flowctrl_write_cpu_halt(unsigned int cpuid, u32 value);
void flowctrl_cpu_suspend_enter(unsigned int cpuid); void flowctrl_cpu_suspend_enter(unsigned int cpuid);
void flowctrl_cpu_suspend_exit(unsigned int cpuid); void flowctrl_cpu_suspend_exit(unsigned int cpuid);
#else
static inline u32 flowctrl_read_cpu_csr(unsigned int cpuid)
{
return 0;
}
static inline void flowctrl_write_cpu_csr(unsigned int cpuid, u32 value)
{
}
static inline void flowctrl_write_cpu_halt(unsigned int cpuid, u32 value) {}
void tegra_flowctrl_init(void); static inline void flowctrl_cpu_suspend_enter(unsigned int cpuid)
#endif {
}
#endif static inline void flowctrl_cpu_suspend_exit(unsigned int cpuid)
{
}
#endif /* CONFIG_SOC_TEGRA_FLOWCTRL */
#endif /* __ASSEMBLY */
#endif /* __SOC_TEGRA_FLOWCTRL_H__ */
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