Commit ee8e5d5f authored by Suzuki K. Poulose's avatar Suzuki K. Poulose Committed by Will Deacon

arm-cci: Split the code for PMU vs driver support

This patch separates the PMU driver code from the low level
CCI driver code and enables the PMU driver for ARM64.

Introduces config options for both.

 ARM_CCI400_PORT_CTRL	- controls the low level driver code for
			  CCI400 ports.
 ARM_CCI400_PMU		- controls the PMU driver code
 ARM_CCI400_COMMON	- Common defintions for CCI400

This patch also changes:
 ARM_CCI - common code for probing the CCI devices. This can be
   used for adding support for newer CCI versions(e.g, CCI-500).

Cc: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Cc: Kukjin Kim <kgene@kernel.org>
Cc: Abhilash Kesavan <a.kesavan@samsung.com>
Cc: Liviu Dudau <liviu.dudau@arm.com>
Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Cc: Sudeep Holla <sudeep.holla@arm.com>
Cc: Nicolas Pitre <nicolas.pitre@linaro.org>
Cc: Punit Agrawal <punit.agrawal@arm.com>
Acked-by: default avatarSudeep Holla <sudeep.holla@arm.com>
Acked-by: default avatarNicolas Pitre <nicolas.pitre@linaro.org>
Acked-by: default avatarPunit Agrawal <punit.agrawal@arm.com>
Signed-off-by: default avatarSuzuki K. Poulose <suzuki.poulose@arm.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
parent 772742a6
...@@ -123,7 +123,7 @@ config SOC_EXYNOS5800 ...@@ -123,7 +123,7 @@ config SOC_EXYNOS5800
config EXYNOS5420_MCPM config EXYNOS5420_MCPM
bool "Exynos5420 Multi-Cluster PM support" bool "Exynos5420 Multi-Cluster PM support"
depends on MCPM && SOC_EXYNOS5420 depends on MCPM && SOC_EXYNOS5420
select ARM_CCI select ARM_CCI400_PORT_CTRL
select ARM_CPU_SUSPEND select ARM_CPU_SUSPEND
help help
This is needed to provide CPU and cluster power management This is needed to provide CPU and cluster power management
......
...@@ -53,7 +53,7 @@ config ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA ...@@ -53,7 +53,7 @@ config ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA
config ARCH_VEXPRESS_DCSCB config ARCH_VEXPRESS_DCSCB
bool "Dual Cluster System Control Block (DCSCB) support" bool "Dual Cluster System Control Block (DCSCB) support"
depends on MCPM depends on MCPM
select ARM_CCI select ARM_CCI400_PORT_CTRL
help help
Support for the Dual Cluster System Configuration Block (DCSCB). Support for the Dual Cluster System Configuration Block (DCSCB).
This is needed to provide CPU and cluster power management This is needed to provide CPU and cluster power management
...@@ -71,7 +71,7 @@ config ARCH_VEXPRESS_SPC ...@@ -71,7 +71,7 @@ config ARCH_VEXPRESS_SPC
config ARCH_VEXPRESS_TC2_PM config ARCH_VEXPRESS_TC2_PM
bool "Versatile Express TC2 power management" bool "Versatile Express TC2 power management"
depends on MCPM depends on MCPM
select ARM_CCI select ARM_CCI400_PORT_CTRL
select ARCH_VEXPRESS_SPC select ARCH_VEXPRESS_SPC
select ARM_CPU_SUSPEND select ARM_CPU_SUSPEND
help help
......
...@@ -43,12 +43,32 @@ config OMAP_INTERCONNECT ...@@ -43,12 +43,32 @@ config OMAP_INTERCONNECT
help help
Driver to enable OMAP interconnect error handling driver. Driver to enable OMAP interconnect error handling driver.
config ARM_CCI config ARM_CCI400_PORT_CTRL
bool "ARM CCI driver support" bool
depends on ARM && OF && CPU_V7 depends on ARM && OF && CPU_V7
select ARM_CCI400_COMMON
help
Low level power management driver for CCI400 cache coherent
interconnect for ARM platforms.
config ARM_CCI400_PMU
bool "ARM CCI400 PMU support"
default y
depends on ARM || ARM64
depends on HW_PERF_EVENTS
select ARM_CCI400_COMMON
help help
Driver supporting the CCI cache coherent interconnect for ARM Support for PMU events monitoring on the ARM CCI cache coherent
platforms. interconnect.
If unsure, say Y
config ARM_CCI400_COMMON
bool
select ARM_CCI
config ARM_CCI
bool
config ARM_CCN config ARM_CCN
bool "ARM CCN driver support" bool "ARM CCN driver support"
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
static void __iomem *cci_ctrl_base; static void __iomem *cci_ctrl_base;
static unsigned long cci_ctrl_phys; static unsigned long cci_ctrl_phys;
#ifdef CONFIG_ARM_CCI400_PORT_CTRL
struct cci_nb_ports { struct cci_nb_ports {
unsigned int nb_ace; unsigned int nb_ace;
unsigned int nb_ace_lite; unsigned int nb_ace_lite;
...@@ -42,12 +43,19 @@ static const struct cci_nb_ports cci400_ports = { ...@@ -42,12 +43,19 @@ static const struct cci_nb_ports cci400_ports = {
.nb_ace_lite = 3 .nb_ace_lite = 3
}; };
#define CCI400_PORTS_DATA (&cci400_ports)
#else
#define CCI400_PORTS_DATA (NULL)
#endif
static const struct of_device_id arm_cci_matches[] = { static const struct of_device_id arm_cci_matches[] = {
{.compatible = "arm,cci-400", .data = &cci400_ports }, #ifdef CONFIG_ARM_CCI400_COMMON
{.compatible = "arm,cci-400", .data = CCI400_PORTS_DATA },
#endif
{}, {},
}; };
#ifdef CONFIG_HW_PERF_EVENTS #ifdef CONFIG_ARM_CCI400_PMU
#define DRIVER_NAME "CCI-400" #define DRIVER_NAME "CCI-400"
#define DRIVER_NAME_PMU DRIVER_NAME " PMU" #define DRIVER_NAME_PMU DRIVER_NAME " PMU"
...@@ -1022,14 +1030,16 @@ static int __init cci_platform_init(void) ...@@ -1022,14 +1030,16 @@ static int __init cci_platform_init(void)
return platform_driver_register(&cci_platform_driver); return platform_driver_register(&cci_platform_driver);
} }
#else /* !CONFIG_HW_PERF_EVENTS */ #else /* !CONFIG_ARM_CCI400_PMU */
static int __init cci_platform_init(void) static int __init cci_platform_init(void)
{ {
return 0; return 0;
} }
#endif /* CONFIG_HW_PERF_EVENTS */ #endif /* CONFIG_ARM_CCI400_PMU */
#ifdef CONFIG_ARM_CCI400_PORT_CTRL
#define CCI_PORT_CTRL 0x0 #define CCI_PORT_CTRL 0x0
#define CCI_CTRL_STATUS 0xc #define CCI_CTRL_STATUS 0xc
...@@ -1460,6 +1470,12 @@ static int cci_probe_ports(struct device_node *np) ...@@ -1460,6 +1470,12 @@ static int cci_probe_ports(struct device_node *np)
return 0; return 0;
} }
#else /* !CONFIG_ARM_CCI400_PORT_CTRL */
static inline int cci_probe_ports(struct device_node *np)
{
return 0;
}
#endif /* CONFIG_ARM_CCI400_PORT_CTRL */
static int cci_probe(void) static int cci_probe(void)
{ {
......
...@@ -30,12 +30,16 @@ struct device_node; ...@@ -30,12 +30,16 @@ struct device_node;
#ifdef CONFIG_ARM_CCI #ifdef CONFIG_ARM_CCI
extern bool cci_probed(void); extern bool cci_probed(void);
#else
static inline bool cci_probed(void) { return false; }
#endif
#ifdef CONFIG_ARM_CCI400_PORT_CTRL
extern int cci_ace_get_port(struct device_node *dn); extern int cci_ace_get_port(struct device_node *dn);
extern int cci_disable_port_by_cpu(u64 mpidr); extern int cci_disable_port_by_cpu(u64 mpidr);
extern int __cci_control_port_by_device(struct device_node *dn, bool enable); extern int __cci_control_port_by_device(struct device_node *dn, bool enable);
extern int __cci_control_port_by_index(u32 port, bool enable); extern int __cci_control_port_by_index(u32 port, bool enable);
#else #else
static inline bool cci_probed(void) { return false; }
static inline int cci_ace_get_port(struct device_node *dn) static inline int cci_ace_get_port(struct device_node *dn)
{ {
return -ENODEV; return -ENODEV;
...@@ -51,6 +55,7 @@ static inline int __cci_control_port_by_index(u32 port, bool enable) ...@@ -51,6 +55,7 @@ static inline int __cci_control_port_by_index(u32 port, bool enable)
return -ENODEV; return -ENODEV;
} }
#endif #endif
#define cci_disable_port_by_device(dev) \ #define cci_disable_port_by_device(dev) \
__cci_control_port_by_device(dev, false) __cci_control_port_by_device(dev, false)
#define cci_enable_port_by_device(dev) \ #define cci_enable_port_by_device(dev) \
......
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