| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef _ASM_GENERIC_ERROR_INJECTION_H |
| #define _ASM_GENERIC_ERROR_INJECTION_H |
| |
| #if defined(__KERNEL__) && !defined(__ASSEMBLY__) |
| enum { |
| EI_ETYPE_NONE, /* Dummy value for undefined case */ |
| EI_ETYPE_NULL, /* Return NULL if failure */ |
| EI_ETYPE_ERRNO, /* Return -ERRNO if failure */ |
| EI_ETYPE_ERRNO_NULL, /* Return -ERRNO or NULL if failure */ |
| EI_ETYPE_TRUE, /* Return true if failure */ |
| }; |
| |
| struct error_injection_entry { |
| unsigned long addr; |
| int etype; |
| }; |
| |
| struct pt_regs; |
| |
| #ifdef CONFIG_FUNCTION_ERROR_INJECTION |
| /* |
| * Whitelist ganerating macro. Specify functions which can be |
| * error-injectable using this macro. |
| */ |
| #define ALLOW_ERROR_INJECTION(fname, _etype) \ |
| static struct error_injection_entry __used \ |
| __attribute__((__section__("_error_injection_whitelist"))) \ |
| _eil_addr_##fname = { \ |
| .addr = (unsigned long)fname, \ |
| .etype = EI_ETYPE_##_etype, \ |
| }; |
| |
| void override_function_with_return(struct pt_regs *regs); |
| #else |
| #define ALLOW_ERROR_INJECTION(fname, _etype) |
| |
| static inline void override_function_with_return(struct pt_regs *regs) { } |
| #endif |
| #endif |
| |
| #endif /* _ASM_GENERIC_ERROR_INJECTION_H */ |