File: condition.go

package info (click to toggle)
golang-golang-x-arch 0.13.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,932 kB
  • sloc: ansic: 1,975; makefile: 59
file content (329 lines) | stat: -rw-r--r-- 9,851 bytes parent folder | download | duplicates (25)
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
// Generated by ARM internal tool
// DO NOT EDIT

// Copyright 2017 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

package arm64asm

// Following functions are used as the predicator: canDecode of according instruction
// Refer to instFormat inside decode.go for more details

func at_sys_cr_system_cond(instr uint32) bool {
	return sys_op_4((instr>>16)&0x7, 0x7, 0x8, (instr>>5)&0x7) == sys_AT
}

func bfi_bfm_32m_bitfield_cond(instr uint32) bool {
	return (instr>>5)&0x1f != 0x1f && uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func bfi_bfm_64m_bitfield_cond(instr uint32) bool {
	return (instr>>5)&0x1f != 0x1f && uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func bfxil_bfm_32m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) >= uint8((instr>>16)&0x3f)
}

func bfxil_bfm_64m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) >= uint8((instr>>16)&0x3f)
}

func cinc_csinc_32_condsel_cond(instr uint32) bool {
	return instr&0x1f0000 != 0x1f0000 && instr&0xe000 != 0xe000 && instr&0x3e0 != 0x3e0 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func cinc_csinc_64_condsel_cond(instr uint32) bool {
	return instr&0x1f0000 != 0x1f0000 && instr&0xe000 != 0xe000 && instr&0x3e0 != 0x3e0 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func cinv_csinv_32_condsel_cond(instr uint32) bool {
	return instr&0x1f0000 != 0x1f0000 && instr&0xe000 != 0xe000 && instr&0x3e0 != 0x3e0 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func cinv_csinv_64_condsel_cond(instr uint32) bool {
	return instr&0x1f0000 != 0x1f0000 && instr&0xe000 != 0xe000 && instr&0x3e0 != 0x3e0 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func cneg_csneg_32_condsel_cond(instr uint32) bool {
	return instr&0xe000 != 0xe000 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func cneg_csneg_64_condsel_cond(instr uint32) bool {
	return instr&0xe000 != 0xe000 && (instr>>5)&0x1f == (instr>>16)&0x1f
}

func csinc_general_cond(instr uint32) bool {
	return instr&0xe000 != 0xe000
}
func csinv_general_cond(instr uint32) bool {
	return instr&0xe000 != 0xe000
}
func dc_sys_cr_system_cond(instr uint32) bool {
	return sys_op_4((instr>>16)&0x7, 0x7, (instr>>8)&0xf, (instr>>5)&0x7) == sys_DC
}

func ic_sys_cr_system_cond(instr uint32) bool {
	return sys_op_4((instr>>16)&0x7, 0x7, (instr>>8)&0xf, (instr>>5)&0x7) == sys_IC
}

func lsl_ubfm_32m_bitfield_cond(instr uint32) bool {
	return instr&0xfc00 != 0x7c00 && (instr>>10)&0x3f+1 == (instr>>16)&0x3f
}

func lsl_ubfm_64m_bitfield_cond(instr uint32) bool {
	return instr&0xfc00 != 0xfc00 && (instr>>10)&0x3f+1 == (instr>>16)&0x3f
}

func mov_orr_32_log_imm_cond(instr uint32) bool {
	return !move_wide_preferred_4((instr>>31)&0x1, (instr>>22)&0x1, (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func mov_orr_64_log_imm_cond(instr uint32) bool {
	return !move_wide_preferred_4((instr>>31)&0x1, (instr>>22)&0x1, (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func mov_movn_32_movewide_cond(instr uint32) bool {
	return !(is_zero((instr>>5)&0xffff) && (instr>>21)&0x3 != 0x0) && !is_ones_n16((instr>>5)&0xffff)
}

func mov_movn_64_movewide_cond(instr uint32) bool {
	return !(is_zero((instr>>5)&0xffff) && (instr>>21)&0x3 != 0x0)
}

func mov_add_32_addsub_imm_cond(instr uint32) bool {
	return instr&0x1f == 0x1f || (instr>>5)&0x1f == 0x1f
}

func mov_add_64_addsub_imm_cond(instr uint32) bool {
	return instr&0x1f == 0x1f || (instr>>5)&0x1f == 0x1f
}

func mov_movz_32_movewide_cond(instr uint32) bool {
	return !(is_zero((instr>>5)&0xffff) && (instr>>21)&0x3 != 0x0)
}

func mov_movz_64_movewide_cond(instr uint32) bool {
	return !(is_zero((instr>>5)&0xffff) && (instr>>21)&0x3 != 0x0)
}

func ror_extr_32_extract_cond(instr uint32) bool {
	return (instr>>5)&0x1f == (instr>>16)&0x1f
}

func ror_extr_64_extract_cond(instr uint32) bool {
	return (instr>>5)&0x1f == (instr>>16)&0x1f
}

func sbfiz_sbfm_32m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func sbfiz_sbfm_64m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func sbfx_sbfm_32m_bitfield_cond(instr uint32) bool {
	return bfxpreferred_4((instr>>31)&0x1, extract_bit((instr>>29)&0x3, 1), (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func sbfx_sbfm_64m_bitfield_cond(instr uint32) bool {
	return bfxpreferred_4((instr>>31)&0x1, extract_bit((instr>>29)&0x3, 1), (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func tlbi_sys_cr_system_cond(instr uint32) bool {
	return sys_op_4((instr>>16)&0x7, 0x8, (instr>>8)&0xf, (instr>>5)&0x7) == sys_TLBI
}

func ubfiz_ubfm_32m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func ubfiz_ubfm_64m_bitfield_cond(instr uint32) bool {
	return uint8((instr>>10)&0x3f) < uint8((instr>>16)&0x3f)
}

func ubfx_ubfm_32m_bitfield_cond(instr uint32) bool {
	return bfxpreferred_4((instr>>31)&0x1, extract_bit((instr>>29)&0x3, 1), (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func ubfx_ubfm_64m_bitfield_cond(instr uint32) bool {
	return bfxpreferred_4((instr>>31)&0x1, extract_bit((instr>>29)&0x3, 1), (instr>>10)&0x3f, (instr>>16)&0x3f)
}

func fcvtzs_asisdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func fcvtzs_asimdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func fcvtzu_asisdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func fcvtzu_asimdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func mov_umov_asimdins_w_w_cond(instr uint32) bool {
	return ((instr>>16)&0x1f)&0x7 == 0x4
}

func mov_umov_asimdins_x_x_cond(instr uint32) bool {
	return ((instr>>16)&0x1f)&0xf == 0x8
}

func mov_orr_asimdsame_only_cond(instr uint32) bool {
	return (instr>>16)&0x1f == (instr>>5)&0x1f
}

func rshrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func scvtf_asisdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func scvtf_asimdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func shl_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func shl_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func shrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sli_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sli_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqrshrn_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqrshrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqrshrun_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqrshrun_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshl_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshl_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshlu_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshlu_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshrn_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshrun_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sqshrun_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sri_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sri_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func srshr_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func srshr_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func srsra_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func srsra_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sshll_asimdshf_l_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sshr_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sshr_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ssra_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ssra_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func sxtl_sshll_asimdshf_l_cond(instr uint32) bool {
	return instr&0x780000 != 0x0 && bit_count((instr>>19)&0xf) == 1
}

func ucvtf_asisdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ucvtf_asimdshf_c_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqrshrn_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqrshrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqshl_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqshl_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqshrn_asisdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uqshrn_asimdshf_n_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func urshr_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func urshr_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ursra_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ursra_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ushll_asimdshf_l_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ushr_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func ushr_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func usra_asisdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func usra_asimdshf_r_cond(instr uint32) bool {
	return instr&0x780000 != 0x0
}
func uxtl_ushll_asimdshf_l_cond(instr uint32) bool {
	return instr&0x780000 != 0x0 && bit_count((instr>>19)&0xf) == 1
}