Linux 5.0 compat: ASM_BUG macro
The 5.0 kernel defines the macro ASM_BUG. In order to prevent a conflict and build failure rename ASM_BUG to ZFS_ASM_BUG. This is currently only an issue on aarch64 but all instances of ASM_BUG we're renamed to avoid any future conflict on x86_64. Reviewed-by: Tomohiro Kusumi <kusumi.tomohiro@gmail.com> Reviewed-by: Richard Laager <rlaager@wiktel.com> Reviewed-by: Chris Dunlop <chris@onthe.net.au> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #8725 Issue #8545
This commit is contained in:
parent
515ddf6504
commit
a20f43b51b
|
@ -123,7 +123,7 @@
|
||||||
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
||||||
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
||||||
|
|
||||||
#define ASM_BUG() ASSERT(0)
|
#define ZFS_ASM_BUG() ASSERT(0)
|
||||||
|
|
||||||
#define OFFSET(ptr, val) (((unsigned char *)(ptr))+val)
|
#define OFFSET(ptr, val) (((unsigned char *)(ptr))+val)
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ typedef struct v {
|
||||||
: "v20", "v21"); \
|
: "v20", "v21"); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -221,7 +221,7 @@ typedef struct v {
|
||||||
: RVR0(r), RVR1(r)); \
|
: RVR0(r), RVR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -256,7 +256,7 @@ typedef struct v {
|
||||||
: WVR0(r), WVR1(r)); \
|
: WVR0(r), WVR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -280,7 +280,7 @@ typedef struct v {
|
||||||
: RVR0(r), RVR1(r)); \
|
: RVR0(r), RVR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -329,7 +329,7 @@ typedef struct v {
|
||||||
[SRC1] "Q" (*(OFFSET(src, 16)))); \
|
[SRC1] "Q" (*(OFFSET(src, 16)))); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ typedef struct v {
|
||||||
: RVR0(r), RVR1(r)); \
|
: RVR0(r), RVR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -441,7 +441,7 @@ typedef struct v {
|
||||||
: "v18", "v19"); \
|
: "v18", "v19"); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -512,7 +512,7 @@ typedef struct v {
|
||||||
: "v10", "v11", "v12", "v13", "v14", "v15"); \
|
: "v10", "v11", "v12", "v13", "v14", "v15"); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -527,7 +527,7 @@ typedef struct v {
|
||||||
_MULx2(c, R_01(r)); \
|
_MULx2(c, R_01(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@
|
||||||
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
||||||
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
||||||
|
|
||||||
#define ASM_BUG() ASSERT(0)
|
#define ZFS_ASM_BUG() ASSERT(0)
|
||||||
|
|
||||||
extern const uint8_t gf_clmul_mod_lt[4*256][16];
|
extern const uint8_t gf_clmul_mod_lt[4*256][16];
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,7 +104,7 @@ typedef struct v {
|
||||||
"vpxor %" VR1(r) ", %" VR3(r)", %" VR3(r)); \
|
"vpxor %" VR1(r) ", %" VR3(r)", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ typedef struct v {
|
||||||
"vmovdqa %" VR1(r) ", %" VR3(r)); \
|
"vmovdqa %" VR1(r) ", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,7 +148,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ typedef struct v {
|
||||||
: : [DST] "r" (dst)); \
|
: : [DST] "r" (dst)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,7 +201,7 @@ typedef struct v {
|
||||||
"vpxor %ymm13, %" VR1(r)", %" VR1(r)); \
|
"vpxor %ymm13, %" VR1(r)", %" VR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,7 +216,7 @@ typedef struct v {
|
||||||
_MUL2(r); \
|
_MUL2(r); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -277,7 +277,7 @@ static const uint8_t __attribute__((aligned(32))) _mul_mask = 0x0F;
|
||||||
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,7 +292,7 @@ static const uint8_t __attribute__((aligned(32))) _mul_mask = 0x0F;
|
||||||
_MULx2(c, R_01(r)); \
|
_MULx2(c, R_01(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -57,7 +57,7 @@
|
||||||
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
||||||
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
||||||
|
|
||||||
#define ASM_BUG() ASSERT(0)
|
#define ZFS_ASM_BUG() ASSERT(0)
|
||||||
|
|
||||||
extern const uint8_t gf_clmul_mod_lt[4*256][16];
|
extern const uint8_t gf_clmul_mod_lt[4*256][16];
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,7 +105,7 @@ typedef struct v {
|
||||||
"vpxorq %" VR1(r) ", %" VR3(r)", %" VR3(r)); \
|
"vpxorq %" VR1(r) ", %" VR3(r)", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,7 +127,7 @@ typedef struct v {
|
||||||
"vmovdqa64 %" VR1(r) ", %" VR3(r)); \
|
"vmovdqa64 %" VR1(r) ", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,7 +149,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ typedef struct v {
|
||||||
: : [DST] "r" (dst)); \
|
: : [DST] "r" (dst)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ typedef struct v {
|
||||||
"vmovdqu8 %zmm13, %" VR1(r) "{%k2}"); \
|
"vmovdqu8 %zmm13, %" VR1(r) "{%k2}"); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,7 +212,7 @@ typedef struct v {
|
||||||
_MUL2(r); \
|
_MUL2(r); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -273,7 +273,7 @@ static const uint8_t __attribute__((aligned(64))) _mul_mask = 0x0F;
|
||||||
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -288,7 +288,7 @@ static const uint8_t __attribute__((aligned(64))) _mul_mask = 0x0F;
|
||||||
_MULx2(c, R_01(r)); \
|
_MULx2(c, R_01(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,7 @@
|
||||||
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
#define _R_23(_0, _1, REG2, REG3, ...) REG2, REG3
|
||||||
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
#define R_23(REG...) _R_23(REG, 1, 2, 3)
|
||||||
|
|
||||||
#define ASM_BUG() ASSERT(0)
|
#define ZFS_ASM_BUG() ASSERT(0)
|
||||||
|
|
||||||
const uint8_t gf_clmul_mod_lt[4*256][16];
|
const uint8_t gf_clmul_mod_lt[4*256][16];
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,7 +105,7 @@ typedef struct v {
|
||||||
"pxor %" VR1(r) ", %" VR3(r)); \
|
"pxor %" VR1(r) ", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,7 +127,7 @@ typedef struct v {
|
||||||
"movdqa %" VR1(r) ", %" VR3(r)); \
|
"movdqa %" VR1(r) ", %" VR3(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,7 +149,7 @@ typedef struct v {
|
||||||
: : [SRC] "r" (src)); \
|
: : [SRC] "r" (src)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ typedef struct v {
|
||||||
: : [DST] "r" (dst)); \
|
: : [DST] "r" (dst)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,7 +200,7 @@ typedef struct v {
|
||||||
"pxor %xmm13, %" VR1(r)); \
|
"pxor %xmm13, %" VR1(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,7 +215,7 @@ typedef struct v {
|
||||||
_MUL2_x2(r); \
|
_MUL2_x2(r); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,7 +284,7 @@ typedef struct v {
|
||||||
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
[lt] "r" (gf_clmul_mod_lt[4*(c)])); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -299,7 +299,7 @@ typedef struct v {
|
||||||
_MULx2(c, R_01(r)); \
|
_MULx2(c, R_01(r)); \
|
||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
ASM_BUG(); \
|
ZFS_ASM_BUG(); \
|
||||||
} \
|
} \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue