77 : STI(ST), XLen(STI.getXLen()), sXLen(
LLT::scalar(XLen)) {
129 auto BoolVecTys = {nxv1s1, nxv2s1, nxv4s1, nxv8s1, nxv16s1, nxv32s1, nxv64s1};
131 auto IntOrFPVecTys = {nxv1s8, nxv2s8, nxv4s8, nxv8s8, nxv16s8, nxv32s8,
132 nxv64s8, nxv1s16, nxv2s16, nxv4s16, nxv8s16, nxv16s16,
133 nxv32s16, nxv1s32, nxv2s32, nxv4s32, nxv8s32, nxv16s32,
134 nxv1s64, nxv2s64, nxv4s64, nxv8s64};
136 auto PtrVecTys = {nxv1p0, nxv2p0, nxv4p0, nxv8p0, nxv16p0};
152 {G_UADDE, G_UADDO, G_USUBE, G_USUBO, G_READ_REGISTER, G_WRITE_REGISTER})
161 {G_UADDSAT, G_SADDSAT, G_USUBSAT, G_SSUBSAT, G_SSHLSAT, G_USHLSAT})
165 .legalFor({{sXLen, sXLen}})
166 .customFor(ST.is64Bit(), {{s32, s32}})
167 .widenScalarToNextPow2(0)
171 getActionDefinitionsBuilder({G_ZEXT, G_SEXT, G_ANYEXT})
172 .legalFor({{s32, s16}})
173 .legalFor(
ST.is64Bit(), {{s64, s16}, {s64, s32}})
179 getActionDefinitionsBuilder(G_TRUNC).
alwaysLegal();
181 getActionDefinitionsBuilder(G_SEXT_INREG)
183 .clampScalar(0, sXLen, sXLen)
187 for (
unsigned Op : {G_MERGE_VALUES, G_UNMERGE_VALUES}) {
188 auto &MergeUnmergeActions = getActionDefinitionsBuilder(
Op);
189 unsigned BigTyIdx =
Op == G_MERGE_VALUES ? 0 : 1;
190 unsigned LitTyIdx =
Op == G_MERGE_VALUES ? 1 : 0;
191 if (XLen == 32 &&
ST.hasStdExtD()) {
192 MergeUnmergeActions.legalIf(
195 MergeUnmergeActions.widenScalarToNextPow2(LitTyIdx, XLen)
196 .widenScalarToNextPow2(BigTyIdx, XLen)
197 .clampScalar(LitTyIdx, sXLen, sXLen)
198 .clampScalar(BigTyIdx, sXLen, sXLen);
201 getActionDefinitionsBuilder({G_FSHL, G_FSHR}).lower();
203 getActionDefinitionsBuilder({G_ROTR, G_ROTL})
204 .legalFor(
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb(), {{sXLen, sXLen}})
205 .customFor(
ST.is64Bit() && (
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb()),
209 getActionDefinitionsBuilder(G_BITREVERSE).maxScalar(0, sXLen).lower();
211 getActionDefinitionsBuilder(G_BITCAST).legalIf(
217 auto &BSWAPActions = getActionDefinitionsBuilder(G_BSWAP);
218 if (
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb())
219 BSWAPActions.legalFor({sXLen}).clampScalar(0, sXLen, sXLen);
221 BSWAPActions.maxScalar(0, sXLen).lower();
223 auto &CountZerosActions = getActionDefinitionsBuilder({G_CTLZ, G_CTTZ});
224 auto &CountZerosPoisonActions =
225 getActionDefinitionsBuilder({G_CTLZ_ZERO_POISON, G_CTTZ_ZERO_POISON});
226 if (
ST.hasStdExtZbb()) {
227 CountZerosActions.legalFor({{sXLen, sXLen}})
228 .customFor({{s32, s32}})
229 .clampScalar(0, s32, sXLen)
230 .widenScalarToNextPow2(0)
231 .scalarSameSizeAs(1, 0);
233 CountZerosActions.maxScalar(0, sXLen).scalarSameSizeAs(1, 0).lower();
234 CountZerosPoisonActions.maxScalar(0, sXLen).scalarSameSizeAs(1, 0);
236 CountZerosPoisonActions.lower();
238 auto &CountSignActions = getActionDefinitionsBuilder(G_CTLS);
239 if (
ST.hasStdExtP()) {
240 CountSignActions.legalFor({{sXLen, sXLen}})
241 .customFor({{s32, s32}})
242 .clampScalar(0, s32, sXLen)
243 .widenScalarToNextPow2(0)
244 .scalarSameSizeAs(1, 0);
246 CountSignActions.maxScalar(0, sXLen).scalarSameSizeAs(1, 0).lower();
249 auto &CTPOPActions = getActionDefinitionsBuilder(G_CTPOP);
250 if (
ST.hasStdExtZbb()) {
251 CTPOPActions.legalFor({{sXLen, sXLen}})
252 .clampScalar(0, sXLen, sXLen)
253 .scalarSameSizeAs(1, 0);
255 CTPOPActions.widenScalarToNextPow2(0, 8)
256 .clampScalar(0, s8, sXLen)
257 .scalarSameSizeAs(1, 0)
261 getActionDefinitionsBuilder(G_CONSTANT)
263 .legalFor(!
ST.is64Bit(), {s32})
264 .customFor(
ST.is64Bit(), {s64})
265 .widenScalarToNextPow2(0)
266 .clampScalar(0, sXLen, sXLen);
269 getActionDefinitionsBuilder(G_FREEZE)
270 .legalFor({s16, s32, p0})
271 .legalFor(
ST.is64Bit(), {s64})
274 .widenScalarToNextPow2(0)
275 .clampScalar(0, s16, sXLen);
279 getActionDefinitionsBuilder(
280 {G_IMPLICIT_DEF, G_CONSTANT_FOLD_BARRIER})
281 .legalFor({s32, sXLen, p0})
284 .widenScalarToNextPow2(0)
285 .clampScalar(0, s32, sXLen);
287 getActionDefinitionsBuilder(G_ICMP)
288 .legalFor({{sXLen, sXLen}, {sXLen, p0}})
291 .widenScalarOrEltToNextPow2OrMinSize(1, 8)
292 .clampScalar(1, sXLen, sXLen)
293 .clampScalar(0, sXLen, sXLen);
295 getActionDefinitionsBuilder(G_SELECT)
296 .legalFor({{s32, sXLen}, {p0, sXLen}})
299 .legalFor(XLen == 64 ||
ST.hasStdExtD(), {{s64, sXLen}})
300 .widenScalarToNextPow2(0)
301 .clampScalar(0, s32, (XLen == 64 ||
ST.hasStdExtD()) ? s64 : s32)
302 .clampScalar(1, sXLen, sXLen);
304 auto &LoadActions = getActionDefinitionsBuilder(G_LOAD);
305 auto &StoreActions = getActionDefinitionsBuilder(G_STORE);
306 auto &ExtLoadActions = getActionDefinitionsBuilder({G_SEXTLOAD, G_ZEXTLOAD});
311 auto getScalarMemAlign = [&
ST](
unsigned Size) {
312 return ST.enableUnalignedScalarMem() ? 8 :
Size;
315 LoadActions.legalForTypesWithMemDesc(
316 {{s16, p0, s8, getScalarMemAlign(8)},
317 {s32, p0, s8, getScalarMemAlign(8)},
318 {s16, p0, s16, getScalarMemAlign(16)},
319 {s32, p0, s16, getScalarMemAlign(16)},
320 {s32, p0, s32, getScalarMemAlign(32)},
321 {p0, p0, sXLen, getScalarMemAlign(XLen)}});
322 StoreActions.legalForTypesWithMemDesc(
323 {{s16, p0, s8, getScalarMemAlign(8)},
324 {s32, p0, s8, getScalarMemAlign(8)},
325 {s16, p0, s16, getScalarMemAlign(16)},
326 {s32, p0, s16, getScalarMemAlign(16)},
327 {s32, p0, s32, getScalarMemAlign(32)},
328 {p0, p0, sXLen, getScalarMemAlign(XLen)}});
329 ExtLoadActions.legalForTypesWithMemDesc(
330 {{sXLen, p0, s8, getScalarMemAlign(8)},
331 {sXLen, p0, s16, getScalarMemAlign(16)}});
333 LoadActions.legalForTypesWithMemDesc(
334 {{s64, p0, s8, getScalarMemAlign(8)},
335 {s64, p0, s16, getScalarMemAlign(16)},
336 {s64, p0, s32, getScalarMemAlign(32)},
337 {s64, p0, s64, getScalarMemAlign(64)}});
338 StoreActions.legalForTypesWithMemDesc(
339 {{s64, p0, s8, getScalarMemAlign(8)},
340 {s64, p0, s16, getScalarMemAlign(16)},
341 {s64, p0, s32, getScalarMemAlign(32)},
342 {s64, p0, s64, getScalarMemAlign(64)}});
343 ExtLoadActions.legalForTypesWithMemDesc(
344 {{s64, p0, s32, getScalarMemAlign(32)}});
345 }
else if (
ST.hasStdExtD()) {
346 LoadActions.legalForTypesWithMemDesc(
347 {{s64, p0, s64, getScalarMemAlign(64)}});
348 StoreActions.legalForTypesWithMemDesc(
349 {{s64, p0, s64, getScalarMemAlign(64)}});
353 if (
ST.hasVInstructions()) {
354 LoadActions.legalForTypesWithMemDesc({{nxv2s8, p0, nxv2s8, 8},
355 {nxv4s8, p0, nxv4s8, 8},
356 {nxv8s8, p0, nxv8s8, 8},
357 {nxv16s8, p0, nxv16s8, 8},
358 {nxv32s8, p0, nxv32s8, 8},
359 {nxv64s8, p0, nxv64s8, 8},
360 {nxv2s16, p0, nxv2s16, 16},
361 {nxv4s16, p0, nxv4s16, 16},
362 {nxv8s16, p0, nxv8s16, 16},
363 {nxv16s16, p0, nxv16s16, 16},
364 {nxv32s16, p0, nxv32s16, 16},
365 {nxv2s32, p0, nxv2s32, 32},
366 {nxv4s32, p0, nxv4s32, 32},
367 {nxv8s32, p0, nxv8s32, 32},
368 {nxv16s32, p0, nxv16s32, 32}});
369 StoreActions.legalForTypesWithMemDesc({{nxv2s8, p0, nxv2s8, 8},
370 {nxv4s8, p0, nxv4s8, 8},
371 {nxv8s8, p0, nxv8s8, 8},
372 {nxv16s8, p0, nxv16s8, 8},
373 {nxv32s8, p0, nxv32s8, 8},
374 {nxv64s8, p0, nxv64s8, 8},
375 {nxv2s16, p0, nxv2s16, 16},
376 {nxv4s16, p0, nxv4s16, 16},
377 {nxv8s16, p0, nxv8s16, 16},
378 {nxv16s16, p0, nxv16s16, 16},
379 {nxv32s16, p0, nxv32s16, 16},
380 {nxv2s32, p0, nxv2s32, 32},
381 {nxv4s32, p0, nxv4s32, 32},
382 {nxv8s32, p0, nxv8s32, 32},
383 {nxv16s32, p0, nxv16s32, 32}});
385 if (
ST.getELen() == 64) {
386 LoadActions.legalForTypesWithMemDesc({{nxv1s8, p0, nxv1s8, 8},
387 {nxv1s16, p0, nxv1s16, 16},
388 {nxv1s32, p0, nxv1s32, 32}});
389 StoreActions.legalForTypesWithMemDesc({{nxv1s8, p0, nxv1s8, 8},
390 {nxv1s16, p0, nxv1s16, 16},
391 {nxv1s32, p0, nxv1s32, 32}});
394 if (
ST.hasVInstructionsI64()) {
395 LoadActions.legalForTypesWithMemDesc({{nxv1s64, p0, nxv1s64, 64},
396 {nxv2s64, p0, nxv2s64, 64},
397 {nxv4s64, p0, nxv4s64, 64},
398 {nxv8s64, p0, nxv8s64, 64}});
399 StoreActions.legalForTypesWithMemDesc({{nxv1s64, p0, nxv1s64, 64},
400 {nxv2s64, p0, nxv2s64, 64},
401 {nxv4s64, p0, nxv4s64, 64},
402 {nxv8s64, p0, nxv8s64, 64}});
411 if (XLen <=
ST.getELen()) {
417 LoadActions.widenScalarToNextPow2(0, 8)
418 .lowerIfMemSizeNotByteSizePow2()
419 .clampScalar(0, s16, sXLen)
422 .clampScalar(0, s16, sXLen)
423 .lowerIfMemSizeNotByteSizePow2()
426 ExtLoadActions.widenScalarToNextPow2(0).clampScalar(0, sXLen, sXLen).lower();
428 getActionDefinitionsBuilder({G_PTR_ADD, G_PTRMASK}).legalFor({{p0, sXLen}});
430 getActionDefinitionsBuilder(G_PTRTOINT)
431 .legalFor({{sXLen, p0}})
432 .clampScalar(0, sXLen, sXLen);
434 getActionDefinitionsBuilder(G_INTTOPTR)
435 .legalFor({{p0, sXLen}})
436 .clampScalar(1, sXLen, sXLen);
438 getActionDefinitionsBuilder(G_BR).alwaysLegal();
440 getActionDefinitionsBuilder(G_BRCOND).legalFor({sXLen}).minScalar(0, sXLen);
442 getActionDefinitionsBuilder(G_BRJT).customFor({{p0, sXLen}});
444 getActionDefinitionsBuilder(G_BRINDIRECT).legalFor({p0});
446 getActionDefinitionsBuilder(G_PHI)
447 .legalFor({p0, s32, sXLen})
448 .widenScalarToNextPow2(0)
449 .clampScalar(0, s32, sXLen);
451 getActionDefinitionsBuilder({G_GLOBAL_VALUE, G_JUMP_TABLE, G_CONSTANT_POOL})
454 if (
ST.hasStdExtZmmul()) {
455 getActionDefinitionsBuilder(G_MUL)
457 .widenScalarToNextPow2(0)
458 .clampScalar(0, sXLen, sXLen);
461 getActionDefinitionsBuilder({G_SMULH, G_UMULH})
466 getActionDefinitionsBuilder({G_SMULO, G_UMULO}).minScalar(0, sXLen).lower();
468 getActionDefinitionsBuilder(G_MUL)
469 .libcallFor({sXLen, sDoubleXLen})
470 .widenScalarToNextPow2(0)
471 .clampScalar(0, sXLen, sDoubleXLen);
473 getActionDefinitionsBuilder({G_SMULH, G_UMULH}).lowerFor({sXLen});
475 getActionDefinitionsBuilder({G_SMULO, G_UMULO})
480 .widenScalarIf(
typeIs(0, sXLen),
485 if (
ST.hasStdExtM()) {
486 getActionDefinitionsBuilder({G_SDIV, G_UDIV, G_UREM})
489 .libcallFor({sDoubleXLen})
490 .clampScalar(0, s32, sDoubleXLen)
491 .widenScalarToNextPow2(0);
492 getActionDefinitionsBuilder(G_SREM)
494 .libcallFor({sDoubleXLen})
495 .clampScalar(0, sXLen, sDoubleXLen)
496 .widenScalarToNextPow2(0);
498 getActionDefinitionsBuilder({G_UDIV, G_SDIV, G_UREM, G_SREM})
499 .libcallFor({sXLen, sDoubleXLen})
500 .clampScalar(0, sXLen, sDoubleXLen)
501 .widenScalarToNextPow2(0);
505 getActionDefinitionsBuilder({G_SDIVREM, G_UDIVREM}).lower();
507 getActionDefinitionsBuilder(G_ABS)
508 .customFor(
ST.hasStdExtZbb(), {sXLen})
509 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
512 getActionDefinitionsBuilder({G_ABDS, G_ABDU})
513 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
516 getActionDefinitionsBuilder({G_UMAX, G_UMIN, G_SMAX, G_SMIN})
517 .legalFor(
ST.hasStdExtZbb(), {sXLen})
518 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
521 getActionDefinitionsBuilder({G_SCMP, G_UCMP}).lower();
523 getActionDefinitionsBuilder(G_FRAME_INDEX).legalFor({p0});
525 getActionDefinitionsBuilder({G_MEMCPY, G_MEMMOVE, G_MEMSET}).
libcall();
527 getActionDefinitionsBuilder(G_MEMCPY_INLINE).lower();
529 getActionDefinitionsBuilder({G_DYN_STACKALLOC, G_STACKSAVE, G_STACKRESTORE})
535 getActionDefinitionsBuilder({G_FADD, G_FSUB, G_FMUL, G_FDIV, G_FMA, G_FSQRT,
536 G_FMAXNUM, G_FMINNUM, G_FMAXIMUMNUM,
538 .legalFor(
ST.hasStdExtF(), {s32})
539 .legalFor(
ST.hasStdExtD(), {s64})
540 .legalFor(
ST.hasStdExtZfh(), {s16})
541 .libcallFor({s32, s64})
542 .libcallFor(
ST.is64Bit(), {s128});
544 getActionDefinitionsBuilder({G_FNEG, G_FABS})
545 .legalFor(
ST.hasStdExtF(), {s32})
546 .legalFor(
ST.hasStdExtD(), {s64})
547 .legalFor(
ST.hasStdExtZfh(), {s16})
548 .lowerFor({s32, s64, s128});
550 getActionDefinitionsBuilder(G_FREM)
551 .libcallFor({s32, s64})
552 .libcallFor(
ST.is64Bit(), {s128})
556 getActionDefinitionsBuilder(G_FCOPYSIGN)
557 .legalFor(
ST.hasStdExtF(), {{s32, s32}})
558 .legalFor(
ST.hasStdExtD(), {{s64, s64}, {s32, s64}, {s64, s32}})
559 .legalFor(
ST.hasStdExtZfh(), {{s16, s16}, {s16, s32}, {s32, s16}})
560 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s16, s64}, {s64, s16}})
564 getActionDefinitionsBuilder(G_FPTRUNC)
565 .legalFor(
ST.hasStdExtD(), {{s32, s64}})
566 .legalFor(
ST.hasStdExtZfh(), {{s16, s32}})
567 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s16, s64}})
568 .libcallFor({{s32, s64}})
569 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}});
570 getActionDefinitionsBuilder(G_FPEXT)
571 .legalFor(
ST.hasStdExtD(), {{s64, s32}})
572 .legalFor(
ST.hasStdExtZfh(), {{s32, s16}})
573 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s64, s16}})
574 .libcallFor({{s64, s32}})
575 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}});
577 getActionDefinitionsBuilder(G_FCMP)
578 .legalFor(
ST.hasStdExtF(), {{sXLen, s32}})
579 .legalFor(
ST.hasStdExtD(), {{sXLen, s64}})
580 .legalFor(
ST.hasStdExtZfh(), {{sXLen, s16}})
581 .clampScalar(0, sXLen, sXLen)
582 .libcallFor({{sXLen, s32}, {sXLen, s64}})
583 .libcallFor(
ST.is64Bit(), {{sXLen, s128}});
586 getActionDefinitionsBuilder(G_IS_FPCLASS)
587 .customFor(
ST.hasStdExtF(), {{s1, s32}})
588 .customFor(
ST.hasStdExtD(), {{s1, s64}})
589 .customFor(
ST.hasStdExtZfh(), {{s1, s16}})
592 getActionDefinitionsBuilder(G_FCONSTANT)
593 .legalFor(
ST.hasStdExtF(), {s32})
594 .legalFor(
ST.hasStdExtD(), {s64})
595 .legalFor(
ST.hasStdExtZfh(), {s16})
596 .customFor(!
ST.is64Bit(), {s32})
597 .customFor(
ST.is64Bit(), {s32, s64})
598 .lowerFor({s64, s128});
600 getActionDefinitionsBuilder({G_FPTOSI, G_FPTOUI})
601 .legalFor(
ST.hasStdExtF(), {{sXLen, s32}})
602 .legalFor(
ST.hasStdExtD(), {{sXLen, s64}})
603 .legalFor(
ST.hasStdExtZfh(), {{sXLen, s16}})
604 .customFor(
ST.is64Bit() &&
ST.hasStdExtF(), {{s32, s32}})
605 .customFor(
ST.is64Bit() &&
ST.hasStdExtD(), {{s32, s64}})
606 .customFor(
ST.is64Bit() &&
ST.hasStdExtZfh(), {{s32, s16}})
607 .widenScalarToNextPow2(0)
609 .libcallFor({{s32, s32}, {s64, s32}, {s32, s64}, {s64, s64}})
610 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}})
611 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}, {s128, s128}});
613 getActionDefinitionsBuilder({G_SITOFP, G_UITOFP})
614 .legalFor(
ST.hasStdExtF(), {{s32, sXLen}})
615 .legalFor(
ST.hasStdExtD(), {{s64, sXLen}})
616 .legalFor(
ST.hasStdExtZfh(), {{s16, sXLen}})
617 .widenScalarToNextPow2(1)
621 return Query.
Types[0].isScalar() && Query.
Types[1].isScalar() &&
622 (Query.
Types[1].getSizeInBits() <
ST.getXLen()) &&
623 ((
ST.hasStdExtF() && Query.
Types[0].getSizeInBits() == 32) ||
624 (
ST.hasStdExtD() && Query.
Types[0].getSizeInBits() == 64) ||
625 (
ST.hasStdExtZfh() &&
626 Query.
Types[0].getSizeInBits() == 16));
631 .libcallFor({{s32, s32}, {s64, s32}, {s32, s64}, {s64, s64}})
632 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}})
633 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}, {s128, s128}});
636 getActionDefinitionsBuilder({G_FCEIL, G_FFLOOR, G_FRINT, G_FNEARBYINT,
637 G_INTRINSIC_TRUNC, G_INTRINSIC_ROUND,
638 G_INTRINSIC_ROUNDEVEN})
639 .legalFor(
ST.hasStdExtZfa(), {s32})
640 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtD(), {s64})
641 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtZfh(), {s16})
642 .libcallFor({s32, s64})
643 .libcallFor(
ST.is64Bit(), {s128});
645 getActionDefinitionsBuilder({G_FMAXIMUM, G_FMINIMUM})
646 .legalFor(
ST.hasStdExtZfa(), {s32})
647 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtD(), {s64})
648 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtZfh(), {s16});
650 getActionDefinitionsBuilder({G_FCOS, G_FSIN, G_FTAN, G_FPOW, G_FLOG, G_FLOG2,
651 G_FLOG10, G_FEXP, G_FEXP2, G_FEXP10, G_FACOS,
652 G_FASIN, G_FATAN, G_FATAN2, G_FCOSH, G_FSINH,
654 .libcallFor({s32, s64})
655 .libcallFor(
ST.is64Bit(), {s128});
656 getActionDefinitionsBuilder({G_FPOWI, G_FLDEXP})
657 .libcallFor({{s32, s32}, {s64, s32}})
658 .libcallFor(
ST.is64Bit(), {s128, s32});
660 getActionDefinitionsBuilder(G_FCANONICALIZE)
661 .legalFor(
ST.hasStdExtF(), {s32})
662 .legalFor(
ST.hasStdExtD(), {s64})
663 .legalFor(
ST.hasStdExtZfh(), {s16});
665 getActionDefinitionsBuilder(G_VASTART).customFor({p0});
669 getActionDefinitionsBuilder(G_VAARG)
672 .clampScalar(0, sXLen, sXLen)
673 .lowerForCartesianProduct({sXLen, p0}, {p0});
675 getActionDefinitionsBuilder(G_VSCALE)
676 .clampScalar(0, sXLen, sXLen)
680 getActionDefinitionsBuilder(G_SPLAT_VECTOR)
692 if (
ST.hasVInstructionsF64() &&
ST.hasStdExtD())
693 SplatActions.legalIf(
all(
695 else if (
ST.hasVInstructionsI64())
696 SplatActions.customIf(
all(
700 SplatActions.clampScalar(1, sXLen, sXLen);
709 getActionDefinitionsBuilder(G_EXTRACT_SUBVECTOR)
718 Query.
Types[0].getElementCount().divideCoefficientBy(8), 8);
719 return std::pair(0, CastTy);
727 getActionDefinitionsBuilder(G_INSERT_SUBVECTOR)
733 getActionDefinitionsBuilder(G_ATOMIC_CMPXCHG_WITH_SUCCESS)
736 getActionDefinitionsBuilder({G_ATOMIC_CMPXCHG, G_ATOMICRMW_ADD})
737 .legalFor(
ST.hasStdExtA(), {{sXLen, p0}})
738 .libcallFor(!
ST.hasStdExtA(), {{s8, p0}, {s16, p0}, {s32, p0}, {s64, p0}})
739 .clampScalar(0, sXLen, sXLen);
741 getActionDefinitionsBuilder(G_ATOMICRMW_SUB)
742 .libcallFor(!
ST.hasStdExtA(), {{s8, p0}, {s16, p0}, {s32, p0}, {s64, p0}})
743 .clampScalar(0, sXLen, sXLen)
752 getActionDefinitionsBuilder(G_INSERT_VECTOR_ELT)
754 InsertVectorEltPred,
typeIs(2, sXLen)))
758 getActionDefinitionsBuilder({G_INTRINSIC, G_INTRINSIC_W_SIDE_EFFECTS})
761 getActionDefinitionsBuilder(G_FENCE).alwaysLegal();
763 getActionDefinitionsBuilder({G_TRAP, G_DEBUGTRAP, G_UBSANTRAP}).alwaysLegal();
765 getLegacyLegalizerInfo().computeTables();