blob: 6a27de4001ee6d700b8b05642d9676a72b8356dd [file] [log] [blame]
Colin Cross1cea7322010-02-21 17:46:23 -08001/*
Colin Cross1cea7322010-02-21 17:46:23 -08002 *
3 * Copyright (C) 2002 ARM Ltd.
4 * All Rights Reserved
Joseph Lo59b0f682012-08-16 17:31:51 +08005 * Copyright (c) 2010, 2012 NVIDIA Corporation. All rights reserved.
Colin Cross1cea7322010-02-21 17:46:23 -08006 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 */
11#include <linux/kernel.h>
Colin Cross1cea7322010-02-21 17:46:23 -080012#include <linux/smp.h>
Colin Cross1cea7322010-02-21 17:46:23 -080013
14#include <asm/cacheflush.h>
Joseph Lo59b0f682012-08-16 17:31:51 +080015#include <asm/smp_plat.h>
Colin Cross1cea7322010-02-21 17:46:23 -080016
Joseph Lo59b0f682012-08-16 17:31:51 +080017#include "sleep.h"
18#include "tegra_cpu_car.h"
Colin Cross1cea7322010-02-21 17:46:23 -080019
Joseph Lo59b0f682012-08-16 17:31:51 +080020static void (*tegra_hotplug_shutdown)(void);
Colin Cross1cea7322010-02-21 17:46:23 -080021
Joseph Lob8119432013-01-03 14:43:00 +080022int tegra_cpu_kill(unsigned cpu)
23{
24 cpu = cpu_logical_map(cpu);
25
26 /* Clock gate the CPU */
27 tegra_wait_cpu_in_reset(cpu);
28 tegra_disable_cpu_clock(cpu);
29
30 return 1;
31}
32
Colin Cross1cea7322010-02-21 17:46:23 -080033/*
34 * platform-specific code to shutdown a CPU
35 *
36 * Called with IRQs disabled
37 */
Marc Zyngiera1725732011-09-08 13:15:22 +010038void __ref tegra_cpu_die(unsigned int cpu)
Colin Cross1cea7322010-02-21 17:46:23 -080039{
Joseph Lo57886612013-01-03 14:42:59 +080040 /* Clean L1 data cache */
41 tegra_disable_clean_inv_dcache();
Colin Cross1cea7322010-02-21 17:46:23 -080042
Joseph Lo59b0f682012-08-16 17:31:51 +080043 /* Shut down the current CPU. */
44 tegra_hotplug_shutdown();
Russell Kingd4450262010-12-19 11:30:43 +000045
Joseph Lo59b0f682012-08-16 17:31:51 +080046 /* Should never return here. */
47 BUG();
Colin Cross1cea7322010-02-21 17:46:23 -080048}
49
Olof Johansson25468fe2012-09-22 00:06:21 -070050int tegra_cpu_disable(unsigned int cpu)
Colin Cross1cea7322010-02-21 17:46:23 -080051{
52 /*
53 * we don't allow CPU 0 to be shutdown (it is still too special
54 * e.g. clock tick interrupts)
55 */
56 return cpu == 0 ? -EPERM : 0;
57}
Joseph Lo59b0f682012-08-16 17:31:51 +080058
Joseph Lo453689e2012-08-16 17:31:52 +080059#ifdef CONFIG_ARCH_TEGRA_2x_SOC
60extern void tegra20_hotplug_shutdown(void);
61void __init tegra20_hotplug_init(void)
62{
63 tegra_hotplug_shutdown = tegra20_hotplug_shutdown;
64}
65#endif
66
Joseph Lo59b0f682012-08-16 17:31:51 +080067#ifdef CONFIG_ARCH_TEGRA_3x_SOC
68extern void tegra30_hotplug_shutdown(void);
69void __init tegra30_hotplug_init(void)
70{
71 tegra_hotplug_shutdown = tegra30_hotplug_shutdown;
72}
73#endif