summaryrefslogtreecommitdiffstats
path: root/lib/Target/Hexagon/HexagonIntrinsicsV5.td
blob: 4746b4c2b65d9bba237c88d44b07259bc57c27f2 (plain)
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
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
class sf_SInst_sf<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID IntRegs:$src1))]>;

class si_SInst_sf<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID IntRegs:$src1))]>;

class sf_SInst_si<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID IntRegs:$src1))]>;

class sf_SInst_di<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID DoubleRegs:$src1))]>;

class sf_SInst_df<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID DoubleRegs:$src1))]>;

class si_SInst_df<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set IntRegs:$dst, (IntID DoubleRegs:$src1))]>;

class df_SInst_sf<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID IntRegs:$src1))]>;

class di_SInst_sf<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID IntRegs:$src1))]>;

class df_SInst_si<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins IntRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID IntRegs:$src1))]>;

class df_SInst_df<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1))]>;

class di_SInst_df<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1))]>;


class df_SInst_di<string opc, Intrinsic IntID>
  : SInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1),
             !strconcat("$dst = ", !strconcat(opc , "($src1)")),
             [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1))]>;

class sf_MInst_sfsf<string opc, Intrinsic IntID>
  : MInst<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2),
             !strconcat("$dst = ", !strconcat(opc , "($src1, $src2)")),
             [(set IntRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>;

class df_MInst_dfdf<string opc, Intrinsic IntID>
  : MInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2),
           !strconcat("$dst = ", !strconcat(opc , "($src1, $src2)")),
           [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1, DoubleRegs:$src2))]>;

class qi_ALU64_dfdf<string opc, Intrinsic IntID>
  : ALU64_rr<(outs PredRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2),
           !strconcat("$dst = ", !strconcat(opc , "($src1, $src2)")),
           [(set PredRegs:$dst, (IntID DoubleRegs:$src1, DoubleRegs:$src2))]>;

class qi_ALU64_dfu5<string opc, Intrinsic IntID>
  : ALU64_ri<(outs PredRegs:$dst), (ins DoubleRegs:$src1, u5Imm:$src2),
           !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2)")),
           [(set PredRegs:$dst, (IntID DoubleRegs:$src1, imm:$src2))]>;


class sf_MInst_sfsfsf_acc<string opc, Intrinsic IntID>
  : MInst_acc<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2,
                                        IntRegs:$dst2),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2)")),
               [(set IntRegs:$dst, (IntID IntRegs:$src1,
                                          IntRegs:$src2, IntRegs:$dst2))],
               "$dst2 = $dst">;

class sf_MInst_sfsfsf_nac<string opc, Intrinsic IntID>
  : MInst_acc<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2,
                                        IntRegs:$dst2),
               !strconcat("$dst -= ", !strconcat(opc ,
                                                 "($src1, $src2)")),
               [(set IntRegs:$dst, (IntID IntRegs:$src1,
                                          IntRegs:$src2, IntRegs:$dst2))],
               "$dst2 = $dst">;


class sf_MInst_sfsfsfsi_sc<string opc, Intrinsic IntID>
  : MInst_acc<(outs IntRegs:$dst), (ins IntRegs:$dst2, IntRegs:$src1,
                                        IntRegs:$src2, IntRegs:$src3),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2, $src3):scale")),
               [(set IntRegs:$dst, (IntID IntRegs:$dst2, IntRegs:$src1,
                                        IntRegs:$src2, IntRegs:$src3))],
               "$dst2 = $dst">;

class sf_MInst_sfsfsf_acc_lib<string opc, Intrinsic IntID>
  : MInst_acc<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2,
                                        IntRegs:$dst2),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2):lib")),
               [(set IntRegs:$dst, (IntID IntRegs:$src1,
                                          IntRegs:$src2, IntRegs:$dst2))],
               "$dst2 = $dst">;

class sf_MInst_sfsfsf_nac_lib<string opc, Intrinsic IntID>
  : MInst_acc<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2,
                                        IntRegs:$dst2),
               !strconcat("$dst -= ", !strconcat(opc ,
                                                 "($src1, $src2):lib")),
               [(set IntRegs:$dst, (IntID IntRegs:$src1,
                                          IntRegs:$src2, IntRegs:$dst2))],
               "$dst2 = $dst">;

