Commit d345d9ca authored by Jiaxun Yang's avatar Jiaxun Yang Committed by Paul Burton

MIPS: cpu-bugs64: Mark inline functions as __always_inline

Commit ac7c3e4f ("compiler: enable CONFIG_OPTIMIZE_INLINING
forcibly") allows compiler to uninline functions marked as 'inline'.
Leading to section mismatch in this case.

Since we're using const variables to pass assembly flags, 'inline's
can't be dropped. So we simply mark them as __always_inline.
Signed-off-by: default avatarJiaxun Yang <jiaxun.yang@flygoat.com>
Cc: linux-mips@vger.kernel.org
[paul.burton@mips.com:
  - Annotate these functions with __init, even if it only serves to
    inform human readers when the code can be used.
  - Drop the __always_inline from check_daddi() & check_daddiu() which
    don't use arguments as immediates in inline asm.
  - Rewrap the commit message.]
Signed-off-by: default avatarPaul Burton <paul.burton@mips.com>
parent 0889d07f
...@@ -24,7 +24,8 @@ static char r4kwar[] __initdata = ...@@ -24,7 +24,8 @@ static char r4kwar[] __initdata =
static char daddiwar[] __initdata = static char daddiwar[] __initdata =
"Enable CPU_DADDI_WORKAROUNDS to rectify."; "Enable CPU_DADDI_WORKAROUNDS to rectify.";
static inline void align_mod(const int align, const int mod) static __always_inline __init
void align_mod(const int align, const int mod)
{ {
asm volatile( asm volatile(
".set push\n\t" ".set push\n\t"
...@@ -38,8 +39,9 @@ static inline void align_mod(const int align, const int mod) ...@@ -38,8 +39,9 @@ static inline void align_mod(const int align, const int mod)
: "n"(align), "n"(mod)); : "n"(align), "n"(mod));
} }
static __always_inline void mult_sh_align_mod(long *v1, long *v2, long *w, static __always_inline __init
const int align, const int mod) void mult_sh_align_mod(long *v1, long *v2, long *w,
const int align, const int mod)
{ {
unsigned long flags; unsigned long flags;
int m1, m2; int m1, m2;
...@@ -113,7 +115,7 @@ static __always_inline void mult_sh_align_mod(long *v1, long *v2, long *w, ...@@ -113,7 +115,7 @@ static __always_inline void mult_sh_align_mod(long *v1, long *v2, long *w,
*w = lw; *w = lw;
} }
static inline void check_mult_sh(void) static __always_inline __init void check_mult_sh(void)
{ {
long v1[8], v2[8], w[8]; long v1[8], v2[8], w[8];
int bug, fix, i; int bug, fix, i;
...@@ -176,7 +178,7 @@ asmlinkage void __init do_daddi_ov(struct pt_regs *regs) ...@@ -176,7 +178,7 @@ asmlinkage void __init do_daddi_ov(struct pt_regs *regs)
exception_exit(prev_state); exception_exit(prev_state);
} }
static inline void check_daddi(void) static __init void check_daddi(void)
{ {
extern asmlinkage void handle_daddi_ov(void); extern asmlinkage void handle_daddi_ov(void);
unsigned long flags; unsigned long flags;
...@@ -242,7 +244,7 @@ static inline void check_daddi(void) ...@@ -242,7 +244,7 @@ static inline void check_daddi(void)
int daddiu_bug = IS_ENABLED(CONFIG_CPU_MIPSR6) ? 0 : -1; int daddiu_bug = IS_ENABLED(CONFIG_CPU_MIPSR6) ? 0 : -1;
static inline void check_daddiu(void) static __init void check_daddiu(void)
{ {
long v, w, tmp; long v, w, tmp;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment