Contributors: 29
Author Tokens Token Proportion Commits Commit Proportion
Eric DeVolder 78 19.60% 4 10.53%
Alexander Nyberg 50 12.56% 1 2.63%
Vivek Goyal 43 10.80% 3 7.89%
Eric W. Biedermann 32 8.04% 1 2.63%
Baoquan He 27 6.78% 1 2.63%
Andrew Morton 19 4.77% 2 5.26%
AKASHI Takahiro 17 4.27% 1 2.63%
Hari Bathini 15 3.77% 2 5.26%
Xunlei Pang 12 3.02% 3 7.89%
Américo Wang 11 2.76% 1 2.63%
Hidehiro Kawai 11 2.76% 1 2.63%
Petr Tesarik 10 2.51% 1 2.63%
Russell King 9 2.26% 1 2.63%
Naveen N. Rao 8 2.01% 1 2.63%
David Disseldorp 7 1.76% 1 2.63%
Philipp Rudo 6 1.51% 1 2.63%
Coiby Xu 6 1.51% 1 2.63%
Kees Cook 5 1.26% 1 2.63%
Jeremy Fitzhardinge 5 1.26% 1 2.63%
Dave Young 5 1.26% 1 2.63%
Magnus Damm 4 1.01% 1 2.63%
Tom Lendacky 4 1.01% 1 2.63%
Ken'ichi Ohmichi 4 1.01% 1 2.63%
Huang Ying 3 0.75% 1 2.63%
Ralf Baechle 3 0.75% 1 2.63%
Liao Chang 1 0.25% 1 2.63%
Greg Kroah-Hartman 1 0.25% 1 2.63%
Simon Horman 1 0.25% 1 2.63%
Valentin Schneider 1 0.25% 1 2.63%
Total 398 38


/* SPDX-License-Identifier: GPL-2.0 */
#ifndef LINUX_CRASH_CORE_H
#define LINUX_CRASH_CORE_H

#include <linux/linkage.h>
#include <linux/elfcore.h>
#include <linux/elf.h>

struct kimage;

struct crash_mem {
	unsigned int max_nr_ranges;
	unsigned int nr_ranges;
	struct range ranges[] __counted_by(max_nr_ranges);
};

#ifdef CONFIG_CRASH_DUMP

int crash_shrink_memory(unsigned long new_size);
ssize_t crash_get_memory_size(void);

#ifndef arch_kexec_protect_crashkres
/*
 * Protection mechanism for crashkernel reserved memory after
 * the kdump kernel is loaded.
 *
 * Provide an empty default implementation here -- architecture
 * code may override this
 */
static inline void arch_kexec_protect_crashkres(void) { }
#endif

#ifndef arch_kexec_unprotect_crashkres
static inline void arch_kexec_unprotect_crashkres(void) { }
#endif



#ifndef arch_crash_handle_hotplug_event
static inline void arch_crash_handle_hotplug_event(struct kimage *image) { }
#endif

int crash_check_update_elfcorehdr(void);

#ifndef crash_hotplug_cpu_support
static inline int crash_hotplug_cpu_support(void) { return 0; }
#endif

#ifndef crash_hotplug_memory_support
static inline int crash_hotplug_memory_support(void) { return 0; }
#endif

#ifndef crash_get_elfcorehdr_size
static inline unsigned int crash_get_elfcorehdr_size(void) { return 0; }
#endif

/* Alignment required for elf header segment */
#define ELF_CORE_HEADER_ALIGN   4096

extern int crash_exclude_mem_range(struct crash_mem *mem,
				   unsigned long long mstart,
				   unsigned long long mend);
extern int crash_prepare_elf64_headers(struct crash_mem *mem, int need_kernel_map,
				       void **addr, unsigned long *sz);

struct kimage;
struct kexec_segment;

#define KEXEC_CRASH_HP_NONE			0
#define KEXEC_CRASH_HP_ADD_CPU			1
#define KEXEC_CRASH_HP_REMOVE_CPU		2
#define KEXEC_CRASH_HP_ADD_MEMORY		3
#define KEXEC_CRASH_HP_REMOVE_MEMORY		4
#define KEXEC_CRASH_HP_INVALID_CPU		-1U

extern void __crash_kexec(struct pt_regs *regs);
extern void crash_kexec(struct pt_regs *regs);
int kexec_should_crash(struct task_struct *p);
int kexec_crash_loaded(void);
void crash_save_cpu(struct pt_regs *regs, int cpu);
extern int kimage_crash_copy_vmcoreinfo(struct kimage *image);

#else /* !CONFIG_CRASH_DUMP*/
struct pt_regs;
struct task_struct;
struct kimage;
static inline void __crash_kexec(struct pt_regs *regs) { }
static inline void crash_kexec(struct pt_regs *regs) { }
static inline int kexec_should_crash(struct task_struct *p) { return 0; }
static inline int kexec_crash_loaded(void) { return 0; }
static inline void crash_save_cpu(struct pt_regs *regs, int cpu) {};
static inline int kimage_crash_copy_vmcoreinfo(struct kimage *image) { return 0; };
#endif /* CONFIG_CRASH_DUMP*/

#endif /* LINUX_CRASH_CORE_H */