class df_MInst_dfdfdf_acc<string opc, Intrinsic IntID>
  : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2,
                                        DoubleRegs:$dst2),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2)")),
               [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1,
                                          DoubleRegs:$src2, DoubleRegs:$dst2))],
               "$dst2 = $dst">;

class df_MInst_dfdfdf_nac<string opc, Intrinsic IntID>
  : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2,
                                        DoubleRegs:$dst2),
               !strconcat("$dst -= ", !strconcat(opc ,
                                                 "($src1, $src2)")),
               [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1,
                                          DoubleRegs:$src2, DoubleRegs:$dst2))],
               "$dst2 = $dst">;


class df_MInst_dfdfdfsi_sc<string opc, Intrinsic IntID>
  : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$dst2, DoubleRegs:$src1,
                                        DoubleRegs:$src2, IntRegs:$src3),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2, $src3):scale")),
               [(set DoubleRegs:$dst, (IntID DoubleRegs:$dst2, DoubleRegs:$src1,
                                        DoubleRegs:$src2, IntRegs:$src3))],
               "$dst2 = $dst">;

class df_MInst_dfdfdf_acc_lib<string opc, Intrinsic IntID>
  : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2,
                                        DoubleRegs:$dst2),
               !strconcat("$dst += ", !strconcat(opc ,
                                                 "($src1, $src2):lib")),
               [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1,
                                          DoubleRegs:$src2, DoubleRegs:$dst2))],
               "$dst2 = $dst">;

class df_MInst_dfdfdf_nac_lib<string opc, Intrinsic IntID>
  : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2,
                                        DoubleRegs:$dst2),
               !strconcat("$dst -= ", !strconcat(opc ,
                                                 "($src1, $src2):lib")),
               [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1,
                                          DoubleRegs:$src2, DoubleRegs:$dst2))],
               "$dst2 = $dst">;

class qi_SInst_sfsf<string opc, Intrinsic IntID>
  : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2),
             !strconcat("$dst = ", !strconcat(opc , "($src1, $src2)")),
             [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>;

class qi_SInst_sfu5<string opc, Intrinsic IntID>
  : MInst<(outs PredRegs:$dst), (ins IntRegs:$src1, u5Imm:$src2),
             !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2)")),
             [(set PredRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>;

class sf_ALU64_u10_pos<string opc, Intrinsic IntID>
  : ALU64_ri<(outs IntRegs:$dst), (ins u10Imm:$src1),
             !strconcat("$dst = ", !strconcat(opc , "#$src1):pos")),
             [(set IntRegs:$dst, (IntID imm:$src1))]>;

class sf_ALU64_u10_neg<string opc, Intrinsic IntID>
  : ALU64_ri<(outs IntRegs:$dst), (ins u10Imm:$src1),
             !strconcat("$dst = ", !strconcat(opc , "#$src1):neg")),
             [(set IntRegs:$dst, (IntID imm:$src1))]>;

class df_ALU64_u10_pos<string opc, Intrinsic IntID>
  : ALU64_ri<(outs DoubleRegs:$dst), (ins u10Imm:$src1),
             !strconcat("$dst = ", !strconcat(opc , "#$src1):pos")),
             [(set DoubleRegs:$dst, (IntID imm:$src1))]>;

class df_ALU64_u10_neg<string opc, Intrinsic IntID>
  : ALU64_ri<(outs DoubleRegs:$dst), (ins u10Imm:$src1),
             !strconcat("$dst = ", !strconcat(opc , "#$src1):neg")),
             [(set DoubleRegs:$dst, (IntID imm:$src1))]>;

class di_MInst_diu6<string opc, Intrinsic IntID>
  : MInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, u6Imm:$src2),
          !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2)")),
          [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1, imm:$src2))]>;

class di_MInst_diu4_rnd<string opc, Intrinsic IntID>
  : MInst<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, u4Imm:$src2),
          !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2):rnd")),
          [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1, imm:$src2))]>;

class si_MInst_diu4_rnd_sat<string opc, Intrinsic IntID>
  : MInst<(outs IntRegs:$dst), (ins DoubleRegs:$src1, u4Imm:$src2),
          !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2):rnd:sat")),
          [(set IntRegs:$dst, (IntID DoubleRegs:$src1, imm:$src2))]>;

class si_SInst_diu4_sat<string opc, Intrinsic IntID>
  : SInst<(outs IntRegs:$dst), (ins DoubleRegs:$src1, u4Imm:$src2),
          !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2):sat")),
          [(set IntRegs:$dst, (IntID DoubleRegs:$src1, imm:$src2))]>;


