On 6/25/2015 7:02 AM, Vitaly Andrianov wrote:
This commit add cpu_die implementation using psci api

Signed-off-by: Vitaly Andrianov <vita...@ti.com>
---
  arch/arm/mach-keystone/platsmp.c | 32 ++++++++++++++++++++++++++++++++
  1 file changed, 32 insertions(+)

diff --git a/arch/arm/mach-keystone/platsmp.c b/arch/arm/mach-keystone/platsmp.c
index 5f46a7c..2c40cc0 100644
--- a/arch/arm/mach-keystone/platsmp.c
+++ b/arch/arm/mach-keystone/platsmp.c
@@ -20,6 +20,7 @@
  #include <asm/prom.h>
  #include <asm/tlbflush.h>
  #include <asm/pgtable.h>
+#include <asm/psci.h>

  #include "keystone.h"

@@ -51,7 +52,38 @@ static inline void __cpuinit 
keystone_smp_secondary_initmem(unsigned int cpu)
  {}
  #endif

+
+#ifdef CONFIG_HOTPLUG_CPU
+static void keystone_cpu_die(unsigned int cpu)
+{
+#ifdef CONFIG_ARM_PSCI
+       struct psci_power_state pwr_state = {0, 0, 0};
+
+       pr_info("keystone_cpu_die(%d) from %d using PSCI\n", cpu,
+              smp_processor_id());
+
+       if (psci_ops.cpu_off)
+               psci_ops.cpu_off(pwr_state);
+#else
+       /*
+        * We may want to add here a direct smc call to monitor
+        * if the kernel doesn't support PSCI API
+        */
+#endif
I don't see much value adding the SMC. I mean CPU_HOTPLUG works with
PSCI o.w doesn't is good enough. If you still like to add it, just abstract above into two functions, one with PSCI and other with
SMC. That way you can avoid that ugly #defines in the middle of the
code.

Regards,
Santosh
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to