Fix the opcode value of LWA
[qemu-kvm/fedora.git] / target-m68k / helpers.h
blob5496b6cbeb3066199b8431fac1de78608f4cfdbd
1 #ifndef DEF_HELPER
2 #define DEF_HELPER(name, ret, args) ret glue(helper_,name) args;
3 #endif
5 #ifdef GEN_HELPER
6 #define DEF_HELPER_0_0(name, ret, args) \
7 DEF_HELPER(name, ret, args) \
8 static inline void gen_helper_##name(void) \
9 { \
10 tcg_gen_helper_0_0(helper_##name); \
12 #define DEF_HELPER_0_1(name, ret, args) \
13 DEF_HELPER(name, ret, args) \
14 static inline void gen_helper_##name(TCGv arg1) \
15 { \
16 tcg_gen_helper_0_1(helper_##name, arg1); \
18 #define DEF_HELPER_0_2(name, ret, args) \
19 DEF_HELPER(name, ret, args) \
20 static inline void gen_helper_##name(TCGv arg1, TCGv arg2) \
21 { \
22 tcg_gen_helper_0_2(helper_##name, arg1, arg2); \
24 #define DEF_HELPER_0_3(name, ret, args) \
25 DEF_HELPER(name, ret, args) \
26 static inline void gen_helper_##name( \
27 TCGv arg1, TCGv arg2, TCGv arg3) \
28 { \
29 tcg_gen_helper_0_3(helper_##name, arg1, arg2, arg3); \
31 #define DEF_HELPER_1_0(name, ret, args) \
32 DEF_HELPER(name, ret, args) \
33 static inline void gen_helper_##name(TCGv ret) \
34 { \
35 tcg_gen_helper_1_0(helper_##name, ret); \
37 #define DEF_HELPER_1_1(name, ret, args) \
38 DEF_HELPER(name, ret, args) \
39 static inline void gen_helper_##name(TCGv ret, TCGv arg1) \
40 { \
41 tcg_gen_helper_1_1(helper_##name, ret, arg1); \
43 #define DEF_HELPER_1_2(name, ret, args) \
44 DEF_HELPER(name, ret, args) \
45 static inline void gen_helper_##name(TCGv ret, TCGv arg1, TCGv arg2) \
46 { \
47 tcg_gen_helper_1_2(helper_##name, ret, arg1, arg2); \
49 #define DEF_HELPER_1_3(name, ret, args) \
50 DEF_HELPER(name, ret, args) \
51 static inline void gen_helper_##name(TCGv ret, \
52 TCGv arg1, TCGv arg2, TCGv arg3) \
53 { \
54 tcg_gen_helper_1_3(helper_##name, ret, arg1, arg2, arg3); \
56 #define DEF_HELPER_1_4(name, ret, args) \
57 DEF_HELPER(name, ret, args) \
58 static inline void gen_helper_##name(TCGv ret, \
59 TCGv arg1, TCGv arg2, TCGv arg3, TCGv arg4) \
60 { \
61 tcg_gen_helper_1_4(helper_##name, ret, arg1, arg2, arg3, arg4); \
63 #else /* !GEN_HELPER */
64 #define DEF_HELPER_0_0 DEF_HELPER
65 #define DEF_HELPER_0_1 DEF_HELPER
66 #define DEF_HELPER_0_2 DEF_HELPER
67 #define DEF_HELPER_0_3 DEF_HELPER
68 #define DEF_HELPER_1_0 DEF_HELPER
69 #define DEF_HELPER_1_1 DEF_HELPER
70 #define DEF_HELPER_1_2 DEF_HELPER
71 #define DEF_HELPER_1_3 DEF_HELPER
72 #define DEF_HELPER_1_4 DEF_HELPER
73 #define HELPER(x) glue(helper_,x)
74 #endif
76 DEF_HELPER_1_1(bitrev, uint32_t, (uint32_t))
77 DEF_HELPER_1_1(ff1, uint32_t, (uint32_t))
78 DEF_HELPER_1_2(sats, uint32_t, (uint32_t, uint32_t))
79 DEF_HELPER_0_2(divu, void, (CPUState *, uint32_t))
80 DEF_HELPER_0_2(divs, void, (CPUState *, uint32_t))
81 DEF_HELPER_1_3(addx_cc, uint32_t, (CPUState *, uint32_t, uint32_t))
82 DEF_HELPER_1_3(subx_cc, uint32_t, (CPUState *, uint32_t, uint32_t))
83 DEF_HELPER_1_3(shl_cc, uint32_t, (CPUState *, uint32_t, uint32_t))
84 DEF_HELPER_1_3(shr_cc, uint32_t, (CPUState *, uint32_t, uint32_t))
85 DEF_HELPER_1_3(sar_cc, uint32_t, (CPUState *, uint32_t, uint32_t))
86 DEF_HELPER_1_2(xflag_lt, uint32_t, (uint32_t, uint32_t))
87 DEF_HELPER_0_2(set_sr, void, (CPUState *, uint32_t))
88 DEF_HELPER_0_3(movec, void, (CPUState *, uint32_t, uint32_t))
90 DEF_HELPER_1_2(f64_to_i32, float32, (CPUState *, float64))
91 DEF_HELPER_1_2(f64_to_f32, float32, (CPUState *, float64))
92 DEF_HELPER_1_2(i32_to_f64, float64, (CPUState *, uint32_t))
93 DEF_HELPER_1_2(f32_to_f64, float64, (CPUState *, float32))
94 DEF_HELPER_1_2(iround_f64, float64, (CPUState *, float64))
95 DEF_HELPER_1_2(itrunc_f64, float64, (CPUState *, float64))
96 DEF_HELPER_1_2(sqrt_f64, float64, (CPUState *, float64))
97 DEF_HELPER_1_1(abs_f64, float64, (float64))
98 DEF_HELPER_1_1(chs_f64, float64, (float64))
99 DEF_HELPER_1_3(add_f64, float64, (CPUState *, float64, float64))
100 DEF_HELPER_1_3(sub_f64, float64, (CPUState *, float64, float64))
101 DEF_HELPER_1_3(mul_f64, float64, (CPUState *, float64, float64))
102 DEF_HELPER_1_3(div_f64, float64, (CPUState *, float64, float64))
103 DEF_HELPER_1_3(sub_cmp_f64, float64, (CPUState *, float64, float64))
104 DEF_HELPER_1_2(compare_f64, uint32_t, (CPUState *, float64))
106 DEF_HELPER_0_3(mac_move, void, (CPUState *, uint32_t, uint32_t))
107 DEF_HELPER_1_3(macmulf, uint64_t, (CPUState *, uint32_t, uint32_t))
108 DEF_HELPER_1_3(macmuls, uint64_t, (CPUState *, uint32_t, uint32_t))
109 DEF_HELPER_1_3(macmulu, uint64_t, (CPUState *, uint32_t, uint32_t))
110 DEF_HELPER_0_2(macsats, void, (CPUState *, uint32_t))
111 DEF_HELPER_0_2(macsatu, void, (CPUState *, uint32_t))
112 DEF_HELPER_0_2(macsatf, void, (CPUState *, uint32_t))
113 DEF_HELPER_0_2(mac_set_flags, void, (CPUState *, uint32_t))
114 DEF_HELPER_0_2(set_macsr, void, (CPUState *, uint32_t))
115 DEF_HELPER_1_2(get_macf, uint32_t, (CPUState *, uint64_t))
116 DEF_HELPER_1_1(get_macs, uint32_t, (uint64_t))
117 DEF_HELPER_1_1(get_macu, uint32_t, (uint64_t))
118 DEF_HELPER_1_2(get_mac_extf, uint32_t, (CPUState *, uint32_t))
119 DEF_HELPER_1_2(get_mac_exti, uint32_t, (CPUState *, uint32_t))
120 DEF_HELPER_0_3(set_mac_extf, void, (CPUState *, uint32_t, uint32_t))
121 DEF_HELPER_0_3(set_mac_exts, void, (CPUState *, uint32_t, uint32_t))
122 DEF_HELPER_0_3(set_mac_extu, void, (CPUState *, uint32_t, uint32_t))
124 DEF_HELPER_0_2(flush_flags, void, (CPUState *, uint32_t))
125 DEF_HELPER_0_1(raise_exception, void, (uint32_t))
127 #undef DEF_HELPER
128 #undef DEF_HELPER_0_0
129 #undef DEF_HELPER_0_1
130 #undef DEF_HELPER_0_2
131 #undef DEF_HELPER_0_3
132 #undef DEF_HELPER_1_0
133 #undef DEF_HELPER_1_1
134 #undef DEF_HELPER_1_2
135 #undef DEF_HELPER_1_3
136 #undef DEF_HELPER_1_4
137 #undef GEN_HELPER
138 #undef DEF_HELPER