Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

ARM: zynq: PM: Enable A9 internal clock gating feature

Signed-off-by: Soren Brinkmann <soren.brinkmann@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>

authored by

Soren Brinkmann and committed by
Michal Simek
ae88b85e 7d1311b9

+30
+6
arch/arm/mach-zynq/common.c
··· 98 98 return revision; 99 99 } 100 100 101 + static void __init zynq_init_late(void) 102 + { 103 + zynq_core_pm_init(); 104 + } 105 + 101 106 /** 102 107 * zynq_init_machine - System specific initialization, intended to be 103 108 * called from board specific initialization. ··· 209 204 .map_io = zynq_map_io, 210 205 .init_irq = zynq_irq_init, 211 206 .init_machine = zynq_init_machine, 207 + .init_late = zynq_init_late, 212 208 .init_time = zynq_timer_init, 213 209 .dt_compat = zynq_dt_match, 214 210 .reserve = zynq_memory_init,
+11
arch/arm/mach-zynq/common.h
··· 40 40 /* Hotplug */ 41 41 extern void zynq_platform_cpu_die(unsigned int cpu); 42 42 43 + static inline void zynq_core_pm_init(void) 44 + { 45 + /* A9 clock gating */ 46 + asm volatile ("mrc p15, 0, r12, c15, c0, 0\n" 47 + "orr r12, r12, #1\n" 48 + "mcr p15, 0, r12, c15, c0, 0\n" 49 + : /* no outputs */ 50 + : /* no inputs */ 51 + : "r12"); 52 + } 53 + 43 54 #endif
+13
arch/arm/mach-zynq/platsmp.c
··· 112 112 scu_enable(zynq_scu_base); 113 113 } 114 114 115 + /** 116 + * zynq_secondary_init - Initialize secondary CPU cores 117 + * @cpu: CPU that is initialized 118 + * 119 + * This function is in the hotplug path. Don't move it into the 120 + * init section!! 121 + */ 122 + static void zynq_secondary_init(unsigned int cpu) 123 + { 124 + zynq_core_pm_init(); 125 + } 126 + 115 127 #ifdef CONFIG_HOTPLUG_CPU 116 128 static int zynq_cpu_kill(unsigned cpu) 117 129 { ··· 136 124 .smp_init_cpus = zynq_smp_init_cpus, 137 125 .smp_prepare_cpus = zynq_smp_prepare_cpus, 138 126 .smp_boot_secondary = zynq_boot_secondary, 127 + .smp_secondary_init = zynq_secondary_init, 139 128 #ifdef CONFIG_HOTPLUG_CPU 140 129 .cpu_die = zynq_platform_cpu_die, 141 130 .cpu_kill = zynq_cpu_kill,