hc
2024-08-14 93e8ba98c407598d13d8ade71bc7802acfb19c58
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _ASM_S390_BUG_H
#define _ASM_S390_BUG_H
 
#include <linux/compiler.h>
 
#ifdef CONFIG_BUG
 
#ifdef CONFIG_DEBUG_BUGVERBOSE
 
#define __EMIT_BUG(x) do {                    \
   asm_inline volatile(                    \
       "0:    mc    0,0\n"                \
       ".section .rodata.str,\"aMS\",@progbits,1\n"    \
       "1:    .asciz    \""__FILE__"\"\n"        \
       ".previous\n"                    \
       ".section __bug_table,\"awM\",@progbits,%2\n"    \
       "2:    .long    0b-2b,1b-2b\n"            \
       "    .short    %0,%1\n"            \
       "    .org    2b+%2\n"            \
       ".previous\n"                    \
       : : "i" (__LINE__),                \
           "i" (x),                    \
           "i" (sizeof(struct bug_entry)));        \
} while (0)
 
#else /* CONFIG_DEBUG_BUGVERBOSE */
 
#define __EMIT_BUG(x) do {                    \
   asm_inline volatile(                    \
       "0:    mc    0,0\n"                \
       ".section __bug_table,\"awM\",@progbits,%1\n"    \
       "1:    .long    0b-1b\n"            \
       "    .short    %0\n"                \
       "    .org    1b+%1\n"            \
       ".previous\n"                    \
       : : "i" (x),                    \
           "i" (sizeof(struct bug_entry)));        \
} while (0)
 
#endif /* CONFIG_DEBUG_BUGVERBOSE */
 
#define BUG() do {                    \
   __EMIT_BUG(0);                    \
   unreachable();                    \
} while (0)
 
#define __WARN_FLAGS(flags) do {            \
   __EMIT_BUG(BUGFLAG_WARNING|(flags));        \
} while (0)
 
#define WARN_ON(x) ({                    \
   int __ret_warn_on = !!(x);            \
   if (__builtin_constant_p(__ret_warn_on)) {    \
       if (__ret_warn_on)            \
           __WARN();            \
   } else {                    \
       if (unlikely(__ret_warn_on))        \
           __WARN();            \
   }                        \
   unlikely(__ret_warn_on);            \
})
 
#define HAVE_ARCH_BUG
#define HAVE_ARCH_WARN_ON
#endif /* CONFIG_BUG */
 
#include <asm-generic/bug.h>
 
#endif /* _ASM_S390_BUG_H */