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_SEXT_INREG)
181 .clampScalar(0, sXLen, sXLen)
185 for (
unsigned Op : {G_MERGE_VALUES, G_UNMERGE_VALUES}) {
186 auto &MergeUnmergeActions = getActionDefinitionsBuilder(
Op);
187 unsigned BigTyIdx =
Op == G_MERGE_VALUES ? 0 : 1;
188 unsigned LitTyIdx =
Op == G_MERGE_VALUES ? 1 : 0;
189 if (XLen == 32 &&
ST.hasStdExtD()) {
190 MergeUnmergeActions.legalIf(
193 MergeUnmergeActions.widenScalarToNextPow2(LitTyIdx, XLen)
194 .widenScalarToNextPow2(BigTyIdx, XLen)
195 .clampScalar(LitTyIdx, sXLen, sXLen)
196 .clampScalar(BigTyIdx, sXLen, sXLen);
199 getActionDefinitionsBuilder({G_FSHL, G_FSHR}).lower();
201 getActionDefinitionsBuilder({G_ROTR, G_ROTL})
202 .legalFor(
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb(), {{sXLen, sXLen}})
203 .customFor(
ST.is64Bit() && (
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb()),
207 getActionDefinitionsBuilder(G_BITREVERSE).maxScalar(0, sXLen).lower();
209 getActionDefinitionsBuilder(G_BITCAST).legalIf(
215 auto &BSWAPActions = getActionDefinitionsBuilder(G_BSWAP);
216 if (
ST.hasStdExtZbb() ||
ST.hasStdExtZbkb())
217 BSWAPActions.legalFor({sXLen}).clampScalar(0, sXLen, sXLen);
219 BSWAPActions.maxScalar(0, sXLen).lower();
221 auto &CountZerosActions = getActionDefinitionsBuilder({G_CTLZ, G_CTTZ});
222 auto &CountZerosUndefActions =
223 getActionDefinitionsBuilder({G_CTLZ_ZERO_UNDEF, G_CTTZ_ZERO_UNDEF});
224 if (
ST.hasStdExtZbb()) {
225 CountZerosActions.legalFor({{sXLen, sXLen}})
226 .customFor({{s32, s32}})
227 .clampScalar(0, s32, sXLen)
228 .widenScalarToNextPow2(0)
229 .scalarSameSizeAs(1, 0);
231 CountZerosActions.maxScalar(0, sXLen).scalarSameSizeAs(1, 0).lower();
232 CountZerosUndefActions.maxScalar(0, sXLen).scalarSameSizeAs(1, 0);
234 CountZerosUndefActions.lower();
236 auto &CTPOPActions = getActionDefinitionsBuilder(G_CTPOP);
237 if (
ST.hasStdExtZbb()) {
238 CTPOPActions.legalFor({{sXLen, sXLen}})
239 .clampScalar(0, sXLen, sXLen)
240 .scalarSameSizeAs(1, 0);
242 CTPOPActions.widenScalarToNextPow2(0, 8)
243 .clampScalar(0, s8, sXLen)
244 .scalarSameSizeAs(1, 0)
248 getActionDefinitionsBuilder(G_CONSTANT)
250 .legalFor(!
ST.is64Bit(), {s32})
251 .customFor(
ST.is64Bit(), {s64})
252 .widenScalarToNextPow2(0)
253 .clampScalar(0, sXLen, sXLen);
256 getActionDefinitionsBuilder(G_FREEZE)
257 .legalFor({s16, s32, p0})
258 .legalFor(
ST.is64Bit(), {s64})
261 .widenScalarToNextPow2(0)
262 .clampScalar(0, s16, sXLen);
266 getActionDefinitionsBuilder(
267 {G_IMPLICIT_DEF, G_CONSTANT_FOLD_BARRIER})
268 .legalFor({s32, sXLen, p0})
271 .widenScalarToNextPow2(0)
272 .clampScalar(0, s32, sXLen);
274 getActionDefinitionsBuilder(G_ICMP)
275 .legalFor({{sXLen, sXLen}, {sXLen, p0}})
278 .widenScalarOrEltToNextPow2OrMinSize(1, 8)
279 .clampScalar(1, sXLen, sXLen)
280 .clampScalar(0, sXLen, sXLen);
282 getActionDefinitionsBuilder(G_SELECT)
283 .legalFor({{s32, sXLen}, {p0, sXLen}})
286 .legalFor(XLen == 64 ||
ST.hasStdExtD(), {{s64, sXLen}})
287 .widenScalarToNextPow2(0)
288 .clampScalar(0, s32, (XLen == 64 ||
ST.hasStdExtD()) ? s64 : s32)
289 .clampScalar(1, sXLen, sXLen);
291 auto &LoadActions = getActionDefinitionsBuilder(G_LOAD);
292 auto &StoreActions = getActionDefinitionsBuilder(G_STORE);
293 auto &ExtLoadActions = getActionDefinitionsBuilder({G_SEXTLOAD, G_ZEXTLOAD});
298 auto getScalarMemAlign = [&
ST](
unsigned Size) {
299 return ST.enableUnalignedScalarMem() ? 8 :
Size;
302 LoadActions.legalForTypesWithMemDesc(
303 {{s16, p0, s8, getScalarMemAlign(8)},
304 {s32, p0, s8, getScalarMemAlign(8)},
305 {s16, p0, s16, getScalarMemAlign(16)},
306 {s32, p0, s16, getScalarMemAlign(16)},
307 {s32, p0, s32, getScalarMemAlign(32)},
308 {p0, p0, sXLen, getScalarMemAlign(XLen)}});
309 StoreActions.legalForTypesWithMemDesc(
310 {{s16, p0, s8, getScalarMemAlign(8)},
311 {s32, p0, s8, getScalarMemAlign(8)},
312 {s16, p0, s16, getScalarMemAlign(16)},
313 {s32, p0, s16, getScalarMemAlign(16)},
314 {s32, p0, s32, getScalarMemAlign(32)},
315 {p0, p0, sXLen, getScalarMemAlign(XLen)}});
316 ExtLoadActions.legalForTypesWithMemDesc(
317 {{sXLen, p0, s8, getScalarMemAlign(8)},
318 {sXLen, p0, s16, getScalarMemAlign(16)}});
320 LoadActions.legalForTypesWithMemDesc(
321 {{s64, p0, s8, getScalarMemAlign(8)},
322 {s64, p0, s16, getScalarMemAlign(16)},
323 {s64, p0, s32, getScalarMemAlign(32)},
324 {s64, p0, s64, getScalarMemAlign(64)}});
325 StoreActions.legalForTypesWithMemDesc(
326 {{s64, p0, s8, getScalarMemAlign(8)},
327 {s64, p0, s16, getScalarMemAlign(16)},
328 {s64, p0, s32, getScalarMemAlign(32)},
329 {s64, p0, s64, getScalarMemAlign(64)}});
330 ExtLoadActions.legalForTypesWithMemDesc(
331 {{s64, p0, s32, getScalarMemAlign(32)}});
332 }
else if (
ST.hasStdExtD()) {
333 LoadActions.legalForTypesWithMemDesc(
334 {{s64, p0, s64, getScalarMemAlign(64)}});
335 StoreActions.legalForTypesWithMemDesc(
336 {{s64, p0, s64, getScalarMemAlign(64)}});
340 if (
ST.hasVInstructions()) {
341 LoadActions.legalForTypesWithMemDesc({{nxv2s8, p0, nxv2s8, 8},
342 {nxv4s8, p0, nxv4s8, 8},
343 {nxv8s8, p0, nxv8s8, 8},
344 {nxv16s8, p0, nxv16s8, 8},
345 {nxv32s8, p0, nxv32s8, 8},
346 {nxv64s8, p0, nxv64s8, 8},
347 {nxv2s16, p0, nxv2s16, 16},
348 {nxv4s16, p0, nxv4s16, 16},
349 {nxv8s16, p0, nxv8s16, 16},
350 {nxv16s16, p0, nxv16s16, 16},
351 {nxv32s16, p0, nxv32s16, 16},
352 {nxv2s32, p0, nxv2s32, 32},
353 {nxv4s32, p0, nxv4s32, 32},
354 {nxv8s32, p0, nxv8s32, 32},
355 {nxv16s32, p0, nxv16s32, 32}});
356 StoreActions.legalForTypesWithMemDesc({{nxv2s8, p0, nxv2s8, 8},
357 {nxv4s8, p0, nxv4s8, 8},
358 {nxv8s8, p0, nxv8s8, 8},
359 {nxv16s8, p0, nxv16s8, 8},
360 {nxv32s8, p0, nxv32s8, 8},
361 {nxv64s8, p0, nxv64s8, 8},
362 {nxv2s16, p0, nxv2s16, 16},
363 {nxv4s16, p0, nxv4s16, 16},
364 {nxv8s16, p0, nxv8s16, 16},
365 {nxv16s16, p0, nxv16s16, 16},
366 {nxv32s16, p0, nxv32s16, 16},
367 {nxv2s32, p0, nxv2s32, 32},
368 {nxv4s32, p0, nxv4s32, 32},
369 {nxv8s32, p0, nxv8s32, 32},
370 {nxv16s32, p0, nxv16s32, 32}});
372 if (
ST.getELen() == 64) {
373 LoadActions.legalForTypesWithMemDesc({{nxv1s8, p0, nxv1s8, 8},
374 {nxv1s16, p0, nxv1s16, 16},
375 {nxv1s32, p0, nxv1s32, 32}});
376 StoreActions.legalForTypesWithMemDesc({{nxv1s8, p0, nxv1s8, 8},
377 {nxv1s16, p0, nxv1s16, 16},
378 {nxv1s32, p0, nxv1s32, 32}});
381 if (
ST.hasVInstructionsI64()) {
382 LoadActions.legalForTypesWithMemDesc({{nxv1s64, p0, nxv1s64, 64},
383 {nxv2s64, p0, nxv2s64, 64},
384 {nxv4s64, p0, nxv4s64, 64},
385 {nxv8s64, p0, nxv8s64, 64}});
386 StoreActions.legalForTypesWithMemDesc({{nxv1s64, p0, nxv1s64, 64},
387 {nxv2s64, p0, nxv2s64, 64},
388 {nxv4s64, p0, nxv4s64, 64},
389 {nxv8s64, p0, nxv8s64, 64}});
398 if (XLen <=
ST.getELen()) {
404 LoadActions.widenScalarToNextPow2(0, 8)
405 .lowerIfMemSizeNotByteSizePow2()
406 .clampScalar(0, s16, sXLen)
409 .clampScalar(0, s16, sXLen)
410 .lowerIfMemSizeNotByteSizePow2()
413 ExtLoadActions.widenScalarToNextPow2(0).clampScalar(0, sXLen, sXLen).lower();
415 getActionDefinitionsBuilder({G_PTR_ADD, G_PTRMASK}).legalFor({{p0, sXLen}});
417 getActionDefinitionsBuilder(G_PTRTOINT)
418 .legalFor({{sXLen, p0}})
419 .clampScalar(0, sXLen, sXLen);
421 getActionDefinitionsBuilder(G_INTTOPTR)
422 .legalFor({{p0, sXLen}})
423 .clampScalar(1, sXLen, sXLen);
425 getActionDefinitionsBuilder(G_BRCOND).legalFor({sXLen}).minScalar(0, sXLen);
427 getActionDefinitionsBuilder(G_BRJT).customFor({{p0, sXLen}});
429 getActionDefinitionsBuilder(G_BRINDIRECT).legalFor({p0});
431 getActionDefinitionsBuilder(G_PHI)
432 .legalFor({p0, s32, sXLen})
433 .widenScalarToNextPow2(0)
434 .clampScalar(0, s32, sXLen);
436 getActionDefinitionsBuilder({G_GLOBAL_VALUE, G_JUMP_TABLE, G_CONSTANT_POOL})
439 if (
ST.hasStdExtZmmul()) {
440 getActionDefinitionsBuilder(G_MUL)
442 .widenScalarToNextPow2(0)
443 .clampScalar(0, sXLen, sXLen);
446 getActionDefinitionsBuilder({G_SMULH, G_UMULH})
451 getActionDefinitionsBuilder({G_SMULO, G_UMULO}).minScalar(0, sXLen).lower();
453 getActionDefinitionsBuilder(G_MUL)
454 .libcallFor({sXLen, sDoubleXLen})
455 .widenScalarToNextPow2(0)
456 .clampScalar(0, sXLen, sDoubleXLen);
458 getActionDefinitionsBuilder({G_SMULH, G_UMULH}).lowerFor({sXLen});
460 getActionDefinitionsBuilder({G_SMULO, G_UMULO})
465 .widenScalarIf(
typeIs(0, sXLen),
470 if (
ST.hasStdExtM()) {
471 getActionDefinitionsBuilder({G_SDIV, G_UDIV, G_UREM})
474 .libcallFor({sDoubleXLen})
475 .clampScalar(0, s32, sDoubleXLen)
476 .widenScalarToNextPow2(0);
477 getActionDefinitionsBuilder(G_SREM)
479 .libcallFor({sDoubleXLen})
480 .clampScalar(0, sXLen, sDoubleXLen)
481 .widenScalarToNextPow2(0);
483 getActionDefinitionsBuilder({G_UDIV, G_SDIV, G_UREM, G_SREM})
484 .libcallFor({sXLen, sDoubleXLen})
485 .clampScalar(0, sXLen, sDoubleXLen)
486 .widenScalarToNextPow2(0);
490 getActionDefinitionsBuilder({G_SDIVREM, G_UDIVREM}).lower();
492 getActionDefinitionsBuilder(G_ABS)
493 .customFor(
ST.hasStdExtZbb(), {sXLen})
494 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
497 getActionDefinitionsBuilder({G_ABDS, G_ABDU})
498 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
501 getActionDefinitionsBuilder({G_UMAX, G_UMIN, G_SMAX, G_SMIN})
502 .legalFor(
ST.hasStdExtZbb(), {sXLen})
503 .minScalar(
ST.hasStdExtZbb(), 0, sXLen)
506 getActionDefinitionsBuilder({G_SCMP, G_UCMP}).lower();
508 getActionDefinitionsBuilder(G_FRAME_INDEX).legalFor({p0});
510 getActionDefinitionsBuilder({G_MEMCPY, G_MEMMOVE, G_MEMSET}).
libcall();
512 getActionDefinitionsBuilder({G_DYN_STACKALLOC, G_STACKSAVE, G_STACKRESTORE})
518 getActionDefinitionsBuilder({G_FADD, G_FSUB, G_FMUL, G_FDIV, G_FMA, G_FSQRT,
519 G_FMAXNUM, G_FMINNUM, G_FMAXIMUMNUM,
521 .legalFor(
ST.hasStdExtF(), {s32})
522 .legalFor(
ST.hasStdExtD(), {s64})
523 .legalFor(
ST.hasStdExtZfh(), {s16})
524 .libcallFor({s32, s64})
525 .libcallFor(
ST.is64Bit(), {s128});
527 getActionDefinitionsBuilder({G_FNEG, G_FABS})
528 .legalFor(
ST.hasStdExtF(), {s32})
529 .legalFor(
ST.hasStdExtD(), {s64})
530 .legalFor(
ST.hasStdExtZfh(), {s16})
531 .lowerFor({s32, s64, s128});
533 getActionDefinitionsBuilder(G_FREM)
534 .libcallFor({s32, s64})
535 .libcallFor(
ST.is64Bit(), {s128})
539 getActionDefinitionsBuilder(G_FCOPYSIGN)
540 .legalFor(
ST.hasStdExtF(), {{s32, s32}})
541 .legalFor(
ST.hasStdExtD(), {{s64, s64}, {s32, s64}, {s64, s32}})
542 .legalFor(
ST.hasStdExtZfh(), {{s16, s16}, {s16, s32}, {s32, s16}})
543 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s16, s64}, {s64, s16}})
547 getActionDefinitionsBuilder(G_FPTRUNC)
548 .legalFor(
ST.hasStdExtD(), {{s32, s64}})
549 .legalFor(
ST.hasStdExtZfh(), {{s16, s32}})
550 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s16, s64}})
551 .libcallFor({{s32, s64}})
552 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}});
553 getActionDefinitionsBuilder(G_FPEXT)
554 .legalFor(
ST.hasStdExtD(), {{s64, s32}})
555 .legalFor(
ST.hasStdExtZfh(), {{s32, s16}})
556 .legalFor(
ST.hasStdExtZfh() &&
ST.hasStdExtD(), {{s64, s16}})
557 .libcallFor({{s64, s32}})
558 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}});
560 getActionDefinitionsBuilder(G_FCMP)
561 .legalFor(
ST.hasStdExtF(), {{sXLen, s32}})
562 .legalFor(
ST.hasStdExtD(), {{sXLen, s64}})
563 .legalFor(
ST.hasStdExtZfh(), {{sXLen, s16}})
564 .clampScalar(0, sXLen, sXLen)
565 .libcallFor({{sXLen, s32}, {sXLen, s64}})
566 .libcallFor(
ST.is64Bit(), {{sXLen, s128}});
569 getActionDefinitionsBuilder(G_IS_FPCLASS)
570 .customFor(
ST.hasStdExtF(), {{s1, s32}})
571 .customFor(
ST.hasStdExtD(), {{s1, s64}})
572 .customFor(
ST.hasStdExtZfh(), {{s1, s16}})
573 .lowerFor({{s1, s32}, {s1, s64}});
575 getActionDefinitionsBuilder(G_FCONSTANT)
576 .legalFor(
ST.hasStdExtF(), {s32})
577 .legalFor(
ST.hasStdExtD(), {s64})
578 .legalFor(
ST.hasStdExtZfh(), {s16})
579 .customFor(!
ST.is64Bit(), {s32})
580 .customFor(
ST.is64Bit(), {s32, s64})
581 .lowerFor({s64, s128});
583 getActionDefinitionsBuilder({G_FPTOSI, G_FPTOUI})
584 .legalFor(
ST.hasStdExtF(), {{sXLen, s32}})
585 .legalFor(
ST.hasStdExtD(), {{sXLen, s64}})
586 .legalFor(
ST.hasStdExtZfh(), {{sXLen, s16}})
587 .customFor(
ST.is64Bit() &&
ST.hasStdExtF(), {{s32, s32}})
588 .customFor(
ST.is64Bit() &&
ST.hasStdExtD(), {{s32, s64}})
589 .customFor(
ST.is64Bit() &&
ST.hasStdExtZfh(), {{s32, s16}})
590 .widenScalarToNextPow2(0)
592 .libcallFor({{s32, s32}, {s64, s32}, {s32, s64}, {s64, s64}})
593 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}})
594 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}, {s128, s128}});
596 getActionDefinitionsBuilder({G_SITOFP, G_UITOFP})
597 .legalFor(
ST.hasStdExtF(), {{s32, sXLen}})
598 .legalFor(
ST.hasStdExtD(), {{s64, sXLen}})
599 .legalFor(
ST.hasStdExtZfh(), {{s16, sXLen}})
600 .widenScalarToNextPow2(1)
604 return Query.
Types[0].isScalar() && Query.
Types[1].isScalar() &&
605 (Query.
Types[1].getSizeInBits() <
ST.getXLen()) &&
606 ((
ST.hasStdExtF() && Query.
Types[0].getSizeInBits() == 32) ||
607 (
ST.hasStdExtD() && Query.
Types[0].getSizeInBits() == 64) ||
608 (
ST.hasStdExtZfh() &&
609 Query.
Types[0].getSizeInBits() == 16));
614 .libcallFor({{s32, s32}, {s64, s32}, {s32, s64}, {s64, s64}})
615 .libcallFor(
ST.is64Bit(), {{s128, s32}, {s128, s64}})
616 .libcallFor(
ST.is64Bit(), {{s32, s128}, {s64, s128}, {s128, s128}});
619 getActionDefinitionsBuilder({G_FCEIL, G_FFLOOR, G_FRINT, G_FNEARBYINT,
620 G_INTRINSIC_TRUNC, G_INTRINSIC_ROUND,
621 G_INTRINSIC_ROUNDEVEN})
622 .legalFor(
ST.hasStdExtZfa(), {s32})
623 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtD(), {s64})
624 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtZfh(), {s16})
625 .libcallFor({s32, s64})
626 .libcallFor(
ST.is64Bit(), {s128});
628 getActionDefinitionsBuilder({G_FMAXIMUM, G_FMINIMUM})
629 .legalFor(
ST.hasStdExtZfa(), {s32})
630 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtD(), {s64})
631 .legalFor(
ST.hasStdExtZfa() &&
ST.hasStdExtZfh(), {s16});
633 getActionDefinitionsBuilder({G_FCOS, G_FSIN, G_FTAN, G_FPOW, G_FLOG, G_FLOG2,
634 G_FLOG10, G_FEXP, G_FEXP2, G_FEXP10, G_FACOS,
635 G_FASIN, G_FATAN, G_FATAN2, G_FCOSH, G_FSINH,
637 .libcallFor({s32, s64})
638 .libcallFor(
ST.is64Bit(), {s128});
639 getActionDefinitionsBuilder({G_FPOWI, G_FLDEXP})
640 .libcallFor({{s32, s32}, {s64, s32}})
641 .libcallFor(
ST.is64Bit(), {s128, s32});
643 getActionDefinitionsBuilder(G_FCANONICALIZE)
644 .legalFor(
ST.hasStdExtF(), {s32})
645 .legalFor(
ST.hasStdExtD(), {s64})
646 .legalFor(
ST.hasStdExtZfh(), {s16});
648 getActionDefinitionsBuilder(G_VASTART).customFor({p0});
652 getActionDefinitionsBuilder(G_VAARG)
655 .clampScalar(0, sXLen, sXLen)
656 .lowerForCartesianProduct({sXLen, p0}, {p0});
658 getActionDefinitionsBuilder(G_VSCALE)
659 .clampScalar(0, sXLen, sXLen)
663 getActionDefinitionsBuilder(G_SPLAT_VECTOR)
675 if (
ST.hasVInstructionsF64() &&
ST.hasStdExtD())
676 SplatActions.legalIf(
all(
678 else if (
ST.hasVInstructionsI64())
679 SplatActions.customIf(
all(
683 SplatActions.clampScalar(1, sXLen, sXLen);
692 getActionDefinitionsBuilder(G_EXTRACT_SUBVECTOR)
701 Query.
Types[0].getElementCount().divideCoefficientBy(8), 8);
702 return std::pair(0, CastTy);
710 getActionDefinitionsBuilder(G_INSERT_SUBVECTOR)
716 getActionDefinitionsBuilder(G_ATOMIC_CMPXCHG_WITH_SUCCESS)
719 getActionDefinitionsBuilder({G_ATOMIC_CMPXCHG, G_ATOMICRMW_ADD})
720 .legalFor(
ST.hasStdExtA(), {{sXLen, p0}})
721 .libcallFor(!
ST.hasStdExtA(), {{s8, p0}, {s16, p0}, {s32, p0}, {s64, p0}})
722 .clampScalar(0, sXLen, sXLen);
724 getActionDefinitionsBuilder(G_ATOMICRMW_SUB)
725 .libcallFor(!
ST.hasStdExtA(), {{s8, p0}, {s16, p0}, {s32, p0}, {s64, p0}})
726 .clampScalar(0, sXLen, sXLen)
735 getActionDefinitionsBuilder(G_INSERT_VECTOR_ELT)
737 InsertVectorEltPred,
typeIs(2, sXLen)))
741 getLegacyLegalizerInfo().computeTables();