def HEXAGON_C4_fastcorner9:
    qi_SInst_qiqi	<"fastcorner9",	int_hexagon_C4_fastcorner9>;
def HEXAGON_C4_fastcorner9_not:
    qi_SInst_qiqi	<"!fastcorner9",	int_hexagon_C4_fastcorner9_not>;
def HEXAGON_M5_vrmpybuu:
    di_MInst_didi	<"vrmpybu",	int_hexagon_M5_vrmpybuu>;
def HEXAGON_M5_vrmacbuu:
    di_MInst_dididi_acc	<"vrmpybu",	int_hexagon_M5_vrmacbuu>;
def HEXAGON_M5_vrmpybsu:
    di_MInst_didi	<"vrmpybsu",	int_hexagon_M5_vrmpybsu>;
def HEXAGON_M5_vrmacbsu:
    di_MInst_dididi_acc	<"vrmpybsu",	int_hexagon_M5_vrmacbsu>;
def HEXAGON_M5_vmpybuu:
    di_MInst_sisi	<"vmpybu",	int_hexagon_M5_vmpybuu>;
def HEXAGON_M5_vmpybsu:
    di_MInst_sisi	<"vmpybsu",	int_hexagon_M5_vmpybsu>;
def HEXAGON_M5_vmacbuu:
    di_MInst_disisi_acc	<"vmpybu",	int_hexagon_M5_vmacbuu>;
def HEXAGON_M5_vmacbsu:
    di_MInst_disisi_acc	<"vmpybsu",	int_hexagon_M5_vmacbsu>;
def HEXAGON_M5_vdmpybsu:
    di_MInst_didi_sat	<"vdmpybsu",	int_hexagon_M5_vdmpybsu>;
def HEXAGON_M5_vdmacbsu:
    di_MInst_dididi_acc_sat	<"vdmpybsu",	int_hexagon_M5_vdmacbsu>;
def HEXAGON_A5_vaddhubs:
    si_SInst_didi_sat	<"vaddhub",	int_hexagon_A5_vaddhubs>;
def HEXAGON_S5_popcountp:
    si_SInst_di	<"popcount",	int_hexagon_S5_popcountp>;
def HEXAGON_S5_asrhub_rnd_sat_goodsyntax:
    si_MInst_diu4_rnd_sat	<"vasrhub",	int_hexagon_S5_asrhub_rnd_sat_goodsyntax>;
def HEXAGON_S5_asrhub_sat:
    si_SInst_diu4_sat	<"vasrhub",	int_hexagon_S5_asrhub_sat>;
def HEXAGON_S5_vasrhrnd_goodsyntax:
    di_MInst_diu4_rnd	<"vasrh",	int_hexagon_S5_vasrhrnd_goodsyntax>;
def HEXAGON_S2_asr_i_p_rnd:
    di_SInst_diu6	<"asr",	int_hexagon_S2_asr_i_p_rnd>;
def HEXAGON_S2_asr_i_p_rnd_goodsyntax:
    di_MInst_diu6	<"asrrnd",	int_hexagon_S2_asr_i_p_rnd_goodsyntax>;
def HEXAGON_F2_sfadd:
    sf_MInst_sfsf	<"sfadd",	int_hexagon_F2_sfadd>;
def HEXAGON_F2_sfsub:
    sf_MInst_sfsf	<"sfsub",	int_hexagon_F2_sfsub>;
def HEXAGON_F2_sfmpy:
    sf_MInst_sfsf	<"sfmpy",	int_hexagon_F2_sfmpy>;
def HEXAGON_F2_sffma:
    sf_MInst_sfsfsf_acc	<"sfmpy",	int_hexagon_F2_sffma>;
def HEXAGON_F2_sffma_sc:
    sf_MInst_sfsfsfsi_sc	<"sfmpy",	int_hexagon_F2_sffma_sc>;
def HEXAGON_F2_sffms:
    sf_MInst_sfsfsf_nac	<"sfmpy",	int_hexagon_F2_sffms>;
def HEXAGON_F2_sffma_lib:
    sf_MInst_sfsfsf_acc_lib	<"sfmpy",	int_hexagon_F2_sffma_lib>;
def HEXAGON_F2_sffms_lib:
    sf_MInst_sfsfsf_nac_lib	<"sfmpy",	int_hexagon_F2_sffms_lib>;
