cregit-Linux how code gets into the kernel

Release 4.11 arch/arm/common/mcpm_platsmp.c

Directory: arch/arm/common
/*
 * linux/arch/arm/mach-vexpress/mcpm_platsmp.c
 *
 * Created by:  Nicolas Pitre, November 2012
 * Copyright:   (C) 2012-2013  Linaro Limited
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * Code to handle secondary CPU bringup and hotplug for the cluster power API.
 */

#include <linux/init.h>
#include <linux/smp.h>
#include <linux/spinlock.h>

#include <asm/mcpm.h>
#include <asm/smp.h>
#include <asm/smp_plat.h>


static void cpu_to_pcpu(unsigned int cpu, unsigned int *pcpu, unsigned int *pcluster) { unsigned int mpidr; mpidr = cpu_logical_map(cpu); *pcpu = MPIDR_AFFINITY_LEVEL(mpidr, 0); *pcluster = MPIDR_AFFINITY_LEVEL(mpidr, 1); }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre3874.51%150.00%
Dave P Martin1325.49%150.00%
Total51100.00%2100.00%


static int mcpm_boot_secondary(unsigned int cpu, struct task_struct *idle) { unsigned int pcpu, pcluster, ret; extern void secondary_startup(void); cpu_to_pcpu(cpu, &pcpu, &pcluster); pr_debug("%s: logical CPU %d is physical CPU %d cluster %d\n", __func__, cpu, pcpu, pcluster); mcpm_set_entry_vector(pcpu, pcluster, NULL); ret = mcpm_cpu_power_up(pcpu, pcluster); if (ret) return ret; mcpm_set_entry_vector(pcpu, pcluster, secondary_startup); arch_send_wakeup_ipi_mask(cpumask_of(cpu)); dsb_sev(); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre6260.78%150.00%
Dave P Martin4039.22%150.00%
Total102100.00%2100.00%


static void mcpm_secondary_init(unsigned int cpu) { mcpm_cpu_powered_up(); }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre13100.00%1100.00%
Total13100.00%1100.00%

#ifdef CONFIG_HOTPLUG_CPU
static int mcpm_cpu_kill(unsigned int cpu) { unsigned int pcpu, pcluster; cpu_to_pcpu(cpu, &pcpu, &pcluster); return !mcpm_wait_for_cpu_powerdown(pcpu, pcluster); }

Contributors

PersonTokensPropCommitsCommitProp
Dave P Martin36100.00%2100.00%
Total36100.00%2100.00%


static bool mcpm_cpu_can_disable(unsigned int cpu) { /* We assume all CPUs may be shut down. */ return true; }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre1071.43%150.00%
Stephen Boyd428.57%150.00%
Total14100.00%2100.00%


static void mcpm_cpu_die(unsigned int cpu) { unsigned int mpidr, pcpu, pcluster; mpidr = read_cpuid_mpidr(); pcpu = MPIDR_AFFINITY_LEVEL(mpidr, 0); pcluster = MPIDR_AFFINITY_LEVEL(mpidr, 1); mcpm_set_entry_vector(pcpu, pcluster, NULL); mcpm_cpu_power_down(); }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre53100.00%1100.00%
Total53100.00%1100.00%

#endif static const struct smp_operations mcpm_smp_ops __initconst = { .smp_boot_secondary = mcpm_boot_secondary, .smp_secondary_init = mcpm_secondary_init, #ifdef CONFIG_HOTPLUG_CPU .cpu_kill = mcpm_cpu_kill, .cpu_can_disable = mcpm_cpu_can_disable, .cpu_die = mcpm_cpu_die, #endif };
void __init mcpm_smp_set_ops(void) { smp_set_ops(&mcpm_smp_ops); }

Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre14100.00%1100.00%
Total14100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Nico Pitre24570.61%228.57%
Dave P Martin9427.09%342.86%
Stephen Boyd61.73%114.29%
Masahiro Yamada20.58%114.29%
Total347100.00%7100.00%
Directory: arch/arm/common
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.