Skip to content

Commit

Permalink
error-injection: Consolidate override function definition
Browse files Browse the repository at this point in the history
The function override_function_with_return() is defined separately for
each architecture and every architecture's definition is almost same
with each other.  E.g. x86 and powerpc both define function in its own
asm/error-injection.h header and override_function_with_return() has
the same definition, the only difference is that x86 defines an extra
function just_return_func() but it is specific for x86 and is only used
by x86's override_function_with_return(), so don't need to export this
function.

This patch consolidates override_function_with_return() definition into
asm-generic/error-injection.h header, thus all architectures can use the
common definition.  As result, the architecture specific headers are
removed; the include/linux/error-injection.h header also changes to
include asm-generic/error-injection.h header rather than architecture
header, furthermore, it includes linux/compiler.h for successful
compilation.

Reviewed-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Leo Yan <leo.yan@linaro.org>
Signed-off-by: Will Deacon <will@kernel.org>
  • Loading branch information
Leo Yan authored and Will Deacon committed Aug 7, 2019
1 parent e21a712 commit 45880f7
Show file tree
Hide file tree
Showing 4 changed files with 9 additions and 29 deletions.
13 changes: 0 additions & 13 deletions arch/powerpc/include/asm/error-injection.h

This file was deleted.

13 changes: 0 additions & 13 deletions arch/x86/include/asm/error-injection.h

This file was deleted.

6 changes: 6 additions & 0 deletions include/asm-generic/error-injection.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ struct error_injection_entry {
int etype;
};

struct pt_regs;

#ifdef CONFIG_FUNCTION_ERROR_INJECTION
/*
* Whitelist ganerating macro. Specify functions which can be
Expand All @@ -28,8 +30,12 @@ static struct error_injection_entry __used \
.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

Expand Down
6 changes: 3 additions & 3 deletions include/linux/error-injection.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,16 @@
#ifndef _LINUX_ERROR_INJECTION_H
#define _LINUX_ERROR_INJECTION_H

#ifdef CONFIG_FUNCTION_ERROR_INJECTION
#include <linux/compiler.h>
#include <asm-generic/error-injection.h>

#include <asm/error-injection.h>
#ifdef CONFIG_FUNCTION_ERROR_INJECTION

extern bool within_error_injection_list(unsigned long addr);
extern int get_injectable_error_type(unsigned long addr);

#else /* !CONFIG_FUNCTION_ERROR_INJECTION */

#include <asm-generic/error-injection.h>
static inline bool within_error_injection_list(unsigned long addr)
{
return false;
Expand Down

0 comments on commit 45880f7

Please sign in to comment.