cregit-Linux how code gets into the kernel

Release 4.11 arch/mips/kernel/crash.c

Directory: arch/mips/kernel
#include <linux/kernel.h>
#include <linux/smp.h>
#include <linux/reboot.h>
#include <linux/kexec.h>
#include <linux/bootmem.h>
#include <linux/crash_dump.h>
#include <linux/delay.h>
#include <linux/irq.h>
#include <linux/types.h>
#include <linux/sched.h>
#include <linux/sched/task_stack.h>

/* This keeps a track of which one is crashing cpu. */

static int crashing_cpu = -1;

static cpumask_t cpus_in_crash = CPU_MASK_NONE;

#ifdef CONFIG_SMP

static void crash_shutdown_secondary(void *passed_regs) { struct pt_regs *regs = passed_regs; int cpu = smp_processor_id(); /* * If we are passed registers, use those. Otherwise get the * regs from the last interrupt, which should be correct, as * we are in an interrupt. But if the regs are not there, * pull them from the top of the stack. They are probably * wrong, but we need something to keep from crashing again. */ if (!regs) regs = get_irq_regs(); if (!regs) regs = task_pt_regs(current); if (!cpu_online(cpu)) return; local_irq_disable(); if (!cpumask_test_cpu(cpu, &cpus_in_crash)) crash_save_cpu(regs, cpu); cpumask_set_cpu(cpu, &cpus_in_crash); while (!atomic_read(&kexec_ready_to_reboot)) cpu_relax(); relocated_kexec_smp_wait(NULL); /* NOTREACHED */ }

Contributors

PersonTokensPropCommitsCommitProp
Ralf Bächle7977.45%133.33%
Corey Minyard1918.63%133.33%
Rusty Russell43.92%133.33%
Total102100.00%3100.00%


static void crash_kexec_prepare_cpus(void) { static int cpus_stopped; unsigned int msecs; unsigned int ncpus; if (cpus_stopped) return; ncpus = num_online_cpus() - 1;/* Excluding the panic cpu */ smp_call_function(crash_shutdown_secondary, NULL, 0); smp_wmb(); /* * The crash CPU sends an IPI and wait for other CPUs to * respond. Delay of at least 10 seconds. */ pr_emerg("Sending IPI to other cpus...\n"); msecs = 10000; while ((cpumask_weight(&cpus_in_crash) < ncpus) && (--msecs > 0)) { cpu_relax(); mdelay(1); } cpus_stopped = 1; }

Contributors

PersonTokensPropCommitsCommitProp
Ralf Bächle6371.59%125.00%
Hidehiro Kawai1820.45%125.00%
Marcin Nowakowski55.68%125.00%
Rusty Russell22.27%125.00%
Total88100.00%4100.00%

/* Override the weak function in kernel/panic.c */
void crash_smp_send_stop(void) { if (_crash_smp_send_stop) _crash_smp_send_stop(); crash_kexec_prepare_cpus(); }

Contributors

PersonTokensPropCommitsCommitProp
Hidehiro Kawai1694.12%150.00%
Ralf Bächle15.88%150.00%
Total17100.00%2100.00%

#else /* !defined(CONFIG_SMP) */
static void crash_kexec_prepare_cpus(void) {}

Contributors

PersonTokensPropCommitsCommitProp
Ralf Bächle7100.00%1100.00%
Total7100.00%1100.00%

#endif /* !defined(CONFIG_SMP) */
void default_machine_crash_shutdown(struct pt_regs *regs) { local_irq_disable(); crashing_cpu = smp_processor_id(); crash_save_cpu(regs, crashing_cpu); crash_kexec_prepare_cpus(); cpumask_set_cpu(crashing_cpu, &cpus_in_crash); }

Contributors

PersonTokensPropCommitsCommitProp
Ralf Bächle3494.44%150.00%
Rusty Russell25.56%150.00%
Total36100.00%2100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Ralf Bächle23777.20%228.57%
Hidehiro Kawai3511.40%114.29%
Corey Minyard196.19%114.29%
Rusty Russell82.61%114.29%
Marcin Nowakowski51.63%114.29%
Ingo Molnar30.98%114.29%
Total307100.00%7100.00%
Directory: arch/mips/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.