488 unsigned builtinID) {
491 case Builtin::BIacos:
492 case Builtin::BIacosf:
493 case Builtin::BIacosl:
494 case Builtin::BI__builtin_acos:
495 case Builtin::BI__builtin_acosf:
496 case Builtin::BI__builtin_acosf16:
497 case Builtin::BI__builtin_acosl:
498 case Builtin::BI__builtin_acosf128:
499 case Builtin::BI__builtin_elementwise_acos:
501 case Builtin::BIasin:
502 case Builtin::BIasinf:
503 case Builtin::BIasinl:
504 case Builtin::BI__builtin_asin:
505 case Builtin::BI__builtin_asinf:
506 case Builtin::BI__builtin_asinf16:
507 case Builtin::BI__builtin_asinl:
508 case Builtin::BI__builtin_asinf128:
509 case Builtin::BI__builtin_elementwise_asin:
511 case Builtin::BIatan:
512 case Builtin::BIatanf:
513 case Builtin::BIatanl:
514 case Builtin::BI__builtin_atan:
515 case Builtin::BI__builtin_atanf:
516 case Builtin::BI__builtin_atanf16:
517 case Builtin::BI__builtin_atanl:
518 case Builtin::BI__builtin_atanf128:
519 case Builtin::BI__builtin_elementwise_atan:
521 case Builtin::BIatan2:
522 case Builtin::BIatan2f:
523 case Builtin::BIatan2l:
524 case Builtin::BI__builtin_atan2:
525 case Builtin::BI__builtin_atan2f:
526 case Builtin::BI__builtin_atan2f16:
527 case Builtin::BI__builtin_atan2l:
528 case Builtin::BI__builtin_atan2f128:
529 case Builtin::BI__builtin_elementwise_atan2:
532 case Builtin::BIceil:
533 case Builtin::BIceilf:
534 case Builtin::BIceill:
535 case Builtin::BI__builtin_ceil:
536 case Builtin::BI__builtin_ceilf:
537 case Builtin::BI__builtin_ceilf16:
538 case Builtin::BI__builtin_ceill:
539 case Builtin::BI__builtin_ceilf128:
541 case Builtin::BI__builtin_elementwise_ceil:
543 case Builtin::BIcopysign:
544 case Builtin::BIcopysignf:
545 case Builtin::BIcopysignl:
546 case Builtin::BI__builtin_copysign:
547 case Builtin::BI__builtin_copysignf:
548 case Builtin::BI__builtin_copysignf16:
549 case Builtin::BI__builtin_copysignl:
550 case Builtin::BI__builtin_copysignf128:
553 case Builtin::BIcosf:
554 case Builtin::BIcosl:
555 case Builtin::BI__builtin_cos:
556 case Builtin::BI__builtin_cosf:
557 case Builtin::BI__builtin_cosf16:
558 case Builtin::BI__builtin_cosl:
559 case Builtin::BI__builtin_cosf128:
561 case Builtin::BI__builtin_elementwise_cos:
562 case Builtin::BIcosh:
563 case Builtin::BIcoshf:
564 case Builtin::BIcoshl:
565 case Builtin::BI__builtin_cosh:
566 case Builtin::BI__builtin_coshf:
567 case Builtin::BI__builtin_coshf16:
568 case Builtin::BI__builtin_coshl:
569 case Builtin::BI__builtin_coshf128:
570 case Builtin::BI__builtin_elementwise_cosh:
573 case Builtin::BIexpf:
574 case Builtin::BIexpl:
575 case Builtin::BI__builtin_exp:
576 case Builtin::BI__builtin_expf:
577 case Builtin::BI__builtin_expf16:
578 case Builtin::BI__builtin_expl:
579 case Builtin::BI__builtin_expf128:
581 case Builtin::BI__builtin_elementwise_exp:
583 case Builtin::BIexp2:
584 case Builtin::BIexp2f:
585 case Builtin::BIexp2l:
586 case Builtin::BI__builtin_exp2:
587 case Builtin::BI__builtin_exp2f:
588 case Builtin::BI__builtin_exp2f16:
589 case Builtin::BI__builtin_exp2l:
590 case Builtin::BI__builtin_exp2f128:
592 case Builtin::BI__builtin_elementwise_exp2:
593 case Builtin::BI__builtin_exp10:
594 case Builtin::BI__builtin_exp10f:
595 case Builtin::BI__builtin_exp10f16:
596 case Builtin::BI__builtin_exp10l:
597 case Builtin::BI__builtin_exp10f128:
598 case Builtin::BI__builtin_elementwise_exp10:
600 case Builtin::BIfabs:
601 case Builtin::BIfabsf:
602 case Builtin::BIfabsl:
603 case Builtin::BI__builtin_fabs:
604 case Builtin::BI__builtin_fabsf:
605 case Builtin::BI__builtin_fabsf16:
606 case Builtin::BI__builtin_fabsl:
607 case Builtin::BI__builtin_fabsf128:
609 case Builtin::BIfloor:
610 case Builtin::BIfloorf:
611 case Builtin::BIfloorl:
612 case Builtin::BI__builtin_floor:
613 case Builtin::BI__builtin_floorf:
614 case Builtin::BI__builtin_floorf16:
615 case Builtin::BI__builtin_floorl:
616 case Builtin::BI__builtin_floorf128:
618 case Builtin::BI__builtin_elementwise_floor:
620 case Builtin::BIfmaf:
621 case Builtin::BIfmal:
622 case Builtin::BI__builtin_fma:
623 case Builtin::BI__builtin_fmaf:
624 case Builtin::BI__builtin_fmaf16:
625 case Builtin::BI__builtin_fmal:
626 case Builtin::BI__builtin_fmaf128:
627 case Builtin::BI__builtin_elementwise_fma:
629 case Builtin::BIfmax:
630 case Builtin::BIfmaxf:
631 case Builtin::BIfmaxl:
632 case Builtin::BI__builtin_fmax:
633 case Builtin::BI__builtin_fmaxf:
634 case Builtin::BI__builtin_fmaxf16:
635 case Builtin::BI__builtin_fmaxl:
636 case Builtin::BI__builtin_fmaxf128:
639 case Builtin::BIfmin:
640 case Builtin::BIfminf:
641 case Builtin::BIfminl:
642 case Builtin::BI__builtin_fmin:
643 case Builtin::BI__builtin_fminf:
644 case Builtin::BI__builtin_fminf16:
645 case Builtin::BI__builtin_fminl:
646 case Builtin::BI__builtin_fminf128:
649 case Builtin::BIfmaximum_num:
650 case Builtin::BIfmaximum_numf:
651 case Builtin::BIfmaximum_numl:
652 case Builtin::BI__builtin_fmaximum_num:
653 case Builtin::BI__builtin_fmaximum_numf:
654 case Builtin::BI__builtin_fmaximum_numf16:
655 case Builtin::BI__builtin_fmaximum_numl:
656 case Builtin::BI__builtin_fmaximum_numf128:
657 case Builtin::BIfminimum_num:
658 case Builtin::BIfminimum_numf:
659 case Builtin::BIfminimum_numl:
660 case Builtin::BI__builtin_fminimum_num:
661 case Builtin::BI__builtin_fminimum_numf:
662 case Builtin::BI__builtin_fminimum_numf16:
663 case Builtin::BI__builtin_fminimum_numl:
664 case Builtin::BI__builtin_fminimum_numf128:
666 case Builtin::BIfmod:
667 case Builtin::BIfmodf:
668 case Builtin::BIfmodl:
669 case Builtin::BI__builtin_fmod:
670 case Builtin::BI__builtin_fmodf:
671 case Builtin::BI__builtin_fmodf16:
672 case Builtin::BI__builtin_fmodl:
673 case Builtin::BI__builtin_fmodf128:
674 case Builtin::BI__builtin_elementwise_fmod:
678 case Builtin::BIlogf:
679 case Builtin::BIlogl:
680 case Builtin::BI__builtin_log:
681 case Builtin::BI__builtin_logf:
682 case Builtin::BI__builtin_logf16:
683 case Builtin::BI__builtin_logl:
684 case Builtin::BI__builtin_logf128:
685 case Builtin::BI__builtin_elementwise_log:
687 case Builtin::BIlog10:
688 case Builtin::BIlog10f:
689 case Builtin::BIlog10l:
690 case Builtin::BI__builtin_log10:
691 case Builtin::BI__builtin_log10f:
692 case Builtin::BI__builtin_log10f16:
693 case Builtin::BI__builtin_log10l:
694 case Builtin::BI__builtin_log10f128:
695 case Builtin::BI__builtin_elementwise_log10:
697 case Builtin::BIlog2:
698 case Builtin::BIlog2f:
699 case Builtin::BIlog2l:
700 case Builtin::BI__builtin_log2:
701 case Builtin::BI__builtin_log2f:
702 case Builtin::BI__builtin_log2f16:
703 case Builtin::BI__builtin_log2l:
704 case Builtin::BI__builtin_log2f128:
705 case Builtin::BI__builtin_elementwise_log2:
707 case Builtin::BInearbyint:
708 case Builtin::BInearbyintf:
709 case Builtin::BInearbyintl:
710 case Builtin::BI__builtin_nearbyint:
711 case Builtin::BI__builtin_nearbyintf:
712 case Builtin::BI__builtin_nearbyintl:
713 case Builtin::BI__builtin_nearbyintf128:
714 case Builtin::BI__builtin_elementwise_nearbyint:
717 case Builtin::BIpowf:
718 case Builtin::BIpowl:
719 case Builtin::BI__builtin_pow:
720 case Builtin::BI__builtin_powf:
721 case Builtin::BI__builtin_powf16:
722 case Builtin::BI__builtin_powl:
723 case Builtin::BI__builtin_powf128:
726 case Builtin::BI__builtin_elementwise_pow:
728 case Builtin::BIrint:
729 case Builtin::BIrintf:
730 case Builtin::BIrintl:
731 case Builtin::BI__builtin_rint:
732 case Builtin::BI__builtin_rintf:
733 case Builtin::BI__builtin_rintf16:
734 case Builtin::BI__builtin_rintl:
735 case Builtin::BI__builtin_rintf128:
736 case Builtin::BI__builtin_elementwise_rint:
738 case Builtin::BIround:
739 case Builtin::BIroundf:
740 case Builtin::BIroundl:
741 case Builtin::BI__builtin_round:
742 case Builtin::BI__builtin_roundf:
743 case Builtin::BI__builtin_roundf16:
744 case Builtin::BI__builtin_roundl:
745 case Builtin::BI__builtin_roundf128:
746 case Builtin::BI__builtin_elementwise_round:
748 case Builtin::BIroundeven:
749 case Builtin::BIroundevenf:
750 case Builtin::BIroundevenl:
751 case Builtin::BI__builtin_roundeven:
752 case Builtin::BI__builtin_roundevenf:
753 case Builtin::BI__builtin_roundevenf16:
754 case Builtin::BI__builtin_roundevenl:
755 case Builtin::BI__builtin_roundevenf128:
756 case Builtin::BI__builtin_elementwise_roundeven:
759 case Builtin::BIsinf:
760 case Builtin::BIsinl:
761 case Builtin::BI__builtin_sin:
762 case Builtin::BI__builtin_sinf:
763 case Builtin::BI__builtin_sinf16:
764 case Builtin::BI__builtin_sinl:
765 case Builtin::BI__builtin_sinf128:
766 case Builtin::BI__builtin_elementwise_sin:
768 case Builtin::BIsinh:
769 case Builtin::BIsinhf:
770 case Builtin::BIsinhl:
771 case Builtin::BI__builtin_sinh:
772 case Builtin::BI__builtin_sinhf:
773 case Builtin::BI__builtin_sinhf16:
774 case Builtin::BI__builtin_sinhl:
775 case Builtin::BI__builtin_sinhf128:
776 case Builtin::BI__builtin_elementwise_sinh:
777 case Builtin::BI__builtin_sincospi:
778 case Builtin::BI__builtin_sincospif:
779 case Builtin::BI__builtin_sincospil:
780 case Builtin::BIsincos:
781 case Builtin::BIsincosf:
782 case Builtin::BIsincosl:
783 case Builtin::BI__builtin_sincos:
784 case Builtin::BI__builtin_sincosf:
785 case Builtin::BI__builtin_sincosf16:
786 case Builtin::BI__builtin_sincosl:
787 case Builtin::BI__builtin_sincosf128:
789 case Builtin::BIsqrt:
790 case Builtin::BIsqrtf:
791 case Builtin::BIsqrtl:
792 case Builtin::BI__builtin_sqrt:
793 case Builtin::BI__builtin_sqrtf:
794 case Builtin::BI__builtin_sqrtf16:
795 case Builtin::BI__builtin_sqrtl:
796 case Builtin::BI__builtin_sqrtf128:
797 case Builtin::BI__builtin_elementwise_sqrt:
800 case Builtin::BItanf:
801 case Builtin::BItanl:
802 case Builtin::BI__builtin_tan:
803 case Builtin::BI__builtin_tanf:
804 case Builtin::BI__builtin_tanf16:
805 case Builtin::BI__builtin_tanl:
806 case Builtin::BI__builtin_tanf128:
807 case Builtin::BI__builtin_elementwise_tan:
809 case Builtin::BItanh:
810 case Builtin::BItanhf:
811 case Builtin::BItanhl:
812 case Builtin::BI__builtin_tanh:
813 case Builtin::BI__builtin_tanhf:
814 case Builtin::BI__builtin_tanhf16:
815 case Builtin::BI__builtin_tanhl:
816 case Builtin::BI__builtin_tanhf128:
817 case Builtin::BI__builtin_elementwise_tanh:
819 case Builtin::BItrunc:
820 case Builtin::BItruncf:
821 case Builtin::BItruncl:
822 case Builtin::BI__builtin_trunc:
823 case Builtin::BI__builtin_truncf:
824 case Builtin::BI__builtin_truncf16:
825 case Builtin::BI__builtin_truncl:
826 case Builtin::BI__builtin_truncf128:
827 case Builtin::BI__builtin_elementwise_trunc:
829 case Builtin::BIlround:
830 case Builtin::BIlroundf:
831 case Builtin::BIlroundl:
832 case Builtin::BI__builtin_lround:
833 case Builtin::BI__builtin_lroundf:
834 case Builtin::BI__builtin_lroundl:
835 case Builtin::BI__builtin_lroundf128:
837 case Builtin::BIllround:
838 case Builtin::BIllroundf:
839 case Builtin::BIllroundl:
840 case Builtin::BI__builtin_llround:
841 case Builtin::BI__builtin_llroundf:
842 case Builtin::BI__builtin_llroundl:
843 case Builtin::BI__builtin_llroundf128:
845 case Builtin::BIlrint:
846 case Builtin::BIlrintf:
847 case Builtin::BIlrintl:
848 case Builtin::BI__builtin_lrint:
849 case Builtin::BI__builtin_lrintf:
850 case Builtin::BI__builtin_lrintl:
851 case Builtin::BI__builtin_lrintf128:
853 case Builtin::BIllrint:
854 case Builtin::BIllrintf:
855 case Builtin::BIllrintl:
856 case Builtin::BI__builtin_llrint:
857 case Builtin::BI__builtin_llrintf:
858 case Builtin::BI__builtin_llrintl:
859 case Builtin::BI__builtin_llrintf128:
861 case Builtin::BI__builtin_ldexp:
862 case Builtin::BI__builtin_ldexpf:
863 case Builtin::BI__builtin_ldexpl:
864 case Builtin::BI__builtin_ldexpf16:
865 case Builtin::BI__builtin_ldexpf128:
866 case Builtin::BI__builtin_elementwise_ldexp:
990 if (
type->isBooleanType())
992 builder.getBool(result.
Val.
getInt().getBoolValue(), loc));
1014 unsigned builtinIDIfNoAsmLabel = fd->
hasAttr<AsmLabelAttr>() ? 0 : builtinID;
1016 bool generateFPMathIntrinsics =
1019 if (generateFPMathIntrinsics) {
1031 switch (builtinIDIfNoAsmLabel) {
1036 case Builtin::BI__builtin_stdarg_start:
1037 case Builtin::BI__builtin_va_start:
1038 case Builtin::BI__va_start: {
1039 mlir::Value vaList = builtinID == Builtin::BI__va_start
1046 case Builtin::BI__builtin_va_end:
1049 case Builtin::BI__builtin_va_copy: {
1052 cir::VACopyOp::create(builder, dstPtr.getLoc(), dstPtr, srcPtr);
1056 case Builtin::BIabs:
1057 case Builtin::BIlabs:
1058 case Builtin::BIllabs:
1059 case Builtin::BI__builtin_abs:
1060 case Builtin::BI__builtin_labs:
1061 case Builtin::BI__builtin_llabs: {
1062 bool sanitizeOverflow =
sanOpts.has(SanitizerKind::SignedIntegerOverflow);
1065 switch (
getLangOpts().getSignedOverflowBehavior()) {
1067 result = cir::AbsOp::create(builder, loc, arg.getType(), arg,
1071 if (!sanitizeOverflow) {
1072 result = cir::AbsOp::create(builder, loc, arg.getType(), arg,
1084 case Builtin::BI__assume:
1085 case Builtin::BI__builtin_assume: {
1090 cir::AssumeOp::create(builder, loc, argValue, cir::AssumeBundleKind::None,
1091 mlir::ValueRange{});
1095 case Builtin::BI__builtin_assume_separate_storage: {
1098 mlir::Value cond = builder.getBool(
true, loc);
1099 cir::AssumeOp::create(builder, loc, cond,
1100 cir::AssumeBundleKind::SeparateStorage,
1101 mlir::ValueRange{value0, value1});
1105 case Builtin::BI__builtin_assume_dereferenceable: {
1111 if (sizeValue.getType() != uintPtrTy)
1112 sizeValue = builder.createIntCast(sizeValue, uintPtrTy);
1113 mlir::Value cond = builder.getBool(
true, loc);
1114 cir::AssumeOp::create(builder, loc, cond,
1115 cir::AssumeBundleKind::Dereferenceable,
1116 mlir::ValueRange{ptrValue, sizeValue});
1120 case Builtin::BI__builtin_assume_aligned: {
1123 mlir::Value offsetValue =
1126 std::optional<llvm::APSInt> alignment =
1128 assert(alignment.has_value() &&
1129 "the second argument to __builtin_assume_aligned must be an "
1130 "integral constant expression");
1132 mlir::Value result =
1134 alignment->getSExtValue(), offsetValue);
1138 case Builtin::BI__builtin_complex: {
1141 mlir::Value complex = builder.createComplexCreate(loc, real, imag);
1145 case Builtin::BI__builtin_creal:
1146 case Builtin::BI__builtin_crealf:
1147 case Builtin::BI__builtin_creall:
1148 case Builtin::BIcreal:
1149 case Builtin::BIcrealf:
1150 case Builtin::BIcreall: {
1152 mlir::Value real = builder.createComplexReal(loc, complex);
1156 case Builtin::BI__builtin_cimag:
1157 case Builtin::BI__builtin_cimagf:
1158 case Builtin::BI__builtin_cimagl:
1159 case Builtin::BIcimag:
1160 case Builtin::BIcimagf:
1161 case Builtin::BIcimagl: {
1163 mlir::Value imag = builder.createComplexImag(loc, complex);
1167 case Builtin::BI__builtin_conj:
1168 case Builtin::BI__builtin_conjf:
1169 case Builtin::BI__builtin_conjl:
1170 case Builtin::BIconj:
1171 case Builtin::BIconjf:
1172 case Builtin::BIconjl: {
1174 mlir::Value
conj = builder.createComplexConj(loc, complex);
1178 case Builtin::BI__builtin_clrsb:
1179 case Builtin::BI__builtin_clrsbl:
1180 case Builtin::BI__builtin_clrsbll:
1183 case Builtin::BI__builtin_ctzs:
1184 case Builtin::BI__builtin_ctz:
1185 case Builtin::BI__builtin_ctzl:
1186 case Builtin::BI__builtin_ctzll:
1190 case Builtin::BI__builtin_ctzg:
1193 case Builtin::BI__builtin_clzs:
1194 case Builtin::BI__builtin_clz:
1195 case Builtin::BI__builtin_clzl:
1196 case Builtin::BI__builtin_clzll:
1200 case Builtin::BI__builtin_clzg:
1203 case Builtin::BI__builtin_elementwise_ctzg:
1206 case Builtin::BI__builtin_elementwise_clzg:
1210 case Builtin::BI__builtin_ffs:
1211 case Builtin::BI__builtin_ffsl:
1212 case Builtin::BI__builtin_ffsll:
1215 case Builtin::BI__builtin_parity:
1216 case Builtin::BI__builtin_parityl:
1217 case Builtin::BI__builtin_parityll:
1220 case Builtin::BI__lzcnt16:
1221 case Builtin::BI__lzcnt:
1222 case Builtin::BI__lzcnt64:
1225 case Builtin::BI__popcnt16:
1226 case Builtin::BI__popcnt:
1227 case Builtin::BI__popcnt64:
1228 case Builtin::BI__builtin_popcount:
1229 case Builtin::BI__builtin_popcountl:
1230 case Builtin::BI__builtin_popcountll:
1231 case Builtin::BI__builtin_popcountg:
1238 case Builtin::BI__builtin_unpredictable: {
1242 case Builtin::BI__builtin_expect:
1243 case Builtin::BI__builtin_expect_with_probability: {
1245 if (
cgm.getCodeGenOpts().OptimizationLevel == 0)
1250 mlir::FloatAttr probAttr;
1251 if (builtinIDIfNoAsmLabel == Builtin::BI__builtin_expect_with_probability) {
1252 llvm::APFloat probability(0.0);
1254 [[maybe_unused]]
bool evalSucceeded =
1256 assert(evalSucceeded &&
1257 "probability should be able to evaluate as float");
1258 bool loseInfo =
false;
1259 probability.convert(llvm::APFloat::IEEEdouble(),
1260 llvm::RoundingMode::Dynamic, &loseInfo);
1261 probAttr = mlir::FloatAttr::get(mlir::Float64Type::get(&
getMLIRContext()),
1265 auto result = cir::ExpectOp::create(builder, loc, argValue.getType(),
1266 argValue, expectedValue, probAttr);
1270 case Builtin::BI__builtin_bswapg: {
1275 if (mlir::isa<cir::BoolType>(arg.getType()))
1277 auto argTy = mlir::cast<cir::IntType>(arg.getType());
1279 if (argTy.getWidth() == 1 || argTy.getWidth() == 8)
1281 assert(argTy.getWidth() % 16 == 0 &&
1282 "__builtin_bswapg requires a single byte or a multiple of 16 bits");
1286 if (argTy.isSigned())
1287 arg = builder.createIntCast(arg, builder.getUIntNTy(argTy.getWidth()));
1291 case Builtin::BI__builtin_bswap16:
1292 case Builtin::BI__builtin_bswap32:
1293 case Builtin::BI__builtin_bswap64:
1294 case Builtin::BI_byteswap_ushort:
1295 case Builtin::BI_byteswap_ulong:
1296 case Builtin::BI_byteswap_uint64: {
1298 return RValue::get(cir::ByteSwapOp::create(builder, loc, arg));
1301 case Builtin::BI__builtin_bitreverse8:
1302 case Builtin::BI__builtin_bitreverse16:
1303 case Builtin::BI__builtin_bitreverse32:
1304 case Builtin::BI__builtin_bitreverse64: {
1306 return RValue::get(cir::BitReverseOp::create(builder, loc, arg));
1309 case Builtin::BI__builtin_rotateleft8:
1310 case Builtin::BI__builtin_rotateleft16:
1311 case Builtin::BI__builtin_rotateleft32:
1312 case Builtin::BI__builtin_rotateleft64:
1315 case Builtin::BI__builtin_rotateright8:
1316 case Builtin::BI__builtin_rotateright16:
1317 case Builtin::BI__builtin_rotateright32:
1318 case Builtin::BI__builtin_rotateright64:
1321 case Builtin::BI__builtin_coro_id:
1322 case Builtin::BI__builtin_coro_promise:
1323 case Builtin::BI__builtin_coro_resume:
1324 case Builtin::BI__builtin_coro_noop:
1325 case Builtin::BI__builtin_coro_destroy:
1326 case Builtin::BI__builtin_coro_done:
1327 case Builtin::BI__builtin_coro_alloc:
1328 case Builtin::BI__builtin_coro_begin:
1329 case Builtin::BI__builtin_coro_end:
1330 case Builtin::BI__builtin_coro_suspend:
1331 case Builtin::BI__builtin_coro_align:
1335 case Builtin::BI__builtin_coro_frame: {
1338 case Builtin::BI__builtin_coro_free:
1340 case Builtin::BI__builtin_coro_size: {
1342 mlir::Type ty =
cgm.getTypes().getFunctionType(
1343 cgm.getTypes().arrangeGlobalDeclaration(gd));
1346 cgm.getOrCreateCIRFunction(nd->getName(), ty, gd,
false);
1347 fnOp.setBuiltin(
true);
1352 case Builtin::BI__builtin_constant_p: {
1365 mlir::cast<cir::IntType>(resultType), 0));
1373 mlir::cast<cir::IntType>(resultType), 0));
1379 "__builtin_constant_p: Obj-C object pointer");
1382 argValue = builder.createBitcast(argValue,
convertType(argType));
1384 mlir::Value result = cir::IsConstantOp::create(
1387 result = builder.createBoolToInt(result, resultType);
1390 case Builtin::BI__builtin_dynamic_object_size:
1391 case Builtin::BI__builtin_object_size: {
1398 bool isDynamic = builtinID == Builtin::BI__builtin_dynamic_object_size;
1400 nullptr, isDynamic));
1403 case Builtin::BI__builtin_prefetch: {
1404 auto evaluateOperandAsInt = [&](
const Expr *arg) {
1406 [[maybe_unused]]
bool evalSucceed =
1407 arg->EvaluateAsInt(res,
cgm.getASTContext());
1408 assert(evalSucceed &&
"expression should be able to evaluate as int");
1412 bool isWrite =
false;
1414 isWrite = evaluateOperandAsInt(e->
getArg(1));
1418 locality = evaluateOperandAsInt(e->
getArg(2));
1421 cir::PrefetchOp::create(builder, loc, address, locality, isWrite);
1424 case Builtin::BI__builtin_readcyclecounter:
1425 case Builtin::BI__builtin_readsteadycounter:
1427 case Builtin::BI__builtin___clear_cache: {
1435 case Builtin::BI__builtin_trap:
1438 case Builtin::BI__builtin_verbose_trap:
1442 case Builtin::BI__debugbreak:
1444 case Builtin::BI__builtin_unreachable:
1447 case Builtin::BI__builtin_powi:
1448 case Builtin::BI__builtin_powif:
1449 case Builtin::BI__builtin_powil: {
1454 mlir::ValueRange{src0, src1}));
1456 case Builtin::BI__builtin_frexpl:
1457 case Builtin::BI__builtin_frexp:
1458 case Builtin::BI__builtin_frexpf:
1459 case Builtin::BI__builtin_frexpf128:
1460 case Builtin::BI__builtin_frexpf16: {
1463 mlir::Type fpTy = val.getType();
1467 auto frexpOp = cir::FrexpOp::create(builder, callLoc, fpTy, intTy, val);
1472 case Builtin::BImodf:
1473 case Builtin::BImodff:
1474 case Builtin::BImodfl:
1475 case Builtin::BI__builtin_modf:
1476 case Builtin::BI__builtin_modff:
1477 case Builtin::BI__builtin_modfl: {
1480 mlir::Type fpTy = val.getType();
1482 auto modfOp = cir::ModfOp::create(builder, callLoc, fpTy, fpTy, val);
1488 case Builtin::BI__builtin_isgreater:
1489 case Builtin::BI__builtin_isgreaterequal:
1490 case Builtin::BI__builtin_isless:
1491 case Builtin::BI__builtin_islessequal:
1492 case Builtin::BI__builtin_islessgreater:
1493 case Builtin::BI__builtin_isunordered: {
1500 mlir::Value cmpResult;
1501 switch (builtinID) {
1502 case Builtin::BI__builtin_isgreater:
1503 cmpResult = builder.createCompare(loc, cir::CmpOpKind::gt, lhs, rhs);
1505 case Builtin::BI__builtin_isgreaterequal:
1506 cmpResult = builder.createCompare(loc, cir::CmpOpKind::ge, lhs, rhs);
1508 case Builtin::BI__builtin_isless:
1509 cmpResult = builder.createCompare(loc, cir::CmpOpKind::lt, lhs, rhs);
1511 case Builtin::BI__builtin_islessequal:
1512 cmpResult = builder.createCompare(loc, cir::CmpOpKind::le, lhs, rhs);
1514 case Builtin::BI__builtin_islessgreater:
1515 cmpResult = builder.createCompare(loc, cir::CmpOpKind::one, lhs, rhs);
1517 case Builtin::BI__builtin_isunordered:
1518 cmpResult = builder.createCompare(loc, cir::CmpOpKind::uno, lhs, rhs);
1521 llvm_unreachable(
"Unknown ordered comparison");
1523 return RValue::get(builder.createBoolToInt(cmpResult, intTy));
1531 case Builtin::BI__builtin_isnan: {
1537 builder.createIsFPClass(loc, v, cir::FPClassTest::Nan),
1541 case Builtin::BI__builtin_issignaling: {
1546 builder.createIsFPClass(loc, v, cir::FPClassTest::SignalingNaN),
1550 case Builtin::BI__builtin_isinf: {
1556 builder.createIsFPClass(loc, v, cir::FPClassTest::Infinity),
1559 case Builtin::BIfinite:
1560 case Builtin::BI__finite:
1561 case Builtin::BIfinitef:
1562 case Builtin::BI__finitef:
1563 case Builtin::BIfinitel:
1564 case Builtin::BI__finitel:
1565 case Builtin::BI__builtin_isfinite: {
1571 builder.createIsFPClass(loc, v, cir::FPClassTest::Finite),
1575 case Builtin::BI__builtin_isnormal: {
1580 builder.createIsFPClass(loc, v, cir::FPClassTest::Normal),
1584 case Builtin::BI__builtin_issubnormal: {
1589 builder.createIsFPClass(loc, v, cir::FPClassTest::Subnormal),
1593 case Builtin::BI__builtin_iszero: {
1598 builder.createIsFPClass(loc, v, cir::FPClassTest::Zero),
1601 case Builtin::BI__builtin_isfpclass: {
1608 uint64_t test = result.
Val.
getInt().getLimitedValue();
1612 builder.createIsFPClass(loc, v, cir::FPClassTest(test)),
1615 case Builtin::BI__builtin_nondeterministic_value:
1617 case Builtin::BI__builtin_elementwise_abs: {
1619 bool isIntTy = cir::isIntOrVectorOfIntType(cirTy);
1624 arg.getType(), arg,
false);
1627 case Builtin::BI__builtin_elementwise_acos:
1629 case Builtin::BI__builtin_elementwise_asin:
1631 case Builtin::BI__builtin_elementwise_atan:
1633 case Builtin::BI__builtin_elementwise_atan2:
1636 case Builtin::BI__builtin_elementwise_exp:
1638 case Builtin::BI__builtin_elementwise_exp2:
1640 case Builtin::BI__builtin_elementwise_log:
1642 case Builtin::BI__builtin_elementwise_log2:
1644 case Builtin::BI__builtin_elementwise_log10:
1646 case Builtin::BI__builtin_elementwise_cos:
1648 case Builtin::BI__builtin_elementwise_floor:
1650 case Builtin::BI__builtin_elementwise_round:
1652 case Builtin::BI__builtin_elementwise_rint:
1654 case Builtin::BI__builtin_elementwise_nearbyint:
1656 case Builtin::BI__builtin_elementwise_sin:
1658 case Builtin::BI__builtin_elementwise_sqrt:
1660 case Builtin::BI__builtin_elementwise_tan:
1662 case Builtin::BI__builtin_elementwise_trunc:
1664 case Builtin::BI__builtin_elementwise_fmod:
1667 case Builtin::BI__builtin_elementwise_ceil:
1668 case Builtin::BI__builtin_elementwise_exp10:
1669 case Builtin::BI__builtin_elementwise_ldexp:
1670 case Builtin::BI__builtin_elementwise_pow:
1671 case Builtin::BI__builtin_elementwise_bitreverse:
1672 case Builtin::BI__builtin_elementwise_cosh:
1673 case Builtin::BI__builtin_elementwise_popcount:
1674 case Builtin::BI__builtin_elementwise_roundeven:
1675 case Builtin::BI__builtin_elementwise_sinh:
1676 case Builtin::BI__builtin_elementwise_tanh:
1677 case Builtin::BI__builtin_elementwise_canonicalize:
1678 case Builtin::BI__builtin_elementwise_copysign:
1679 case Builtin::BI__builtin_elementwise_fma:
1681 case Builtin::BI__builtin_elementwise_fshl: {
1686 return RValue::get(builder.emitIntrinsicCallOp(loc,
"fshl", a.getType(),
1687 mlir::ValueRange{a, b, c}));
1689 case Builtin::BI__builtin_elementwise_fshr: {
1694 return RValue::get(builder.emitIntrinsicCallOp(loc,
"fshr", a.getType(),
1695 mlir::ValueRange{a, b, c}));
1697 case Builtin::BI__builtin_elementwise_add_sat:
1698 case Builtin::BI__builtin_elementwise_sub_sat:
1699 case Builtin::BI__builtin_elementwise_max:
1700 case Builtin::BI__builtin_elementwise_min:
1701 case Builtin::BI__builtin_elementwise_maxnum:
1702 case Builtin::BI__builtin_elementwise_minnum:
1703 case Builtin::BI__builtin_elementwise_maximum:
1704 case Builtin::BI__builtin_elementwise_minimum:
1705 case Builtin::BI__builtin_elementwise_maximumnum:
1706 case Builtin::BI__builtin_elementwise_minimumnum:
1707 case Builtin::BI__builtin_reduce_max:
1708 case Builtin::BI__builtin_reduce_min:
1709 case Builtin::BI__builtin_reduce_add:
1710 case Builtin::BI__builtin_reduce_mul:
1711 case Builtin::BI__builtin_reduce_xor:
1712 case Builtin::BI__builtin_reduce_or:
1713 case Builtin::BI__builtin_reduce_and:
1714 case Builtin::BI__builtin_reduce_assoc_fadd:
1715 case Builtin::BI__builtin_reduce_in_order_fadd:
1716 case Builtin::BI__builtin_reduce_maximum:
1717 case Builtin::BI__builtin_reduce_minimum:
1718 case Builtin::BI__builtin_matrix_transpose:
1719 case Builtin::BI__builtin_matrix_column_major_load:
1720 case Builtin::BI__builtin_matrix_column_major_store:
1721 case Builtin::BI__builtin_masked_load:
1722 case Builtin::BI__builtin_masked_expand_load:
1723 case Builtin::BI__builtin_masked_gather:
1724 case Builtin::BI__builtin_masked_store:
1725 case Builtin::BI__builtin_masked_compress_store:
1726 case Builtin::BI__builtin_masked_scatter:
1728 case Builtin::BI__builtin_isinf_sign: {
1733 builder.createIsFPClass(loc, arg, cir::FPClassTest::Infinity);
1736 cir::ConstantOp zero = builder.getNullValue(intTy, loc);
1737 cir::ConstantOp one = builder.getConstant(loc, cir::IntAttr::get(intTy, 1));
1738 cir::ConstantOp negativeOne =
1739 builder.getConstant(loc, cir::IntAttr::get(intTy, -1));
1740 mlir::Value signResult = builder.createSelect(loc, isNeg, negativeOne, one);
1741 mlir::Value result = builder.createSelect(loc, isInf, signResult, zero);
1744 case Builtin::BI__builtin_flt_rounds: {
1747 mlir::Value result =
1748 builder.emitIntrinsicCallOp(loc,
"get.rounding", resultType);
1749 if (result.getType() != resultType)
1751 builder.createCast(loc, cir::CastKind::integral, result, resultType);
1754 case Builtin::BI__builtin_set_flt_rounds: {
1757 builder.emitIntrinsicCallOp(loc,
"set.rounding", builder.getVoidTy(),
1758 mlir::ValueRange{v});
1761 case Builtin::BI__builtin_fpclassify: {
1777 cir::IsFPClassOp::create(builder, loc, value, cir::FPClassTest::Zero);
1778 mlir::Value result =
1779 cir::TernaryOp::create(
1780 builder, loc, isZero,
1782 [&](mlir::OpBuilder &opBuilder, mlir::Location location) {
1784 cir::YieldOp::create(opBuilder, location, zeroLiteral);
1787 [&](mlir::OpBuilder &opBuilder, mlir::Location location) {
1788 auto isNan = cir::IsFPClassOp::create(opBuilder, location, value,
1789 cir::FPClassTest::Nan);
1790 mlir::Value nanResult =
1791 cir::TernaryOp::create(
1792 opBuilder, location, isNan,
1794 [&](mlir::OpBuilder &opBuilder, mlir::Location location) {
1796 cir::YieldOp::create(opBuilder, location, nanLiteral);
1799 [&](mlir::OpBuilder &opBuilder, mlir::Location location) {
1800 auto isInfinity = cir::IsFPClassOp::create(
1801 opBuilder, location, value,
1802 cir::FPClassTest::Infinity);
1803 mlir::Value infResult =
1804 cir::TernaryOp::create(
1805 opBuilder, location, isInfinity,
1807 [&](mlir::OpBuilder &opBuilder,
1808 mlir::Location location) {
1809 mlir::Value infinityLiteral =
1811 cir::YieldOp::create(opBuilder, location,
1815 [&](mlir::OpBuilder &opBuilder,
1816 mlir::Location location) {
1817 auto isNormal = cir::IsFPClassOp::create(
1818 opBuilder, location, value,
1819 cir::FPClassTest::Normal);
1820 mlir::Value fpNormal =
1822 mlir::Value fpSubnormal =
1825 cir::SelectOp::create(
1826 opBuilder, location, resultTy,
1827 isNormal, fpNormal, fpSubnormal);
1828 cir::YieldOp::create(opBuilder, location,
1832 cir::YieldOp::create(opBuilder, location, infResult);
1835 cir::YieldOp::create(opBuilder, location, nanResult);
1840 case Builtin::BIalloca:
1841 case Builtin::BI_alloca:
1842 case Builtin::BI__builtin_alloca_uninitialized:
1843 case Builtin::BI__builtin_alloca:
1845 case Builtin::BI__builtin_alloca_with_align_uninitialized:
1846 case Builtin::BI__builtin_alloca_with_align:
1847 case Builtin::BI__builtin_infer_alloc_token:
1849 case Builtin::BIbzero:
1850 case Builtin::BI__builtin_bzero: {
1855 mlir::Value zero = builder.getNullValue(builder.getUInt8Ty(), loc);
1857 builder.createMemSet(loc, destPtrCast, zero, size);
1861 case Builtin::BIbcopy:
1862 case Builtin::BI__builtin_bcopy: {
1874 case Builtin::BI__builtin_char_memchr:
1875 case Builtin::BI__builtin_memchr: {
1878 builder.createBitcast(srcPtr.
getPointer(), builder.getVoidPtrTy());
1885 case Builtin::BImemcpy:
1886 case Builtin::BI__builtin_memcpy:
1887 case Builtin::BImempcpy:
1888 case Builtin::BI__builtin_mempcpy:
1889 case Builtin::BI__builtin_memcpy_inline:
1890 case Builtin::BI__builtin___memcpy_chk:
1891 case Builtin::BI__builtin_objc_memmove_collectable:
1892 case Builtin::BI__builtin___memmove_chk:
1893 case Builtin::BI__builtin_trivially_relocate:
1894 case Builtin::BImemmove:
1895 case Builtin::BI__builtin_memmove:
1896 case Builtin::BImemset:
1897 case Builtin::BI__builtin_memset:
1898 case Builtin::BI__builtin_memset_inline:
1899 case Builtin::BI__builtin___memset_chk:
1900 case Builtin::BI__builtin_wmemchr:
1901 case Builtin::BI__builtin_wmemcmp:
1903 case Builtin::BI__builtin_dwarf_cfa:
1905 case Builtin::BI__builtin_return_address: {
1909 builder.getConstAPInt(loc, builder.getUInt32Ty(), level)));
1911 case Builtin::BI_ReturnAddress: {
1914 builder.getConstInt(loc, builder.getUInt32Ty(), 0)));
1916 case Builtin::BI__builtin_frame_address: {
1919 mlir::Value addr = cir::FrameAddrOp::create(
1921 builder.getConstAPInt(loc, builder.getUInt32Ty(), level));
1923 builder.createCast(loc, cir::CastKind::bitcast, addr,
voidPtrTy));
1925 case Builtin::BI__builtin_extract_return_addr:
1926 case Builtin::BI__builtin_frob_return_addr:
1927 case Builtin::BI__builtin_dwarf_sp_column:
1928 case Builtin::BI__builtin_init_dwarf_reg_size_table:
1929 case Builtin::BI__builtin_eh_return:
1930 case Builtin::BI__builtin_unwind_init:
1931 case Builtin::BI__builtin_extend_pointer:
1933 case Builtin::BI__builtin_setjmp: {
1937 cir::PointerType
voidPtrTy = builder.getVoidPtrTy();
1938 cir::PointerType ppTy = builder.getPointerTo(
voidPtrTy);
1947 mlir::Value frameAddress =
1948 cir::FrameAddrOp::create(builder, loc,
voidPtrTy,
1949 mlir::ValueRange{builder.getUInt32(0, loc)})
1952 builder.createStore(loc, frameAddress, castBuf);
1954 mlir::Value stacksave =
1955 cir::StackSaveOp::create(builder, loc,
voidPtrTy).getResult();
1956 cir::PtrStrideOp stackSaveSlot = cir::PtrStrideOp::create(
1957 builder, loc, ppTy, castBuf.
getPointer(), builder.getSInt32(2, loc));
1958 llvm::TypeSize voidPtrTySize =
1961 CharUnits().fromQuantity(2 * voidPtrTySize));
1963 builder.createStore(loc, stacksave, slotAddr);
1964 auto op = cir::EhSetjmpOp::create(builder, loc, castBuf.
getPointer());
1967 case Builtin::BI__builtin_longjmp: {
1971 cir::EhLongjmpOp::create(builder, loc, buf);
1972 cir::UnreachableOp::create(builder, loc);
1975 case Builtin::BI__builtin_launder: {
1977 QualType argTy = arg->getType()->getPointeeType();
1980 if (
cgm.getCodeGenOpts().StrictVTablePointers &&
1983 ptr = cir::LaunderOp::create(builder, loc, ptr).getResult();
1987 case Builtin::BI__sync_fetch_and_add:
1988 case Builtin::BI__sync_fetch_and_sub:
1989 case Builtin::BI__sync_fetch_and_or:
1990 case Builtin::BI__sync_fetch_and_and:
1991 case Builtin::BI__sync_fetch_and_xor:
1992 case Builtin::BI__sync_fetch_and_nand:
1993 case Builtin::BI__sync_add_and_fetch:
1994 case Builtin::BI__sync_sub_and_fetch:
1995 case Builtin::BI__sync_and_and_fetch:
1996 case Builtin::BI__sync_or_and_fetch:
1997 case Builtin::BI__sync_xor_and_fetch:
1998 case Builtin::BI__sync_nand_and_fetch:
1999 case Builtin::BI__sync_val_compare_and_swap:
2000 case Builtin::BI__sync_bool_compare_and_swap:
2001 case Builtin::BI__sync_lock_test_and_set:
2002 case Builtin::BI__sync_lock_release:
2003 case Builtin::BI__sync_swap:
2005 case Builtin::BI__sync_fetch_and_add_1:
2006 case Builtin::BI__sync_fetch_and_add_2:
2007 case Builtin::BI__sync_fetch_and_add_4:
2008 case Builtin::BI__sync_fetch_and_add_8:
2009 case Builtin::BI__sync_fetch_and_add_16:
2011 case Builtin::BI__sync_fetch_and_sub_1:
2012 case Builtin::BI__sync_fetch_and_sub_2:
2013 case Builtin::BI__sync_fetch_and_sub_4:
2014 case Builtin::BI__sync_fetch_and_sub_8:
2015 case Builtin::BI__sync_fetch_and_sub_16:
2017 case Builtin::BI__sync_fetch_and_or_1:
2018 case Builtin::BI__sync_fetch_and_or_2:
2019 case Builtin::BI__sync_fetch_and_or_4:
2020 case Builtin::BI__sync_fetch_and_or_8:
2021 case Builtin::BI__sync_fetch_and_or_16:
2023 case Builtin::BI__sync_fetch_and_and_1:
2024 case Builtin::BI__sync_fetch_and_and_2:
2025 case Builtin::BI__sync_fetch_and_and_4:
2026 case Builtin::BI__sync_fetch_and_and_8:
2027 case Builtin::BI__sync_fetch_and_and_16:
2029 case Builtin::BI__sync_fetch_and_xor_1:
2030 case Builtin::BI__sync_fetch_and_xor_2:
2031 case Builtin::BI__sync_fetch_and_xor_4:
2032 case Builtin::BI__sync_fetch_and_xor_8:
2033 case Builtin::BI__sync_fetch_and_xor_16:
2035 case Builtin::BI__sync_fetch_and_nand_1:
2036 case Builtin::BI__sync_fetch_and_nand_2:
2037 case Builtin::BI__sync_fetch_and_nand_4:
2038 case Builtin::BI__sync_fetch_and_nand_8:
2039 case Builtin::BI__sync_fetch_and_nand_16:
2041 case Builtin::BI__sync_fetch_and_min:
2042 case Builtin::BI__sync_fetch_and_max:
2043 case Builtin::BI__sync_fetch_and_umin:
2044 case Builtin::BI__sync_fetch_and_umax:
2047 case Builtin::BI__sync_add_and_fetch_1:
2048 case Builtin::BI__sync_add_and_fetch_2:
2049 case Builtin::BI__sync_add_and_fetch_4:
2050 case Builtin::BI__sync_add_and_fetch_8:
2051 case Builtin::BI__sync_add_and_fetch_16:
2054 case Builtin::BI__sync_sub_and_fetch_1:
2055 case Builtin::BI__sync_sub_and_fetch_2:
2056 case Builtin::BI__sync_sub_and_fetch_4:
2057 case Builtin::BI__sync_sub_and_fetch_8:
2058 case Builtin::BI__sync_sub_and_fetch_16:
2061 case Builtin::BI__sync_and_and_fetch_1:
2062 case Builtin::BI__sync_and_and_fetch_2:
2063 case Builtin::BI__sync_and_and_fetch_4:
2064 case Builtin::BI__sync_and_and_fetch_8:
2065 case Builtin::BI__sync_and_and_fetch_16:
2068 case Builtin::BI__sync_or_and_fetch_1:
2069 case Builtin::BI__sync_or_and_fetch_2:
2070 case Builtin::BI__sync_or_and_fetch_4:
2071 case Builtin::BI__sync_or_and_fetch_8:
2072 case Builtin::BI__sync_or_and_fetch_16:
2074 case Builtin::BI__sync_xor_and_fetch_1:
2075 case Builtin::BI__sync_xor_and_fetch_2:
2076 case Builtin::BI__sync_xor_and_fetch_4:
2077 case Builtin::BI__sync_xor_and_fetch_8:
2078 case Builtin::BI__sync_xor_and_fetch_16:
2081 case Builtin::BI__sync_nand_and_fetch_1:
2082 case Builtin::BI__sync_nand_and_fetch_2:
2083 case Builtin::BI__sync_nand_and_fetch_4:
2084 case Builtin::BI__sync_nand_and_fetch_8:
2085 case Builtin::BI__sync_nand_and_fetch_16:
2088 case Builtin::BI__sync_val_compare_and_swap_1:
2089 case Builtin::BI__sync_val_compare_and_swap_2:
2090 case Builtin::BI__sync_val_compare_and_swap_4:
2091 case Builtin::BI__sync_val_compare_and_swap_8:
2092 case Builtin::BI__sync_val_compare_and_swap_16:
2093 case Builtin::BI__sync_bool_compare_and_swap_1:
2094 case Builtin::BI__sync_bool_compare_and_swap_2:
2095 case Builtin::BI__sync_bool_compare_and_swap_4:
2096 case Builtin::BI__sync_bool_compare_and_swap_8:
2097 case Builtin::BI__sync_bool_compare_and_swap_16:
2098 case Builtin::BI__sync_swap_1:
2099 case Builtin::BI__sync_swap_2:
2100 case Builtin::BI__sync_swap_4:
2101 case Builtin::BI__sync_swap_8:
2102 case Builtin::BI__sync_swap_16:
2103 case Builtin::BI__sync_lock_test_and_set_1:
2104 case Builtin::BI__sync_lock_test_and_set_2:
2105 case Builtin::BI__sync_lock_test_and_set_4:
2106 case Builtin::BI__sync_lock_test_and_set_8:
2107 case Builtin::BI__sync_lock_test_and_set_16:
2108 case Builtin::BI__sync_lock_release_1:
2109 case Builtin::BI__sync_lock_release_2:
2110 case Builtin::BI__sync_lock_release_4:
2111 case Builtin::BI__sync_lock_release_8:
2112 case Builtin::BI__sync_lock_release_16:
2114 case Builtin::BI__sync_synchronize: {
2122 cir::AtomicFenceOp::create(
2124 cir::MemOrder::SequentiallyConsistent,
2126 cir::SyncScopeKind::System));
2129 case Builtin::BI__builtin_nontemporal_load:
2130 case Builtin::BI__builtin_nontemporal_store:
2131 case Builtin::BI__c11_atomic_is_lock_free:
2132 case Builtin::BI__atomic_is_lock_free:
2133 case Builtin::BI__atomic_test_and_set:
2134 case Builtin::BI__atomic_clear:
2136 case Builtin::BI__atomic_thread_fence:
2137 case Builtin::BI__c11_atomic_thread_fence: {
2141 case Builtin::BI__atomic_signal_fence:
2142 case Builtin::BI__c11_atomic_signal_fence: {
2146 case Builtin::BI__scoped_atomic_thread_fence:
2148 case Builtin::BI__builtin_signbit:
2149 case Builtin::BI__builtin_signbitf:
2150 case Builtin::BI__builtin_signbitl: {
2154 mlir::Operation *signBitOp = cir::SignBitOp::create(builder, loc, value);
2155 mlir::Value result = builder.createBoolToInt(signBitOp->getResult(0),
2159 case Builtin::BI__warn_memset_zero_len:
2160 case Builtin::BI__annotation:
2161 case Builtin::BI__builtin_annotation:
2162 case Builtin::BI__builtin_addcb:
2163 case Builtin::BI__builtin_addcs:
2164 case Builtin::BI__builtin_addc:
2165 case Builtin::BI__builtin_addcl:
2166 case Builtin::BI__builtin_addcll:
2167 case Builtin::BI__builtin_subcb:
2168 case Builtin::BI__builtin_subcs:
2169 case Builtin::BI__builtin_subc:
2170 case Builtin::BI__builtin_subcl:
2171 case Builtin::BI__builtin_subcll:
2174 case Builtin::BI__builtin_add_overflow:
2175 case Builtin::BI__builtin_sub_overflow:
2176 case Builtin::BI__builtin_mul_overflow: {
2184 WidthAndSignedness leftInfo =
2186 WidthAndSignedness rightInfo =
2188 WidthAndSignedness resultInfo =
2194 WidthAndSignedness encompassingInfo =
2197 auto encompassingCIRTy = cir::IntType::get(
2198 &
getMLIRContext(), encompassingInfo.width, encompassingInfo.isSigned);
2199 auto resultCIRTy = mlir::cast<cir::IntType>(
cgm.convertType(resultQTy));
2206 if (x.getType() != encompassingCIRTy) {
2207 x = builder.createCast(mlir::isa<cir::BoolType>(x.getType())
2208 ? cir::CastKind::bool_to_int
2209 : cir::CastKind::integral,
2210 x, encompassingCIRTy);
2213 if (y.getType() != encompassingCIRTy) {
2214 y = builder.createCast(mlir::isa<cir::BoolType>(y.getType())
2215 ? cir::CastKind::bool_to_int
2216 : cir::CastKind::integral,
2217 y, encompassingCIRTy);
2222 mlir::Value result, overflow;
2223 switch (builtinID) {
2225 llvm_unreachable(
"Unknown overflow builtin id.");
2226 case Builtin::BI__builtin_add_overflow:
2227 std::tie(result, overflow) =
2230 case Builtin::BI__builtin_sub_overflow:
2231 std::tie(result, overflow) =
2234 case Builtin::BI__builtin_mul_overflow:
2235 std::tie(result, overflow) =
2252 builder.createStore(loc, result, resultPtr, isVolatile);
2257 case Builtin::BI__builtin_uadd_overflow:
2258 case Builtin::BI__builtin_uaddl_overflow:
2259 case Builtin::BI__builtin_uaddll_overflow:
2260 case Builtin::BI__builtin_usub_overflow:
2261 case Builtin::BI__builtin_usubl_overflow:
2262 case Builtin::BI__builtin_usubll_overflow:
2263 case Builtin::BI__builtin_umul_overflow:
2264 case Builtin::BI__builtin_umull_overflow:
2265 case Builtin::BI__builtin_umulll_overflow:
2266 case Builtin::BI__builtin_sadd_overflow:
2267 case Builtin::BI__builtin_saddl_overflow:
2268 case Builtin::BI__builtin_saddll_overflow:
2269 case Builtin::BI__builtin_ssub_overflow:
2270 case Builtin::BI__builtin_ssubl_overflow:
2271 case Builtin::BI__builtin_ssubll_overflow:
2272 case Builtin::BI__builtin_smul_overflow:
2273 case Builtin::BI__builtin_smull_overflow:
2274 case Builtin::BI__builtin_smulll_overflow: {
2284 auto resultCIRTy = mlir::cast<cir::IntType>(
cgm.convertType(resultQTy));
2288 mlir::Value result, overflow;
2289 switch (builtinID) {
2291 llvm_unreachable(
"Unknown overflow builtin id.");
2292 case Builtin::BI__builtin_uadd_overflow:
2293 case Builtin::BI__builtin_uaddl_overflow:
2294 case Builtin::BI__builtin_uaddll_overflow:
2295 case Builtin::BI__builtin_sadd_overflow:
2296 case Builtin::BI__builtin_saddl_overflow:
2297 case Builtin::BI__builtin_saddll_overflow:
2298 std::tie(result, overflow) =
2301 case Builtin::BI__builtin_usub_overflow:
2302 case Builtin::BI__builtin_usubl_overflow:
2303 case Builtin::BI__builtin_usubll_overflow:
2304 case Builtin::BI__builtin_ssub_overflow:
2305 case Builtin::BI__builtin_ssubl_overflow:
2306 case Builtin::BI__builtin_ssubll_overflow:
2307 std::tie(result, overflow) =
2310 case Builtin::BI__builtin_umul_overflow:
2311 case Builtin::BI__builtin_umull_overflow:
2312 case Builtin::BI__builtin_umulll_overflow:
2313 case Builtin::BI__builtin_smul_overflow:
2314 case Builtin::BI__builtin_smull_overflow:
2315 case Builtin::BI__builtin_smulll_overflow:
2316 std::tie(result, overflow) =
2323 builder.createStore(loc,
emitToMemory(result, resultQTy), resultPtr,
2329 case Builtin::BIaddressof:
2330 case Builtin::BI__addressof:
2331 case Builtin::BI__builtin_addressof:
2333 case Builtin::BI__builtin_function_start:
2335 case Builtin::BI__builtin_operator_new:
2338 case Builtin::BI__builtin_operator_delete:
2342 case Builtin::BI__builtin_is_aligned:
2343 case Builtin::BI__builtin_align_up:
2344 case Builtin::BI__builtin_align_down:
2345 case Builtin::BI__noop:
2346 case Builtin::BI__builtin_call_with_static_chain:
2347 case Builtin::BI_InterlockedExchange8:
2348 case Builtin::BI_InterlockedExchange16:
2349 case Builtin::BI_InterlockedExchange:
2350 case Builtin::BI_InterlockedExchangePointer:
2351 case Builtin::BI_InterlockedCompareExchangePointer:
2352 case Builtin::BI_InterlockedCompareExchangePointer_nf:
2353 case Builtin::BI_InterlockedCompareExchange8:
2354 case Builtin::BI_InterlockedCompareExchange16:
2355 case Builtin::BI_InterlockedCompareExchange:
2356 case Builtin::BI_InterlockedCompareExchange64:
2357 case Builtin::BI_InterlockedIncrement16:
2358 case Builtin::BI_InterlockedIncrement:
2359 case Builtin::BI_InterlockedDecrement16:
2360 case Builtin::BI_InterlockedDecrement:
2361 case Builtin::BI_InterlockedAnd8:
2362 case Builtin::BI_InterlockedAnd16:
2363 case Builtin::BI_InterlockedAnd:
2364 case Builtin::BI_InterlockedExchangeAdd8:
2365 case Builtin::BI_InterlockedExchangeAdd16:
2366 case Builtin::BI_InterlockedExchangeAdd:
2367 case Builtin::BI_InterlockedExchangeSub8:
2368 case Builtin::BI_InterlockedExchangeSub16:
2369 case Builtin::BI_InterlockedExchangeSub:
2370 case Builtin::BI_InterlockedOr8:
2371 case Builtin::BI_InterlockedOr16:
2372 case Builtin::BI_InterlockedOr:
2373 case Builtin::BI_InterlockedXor8:
2374 case Builtin::BI_InterlockedXor16:
2375 case Builtin::BI_InterlockedXor:
2376 case Builtin::BI_bittest64:
2377 case Builtin::BI_bittest:
2378 case Builtin::BI_bittestandcomplement64:
2379 case Builtin::BI_bittestandcomplement:
2380 case Builtin::BI_bittestandreset64:
2381 case Builtin::BI_bittestandreset:
2382 case Builtin::BI_bittestandset64:
2383 case Builtin::BI_bittestandset:
2384 case Builtin::BI_interlockedbittestandreset:
2385 case Builtin::BI_interlockedbittestandreset64:
2386 case Builtin::BI_interlockedbittestandreset64_acq:
2387 case Builtin::BI_interlockedbittestandreset64_rel:
2388 case Builtin::BI_interlockedbittestandreset64_nf:
2389 case Builtin::BI_interlockedbittestandset64:
2390 case Builtin::BI_interlockedbittestandset64_acq:
2391 case Builtin::BI_interlockedbittestandset64_rel:
2392 case Builtin::BI_interlockedbittestandset64_nf:
2393 case Builtin::BI_interlockedbittestandset:
2394 case Builtin::BI_interlockedbittestandset_acq:
2395 case Builtin::BI_interlockedbittestandset_rel:
2396 case Builtin::BI_interlockedbittestandset_nf:
2397 case Builtin::BI_interlockedbittestandreset_acq:
2398 case Builtin::BI_interlockedbittestandreset_rel:
2399 case Builtin::BI_interlockedbittestandreset_nf:
2400 case Builtin::BI__iso_volatile_load8:
2401 case Builtin::BI__iso_volatile_load16:
2402 case Builtin::BI__iso_volatile_load32:
2403 case Builtin::BI__iso_volatile_load64:
2404 case Builtin::BI__iso_volatile_store8:
2405 case Builtin::BI__iso_volatile_store16:
2406 case Builtin::BI__iso_volatile_store32:
2407 case Builtin::BI__iso_volatile_store64:
2408 case Builtin::BI__builtin_ptrauth_sign_constant:
2409 case Builtin::BI__builtin_ptrauth_auth:
2410 case Builtin::BI__builtin_ptrauth_auth_and_resign:
2411 case Builtin::BI__builtin_ptrauth_blend_discriminator:
2412 case Builtin::BI__builtin_ptrauth_sign_generic_data:
2413 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
2414 case Builtin::BI__builtin_ptrauth_strip:
2415 case Builtin::BI__builtin_get_vtable_pointer:
2416 case Builtin::BI__exception_code:
2417 case Builtin::BI_exception_code:
2418 case Builtin::BI__exception_info:
2419 case Builtin::BI_exception_info:
2420 case Builtin::BI__abnormal_termination:
2421 case Builtin::BI_abnormal_termination:
2423 case Builtin::BI_setjmpex:
2424 case Builtin::BI_setjmp:
2431 case Builtin::BImove:
2432 case Builtin::BImove_if_noexcept:
2433 case Builtin::BIforward:
2434 case Builtin::BIforward_like:
2435 case Builtin::BIas_const:
2437 case Builtin::BI__GetExceptionInfo:
2438 case Builtin::BI__fastfail:
2439 case Builtin::BIread_pipe:
2440 case Builtin::BIwrite_pipe:
2441 case Builtin::BIreserve_read_pipe:
2442 case Builtin::BIreserve_write_pipe:
2443 case Builtin::BIwork_group_reserve_read_pipe:
2444 case Builtin::BIwork_group_reserve_write_pipe:
2445 case Builtin::BIsub_group_reserve_read_pipe:
2446 case Builtin::BIsub_group_reserve_write_pipe:
2447 case Builtin::BIcommit_read_pipe:
2448 case Builtin::BIcommit_write_pipe:
2449 case Builtin::BIwork_group_commit_read_pipe:
2450 case Builtin::BIwork_group_commit_write_pipe:
2451 case Builtin::BIsub_group_commit_read_pipe:
2452 case Builtin::BIsub_group_commit_write_pipe:
2453 case Builtin::BIget_pipe_num_packets:
2454 case Builtin::BIget_pipe_max_packets:
2455 case Builtin::BIto_global:
2456 case Builtin::BIto_local:
2457 case Builtin::BIto_private:
2458 case Builtin::BIenqueue_kernel:
2459 case Builtin::BIget_kernel_work_group_size:
2460 case Builtin::BIget_kernel_preferred_work_group_size_multiple:
2461 case Builtin::BIget_kernel_max_sub_group_size_for_ndrange:
2462 case Builtin::BIget_kernel_sub_group_count_for_ndrange:
2463 case Builtin::BI__builtin_store_half:
2464 case Builtin::BI__builtin_store_halff:
2465 case Builtin::BI__builtin_load_half:
2466 case Builtin::BI__builtin_load_halff:
2468 case Builtin::BI__builtin_printf:
2469 case Builtin::BIprintf:
2482 case Builtin::BI__builtin_canonicalize:
2483 case Builtin::BI__builtin_canonicalizef:
2484 case Builtin::BI__builtin_canonicalizef16:
2485 case Builtin::BI__builtin_canonicalizel:
2486 case Builtin::BI__builtin_thread_pointer:
2487 case Builtin::BI__builtin_os_log_format:
2488 case Builtin::BI__xray_customevent:
2489 case Builtin::BI__xray_typedevent:
2490 case Builtin::BI__builtin_ms_va_start:
2491 case Builtin::BI__builtin_ms_va_end:
2492 case Builtin::BI__builtin_ms_va_copy:
2493 case Builtin::BI__builtin_get_device_side_mangled_name:
2501 getContext().BuiltinInfo.isLibFunction(builtinID))
2503 cgm.getBuiltinLibFunction(fd, builtinID));
2507 if (
getContext().BuiltinInfo.isPredefinedLibFunction(builtinID))
2513 Intrinsic::ID intrinsicID = Intrinsic::not_intrinsic;
2516 if (!prefix.empty()) {
2517 intrinsicID = Intrinsic::getIntrinsicForClangBuiltin(prefix, name);
2521 if (intrinsicID == Intrinsic::not_intrinsic)
2522 intrinsicID = Intrinsic::getIntrinsicForMSBuiltin(prefix, name);
2525 if (intrinsicID != Intrinsic::not_intrinsic) {
2526 unsigned iceArguments = 0;
2531 StringRef name = Intrinsic::getName(intrinsicID);
2535 assert(name.starts_with(
"llvm.") &&
"expected llvm. prefix");
2536 name = name.drop_front(5);
2538 cir::FuncType intrinsicType =
2543 for (
unsigned i = 0; i < e->
getNumArgs(); i++) {
2544 mlir::Value argValue =
2548 mlir::Type argType = argValue.getType();
2549 mlir::Type expectedTy = intrinsicType.getInput(i);
2552 mlir::Type correctedExpectedTy = expectedTy;
2553 if (fd && i < fd->getNumParams()) {
2558 if (mlir::isa<cir::PointerType>(expectedTy)) {
2559 bool argIsPointer = mlir::isa<cir::PointerType>(argType);
2560 bool argIsVectorOfPointer =
false;
2561 if (
auto vecTy = dyn_cast<mlir::VectorType>(argType))
2562 argIsVectorOfPointer =
2563 mlir::isa<cir::PointerType>(vecTy.getElementType());
2565 if (!argIsPointer && !argIsVectorOfPointer) {
2568 "intrinsic expects a pointer type (NYI for non-pointer)");
2573 if (argType != expectedTy)
2578 if (argType != correctedExpectedTy)
2579 argValue = builder.createBitcast(argValue, correctedExpectedTy);
2582 args.push_back(argValue);
2587 mlir::Type correctedReturnType = intrinsicType.
getReturnType();
2589 correctedReturnType =
2594 cir::LLVMIntrinsicCallOp intrinsicCall = cir::LLVMIntrinsicCallOp::create(
2596 correctedReturnType, args);
2598 mlir::Value intrinsicRes = intrinsicCall.getResult();
2622 if (std::optional<mlir::Value> rst =
2624 mlir::Value v = rst.value();
2632 if (mlir::isa<cir::VoidType>(v.getType()))
2639 llvm_unreachable(
"No current target builtin returns complex");
2641 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");
2645 std::string(
"unimplemented builtin call: ") +
2646 getContext().BuiltinInfo.getName(builtinID));