
Since error-injection framework is not limited to be used by kprobes, nor bpf. Other kernel subsystems can use it freely for checking safeness of error-injection, e.g. livepatch, ftrace etc. So this separate error-injection framework from kprobes. Some differences has been made: - "kprobe" word is removed from any APIs/structures. - BPF_ALLOW_ERROR_INJECTION() is renamed to ALLOW_ERROR_INJECTION() since it is not limited for BPF too. - CONFIG_FUNCTION_ERROR_INJECTION is the config item of this feature. It is automatically enabled if the arch supports error injection feature for kprobe or ftrace etc. Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org> Reviewed-by: Josef Bacik <jbacik@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
21 lines
599 B
C
21 lines
599 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _ASM_GENERIC_ERROR_INJECTION_H
|
|
#define _ASM_GENERIC_ERROR_INJECTION_H
|
|
|
|
#if defined(__KERNEL__) && !defined(__ASSEMBLY__)
|
|
#ifdef CONFIG_FUNCTION_ERROR_INJECTION
|
|
/*
|
|
* Whitelist ganerating macro. Specify functions which can be
|
|
* error-injectable using this macro.
|
|
*/
|
|
#define ALLOW_ERROR_INJECTION(fname) \
|
|
static unsigned long __used \
|
|
__attribute__((__section__("_error_injection_whitelist"))) \
|
|
_eil_addr_##fname = (unsigned long)fname;
|
|
#else
|
|
#define ALLOW_ERROR_INJECTION(fname)
|
|
#endif
|
|
#endif
|
|
|
|
#endif /* _ASM_GENERIC_ERROR_INJECTION_H */
|