def HEXAGON_F2_sfcmpeq:
    qi_SInst_sfsf	<"sfcmp.eq",	int_hexagon_F2_sfcmpeq>;
def HEXAGON_F2_sfcmpgt:
    qi_SInst_sfsf	<"sfcmp.gt",	int_hexagon_F2_sfcmpgt>;
def HEXAGON_F2_sfcmpge:
    qi_SInst_sfsf	<"sfcmp.ge",	int_hexagon_F2_sfcmpge>;
def HEXAGON_F2_sfcmpuo:
    qi_SInst_sfsf	<"sfcmp.uo",	int_hexagon_F2_sfcmpuo>;
def HEXAGON_F2_sfmax:
    sf_MInst_sfsf	<"sfmax",	int_hexagon_F2_sfmax>;
def HEXAGON_F2_sfmin:
    sf_MInst_sfsf	<"sfmin",	int_hexagon_F2_sfmin>;
def HEXAGON_F2_sfclass:
    qi_SInst_sfu5	<"sfclass",	int_hexagon_F2_sfclass>;
def HEXAGON_F2_sfimm_p:
    sf_ALU64_u10_pos	<"sfmake",	int_hexagon_F2_sfimm_p>;
def HEXAGON_F2_sfimm_n:
    sf_ALU64_u10_neg	<"sfmake",	int_hexagon_F2_sfimm_n>;
def HEXAGON_F2_sffixupn:
    sf_MInst_sfsf	<"sffixupn",	int_hexagon_F2_sffixupn>;
def HEXAGON_F2_sffixupd:
    sf_MInst_sfsf	<"sffixupd",	int_hexagon_F2_sffixupd>;
def HEXAGON_F2_sffixupr:
    sf_SInst_sf	<"sffixupr",	int_hexagon_F2_sffixupr>;
def HEXAGON_F2_dfadd:
    df_MInst_dfdf	<"dfadd",	int_hexagon_F2_dfadd>;
def HEXAGON_F2_dfsub:
    df_MInst_dfdf	<"dfsub",	int_hexagon_F2_dfsub>;
def HEXAGON_F2_dfmpy:
    df_MInst_dfdf	<"dfmpy",	int_hexagon_F2_dfmpy>;
def HEXAGON_F2_dffma:
    df_MInst_dfdfdf_acc	<"dfmpy",	int_hexagon_F2_dffma>;
def HEXAGON_F2_dffms:
    df_MInst_dfdfdf_nac	<"dfmpy",	int_hexagon_F2_dffms>;
def HEXAGON_F2_dffma_lib:
    df_MInst_dfdfdf_acc_lib	<"dfmpy",	int_hexagon_F2_dffma_lib>;
def HEXAGON_F2_dffms_lib:
    df_MInst_dfdfdf_nac_lib	<"dfmpy",	int_hexagon_F2_dffms_lib>;
def HEXAGON_F2_dffma_sc:
    df_MInst_dfdfdfsi_sc	<"dfmpy",	int_hexagon_F2_dffma_sc>;
def HEXAGON_F2_dfmax:
    df_MInst_dfdf	<"dfmax",	int_hexagon_F2_dfmax>;
def HEXAGON_F2_dfmin:
    df_MInst_dfdf	<"dfmin",	int_hexagon_F2_dfmin>;
def HEXAGON_F2_dfcmpeq:
    qi_ALU64_dfdf	<"dfcmp.eq",	int_hexagon_F2_dfcmpeq>;
def HEXAGON_F2_dfcmpgt:
    qi_ALU64_dfdf	<"dfcmp.gt",	int_hexagon_F2_dfcmpgt>;
def HEXAGON_F2_dfcmpge:
    qi_ALU64_dfdf	<"dfcmp.ge",	int_hexagon_F2_dfcmpge>;
def HEXAGON_F2_dfcmpuo:
    qi_ALU64_dfdf	<"dfcmp.uo",	int_hexagon_F2_dfcmpuo>;
def HEXAGON_F2_dfclass:
    qi_ALU64_dfu5	<"dfclass",	int_hexagon_F2_dfclass>;
def HEXAGON_F2_dfimm_p:
    df_ALU64_u10_pos	<"dfmake",	int_hexagon_F2_dfimm_p>;
def HEXAGON_F2_dfimm_n:
    df_ALU64_u10_neg	<"dfmake",	int_hexagon_F2_dfimm_n>;
def HEXAGON_F2_dffixupn:
    df_MInst_dfdf	<"dffixupn",	int_hexagon_F2_dffixupn>;
