Contributors: 29
Author Tokens Token Proportion Commits Commit Proportion
Eric DeVolder 65 16.58% 4 10.53%
Alexander Nyberg 50 12.76% 1 2.63%
Vivek Goyal 43 10.97% 3 7.89%
Baoquan He 35 8.93% 1 2.63%
Eric W. Biedermann 32 8.16% 1 2.63%
Andrew Morton 17 4.34% 1 2.63%
Hari Bathini 17 4.34% 2 5.26%
AKASHI Takahiro 17 4.34% 1 2.63%
Américo Wang 15 3.83% 1 2.63%
Sourabh Jain 11 2.81% 2 5.26%
Hidehiro Kawai 11 2.81% 1 2.63%
Naveen N. Rao 10 2.55% 1 2.63%
Xunlei Pang 10 2.55% 3 7.89%
Petr Tesarik 8 2.04% 1 2.63%
David Disseldorp 7 1.79% 1 2.63%
Philipp Rudo 6 1.53% 1 2.63%
Dave Young 5 1.28% 1 2.63%
Kees Cook 5 1.28% 1 2.63%
Magnus Damm 4 1.02% 1 2.63%
Ken'ichi Ohmichi 4 1.02% 1 2.63%
Thomas Gleixner 4 1.02% 1 2.63%
Russell King 3 0.77% 1 2.63%
Ard Biesheuvel 3 0.77% 1 2.63%
Ralf Baechle 3 0.77% 1 2.63%
Huang Ying 3 0.77% 1 2.63%
Simon Horman 1 0.26% 1 2.63%
Valentin Schneider 1 0.26% 1 2.63%
Greg Kroah-Hartman 1 0.26% 1 2.63%
Liao Chang 1 0.26% 1 2.63%
Total 392 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, void *arg) { }
#endif

int crash_check_hotplug_support(void);

#ifndef arch_crash_hotplug_support
static inline int arch_crash_hotplug_support(struct kimage *image, unsigned long kexec_flags)
{
	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 */