Commit 93c2f55f authored by Guenter Roeck's avatar Guenter Roeck Committed by Heiko Carstens

s390/ctl_reg: mark __ctl_set_bit and __ctl_clear_bit as __always_inline

s390:tinyconfig fails to build with gcc 8.3.0.

arch/s390/include/asm/ctl_reg.h:52:2: error: impossible constraint in 'asm'
  asm volatile(       \
  ^~~
arch/s390/include/asm/ctl_reg.h:62:2: note: in expansion of macro '__ctl_store'
  __ctl_store(reg, cr, cr);
  ^~~~~~~~~~~
s390/include/asm/ctl_reg.h:41:2: error: impossible constraint in 'asm'
  asm volatile(       \
  ^~~
arch/s390/include/asm/ctl_reg.h:64:2:
note: in expansion of macro '__ctl_load'
  __ctl_load(reg, cr, cr);
  ^~~~~~~~~~

Marking __ctl_set_bit and __ctl_clear_bit as __always_inline fixes the
problem.

Fixes: 9012d011 ("compiler: allow all arches to enable CONFIG_OPTIMIZE_INLINING")
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
parent f9364df3
...@@ -55,7 +55,7 @@ ...@@ -55,7 +55,7 @@
: "i" (low), "i" (high)); \ : "i" (low), "i" (high)); \
} while (0) } while (0)
static inline void __ctl_set_bit(unsigned int cr, unsigned int bit) static __always_inline void __ctl_set_bit(unsigned int cr, unsigned int bit)
{ {
unsigned long reg; unsigned long reg;
...@@ -64,7 +64,7 @@ static inline void __ctl_set_bit(unsigned int cr, unsigned int bit) ...@@ -64,7 +64,7 @@ static inline void __ctl_set_bit(unsigned int cr, unsigned int bit)
__ctl_load(reg, cr, cr); __ctl_load(reg, cr, cr);
} }
static inline void __ctl_clear_bit(unsigned int cr, unsigned int bit) static __always_inline void __ctl_clear_bit(unsigned int cr, unsigned int bit)
{ {
unsigned long reg; unsigned long reg;
......
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