def HEXAGON_F2_dffixupd:
    df_MInst_dfdf	<"dffixupd",	int_hexagon_F2_dffixupd>;
def HEXAGON_F2_dffixupr:
    df_SInst_df	<"dffixupr",	int_hexagon_F2_dffixupr>;
def HEXAGON_F2_conv_sf2df:
    df_SInst_sf	<"convert_sf2df",	int_hexagon_F2_conv_sf2df>;
def HEXAGON_F2_conv_df2sf:
    sf_SInst_df	<"convert_df2sf",	int_hexagon_F2_conv_df2sf>;
def HEXAGON_F2_conv_uw2sf:
    sf_SInst_si	<"convert_uw2sf",	int_hexagon_F2_conv_uw2sf>;
def HEXAGON_F2_conv_uw2df:
    df_SInst_si	<"convert_uw2df",	int_hexagon_F2_conv_uw2df>;
def HEXAGON_F2_conv_w2sf:
    sf_SInst_si	<"convert_w2sf",	int_hexagon_F2_conv_w2sf>;
def HEXAGON_F2_conv_w2df:
    df_SInst_si	<"convert_w2df",	int_hexagon_F2_conv_w2df>;
def HEXAGON_F2_conv_ud2sf:
    sf_SInst_di	<"convert_ud2sf",	int_hexagon_F2_conv_ud2sf>;
def HEXAGON_F2_conv_ud2df:
    df_SInst_di	<"convert_ud2df",	int_hexagon_F2_conv_ud2df>;
def HEXAGON_F2_conv_d2sf:
    sf_SInst_di	<"convert_d2sf",	int_hexagon_F2_conv_d2sf>;
def HEXAGON_F2_conv_d2df:
    df_SInst_di	<"convert_d2df",	int_hexagon_F2_conv_d2df>;
def HEXAGON_F2_conv_sf2uw:
    si_SInst_sf	<"convert_sf2uw",	int_hexagon_F2_conv_sf2uw>;
def HEXAGON_F2_conv_sf2w:
    si_SInst_sf	<"convert_sf2w",	int_hexagon_F2_conv_sf2w>;
def HEXAGON_F2_conv_sf2ud:
    di_SInst_sf	<"convert_sf2ud",	int_hexagon_F2_conv_sf2ud>;
def HEXAGON_F2_conv_sf2d:
    di_SInst_sf	<"convert_sf2d",	int_hexagon_F2_conv_sf2d>;
def HEXAGON_F2_conv_df2uw:
    si_SInst_df	<"convert_df2uw",	int_hexagon_F2_conv_df2uw>;
def HEXAGON_F2_conv_df2w:
    si_SInst_df	<"convert_df2w",	int_hexagon_F2_conv_df2w>;
def HEXAGON_F2_conv_df2ud:
    di_SInst_df	<"convert_df2ud",	int_hexagon_F2_conv_df2ud>;
def HEXAGON_F2_conv_df2d:
    di_SInst_df	<"convert_df2d",	int_hexagon_F2_conv_df2d>;
def HEXAGON_F2_conv_sf2uw_chop:
    si_SInst_sf	<"convert_sf2uw",	int_hexagon_F2_conv_sf2uw_chop>;
def HEXAGON_F2_conv_sf2w_chop:
    si_SInst_sf	<"convert_sf2w",	int_hexagon_F2_conv_sf2w_chop>;
def HEXAGON_F2_conv_sf2ud_chop:
    di_SInst_sf	<"convert_sf2ud",	int_hexagon_F2_conv_sf2ud_chop>;
def HEXAGON_F2_conv_sf2d_chop:
    di_SInst_sf	<"convert_sf2d",	int_hexagon_F2_conv_sf2d_chop>;
def HEXAGON_F2_conv_df2uw_chop:
    si_SInst_df	<"convert_df2uw",	int_hexagon_F2_conv_df2uw_chop>;
def HEXAGON_F2_conv_df2w_chop:
    si_SInst_df	<"convert_df2w",	int_hexagon_F2_conv_df2w_chop>;
def HEXAGON_F2_conv_df2ud_chop:
    di_SInst_df	<"convert_df2ud",	int_hexagon_F2_conv_df2ud_chop>;
def HEXAGON_F2_conv_df2d_chop:
    di_SInst_df	<"convert_df2d",	int_hexagon_F2_conv_df2d_chop>;