3017 assert(!
getContext().BuiltinInfo.isImmediate(BuiltinID) &&
3018 "Should not codegen for consteval builtins");
3025 !
Result.hasSideEffects()) {
3029 if (
Result.Val.isFloat())
3039 &
getTarget().getLongDoubleFormat() == &llvm::APFloat::IEEEquad())
3046 const unsigned BuiltinIDIfNoAsmLabel =
3047 FD->
hasAttr<AsmLabelAttr>() ? 0 : BuiltinID;
3049 std::optional<bool> ErrnoOverriden;
3055 if (OP.hasMathErrnoOverride())
3056 ErrnoOverriden = OP.getMathErrnoOverride();
3062 bool IsOptimizationEnabled =
CGM.getCodeGenOpts().OptimizationLevel != 0;
3064 bool GenerateFPMathIntrinsics =
3066 BuiltinID,
CGM.getTriple(), ErrnoOverriden,
getLangOpts().MathErrno,
3067 OptNone, IsOptimizationEnabled);
3069 if (GenerateFPMathIntrinsics) {
3070 switch (BuiltinIDIfNoAsmLabel) {
3071 case Builtin::BIacos:
3072 case Builtin::BIacosf:
3073 case Builtin::BIacosl:
3074 case Builtin::BI__builtin_acos:
3075 case Builtin::BI__builtin_acosf:
3076 case Builtin::BI__builtin_acosf16:
3077 case Builtin::BI__builtin_acosl:
3078 case Builtin::BI__builtin_acosf128:
3079 case Builtin::BI__builtin_elementwise_acos:
3081 *
this, E, Intrinsic::acos, Intrinsic::experimental_constrained_acos));
3083 case Builtin::BIasin:
3084 case Builtin::BIasinf:
3085 case Builtin::BIasinl:
3086 case Builtin::BI__builtin_asin:
3087 case Builtin::BI__builtin_asinf:
3088 case Builtin::BI__builtin_asinf16:
3089 case Builtin::BI__builtin_asinl:
3090 case Builtin::BI__builtin_asinf128:
3091 case Builtin::BI__builtin_elementwise_asin:
3093 *
this, E, Intrinsic::asin, Intrinsic::experimental_constrained_asin));
3095 case Builtin::BIatan:
3096 case Builtin::BIatanf:
3097 case Builtin::BIatanl:
3098 case Builtin::BI__builtin_atan:
3099 case Builtin::BI__builtin_atanf:
3100 case Builtin::BI__builtin_atanf16:
3101 case Builtin::BI__builtin_atanl:
3102 case Builtin::BI__builtin_atanf128:
3103 case Builtin::BI__builtin_elementwise_atan:
3105 *
this, E, Intrinsic::atan, Intrinsic::experimental_constrained_atan));
3107 case Builtin::BIatan2:
3108 case Builtin::BIatan2f:
3109 case Builtin::BIatan2l:
3110 case Builtin::BI__builtin_atan2:
3111 case Builtin::BI__builtin_atan2f:
3112 case Builtin::BI__builtin_atan2f16:
3113 case Builtin::BI__builtin_atan2l:
3114 case Builtin::BI__builtin_atan2f128:
3115 case Builtin::BI__builtin_elementwise_atan2:
3117 *
this, E, Intrinsic::atan2,
3118 Intrinsic::experimental_constrained_atan2));
3120 case Builtin::BIceil:
3121 case Builtin::BIceilf:
3122 case Builtin::BIceill:
3123 case Builtin::BI__builtin_ceil:
3124 case Builtin::BI__builtin_ceilf:
3125 case Builtin::BI__builtin_ceilf16:
3126 case Builtin::BI__builtin_ceill:
3127 case Builtin::BI__builtin_ceilf128:
3128 case Builtin::BI__builtin_elementwise_ceil:
3131 Intrinsic::experimental_constrained_ceil));
3133 case Builtin::BIcopysign:
3134 case Builtin::BIcopysignf:
3135 case Builtin::BIcopysignl:
3136 case Builtin::BI__builtin_copysign:
3137 case Builtin::BI__builtin_copysignf:
3138 case Builtin::BI__builtin_copysignf16:
3139 case Builtin::BI__builtin_copysignl:
3140 case Builtin::BI__builtin_copysignf128:
3144 case Builtin::BIcos:
3145 case Builtin::BIcosf:
3146 case Builtin::BIcosl:
3147 case Builtin::BI__builtin_cos:
3148 case Builtin::BI__builtin_cosf:
3149 case Builtin::BI__builtin_cosf16:
3150 case Builtin::BI__builtin_cosl:
3151 case Builtin::BI__builtin_cosf128:
3152 case Builtin::BI__builtin_elementwise_cos:
3155 Intrinsic::experimental_constrained_cos));
3157 case Builtin::BIcosh:
3158 case Builtin::BIcoshf:
3159 case Builtin::BIcoshl:
3160 case Builtin::BI__builtin_cosh:
3161 case Builtin::BI__builtin_coshf:
3162 case Builtin::BI__builtin_coshf16:
3163 case Builtin::BI__builtin_coshl:
3164 case Builtin::BI__builtin_coshf128:
3165 case Builtin::BI__builtin_elementwise_cosh:
3167 *
this, E, Intrinsic::cosh, Intrinsic::experimental_constrained_cosh));
3169 case Builtin::BIexp:
3170 case Builtin::BIexpf:
3171 case Builtin::BIexpl:
3172 case Builtin::BI__builtin_exp:
3173 case Builtin::BI__builtin_expf:
3174 case Builtin::BI__builtin_expf16:
3175 case Builtin::BI__builtin_expl:
3176 case Builtin::BI__builtin_expf128:
3177 case Builtin::BI__builtin_elementwise_exp:
3180 Intrinsic::experimental_constrained_exp));
3182 case Builtin::BIexp2:
3183 case Builtin::BIexp2f:
3184 case Builtin::BIexp2l:
3185 case Builtin::BI__builtin_exp2:
3186 case Builtin::BI__builtin_exp2f:
3187 case Builtin::BI__builtin_exp2f16:
3188 case Builtin::BI__builtin_exp2l:
3189 case Builtin::BI__builtin_exp2f128:
3190 case Builtin::BI__builtin_elementwise_exp2:
3193 Intrinsic::experimental_constrained_exp2));
3194 case Builtin::BI__builtin_exp10:
3195 case Builtin::BI__builtin_exp10f:
3196 case Builtin::BI__builtin_exp10f16:
3197 case Builtin::BI__builtin_exp10l:
3198 case Builtin::BI__builtin_exp10f128:
3199 case Builtin::BI__builtin_elementwise_exp10: {
3201 if (
Builder.getIsFPConstrained())
3206 case Builtin::BIfabs:
3207 case Builtin::BIfabsf:
3208 case Builtin::BIfabsl:
3209 case Builtin::BI__builtin_fabs:
3210 case Builtin::BI__builtin_fabsf:
3211 case Builtin::BI__builtin_fabsf16:
3212 case Builtin::BI__builtin_fabsl:
3213 case Builtin::BI__builtin_fabsf128:
3217 case Builtin::BIfloor:
3218 case Builtin::BIfloorf:
3219 case Builtin::BIfloorl:
3220 case Builtin::BI__builtin_floor:
3221 case Builtin::BI__builtin_floorf:
3222 case Builtin::BI__builtin_floorf16:
3223 case Builtin::BI__builtin_floorl:
3224 case Builtin::BI__builtin_floorf128:
3225 case Builtin::BI__builtin_elementwise_floor:
3228 Intrinsic::experimental_constrained_floor));
3230 case Builtin::BIfma:
3231 case Builtin::BIfmaf:
3232 case Builtin::BIfmal:
3233 case Builtin::BI__builtin_fma:
3234 case Builtin::BI__builtin_fmaf:
3235 case Builtin::BI__builtin_fmaf16:
3236 case Builtin::BI__builtin_fmal:
3237 case Builtin::BI__builtin_fmaf128:
3238 case Builtin::BI__builtin_elementwise_fma:
3241 Intrinsic::experimental_constrained_fma));
3243 case Builtin::BIfmax:
3244 case Builtin::BIfmaxf:
3245 case Builtin::BIfmaxl:
3246 case Builtin::BI__builtin_fmax:
3247 case Builtin::BI__builtin_fmaxf:
3248 case Builtin::BI__builtin_fmaxf16:
3249 case Builtin::BI__builtin_fmaxl:
3250 case Builtin::BI__builtin_fmaxf128: {
3251 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
3252 Builder.getFastMathFlags().setNoSignedZeros();
3254 *
this, E, Intrinsic::maxnum,
3255 Intrinsic::experimental_constrained_maxnum));
3258 case Builtin::BIfmin:
3259 case Builtin::BIfminf:
3260 case Builtin::BIfminl:
3261 case Builtin::BI__builtin_fmin:
3262 case Builtin::BI__builtin_fminf:
3263 case Builtin::BI__builtin_fminf16:
3264 case Builtin::BI__builtin_fminl:
3265 case Builtin::BI__builtin_fminf128: {
3266 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
3267 Builder.getFastMathFlags().setNoSignedZeros();
3269 *
this, E, Intrinsic::minnum,
3270 Intrinsic::experimental_constrained_minnum));
3273 case Builtin::BIfmaximum_num:
3274 case Builtin::BIfmaximum_numf:
3275 case Builtin::BIfmaximum_numl:
3276 case Builtin::BI__builtin_fmaximum_num:
3277 case Builtin::BI__builtin_fmaximum_numf:
3278 case Builtin::BI__builtin_fmaximum_numf16:
3279 case Builtin::BI__builtin_fmaximum_numl:
3280 case Builtin::BI__builtin_fmaximum_numf128:
3284 case Builtin::BIfminimum_num:
3285 case Builtin::BIfminimum_numf:
3286 case Builtin::BIfminimum_numl:
3287 case Builtin::BI__builtin_fminimum_num:
3288 case Builtin::BI__builtin_fminimum_numf:
3289 case Builtin::BI__builtin_fminimum_numf16:
3290 case Builtin::BI__builtin_fminimum_numl:
3291 case Builtin::BI__builtin_fminimum_numf128:
3297 case Builtin::BIfmod:
3298 case Builtin::BIfmodf:
3299 case Builtin::BIfmodl:
3300 case Builtin::BI__builtin_fmod:
3301 case Builtin::BI__builtin_fmodf:
3302 case Builtin::BI__builtin_fmodf16:
3303 case Builtin::BI__builtin_fmodl:
3304 case Builtin::BI__builtin_fmodf128:
3305 case Builtin::BI__builtin_elementwise_fmod: {
3309 if (
Builder.getIsFPConstrained()) {
3310 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_frem,
3318 case Builtin::BIlog:
3319 case Builtin::BIlogf:
3320 case Builtin::BIlogl:
3321 case Builtin::BI__builtin_log:
3322 case Builtin::BI__builtin_logf:
3323 case Builtin::BI__builtin_logf16:
3324 case Builtin::BI__builtin_logl:
3325 case Builtin::BI__builtin_logf128:
3326 case Builtin::BI__builtin_elementwise_log:
3329 Intrinsic::experimental_constrained_log));
3331 case Builtin::BIlog10:
3332 case Builtin::BIlog10f:
3333 case Builtin::BIlog10l:
3334 case Builtin::BI__builtin_log10:
3335 case Builtin::BI__builtin_log10f:
3336 case Builtin::BI__builtin_log10f16:
3337 case Builtin::BI__builtin_log10l:
3338 case Builtin::BI__builtin_log10f128:
3339 case Builtin::BI__builtin_elementwise_log10:
3342 Intrinsic::experimental_constrained_log10));
3344 case Builtin::BIlog2:
3345 case Builtin::BIlog2f:
3346 case Builtin::BIlog2l:
3347 case Builtin::BI__builtin_log2:
3348 case Builtin::BI__builtin_log2f:
3349 case Builtin::BI__builtin_log2f16:
3350 case Builtin::BI__builtin_log2l:
3351 case Builtin::BI__builtin_log2f128:
3352 case Builtin::BI__builtin_elementwise_log2:
3355 Intrinsic::experimental_constrained_log2));
3357 case Builtin::BInearbyint:
3358 case Builtin::BInearbyintf:
3359 case Builtin::BInearbyintl:
3360 case Builtin::BI__builtin_nearbyint:
3361 case Builtin::BI__builtin_nearbyintf:
3362 case Builtin::BI__builtin_nearbyintl:
3363 case Builtin::BI__builtin_nearbyintf128:
3364 case Builtin::BI__builtin_elementwise_nearbyint:
3366 Intrinsic::nearbyint,
3367 Intrinsic::experimental_constrained_nearbyint));
3369 case Builtin::BIpow:
3370 case Builtin::BIpowf:
3371 case Builtin::BIpowl:
3372 case Builtin::BI__builtin_pow:
3373 case Builtin::BI__builtin_powf:
3374 case Builtin::BI__builtin_powf16:
3375 case Builtin::BI__builtin_powl:
3376 case Builtin::BI__builtin_powf128:
3377 case Builtin::BI__builtin_elementwise_pow:
3380 Intrinsic::experimental_constrained_pow));
3382 case Builtin::BIrint:
3383 case Builtin::BIrintf:
3384 case Builtin::BIrintl:
3385 case Builtin::BI__builtin_rint:
3386 case Builtin::BI__builtin_rintf:
3387 case Builtin::BI__builtin_rintf16:
3388 case Builtin::BI__builtin_rintl:
3389 case Builtin::BI__builtin_rintf128:
3390 case Builtin::BI__builtin_elementwise_rint:
3393 Intrinsic::experimental_constrained_rint));
3395 case Builtin::BIround:
3396 case Builtin::BIroundf:
3397 case Builtin::BIroundl:
3398 case Builtin::BI__builtin_round:
3399 case Builtin::BI__builtin_roundf:
3400 case Builtin::BI__builtin_roundf16:
3401 case Builtin::BI__builtin_roundl:
3402 case Builtin::BI__builtin_roundf128:
3403 case Builtin::BI__builtin_elementwise_round:
3406 Intrinsic::experimental_constrained_round));
3408 case Builtin::BIroundeven:
3409 case Builtin::BIroundevenf:
3410 case Builtin::BIroundevenl:
3411 case Builtin::BI__builtin_roundeven:
3412 case Builtin::BI__builtin_roundevenf:
3413 case Builtin::BI__builtin_roundevenf16:
3414 case Builtin::BI__builtin_roundevenl:
3415 case Builtin::BI__builtin_roundevenf128:
3416 case Builtin::BI__builtin_elementwise_roundeven:
3418 Intrinsic::roundeven,
3419 Intrinsic::experimental_constrained_roundeven));
3421 case Builtin::BIsin:
3422 case Builtin::BIsinf:
3423 case Builtin::BIsinl:
3424 case Builtin::BI__builtin_sin:
3425 case Builtin::BI__builtin_sinf:
3426 case Builtin::BI__builtin_sinf16:
3427 case Builtin::BI__builtin_sinl:
3428 case Builtin::BI__builtin_sinf128:
3429 case Builtin::BI__builtin_elementwise_sin:
3432 Intrinsic::experimental_constrained_sin));
3434 case Builtin::BIsinh:
3435 case Builtin::BIsinhf:
3436 case Builtin::BIsinhl:
3437 case Builtin::BI__builtin_sinh:
3438 case Builtin::BI__builtin_sinhf:
3439 case Builtin::BI__builtin_sinhf16:
3440 case Builtin::BI__builtin_sinhl:
3441 case Builtin::BI__builtin_sinhf128:
3442 case Builtin::BI__builtin_elementwise_sinh:
3444 *
this, E, Intrinsic::sinh, Intrinsic::experimental_constrained_sinh));
3446 case Builtin::BI__builtin_sincospi:
3447 case Builtin::BI__builtin_sincospif:
3448 case Builtin::BI__builtin_sincospil:
3449 if (
Builder.getIsFPConstrained())
3454 case Builtin::BIsincos:
3455 case Builtin::BIsincosf:
3456 case Builtin::BIsincosl:
3457 case Builtin::BI__builtin_sincos:
3458 case Builtin::BI__builtin_sincosf:
3459 case Builtin::BI__builtin_sincosf16:
3460 case Builtin::BI__builtin_sincosl:
3461 case Builtin::BI__builtin_sincosf128:
3462 if (
Builder.getIsFPConstrained())
3467 case Builtin::BIsqrt:
3468 case Builtin::BIsqrtf:
3469 case Builtin::BIsqrtl:
3470 case Builtin::BI__builtin_sqrt:
3471 case Builtin::BI__builtin_sqrtf:
3472 case Builtin::BI__builtin_sqrtf16:
3473 case Builtin::BI__builtin_sqrtl:
3474 case Builtin::BI__builtin_sqrtf128:
3475 case Builtin::BI__builtin_elementwise_sqrt: {
3477 *
this, E, Intrinsic::sqrt, Intrinsic::experimental_constrained_sqrt);
3482 case Builtin::BItan:
3483 case Builtin::BItanf:
3484 case Builtin::BItanl:
3485 case Builtin::BI__builtin_tan:
3486 case Builtin::BI__builtin_tanf:
3487 case Builtin::BI__builtin_tanf16:
3488 case Builtin::BI__builtin_tanl:
3489 case Builtin::BI__builtin_tanf128:
3490 case Builtin::BI__builtin_elementwise_tan:
3492 *
this, E, Intrinsic::tan, Intrinsic::experimental_constrained_tan));
3494 case Builtin::BItanh:
3495 case Builtin::BItanhf:
3496 case Builtin::BItanhl:
3497 case Builtin::BI__builtin_tanh:
3498 case Builtin::BI__builtin_tanhf:
3499 case Builtin::BI__builtin_tanhf16:
3500 case Builtin::BI__builtin_tanhl:
3501 case Builtin::BI__builtin_tanhf128:
3502 case Builtin::BI__builtin_elementwise_tanh:
3504 *
this, E, Intrinsic::tanh, Intrinsic::experimental_constrained_tanh));
3506 case Builtin::BItrunc:
3507 case Builtin::BItruncf:
3508 case Builtin::BItruncl:
3509 case Builtin::BI__builtin_trunc:
3510 case Builtin::BI__builtin_truncf:
3511 case Builtin::BI__builtin_truncf16:
3512 case Builtin::BI__builtin_truncl:
3513 case Builtin::BI__builtin_truncf128:
3514 case Builtin::BI__builtin_elementwise_trunc:
3517 Intrinsic::experimental_constrained_trunc));
3519 case Builtin::BIlround:
3520 case Builtin::BIlroundf:
3521 case Builtin::BIlroundl:
3522 case Builtin::BI__builtin_lround:
3523 case Builtin::BI__builtin_lroundf:
3524 case Builtin::BI__builtin_lroundl:
3525 case Builtin::BI__builtin_lroundf128:
3527 *
this, E, Intrinsic::lround,
3528 Intrinsic::experimental_constrained_lround));
3530 case Builtin::BIllround:
3531 case Builtin::BIllroundf:
3532 case Builtin::BIllroundl:
3533 case Builtin::BI__builtin_llround:
3534 case Builtin::BI__builtin_llroundf:
3535 case Builtin::BI__builtin_llroundl:
3536 case Builtin::BI__builtin_llroundf128:
3538 *
this, E, Intrinsic::llround,
3539 Intrinsic::experimental_constrained_llround));
3541 case Builtin::BIlrint:
3542 case Builtin::BIlrintf:
3543 case Builtin::BIlrintl:
3544 case Builtin::BI__builtin_lrint:
3545 case Builtin::BI__builtin_lrintf:
3546 case Builtin::BI__builtin_lrintl:
3547 case Builtin::BI__builtin_lrintf128:
3549 *
this, E, Intrinsic::lrint,
3550 Intrinsic::experimental_constrained_lrint));
3552 case Builtin::BIllrint:
3553 case Builtin::BIllrintf:
3554 case Builtin::BIllrintl:
3555 case Builtin::BI__builtin_llrint:
3556 case Builtin::BI__builtin_llrintf:
3557 case Builtin::BI__builtin_llrintl:
3558 case Builtin::BI__builtin_llrintf128:
3560 *
this, E, Intrinsic::llrint,
3561 Intrinsic::experimental_constrained_llrint));
3562 case Builtin::BI__builtin_ldexp:
3563 case Builtin::BI__builtin_ldexpf:
3564 case Builtin::BI__builtin_ldexpl:
3565 case Builtin::BI__builtin_ldexpf16:
3566 case Builtin::BI__builtin_ldexpf128:
3567 case Builtin::BI__builtin_elementwise_ldexp:
3569 *
this, E, Intrinsic::ldexp,
3570 Intrinsic::experimental_constrained_ldexp));
3579 Value *Val = A.emitRawPointer(*
this);
3583 if (
SanOpts.has(SanitizerKind::Alignment)) {
3585 SkippedChecks.
set(SanitizerKind::All);
3586 SkippedChecks.
clear(SanitizerKind::Alignment);
3589 if (
auto *CE = dyn_cast<ImplicitCastExpr>(Arg))
3590 if (CE->getCastKind() == CK_BitCast)
3591 Arg = CE->getSubExpr();
3597 switch (BuiltinIDIfNoAsmLabel) {
3599 case Builtin::BI__builtin___CFStringMakeConstantString:
3600 case Builtin::BI__builtin___NSStringMakeConstantString:
3602 case Builtin::BI__builtin_stdarg_start:
3603 case Builtin::BI__builtin_va_start:
3604 case Builtin::BI__va_start:
3605 case Builtin::BI__builtin_c23_va_start:
3606 case Builtin::BI__builtin_va_end:
3610 BuiltinID != Builtin::BI__builtin_va_end);
3612 case Builtin::BI__builtin_va_copy: {
3615 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::vacopy, {DstPtr->getType()}),
3619 case Builtin::BIabs:
3620 case Builtin::BIlabs:
3621 case Builtin::BIllabs:
3622 case Builtin::BI__builtin_abs:
3623 case Builtin::BI__builtin_labs:
3624 case Builtin::BI__builtin_llabs: {
3625 bool SanitizeOverflow =
SanOpts.has(SanitizerKind::SignedIntegerOverflow);
3628 switch (
getLangOpts().getSignedOverflowBehavior()) {
3633 if (!SanitizeOverflow) {
3645 case Builtin::BI__builtin_complex: {
3650 case Builtin::BI__builtin_conj:
3651 case Builtin::BI__builtin_conjf:
3652 case Builtin::BI__builtin_conjl:
3653 case Builtin::BIconj:
3654 case Builtin::BIconjf:
3655 case Builtin::BIconjl: {
3657 Value *Real = ComplexVal.first;
3658 Value *Imag = ComplexVal.second;
3659 Imag =
Builder.CreateFNeg(Imag,
"neg");
3662 case Builtin::BI__builtin_creal:
3663 case Builtin::BI__builtin_crealf:
3664 case Builtin::BI__builtin_creall:
3665 case Builtin::BIcreal:
3666 case Builtin::BIcrealf:
3667 case Builtin::BIcreall: {
3672 case Builtin::BI__builtin_preserve_access_index: {
3677 CGM.Error(E->
getExprLoc(),
"using builtin_preserve_access_index() without -g");
3683 CGM.Error(E->
getExprLoc(),
"nested builtin_preserve_access_index() not supported");
3693 case Builtin::BI__builtin_cimag:
3694 case Builtin::BI__builtin_cimagf:
3695 case Builtin::BI__builtin_cimagl:
3696 case Builtin::BIcimag:
3697 case Builtin::BIcimagf:
3698 case Builtin::BIcimagl: {
3703 case Builtin::BI__builtin_clrsb:
3704 case Builtin::BI__builtin_clrsbl:
3705 case Builtin::BI__builtin_clrsbll: {
3716 Value *Tmp =
Builder.CreateSelect(IsNeg, Inverse, ArgValue);
3724 case Builtin::BI__builtin_ctzs:
3725 case Builtin::BI__builtin_ctz:
3726 case Builtin::BI__builtin_ctzl:
3727 case Builtin::BI__builtin_ctzll:
3728 case Builtin::BI__builtin_ctzg:
3729 case Builtin::BI__builtin_elementwise_ctzg: {
3731 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_ctzg ||
3732 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg) &&
3745 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3746 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg);
3748 if (
Result->getType() != ResultType)
3757 Value *ResultOrFallback =
3758 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"ctzg");
3761 case Builtin::BI__builtin_clzs:
3762 case Builtin::BI__builtin_clz:
3763 case Builtin::BI__builtin_clzl:
3764 case Builtin::BI__builtin_clzll:
3765 case Builtin::BI__builtin_clzg:
3766 case Builtin::BI__builtin_elementwise_clzg: {
3768 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_clzg ||
3769 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg) &&
3782 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3783 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg);
3785 if (
Result->getType() != ResultType)
3794 Value *ResultOrFallback =
3795 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"clzg");
3798 case Builtin::BI__builtin_ffs:
3799 case Builtin::BI__builtin_ffsl:
3800 case Builtin::BI__builtin_ffsll: {
3809 Builder.CreateAdd(
Builder.CreateCall(F, {ArgValue, Builder.getTrue()}),
3810 llvm::ConstantInt::get(
ArgType, 1));
3814 if (
Result->getType() != ResultType)
3819 case Builtin::BI__builtin_parity:
3820 case Builtin::BI__builtin_parityl:
3821 case Builtin::BI__builtin_parityll: {
3831 if (
Result->getType() != ResultType)
3836 case Builtin::BI__lzcnt16:
3837 case Builtin::BI__lzcnt:
3838 case Builtin::BI__lzcnt64: {
3846 if (
Result->getType() != ResultType)
3851 case Builtin::BI__popcnt16:
3852 case Builtin::BI__popcnt:
3853 case Builtin::BI__popcnt64:
3854 case Builtin::BI__builtin_popcount:
3855 case Builtin::BI__builtin_popcountl:
3856 case Builtin::BI__builtin_popcountll:
3857 case Builtin::BI__builtin_popcountg: {
3865 if (
Result->getType() != ResultType)
3870 case Builtin::BI__builtin_unpredictable: {
3876 case Builtin::BI__builtin_expect: {
3884 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3889 Builder.CreateCall(FnExpect, {ArgValue, ExpectedValue},
"expval");
3892 case Builtin::BI__builtin_expect_with_probability: {
3897 llvm::APFloat Probability(0.0);
3900 assert(EvalSucceed &&
"probability should be able to evaluate as float");
3902 bool LoseInfo =
false;
3903 Probability.convert(llvm::APFloat::IEEEdouble(),
3904 llvm::RoundingMode::Dynamic, &LoseInfo);
3906 Constant *Confidence = ConstantFP::get(Ty, Probability);
3910 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3914 CGM.getIntrinsic(Intrinsic::expect_with_probability,
ArgType);
3916 FnExpect, {ArgValue, ExpectedValue, Confidence},
"expval");
3919 case Builtin::BI__builtin_assume_aligned: {
3922 Value *OffsetValue =
3927 if (AlignmentCI->getValue().ugt(llvm::Value::MaximumAlignment))
3928 AlignmentCI = ConstantInt::get(AlignmentCI->getIntegerType(),
3929 llvm::Value::MaximumAlignment);
3933 AlignmentCI, OffsetValue);
3936 case Builtin::BI__builtin_assume_dereferenceable: {
3944 Builder.CreateDereferenceableAssumption(PtrValue, SizeValue);
3947 case Builtin::BI__assume:
3948 case Builtin::BI__builtin_assume: {
3953 Function *FnAssume =
CGM.getIntrinsic(Intrinsic::assume);
3954 Builder.CreateCall(FnAssume, ArgValue);
3957 case Builtin::BI__builtin_assume_separate_storage: {
3964 Value *Values[] = {Value0, Value1};
3965 OperandBundleDefT<Value *> OBD(
"separate_storage", Values);
3966 Builder.CreateAssumption({OBD});
3969 case Builtin::BI__builtin_allow_runtime_check: {
3972 LLVMContext &Ctx =
CGM.getLLVMContext();
3974 CGM.getIntrinsic(Intrinsic::allow_runtime_check),
3975 llvm::MetadataAsValue::get(Ctx, llvm::MDString::get(Ctx, Kind)));
3978 case Builtin::BI__builtin_allow_sanitize_check: {
3979 Intrinsic::ID IntrID = Intrinsic::not_intrinsic;
3987 if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Address |
3988 SanitizerKind::KernelAddress) &&
3989 (Name ==
"address" || Name ==
"kernel-address")) {
3990 IntrID = Intrinsic::allow_sanitize_address;
3991 }
else if (
getLangOpts().Sanitize.has(SanitizerKind::Thread) &&
3993 IntrID = Intrinsic::allow_sanitize_thread;
3994 }
else if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Memory |
3995 SanitizerKind::KernelMemory) &&
3996 (Name ==
"memory" || Name ==
"kernel-memory")) {
3997 IntrID = Intrinsic::allow_sanitize_memory;
3999 SanitizerKind::HWAddress | SanitizerKind::KernelHWAddress) &&
4000 (Name ==
"hwaddress" || Name ==
"kernel-hwaddress")) {
4001 IntrID = Intrinsic::allow_sanitize_hwaddress;
4004 if (IntrID != Intrinsic::not_intrinsic) {
4013 case Builtin::BI__arithmetic_fence: {
4017 llvm::FastMathFlags FMF =
Builder.getFastMathFlags();
4018 bool isArithmeticFenceEnabled =
4019 FMF.allowReassoc() &&
4022 if (
ArgType->isComplexType()) {
4023 if (isArithmeticFenceEnabled) {
4026 Value *Real =
Builder.CreateArithmeticFence(ComplexVal.first,
4028 Value *Imag =
Builder.CreateArithmeticFence(ComplexVal.second,
4033 Value *Real = ComplexVal.first;
4034 Value *Imag = ComplexVal.second;
4038 if (isArithmeticFenceEnabled)
4043 case Builtin::BI__builtin_bswapg: {
4046 assert(
IntTy &&
"LLVM's __builtin_bswapg only supports integer variants");
4047 if (
IntTy->getBitWidth() == 1 ||
IntTy->getBitWidth() == 8)
4049 assert(((
IntTy->getBitWidth() % 16 == 0 &&
IntTy->getBitWidth() != 0)) &&
4050 "LLVM's __builtin_bswapg only supports integer variants that has a "
4051 "multiple of 16 bits as well as a single byte");
4055 case Builtin::BI__builtin_bswap16:
4056 case Builtin::BI__builtin_bswap32:
4057 case Builtin::BI__builtin_bswap64:
4058 case Builtin::BI_byteswap_ushort:
4059 case Builtin::BI_byteswap_ulong:
4060 case Builtin::BI_byteswap_uint64: {
4064 case Builtin::BI__builtin_bitreverseg: {
4068 "LLVM's __builtin_bitreverseg only support integer variants");
4069 if (
IntTy->getBitWidth() == 1)
4074 case Builtin::BI__builtin_bitreverse8:
4075 case Builtin::BI__builtin_bitreverse16:
4076 case Builtin::BI__builtin_bitreverse32:
4077 case Builtin::BI__builtin_bitreverse64: {
4081 case Builtin::BI__builtin_rotateleft8:
4082 case Builtin::BI__builtin_rotateleft16:
4083 case Builtin::BI__builtin_rotateleft32:
4084 case Builtin::BI__builtin_rotateleft64:
4085 case Builtin::BI__builtin_stdc_rotate_left:
4086 case Builtin::BIstdc_rotate_left_uc:
4087 case Builtin::BIstdc_rotate_left_us:
4088 case Builtin::BIstdc_rotate_left_ui:
4089 case Builtin::BIstdc_rotate_left_ul:
4090 case Builtin::BIstdc_rotate_left_ull:
4091 case Builtin::BI_rotl8:
4092 case Builtin::BI_rotl16:
4093 case Builtin::BI_rotl:
4094 case Builtin::BI_lrotl:
4095 case Builtin::BI_rotl64:
4098 case Builtin::BI__builtin_rotateright8:
4099 case Builtin::BI__builtin_rotateright16:
4100 case Builtin::BI__builtin_rotateright32:
4101 case Builtin::BI__builtin_rotateright64:
4102 case Builtin::BI__builtin_stdc_rotate_right:
4103 case Builtin::BIstdc_rotate_right_uc:
4104 case Builtin::BIstdc_rotate_right_us:
4105 case Builtin::BIstdc_rotate_right_ui:
4106 case Builtin::BIstdc_rotate_right_ul:
4107 case Builtin::BIstdc_rotate_right_ull:
4108 case Builtin::BI_rotr8:
4109 case Builtin::BI_rotr16:
4110 case Builtin::BI_rotr:
4111 case Builtin::BI_lrotr:
4112 case Builtin::BI_rotr64:
4115 case Builtin::BIstdc_leading_zeros_uc:
4116 case Builtin::BIstdc_leading_zeros_us:
4117 case Builtin::BIstdc_leading_zeros_ui:
4118 case Builtin::BIstdc_leading_zeros_ul:
4119 case Builtin::BIstdc_leading_zeros_ull:
4120 case Builtin::BI__builtin_stdc_leading_zeros:
4122 case Builtin::BIstdc_leading_ones_uc:
4123 case Builtin::BIstdc_leading_ones_us:
4124 case Builtin::BIstdc_leading_ones_ui:
4125 case Builtin::BIstdc_leading_ones_ul:
4126 case Builtin::BIstdc_leading_ones_ull:
4127 case Builtin::BI__builtin_stdc_leading_ones:
4129 case Builtin::BIstdc_trailing_zeros_uc:
4130 case Builtin::BIstdc_trailing_zeros_us:
4131 case Builtin::BIstdc_trailing_zeros_ui:
4132 case Builtin::BIstdc_trailing_zeros_ul:
4133 case Builtin::BIstdc_trailing_zeros_ull:
4134 case Builtin::BI__builtin_stdc_trailing_zeros:
4136 case Builtin::BIstdc_trailing_ones_uc:
4137 case Builtin::BIstdc_trailing_ones_us:
4138 case Builtin::BIstdc_trailing_ones_ui:
4139 case Builtin::BIstdc_trailing_ones_ul:
4140 case Builtin::BIstdc_trailing_ones_ull:
4141 case Builtin::BI__builtin_stdc_trailing_ones:
4143 case Builtin::BIstdc_first_leading_zero_uc:
4144 case Builtin::BIstdc_first_leading_zero_us:
4145 case Builtin::BIstdc_first_leading_zero_ui:
4146 case Builtin::BIstdc_first_leading_zero_ul:
4147 case Builtin::BIstdc_first_leading_zero_ull:
4148 case Builtin::BI__builtin_stdc_first_leading_zero:
4150 case Builtin::BIstdc_first_leading_one_uc:
4151 case Builtin::BIstdc_first_leading_one_us:
4152 case Builtin::BIstdc_first_leading_one_ui:
4153 case Builtin::BIstdc_first_leading_one_ul:
4154 case Builtin::BIstdc_first_leading_one_ull:
4155 case Builtin::BI__builtin_stdc_first_leading_one:
4157 case Builtin::BIstdc_first_trailing_zero_uc:
4158 case Builtin::BIstdc_first_trailing_zero_us:
4159 case Builtin::BIstdc_first_trailing_zero_ui:
4160 case Builtin::BIstdc_first_trailing_zero_ul:
4161 case Builtin::BIstdc_first_trailing_zero_ull:
4162 case Builtin::BI__builtin_stdc_first_trailing_zero:
4164 case Builtin::BIstdc_first_trailing_one_uc:
4165 case Builtin::BIstdc_first_trailing_one_us:
4166 case Builtin::BIstdc_first_trailing_one_ui:
4167 case Builtin::BIstdc_first_trailing_one_ul:
4168 case Builtin::BIstdc_first_trailing_one_ull:
4169 case Builtin::BI__builtin_stdc_first_trailing_one:
4171 case Builtin::BIstdc_count_zeros_uc:
4172 case Builtin::BIstdc_count_zeros_us:
4173 case Builtin::BIstdc_count_zeros_ui:
4174 case Builtin::BIstdc_count_zeros_ul:
4175 case Builtin::BIstdc_count_zeros_ull:
4176 case Builtin::BI__builtin_stdc_count_zeros:
4178 case Builtin::BIstdc_count_ones_uc:
4179 case Builtin::BIstdc_count_ones_us:
4180 case Builtin::BIstdc_count_ones_ui:
4181 case Builtin::BIstdc_count_ones_ul:
4182 case Builtin::BIstdc_count_ones_ull:
4183 case Builtin::BI__builtin_stdc_count_ones:
4186 case Builtin::BIstdc_has_single_bit_uc:
4187 case Builtin::BIstdc_has_single_bit_us:
4188 case Builtin::BIstdc_has_single_bit_ui:
4189 case Builtin::BIstdc_has_single_bit_ul:
4190 case Builtin::BIstdc_has_single_bit_ull:
4191 case Builtin::BI__builtin_stdc_has_single_bit: {
4199 case Builtin::BIstdc_bit_width_uc:
4200 case Builtin::BIstdc_bit_width_us:
4201 case Builtin::BIstdc_bit_width_ui:
4202 case Builtin::BIstdc_bit_width_ul:
4203 case Builtin::BIstdc_bit_width_ull:
4204 case Builtin::BI__builtin_stdc_bit_width:
4206 case Builtin::BIstdc_bit_floor_uc:
4207 case Builtin::BIstdc_bit_floor_us:
4208 case Builtin::BIstdc_bit_floor_ui:
4209 case Builtin::BIstdc_bit_floor_ul:
4210 case Builtin::BIstdc_bit_floor_ull:
4211 case Builtin::BI__builtin_stdc_bit_floor: {
4214 unsigned BitWidth =
ArgType->getIntegerBitWidth();
4226 case Builtin::BIstdc_bit_ceil_uc:
4227 case Builtin::BIstdc_bit_ceil_us:
4228 case Builtin::BIstdc_bit_ceil_ui:
4229 case Builtin::BIstdc_bit_ceil_ul:
4230 case Builtin::BIstdc_bit_ceil_ull:
4231 case Builtin::BI__builtin_stdc_bit_ceil: {
4234 unsigned BitWidth =
ArgType->getIntegerBitWidth();
4238 Value *IsLEOne =
Builder.CreateICmpULE(ArgValue, One,
"isleone");
4240 BasicBlock *EntryBB =
Builder.GetInsertBlock();
4244 Builder.CreateCondBr(IsLEOne, MergeBB, CalcBB);
4246 Builder.SetInsertPoint(CalcBB);
4258 Builder.SetInsertPoint(MergeBB);
4260 Phi->addIncoming(One, EntryBB);
4261 Phi->addIncoming(Tmp, CalcBB);
4265 case Builtin::BI__builtin_constant_p: {
4272 if (!
ArgType->isIntegralOrEnumerationType() && !
ArgType->isFloatingType() &&
4273 !
ArgType->isObjCObjectPointerType() && !
ArgType->isBlockPointerType())
4276 return RValue::get(ConstantInt::get(ResultType, 0));
4281 return RValue::get(ConstantInt::get(ResultType, 0));
4284 if (
ArgType->isObjCObjectPointerType()) {
4293 if (
Result->getType() != ResultType)
4297 case Builtin::BI__builtin_dynamic_object_size:
4298 case Builtin::BI__builtin_object_size: {
4305 bool IsDynamic = BuiltinID == Builtin::BI__builtin_dynamic_object_size;
4307 nullptr, IsDynamic));
4309 case Builtin::BI__builtin_counted_by_ref: {
4311 llvm::Value *
Result = llvm::ConstantPointerNull::get(
4316 if (
auto *UO = dyn_cast<UnaryOperator>(Arg);
4317 UO && UO->getOpcode() == UO_AddrOf) {
4320 if (
auto *ASE = dyn_cast<ArraySubscriptExpr>(Arg))
4324 if (
const MemberExpr *ME = dyn_cast_if_present<MemberExpr>(Arg)) {
4332 llvm::report_fatal_error(
"Cannot find the counted_by 'count' field");
4338 case Builtin::BI__builtin_prefetch: {
4342 llvm::ConstantInt::get(
Int32Ty, 0);
4344 llvm::ConstantInt::get(
Int32Ty, 3);
4350 case Builtin::BI__builtin_readcyclecounter: {
4351 Function *F =
CGM.getIntrinsic(Intrinsic::readcyclecounter);
4354 case Builtin::BI__builtin_readsteadycounter: {
4355 Function *F =
CGM.getIntrinsic(Intrinsic::readsteadycounter);
4358 case Builtin::BI__builtin___clear_cache: {
4361 Function *F =
CGM.getIntrinsic(Intrinsic::clear_cache, {
CGM.DefaultPtrTy});
4364 case Builtin::BI__builtin_trap:
4367 case Builtin::BI__builtin_verbose_trap: {
4368 llvm::DILocation *TrapLocation =
Builder.getCurrentDebugLocation();
4379 case Builtin::BI__debugbreak:
4382 case Builtin::BI__builtin_unreachable: {
4391 case Builtin::BI__builtin_powi:
4392 case Builtin::BI__builtin_powif:
4393 case Builtin::BI__builtin_powil: {
4397 if (
Builder.getIsFPConstrained()) {
4401 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_powi,
4407 { Src0->getType(), Src1->getType() });
4410 case Builtin::BI__builtin_frexpl: {
4414 if (&
getTarget().getLongDoubleFormat() == &llvm::APFloat::PPCDoubleDouble())
4418 case Builtin::BI__builtin_frexp:
4419 case Builtin::BI__builtin_frexpf:
4420 case Builtin::BI__builtin_frexpf128:
4421 case Builtin::BI__builtin_frexpf16:
4423 case Builtin::BImodf:
4424 case Builtin::BImodff:
4425 case Builtin::BImodfl:
4426 case Builtin::BI__builtin_modf:
4427 case Builtin::BI__builtin_modff:
4428 case Builtin::BI__builtin_modfl:
4429 if (
Builder.getIsFPConstrained())
4432 case Builtin::BI__builtin_isgreater:
4433 case Builtin::BI__builtin_isgreaterequal:
4434 case Builtin::BI__builtin_isless:
4435 case Builtin::BI__builtin_islessequal:
4436 case Builtin::BI__builtin_islessgreater:
4437 case Builtin::BI__builtin_isunordered: {
4444 switch (BuiltinID) {
4445 default: llvm_unreachable(
"Unknown ordered comparison");
4446 case Builtin::BI__builtin_isgreater:
4447 LHS =
Builder.CreateFCmpOGT(LHS, RHS,
"cmp");
4449 case Builtin::BI__builtin_isgreaterequal:
4450 LHS =
Builder.CreateFCmpOGE(LHS, RHS,
"cmp");
4452 case Builtin::BI__builtin_isless:
4453 LHS =
Builder.CreateFCmpOLT(LHS, RHS,
"cmp");
4455 case Builtin::BI__builtin_islessequal:
4456 LHS =
Builder.CreateFCmpOLE(LHS, RHS,
"cmp");
4458 case Builtin::BI__builtin_islessgreater:
4459 LHS =
Builder.CreateFCmpONE(LHS, RHS,
"cmp");
4461 case Builtin::BI__builtin_isunordered:
4462 LHS =
Builder.CreateFCmpUNO(LHS, RHS,
"cmp");
4469 case Builtin::BI__builtin_isnan: {
4479 case Builtin::BI__builtin_issignaling: {
4487 case Builtin::BI__builtin_isinf: {
4497 case Builtin::BIfinite:
4498 case Builtin::BI__finite:
4499 case Builtin::BIfinitef:
4500 case Builtin::BI__finitef:
4501 case Builtin::BIfinitel:
4502 case Builtin::BI__finitel:
4503 case Builtin::BI__builtin_isfinite: {
4513 case Builtin::BI__builtin_isnormal: {
4521 case Builtin::BI__builtin_issubnormal: {
4525 Builder.CreateZExt(
Builder.createIsFPClass(
V, FPClassTest::fcSubnormal),
4529 case Builtin::BI__builtin_iszero: {
4537 case Builtin::BI__builtin_isfpclass: {
4541 uint64_t Test =
Result.Val.getInt().getLimitedValue();
4548 case Builtin::BI__builtin_nondeterministic_value: {
4557 case Builtin::BI__builtin_elementwise_abs: {
4562 QT = VecTy->getElementType();
4566 nullptr,
"elt.abs");
4573 case Builtin::BI__builtin_elementwise_bitreverse:
4575 *
this, E, Intrinsic::bitreverse,
"elt.bitreverse"));
4576 case Builtin::BI__builtin_elementwise_popcount:
4578 *
this, E, Intrinsic::ctpop,
"elt.ctpop"));
4579 case Builtin::BI__builtin_elementwise_canonicalize:
4581 *
this, E, Intrinsic::canonicalize,
"elt.canonicalize"));
4582 case Builtin::BI__builtin_elementwise_copysign:
4585 case Builtin::BI__builtin_elementwise_fshl:
4588 case Builtin::BI__builtin_elementwise_fshr:
4591 case Builtin::BI__builtin_elementwise_clmul:
4595 case Builtin::BI__builtin_elementwise_add_sat:
4596 case Builtin::BI__builtin_elementwise_sub_sat: {
4600 assert(Op0->
getType()->isIntOrIntVectorTy() &&
"integer type expected");
4603 Ty = VecTy->getElementType();
4606 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_add_sat)
4607 Opc = IsSigned ? Intrinsic::sadd_sat : Intrinsic::uadd_sat;
4609 Opc = IsSigned ? Intrinsic::ssub_sat : Intrinsic::usub_sat;
4610 Result =
Builder.CreateBinaryIntrinsic(Opc, Op0, Op1,
nullptr,
"elt.sat");
4614 case Builtin::BI__builtin_elementwise_max: {
4618 if (Op0->
getType()->isIntOrIntVectorTy()) {
4621 Ty = VecTy->getElementType();
4624 Op1,
nullptr,
"elt.max");
4626 Result =
Builder.CreateMaxNum(Op0, Op1,
nullptr,
"elt.max");
4629 case Builtin::BI__builtin_elementwise_min: {
4633 if (Op0->
getType()->isIntOrIntVectorTy()) {
4636 Ty = VecTy->getElementType();
4639 Op1,
nullptr,
"elt.min");
4641 Result =
Builder.CreateMinNum(Op0, Op1,
nullptr,
"elt.min");
4645 case Builtin::BI__builtin_elementwise_maxnum: {
4649 Op1,
nullptr,
"elt.maxnum");
4653 case Builtin::BI__builtin_elementwise_minnum: {
4657 Op1,
nullptr,
"elt.minnum");
4661 case Builtin::BI__builtin_elementwise_maximum: {
4665 nullptr,
"elt.maximum");
4669 case Builtin::BI__builtin_elementwise_minimum: {
4673 nullptr,
"elt.minimum");
4677 case Builtin::BI__builtin_elementwise_maximumnum: {
4681 Intrinsic::maximumnum, Op0, Op1,
nullptr,
"elt.maximumnum");
4685 case Builtin::BI__builtin_elementwise_minimumnum: {
4689 Intrinsic::minimumnum, Op0, Op1,
nullptr,
"elt.minimumnum");
4693 case Builtin::BI__builtin_reduce_max: {
4694 auto GetIntrinsicID = [
this](
QualType QT) {
4696 QT = VecTy->getElementType();
4697 else if (QT->isSizelessVectorType())
4698 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4700 if (QT->isSignedIntegerType())
4701 return Intrinsic::vector_reduce_smax;
4702 if (QT->isUnsignedIntegerType())
4703 return Intrinsic::vector_reduce_umax;
4704 assert(QT->isFloatingType() &&
"must have a float here");
4705 return Intrinsic::vector_reduce_fmax;
4708 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4711 case Builtin::BI__builtin_reduce_min: {
4712 auto GetIntrinsicID = [
this](
QualType QT) {
4714 QT = VecTy->getElementType();
4715 else if (QT->isSizelessVectorType())
4716 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4718 if (QT->isSignedIntegerType())
4719 return Intrinsic::vector_reduce_smin;
4720 if (QT->isUnsignedIntegerType())
4721 return Intrinsic::vector_reduce_umin;
4722 assert(QT->isFloatingType() &&
"must have a float here");
4723 return Intrinsic::vector_reduce_fmin;
4727 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4730 case Builtin::BI__builtin_reduce_add:
4732 *
this, E, Intrinsic::vector_reduce_add,
"rdx.add"));
4733 case Builtin::BI__builtin_reduce_mul:
4735 *
this, E, Intrinsic::vector_reduce_mul,
"rdx.mul"));
4736 case Builtin::BI__builtin_reduce_xor:
4738 *
this, E, Intrinsic::vector_reduce_xor,
"rdx.xor"));
4739 case Builtin::BI__builtin_reduce_or:
4741 *
this, E, Intrinsic::vector_reduce_or,
"rdx.or"));
4742 case Builtin::BI__builtin_reduce_and:
4744 *
this, E, Intrinsic::vector_reduce_and,
"rdx.and"));
4745 case Builtin::BI__builtin_reduce_maximum:
4747 *
this, E, Intrinsic::vector_reduce_fmaximum,
"rdx.maximum"));
4748 case Builtin::BI__builtin_reduce_minimum:
4750 *
this, E, Intrinsic::vector_reduce_fminimum,
"rdx.minimum"));
4751 case Builtin::BI__builtin_reduce_assoc_fadd:
4752 case Builtin::BI__builtin_reduce_in_order_fadd: {
4754 llvm::Type *ScalarTy =
Vector->getType()->getScalarType();
4755 llvm::Value *StartValue =
nullptr;
4758 llvm::Value *Args[] = {StartValue
4760 : llvm::ConstantFP::get(ScalarTy, -0.0F),
4763 CGM.getIntrinsic(Intrinsic::vector_reduce_fadd,
Vector->getType());
4764 llvm::CallBase *Reduce =
Builder.CreateCall(F, Args,
"rdx.addf");
4765 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_reduce_assoc_fadd) {
4768 llvm::FastMathFlags FMF;
4769 FMF.setAllowReassoc();
4775 case Builtin::BI__builtin_matrix_transpose: {
4779 Value *
Result = MB.CreateMatrixTranspose(MatValue, MatrixTy->getNumRows(),
4780 MatrixTy->getNumColumns());
4784 case Builtin::BI__builtin_matrix_column_major_load: {
4790 assert(PtrTy &&
"arg0 must be of pointer type");
4791 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4800 ResultTy->getNumRows(), ResultTy->getNumColumns(),
"matrix");
4804 case Builtin::BI__builtin_matrix_column_major_store: {
4812 assert(PtrTy &&
"arg1 must be of pointer type");
4813 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4821 MatrixTy->getNumRows(), MatrixTy->getNumColumns());
4826 case Builtin::BI__builtin_masked_load:
4827 case Builtin::BI__builtin_masked_expand_load: {
4831 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4832 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4840 if (BuiltinID == Builtin::BI__builtin_masked_load) {
4842 PassThru,
"masked_load");
4844 Function *F =
CGM.getIntrinsic(Intrinsic::masked_expandload, {RetTy});
4846 Builder.CreateCall(F, {Ptr, Mask, PassThru},
"masked_expand_load");
4850 case Builtin::BI__builtin_masked_gather: {
4855 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4859 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4863 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4865 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4868 RetTy, PtrVec, Align.
getAsAlign(), Mask, PassThru,
"masked_gather");
4871 case Builtin::BI__builtin_masked_store:
4872 case Builtin::BI__builtin_masked_compress_store: {
4878 llvm::Type *ValLLTy =
CGM.getTypes().ConvertType(ValTy);
4884 if (BuiltinID == Builtin::BI__builtin_masked_store) {
4888 CGM.getIntrinsic(llvm::Intrinsic::masked_compressstore, {ValLLTy});
4889 Builder.CreateCall(F, {Val, Ptr, Mask});
4893 case Builtin::BI__builtin_masked_scatter: {
4903 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4905 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4910 case Builtin::BI__builtin_isinf_sign: {
4917 AbsArg, ConstantFP::getInfinity(Arg->
getType()),
"isinf");
4923 Value *NegativeOne = ConstantInt::getAllOnesValue(
IntTy);
4924 Value *SignResult =
Builder.CreateSelect(IsNeg, NegativeOne, One);
4929 case Builtin::BI__builtin_flt_rounds: {
4930 Function *F =
CGM.getIntrinsic(Intrinsic::get_rounding);
4934 if (
Result->getType() != ResultType)
4940 case Builtin::BI__builtin_set_flt_rounds: {
4941 Function *F =
CGM.getIntrinsic(Intrinsic::set_rounding);
4948 case Builtin::BI__builtin_fpclassify: {
4955 BasicBlock *Begin =
Builder.GetInsertBlock();
4960 "fpclassify_result");
4963 Builder.SetInsertPoint(Begin);
4964 Value *IsZero =
Builder.CreateFCmpOEQ(
V, Constant::getNullValue(Ty),
4968 Builder.CreateCondBr(IsZero, End, NotZero);
4969 Result->addIncoming(ZeroLiteral, Begin);
4972 Builder.SetInsertPoint(NotZero);
4976 Builder.CreateCondBr(IsNan, End, NotNan);
4977 Result->addIncoming(NanLiteral, NotZero);
4980 Builder.SetInsertPoint(NotNan);
4983 Builder.CreateFCmpOEQ(VAbs, ConstantFP::getInfinity(
V->getType()),
4987 Builder.CreateCondBr(IsInf, End, NotInf);
4988 Result->addIncoming(InfLiteral, NotNan);
4991 Builder.SetInsertPoint(NotInf);
4992 APFloat Smallest = APFloat::getSmallestNormalized(
4995 Builder.CreateFCmpUGE(VAbs, ConstantFP::get(
V->getContext(), Smallest),
4997 Value *NormalResult =
5001 Result->addIncoming(NormalResult, NotInf);
5014 case Builtin::BIalloca:
5015 case Builtin::BI_alloca:
5016 case Builtin::BI__builtin_alloca_uninitialized:
5017 case Builtin::BI__builtin_alloca: {
5021 const Align SuitableAlignmentInBytes =
5025 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
5026 AI->setAlignment(SuitableAlignmentInBytes);
5027 if (BuiltinID != Builtin::BI__builtin_alloca_uninitialized)
5029 if (AI->getAddressSpace() !=
5030 CGM.getContext().getTargetAddressSpace(
5032 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
5038 case Builtin::BI__builtin_alloca_with_align_uninitialized:
5039 case Builtin::BI__builtin_alloca_with_align: {
5043 unsigned AlignmentInBits = AlignmentInBitsCI->getZExtValue();
5044 const Align AlignmentInBytes =
5045 CGM.getContext().toCharUnitsFromBits(AlignmentInBits).getAsAlign();
5046 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
5047 AI->setAlignment(AlignmentInBytes);
5048 if (BuiltinID != Builtin::BI__builtin_alloca_with_align_uninitialized)
5050 if (AI->getAddressSpace() !=
5051 CGM.getContext().getTargetAddressSpace(
5053 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
5059 case Builtin::BI__builtin_infer_alloc_token: {
5063 CGM.getIntrinsic(llvm::Intrinsic::alloc_token_id, {
IntPtrTy});
5064 llvm::CallBase *TokenID =
Builder.CreateCall(F, MDV);
5068 case Builtin::BIbzero:
5069 case Builtin::BI__builtin_bzero: {
5074 auto *I =
Builder.CreateMemSet(Dest,
Builder.getInt8(0), SizeVal,
false);
5079 case Builtin::BIbcopy:
5080 case Builtin::BI__builtin_bcopy: {
5090 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5095 case Builtin::BImemcpy:
5096 case Builtin::BI__builtin_memcpy:
5097 case Builtin::BImempcpy:
5098 case Builtin::BI__builtin_mempcpy: {
5104 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
5106 if (BuiltinID == Builtin::BImempcpy ||
5107 BuiltinID == Builtin::BI__builtin_mempcpy)
5114 case Builtin::BI__builtin_memcpy_inline: {
5121 auto *I =
Builder.CreateMemCpyInline(Dest, Src, Size);
5126 case Builtin::BI__builtin_char_memchr:
5127 BuiltinID = Builtin::BI__builtin_memchr;
5130 case Builtin::BI__builtin___memcpy_chk: {
5136 llvm::APSInt Size = SizeResult.
Val.
getInt();
5137 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5138 if (Size.ugt(DstSize))
5142 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5143 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
5148 case Builtin::BI__builtin_objc_memmove_collectable: {
5152 CGM.getObjCRuntime().EmitGCMemmoveCollectable(*
this,
5153 DestAddr, SrcAddr, SizeVal);
5157 case Builtin::BI__builtin___memmove_chk: {
5163 llvm::APSInt Size = SizeResult.
Val.
getInt();
5164 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5165 if (Size.ugt(DstSize))
5169 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5170 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5175 case Builtin::BI__builtin_trivially_relocate:
5176 case Builtin::BImemmove:
5177 case Builtin::BI__builtin_memmove: {
5181 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_trivially_relocate)
5191 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5195 case Builtin::BImemset:
5196 case Builtin::BI__builtin_memset: {
5203 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
5207 case Builtin::BI__builtin_memset_inline: {
5216 auto *I =
Builder.CreateMemSetInline(Dest, ByteVal, Size);
5220 case Builtin::BI__builtin___memset_chk: {
5226 llvm::APSInt Size = SizeResult.
Val.
getInt();
5227 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5228 if (Size.ugt(DstSize))
5233 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5234 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
5238 case Builtin::BI__builtin_wmemchr: {
5249 BasicBlock *Entry =
Builder.GetInsertBlock();
5254 Builder.CreateCondBr(SizeEq0, Exit, CmpEq);
5258 StrPhi->addIncoming(Str, Entry);
5260 SizePhi->addIncoming(Size, Entry);
5263 Value *StrCh =
Builder.CreateAlignedLoad(WCharTy, StrPhi, WCharAlign);
5264 Value *FoundChr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 0);
5269 Value *NextStr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 1);
5271 Value *NextSizeEq0 =
5272 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
5273 Builder.CreateCondBr(NextSizeEq0, Exit, CmpEq);
5274 StrPhi->addIncoming(NextStr,
Next);
5275 SizePhi->addIncoming(NextSize,
Next);
5279 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()), Entry);
5280 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()),
Next);
5281 Ret->addIncoming(FoundChr, CmpEq);
5284 case Builtin::BI__builtin_wmemcmp: {
5296 BasicBlock *Entry =
Builder.GetInsertBlock();
5302 Builder.CreateCondBr(SizeEq0, Exit, CmpGT);
5306 DstPhi->addIncoming(Dst, Entry);
5308 SrcPhi->addIncoming(Src, Entry);
5310 SizePhi->addIncoming(Size, Entry);
5313 Value *DstCh =
Builder.CreateAlignedLoad(WCharTy, DstPhi, WCharAlign);
5314 Value *SrcCh =
Builder.CreateAlignedLoad(WCharTy, SrcPhi, WCharAlign);
5316 Builder.CreateCondBr(DstGtSrc, Exit, CmpLT);
5323 Value *NextDst =
Builder.CreateConstInBoundsGEP1_32(WCharTy, DstPhi, 1);
5324 Value *NextSrc =
Builder.CreateConstInBoundsGEP1_32(WCharTy, SrcPhi, 1);
5326 Value *NextSizeEq0 =
5327 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
5328 Builder.CreateCondBr(NextSizeEq0, Exit, CmpGT);
5329 DstPhi->addIncoming(NextDst,
Next);
5330 SrcPhi->addIncoming(NextSrc,
Next);
5331 SizePhi->addIncoming(NextSize,
Next);
5335 Ret->addIncoming(ConstantInt::get(
IntTy, 0), Entry);
5336 Ret->addIncoming(ConstantInt::get(
IntTy, 1), CmpGT);
5337 Ret->addIncoming(ConstantInt::getAllOnesValue(
IntTy), CmpLT);
5338 Ret->addIncoming(ConstantInt::get(
IntTy, 0),
Next);
5341 case Builtin::BI__builtin_dwarf_cfa: {
5352 Function *F =
CGM.getIntrinsic(Intrinsic::eh_dwarf_cfa);
5354 llvm::ConstantInt::get(
Int32Ty, Offset)));
5356 case Builtin::BI__builtin_return_address: {
5360 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5363 case Builtin::BI_ReturnAddress: {
5365 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5368 case Builtin::BI__builtin_frame_address: {
5374 case Builtin::BI__builtin_stack_address: {
5378 case Builtin::BI__builtin_extract_return_addr: {
5383 case Builtin::BI__builtin_frob_return_addr: {
5388 case Builtin::BI__builtin_dwarf_sp_column: {
5389 llvm::IntegerType *Ty
5393 CGM.ErrorUnsupported(E,
"__builtin_dwarf_sp_column");
5398 case Builtin::BI__builtin_init_dwarf_reg_size_table: {
5401 CGM.ErrorUnsupported(E,
"__builtin_init_dwarf_reg_size_table");
5404 case Builtin::BI__builtin_eh_return: {
5409 assert((
IntTy->getBitWidth() == 32 ||
IntTy->getBitWidth() == 64) &&
5410 "LLVM's __builtin_eh_return only supports 32- and 64-bit variants");
5412 CGM.getIntrinsic(
IntTy->getBitWidth() == 32 ? Intrinsic::eh_return_i32
5413 : Intrinsic::eh_return_i64);
5414 Builder.CreateCall(F, {Int, Ptr});
5422 case Builtin::BI__builtin_unwind_init: {
5423 Function *F =
CGM.getIntrinsic(Intrinsic::eh_unwind_init);
5427 case Builtin::BI__builtin_extend_pointer: {
5452 case Builtin::BI__builtin_setjmp: {
5460 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5467 ConstantInt::get(
Int32Ty, 0));
5468 Builder.CreateStore(FrameAddr, Buf);
5475 Builder.CreateStore(StackAddr, StackSaveSlot);
5478 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5481 case Builtin::BI__builtin_longjmp: {
5485 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::eh_sjlj_longjmp), Buf);
5495 case Builtin::BI__builtin_launder: {
5500 Ptr =
Builder.CreateLaunderInvariantGroup(Ptr);
5504 case Builtin::BI__builtin_clear_padding: {
5507 PaddingClearer clearer{*
this};
5508 clearer.run(Src, PointeeTy);
5511 case Builtin::BI__sync_fetch_and_add:
5512 case Builtin::BI__sync_fetch_and_sub:
5513 case Builtin::BI__sync_fetch_and_or:
5514 case Builtin::BI__sync_fetch_and_and:
5515 case Builtin::BI__sync_fetch_and_xor:
5516 case Builtin::BI__sync_fetch_and_nand:
5517 case Builtin::BI__sync_add_and_fetch:
5518 case Builtin::BI__sync_sub_and_fetch:
5519 case Builtin::BI__sync_and_and_fetch:
5520 case Builtin::BI__sync_or_and_fetch:
5521 case Builtin::BI__sync_xor_and_fetch:
5522 case Builtin::BI__sync_nand_and_fetch:
5523 case Builtin::BI__sync_val_compare_and_swap:
5524 case Builtin::BI__sync_bool_compare_and_swap:
5525 case Builtin::BI__sync_lock_test_and_set:
5526 case Builtin::BI__sync_lock_release:
5527 case Builtin::BI__sync_swap:
5528 llvm_unreachable(
"Shouldn't make it through sema");
5529 case Builtin::BI__sync_fetch_and_add_1:
5530 case Builtin::BI__sync_fetch_and_add_2:
5531 case Builtin::BI__sync_fetch_and_add_4:
5532 case Builtin::BI__sync_fetch_and_add_8:
5533 case Builtin::BI__sync_fetch_and_add_16:
5535 case Builtin::BI__sync_fetch_and_sub_1:
5536 case Builtin::BI__sync_fetch_and_sub_2:
5537 case Builtin::BI__sync_fetch_and_sub_4:
5538 case Builtin::BI__sync_fetch_and_sub_8:
5539 case Builtin::BI__sync_fetch_and_sub_16:
5541 case Builtin::BI__sync_fetch_and_or_1:
5542 case Builtin::BI__sync_fetch_and_or_2:
5543 case Builtin::BI__sync_fetch_and_or_4:
5544 case Builtin::BI__sync_fetch_and_or_8:
5545 case Builtin::BI__sync_fetch_and_or_16:
5547 case Builtin::BI__sync_fetch_and_and_1:
5548 case Builtin::BI__sync_fetch_and_and_2:
5549 case Builtin::BI__sync_fetch_and_and_4:
5550 case Builtin::BI__sync_fetch_and_and_8:
5551 case Builtin::BI__sync_fetch_and_and_16:
5553 case Builtin::BI__sync_fetch_and_xor_1:
5554 case Builtin::BI__sync_fetch_and_xor_2:
5555 case Builtin::BI__sync_fetch_and_xor_4:
5556 case Builtin::BI__sync_fetch_and_xor_8:
5557 case Builtin::BI__sync_fetch_and_xor_16:
5559 case Builtin::BI__sync_fetch_and_nand_1:
5560 case Builtin::BI__sync_fetch_and_nand_2:
5561 case Builtin::BI__sync_fetch_and_nand_4:
5562 case Builtin::BI__sync_fetch_and_nand_8:
5563 case Builtin::BI__sync_fetch_and_nand_16:
5567 case Builtin::BI__sync_fetch_and_min:
5569 case Builtin::BI__sync_fetch_and_max:
5571 case Builtin::BI__sync_fetch_and_umin:
5573 case Builtin::BI__sync_fetch_and_umax:
5576 case Builtin::BI__sync_add_and_fetch_1:
5577 case Builtin::BI__sync_add_and_fetch_2:
5578 case Builtin::BI__sync_add_and_fetch_4:
5579 case Builtin::BI__sync_add_and_fetch_8:
5580 case Builtin::BI__sync_add_and_fetch_16:
5582 llvm::Instruction::Add);
5583 case Builtin::BI__sync_sub_and_fetch_1:
5584 case Builtin::BI__sync_sub_and_fetch_2:
5585 case Builtin::BI__sync_sub_and_fetch_4:
5586 case Builtin::BI__sync_sub_and_fetch_8:
5587 case Builtin::BI__sync_sub_and_fetch_16:
5589 llvm::Instruction::Sub);
5590 case Builtin::BI__sync_and_and_fetch_1:
5591 case Builtin::BI__sync_and_and_fetch_2:
5592 case Builtin::BI__sync_and_and_fetch_4:
5593 case Builtin::BI__sync_and_and_fetch_8:
5594 case Builtin::BI__sync_and_and_fetch_16:
5596 llvm::Instruction::And);
5597 case Builtin::BI__sync_or_and_fetch_1:
5598 case Builtin::BI__sync_or_and_fetch_2:
5599 case Builtin::BI__sync_or_and_fetch_4:
5600 case Builtin::BI__sync_or_and_fetch_8:
5601 case Builtin::BI__sync_or_and_fetch_16:
5603 llvm::Instruction::Or);
5604 case Builtin::BI__sync_xor_and_fetch_1:
5605 case Builtin::BI__sync_xor_and_fetch_2:
5606 case Builtin::BI__sync_xor_and_fetch_4:
5607 case Builtin::BI__sync_xor_and_fetch_8:
5608 case Builtin::BI__sync_xor_and_fetch_16:
5610 llvm::Instruction::Xor);
5611 case Builtin::BI__sync_nand_and_fetch_1:
5612 case Builtin::BI__sync_nand_and_fetch_2:
5613 case Builtin::BI__sync_nand_and_fetch_4:
5614 case Builtin::BI__sync_nand_and_fetch_8:
5615 case Builtin::BI__sync_nand_and_fetch_16:
5617 llvm::Instruction::And,
true);
5619 case Builtin::BI__sync_val_compare_and_swap_1:
5620 case Builtin::BI__sync_val_compare_and_swap_2:
5621 case Builtin::BI__sync_val_compare_and_swap_4:
5622 case Builtin::BI__sync_val_compare_and_swap_8:
5623 case Builtin::BI__sync_val_compare_and_swap_16:
5625 *
this, E,
false, AtomicOrdering::SequentiallyConsistent,
5626 AtomicOrdering::SequentiallyConsistent));
5628 case Builtin::BI__sync_bool_compare_and_swap_1:
5629 case Builtin::BI__sync_bool_compare_and_swap_2:
5630 case Builtin::BI__sync_bool_compare_and_swap_4:
5631 case Builtin::BI__sync_bool_compare_and_swap_8:
5632 case Builtin::BI__sync_bool_compare_and_swap_16:
5634 *
this, E,
true, AtomicOrdering::SequentiallyConsistent,
5635 AtomicOrdering::SequentiallyConsistent));
5637 case Builtin::BI__sync_swap_1:
5638 case Builtin::BI__sync_swap_2:
5639 case Builtin::BI__sync_swap_4:
5640 case Builtin::BI__sync_swap_8:
5641 case Builtin::BI__sync_swap_16:
5644 case Builtin::BI__sync_lock_test_and_set_1:
5645 case Builtin::BI__sync_lock_test_and_set_2:
5646 case Builtin::BI__sync_lock_test_and_set_4:
5647 case Builtin::BI__sync_lock_test_and_set_8:
5648 case Builtin::BI__sync_lock_test_and_set_16:
5651 case Builtin::BI__sync_lock_release_1:
5652 case Builtin::BI__sync_lock_release_2:
5653 case Builtin::BI__sync_lock_release_4:
5654 case Builtin::BI__sync_lock_release_8:
5655 case Builtin::BI__sync_lock_release_16: {
5661 llvm::StoreInst *Store =
5662 Builder.CreateStore(llvm::Constant::getNullValue(ITy), Ptr);
5663 Store->setAtomic(llvm::AtomicOrdering::Release);
5667 case Builtin::BI__sync_synchronize: {
5675 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent);
5679 case Builtin::BI__builtin_nontemporal_load:
5681 case Builtin::BI__builtin_nontemporal_store:
5683 case Builtin::BI__c11_atomic_is_lock_free:
5684 case Builtin::BI__atomic_is_lock_free: {
5688 const char *LibCallName =
"__atomic_is_lock_free";
5692 if (BuiltinID == Builtin::BI__atomic_is_lock_free)
5699 CGM.getTypes().arrangeBuiltinFunctionCall(E->
getType(), Args);
5700 llvm::FunctionType *FTy =
CGM.getTypes().GetFunctionType(FuncInfo);
5701 llvm::FunctionCallee
Func =
CGM.CreateRuntimeFunction(FTy, LibCallName);
5706 case Builtin::BI__atomic_thread_fence:
5707 case Builtin::BI__atomic_signal_fence:
5708 case Builtin::BI__c11_atomic_thread_fence:
5709 case Builtin::BI__c11_atomic_signal_fence: {
5710 llvm::SyncScope::ID SSID;
5711 if (BuiltinID == Builtin::BI__atomic_signal_fence ||
5712 BuiltinID == Builtin::BI__c11_atomic_signal_fence)
5713 SSID = llvm::SyncScope::SingleThread;
5715 SSID = llvm::SyncScope::System;
5725 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5728 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5731 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5734 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5740 llvm::BasicBlock *AcquireBB, *ReleaseBB, *AcqRelBB, *SeqCstBB;
5747 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5748 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5750 Builder.SetInsertPoint(AcquireBB);
5751 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5753 SI->addCase(
Builder.getInt32(1), AcquireBB);
5754 SI->addCase(
Builder.getInt32(2), AcquireBB);
5756 Builder.SetInsertPoint(ReleaseBB);
5757 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5759 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5761 Builder.SetInsertPoint(AcqRelBB);
5762 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5764 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5766 Builder.SetInsertPoint(SeqCstBB);
5767 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5769 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5771 Builder.SetInsertPoint(ContBB);
5774 case Builtin::BI__scoped_atomic_thread_fence: {
5779 auto Ord = dyn_cast<llvm::ConstantInt>(Order);
5780 auto Scp = dyn_cast<llvm::ConstantInt>(
Scope);
5782 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5783 ? ScopeModel->map(Scp->getZExtValue())
5784 : ScopeModel->map(ScopeModel->getFallBackValue());
5785 switch (Ord->getZExtValue()) {
5792 llvm::AtomicOrdering::Acquire,
5794 llvm::AtomicOrdering::Acquire,
5799 llvm::AtomicOrdering::Release,
5801 llvm::AtomicOrdering::Release,
5805 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease,
5808 llvm::AtomicOrdering::AcquireRelease,
5812 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent,
5815 llvm::AtomicOrdering::SequentiallyConsistent,
5827 switch (Ord->getZExtValue()) {
5830 ContBB->eraseFromParent();
5834 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5835 llvm::AtomicOrdering::Acquire);
5838 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5839 llvm::AtomicOrdering::Release);
5842 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5843 llvm::AtomicOrdering::AcquireRelease);
5846 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5847 llvm::AtomicOrdering::SequentiallyConsistent);
5856 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5857 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5858 SI->addCase(
Builder.getInt32(1), AcquireBB);
5859 SI->addCase(
Builder.getInt32(2), AcquireBB);
5860 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5861 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5862 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5864 OrderBBs.emplace_back(AcquireBB, llvm::AtomicOrdering::Acquire);
5865 OrderBBs.emplace_back(ReleaseBB, llvm::AtomicOrdering::Release);
5866 OrderBBs.emplace_back(AcqRelBB, llvm::AtomicOrdering::AcquireRelease);
5867 OrderBBs.emplace_back(SeqCstBB,
5868 llvm::AtomicOrdering::SequentiallyConsistent);
5871 for (
auto &[OrderBB, Ordering] : OrderBBs) {
5872 Builder.SetInsertPoint(OrderBB);
5874 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5875 ? ScopeModel->map(Scp->getZExtValue())
5876 : ScopeModel->map(ScopeModel->getFallBackValue());
5882 llvm::DenseMap<unsigned, llvm::BasicBlock *> BBs;
5883 for (
unsigned Scp : ScopeModel->getRuntimeValues())
5887 llvm::SwitchInst *SI =
Builder.CreateSwitch(SC, ContBB);
5888 for (
unsigned Scp : ScopeModel->getRuntimeValues()) {
5890 SI->addCase(
Builder.getInt32(Scp), B);
5901 Builder.SetInsertPoint(ContBB);
5905 case Builtin::BI__builtin_signbit:
5906 case Builtin::BI__builtin_signbitf:
5907 case Builtin::BI__builtin_signbitl: {
5912 case Builtin::BI__warn_memset_zero_len:
5914 case Builtin::BI__annotation: {
5919 assert(Str->getCharByteWidth() == 2 || Str->getCharByteWidth() == 4);
5920 StringRef WideBytes = Str->getBytes();
5921 std::string StrUtf8;
5923 (Str->getCharByteWidth() == 2)
5924 ? convertUTF16ToUTF8String(
5925 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8)
5926 : convertUTF32ToUTF8String(
5927 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8);
5929 CGM.ErrorUnsupported(E,
"non-Unicode __annotation argument");
5932 Strings.push_back(llvm::MDString::get(
getLLVMContext(), StrUtf8));
5936 llvm::Function *F =
CGM.getIntrinsic(Intrinsic::codeview_annotation, {});
5941 case Builtin::BI__builtin_annotation: {
5943 llvm::Function *F =
CGM.getIntrinsic(
5944 Intrinsic::annotation, {AnnVal->getType(),
CGM.ConstGlobalsPtrTy});
5953 case Builtin::BI__builtin_addcb:
5954 case Builtin::BI__builtin_addcs:
5955 case Builtin::BI__builtin_addc:
5956 case Builtin::BI__builtin_addcl:
5957 case Builtin::BI__builtin_addcll:
5958 case Builtin::BI__builtin_subcb:
5959 case Builtin::BI__builtin_subcs:
5960 case Builtin::BI__builtin_subc:
5961 case Builtin::BI__builtin_subcl:
5962 case Builtin::BI__builtin_subcll: {
5988 Intrinsic::ID IntrinsicId;
5989 switch (BuiltinID) {
5990 default: llvm_unreachable(
"Unknown multiprecision builtin id.");
5991 case Builtin::BI__builtin_addcb:
5992 case Builtin::BI__builtin_addcs:
5993 case Builtin::BI__builtin_addc:
5994 case Builtin::BI__builtin_addcl:
5995 case Builtin::BI__builtin_addcll:
5996 IntrinsicId = Intrinsic::uadd_with_overflow;
5998 case Builtin::BI__builtin_subcb:
5999 case Builtin::BI__builtin_subcs:
6000 case Builtin::BI__builtin_subc:
6001 case Builtin::BI__builtin_subcl:
6002 case Builtin::BI__builtin_subcll:
6003 IntrinsicId = Intrinsic::usub_with_overflow;
6008 llvm::Value *Carry1;
6011 llvm::Value *Carry2;
6013 Sum1, Carryin, Carry2);
6014 llvm::Value *CarryOut =
Builder.CreateZExt(
Builder.CreateOr(Carry1, Carry2),
6016 Builder.CreateStore(CarryOut, CarryOutPtr);
6020 case Builtin::BI__builtin_add_overflow:
6021 case Builtin::BI__builtin_sub_overflow:
6022 case Builtin::BI__builtin_mul_overflow: {
6030 WidthAndSignedness LeftInfo =
6032 WidthAndSignedness RightInfo =
6034 WidthAndSignedness ResultInfo =
6041 RightInfo, ResultArg, ResultQTy,
6047 *
this, LeftArg, LeftInfo, RightArg, RightInfo, ResultArg, ResultQTy,
6050 WidthAndSignedness EncompassingInfo =
6053 llvm::Type *EncompassingLLVMTy =
6054 llvm::IntegerType::get(
CGM.getLLVMContext(), EncompassingInfo.Width);
6056 llvm::Type *ResultLLVMTy =
CGM.getTypes().ConvertType(ResultQTy);
6058 Intrinsic::ID IntrinsicId;
6059 switch (BuiltinID) {
6061 llvm_unreachable(
"Unknown overflow builtin id.");
6062 case Builtin::BI__builtin_add_overflow:
6063 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::sadd_with_overflow
6064 : Intrinsic::uadd_with_overflow;
6066 case Builtin::BI__builtin_sub_overflow:
6067 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::ssub_with_overflow
6068 : Intrinsic::usub_with_overflow;
6070 case Builtin::BI__builtin_mul_overflow:
6071 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::smul_with_overflow
6072 : Intrinsic::umul_with_overflow;
6081 Left =
Builder.CreateIntCast(Left, EncompassingLLVMTy, LeftInfo.Signed);
6082 Right =
Builder.CreateIntCast(Right, EncompassingLLVMTy, RightInfo.Signed);
6085 llvm::Value *Overflow, *
Result;
6088 if (EncompassingInfo.Width > ResultInfo.Width) {
6091 llvm::Value *ResultTrunc =
Builder.CreateTrunc(
Result, ResultLLVMTy);
6095 llvm::Value *ResultTruncExt =
Builder.CreateIntCast(
6096 ResultTrunc, EncompassingLLVMTy, ResultInfo.Signed);
6097 llvm::Value *TruncationOverflow =
6100 Overflow =
Builder.CreateOr(Overflow, TruncationOverflow);
6112 case Builtin::BI__builtin_uadd_overflow:
6113 case Builtin::BI__builtin_uaddl_overflow:
6114 case Builtin::BI__builtin_uaddll_overflow:
6115 case Builtin::BI__builtin_usub_overflow:
6116 case Builtin::BI__builtin_usubl_overflow:
6117 case Builtin::BI__builtin_usubll_overflow:
6118 case Builtin::BI__builtin_umul_overflow:
6119 case Builtin::BI__builtin_umull_overflow:
6120 case Builtin::BI__builtin_umulll_overflow:
6121 case Builtin::BI__builtin_sadd_overflow:
6122 case Builtin::BI__builtin_saddl_overflow:
6123 case Builtin::BI__builtin_saddll_overflow:
6124 case Builtin::BI__builtin_ssub_overflow:
6125 case Builtin::BI__builtin_ssubl_overflow:
6126 case Builtin::BI__builtin_ssubll_overflow:
6127 case Builtin::BI__builtin_smul_overflow:
6128 case Builtin::BI__builtin_smull_overflow:
6129 case Builtin::BI__builtin_smulll_overflow: {
6139 Intrinsic::ID IntrinsicId;
6140 switch (BuiltinID) {
6141 default: llvm_unreachable(
"Unknown overflow builtin id.");
6142 case Builtin::BI__builtin_uadd_overflow:
6143 case Builtin::BI__builtin_uaddl_overflow:
6144 case Builtin::BI__builtin_uaddll_overflow:
6145 IntrinsicId = Intrinsic::uadd_with_overflow;
6147 case Builtin::BI__builtin_usub_overflow:
6148 case Builtin::BI__builtin_usubl_overflow:
6149 case Builtin::BI__builtin_usubll_overflow:
6150 IntrinsicId = Intrinsic::usub_with_overflow;
6152 case Builtin::BI__builtin_umul_overflow:
6153 case Builtin::BI__builtin_umull_overflow:
6154 case Builtin::BI__builtin_umulll_overflow:
6155 IntrinsicId = Intrinsic::umul_with_overflow;
6157 case Builtin::BI__builtin_sadd_overflow:
6158 case Builtin::BI__builtin_saddl_overflow:
6159 case Builtin::BI__builtin_saddll_overflow:
6160 IntrinsicId = Intrinsic::sadd_with_overflow;
6162 case Builtin::BI__builtin_ssub_overflow:
6163 case Builtin::BI__builtin_ssubl_overflow:
6164 case Builtin::BI__builtin_ssubll_overflow:
6165 IntrinsicId = Intrinsic::ssub_with_overflow;
6167 case Builtin::BI__builtin_smul_overflow:
6168 case Builtin::BI__builtin_smull_overflow:
6169 case Builtin::BI__builtin_smulll_overflow:
6170 IntrinsicId = Intrinsic::smul_with_overflow;
6177 Builder.CreateStore(Sum, SumOutPtr);
6181 case Builtin::BIaddressof:
6182 case Builtin::BI__addressof:
6183 case Builtin::BI__builtin_addressof:
6185 case Builtin::BI__builtin_function_start:
6188 case Builtin::BI__builtin_operator_new:
6191 case Builtin::BI__builtin_operator_delete:
6196 case Builtin::BI__builtin_is_aligned:
6198 case Builtin::BI__builtin_align_up:
6200 case Builtin::BI__builtin_align_down:
6203 case Builtin::BI__noop:
6206 case Builtin::BI__builtin_call_with_static_chain: {
6213 case Builtin::BI_InterlockedExchange8:
6214 case Builtin::BI_InterlockedExchange16:
6215 case Builtin::BI_InterlockedExchange:
6216 case Builtin::BI_InterlockedExchangePointer:
6219 case Builtin::BI_InterlockedCompareExchangePointer:
6222 case Builtin::BI_InterlockedCompareExchangePointer_nf:
6225 case Builtin::BI_InterlockedCompareExchange8:
6226 case Builtin::BI_InterlockedCompareExchange16:
6227 case Builtin::BI_InterlockedCompareExchange:
6228 case Builtin::BI_InterlockedCompareExchange64:
6230 case Builtin::BI_InterlockedIncrement16:
6231 case Builtin::BI_InterlockedIncrement:
6234 case Builtin::BI_InterlockedDecrement16:
6235 case Builtin::BI_InterlockedDecrement:
6238 case Builtin::BI_InterlockedAnd8:
6239 case Builtin::BI_InterlockedAnd16:
6240 case Builtin::BI_InterlockedAnd:
6242 case Builtin::BI_InterlockedExchangeAdd8:
6243 case Builtin::BI_InterlockedExchangeAdd16:
6244 case Builtin::BI_InterlockedExchangeAdd:
6247 case Builtin::BI_InterlockedExchangeSub8:
6248 case Builtin::BI_InterlockedExchangeSub16:
6249 case Builtin::BI_InterlockedExchangeSub:
6252 case Builtin::BI_InterlockedOr8:
6253 case Builtin::BI_InterlockedOr16:
6254 case Builtin::BI_InterlockedOr:
6256 case Builtin::BI_InterlockedXor8:
6257 case Builtin::BI_InterlockedXor16:
6258 case Builtin::BI_InterlockedXor:
6261 case Builtin::BI_bittest64:
6262 case Builtin::BI_bittest:
6263 case Builtin::BI_bittestandcomplement64:
6264 case Builtin::BI_bittestandcomplement:
6265 case Builtin::BI_bittestandreset64:
6266 case Builtin::BI_bittestandreset:
6267 case Builtin::BI_bittestandset64:
6268 case Builtin::BI_bittestandset:
6269 case Builtin::BI_interlockedbittestandreset:
6270 case Builtin::BI_interlockedbittestandreset64:
6271 case Builtin::BI_interlockedbittestandreset64_acq:
6272 case Builtin::BI_interlockedbittestandreset64_rel:
6273 case Builtin::BI_interlockedbittestandreset64_nf:
6274 case Builtin::BI_interlockedbittestandset64:
6275 case Builtin::BI_interlockedbittestandset64_acq:
6276 case Builtin::BI_interlockedbittestandset64_rel:
6277 case Builtin::BI_interlockedbittestandset64_nf:
6278 case Builtin::BI_interlockedbittestandset:
6279 case Builtin::BI_interlockedbittestandset_acq:
6280 case Builtin::BI_interlockedbittestandset_rel:
6281 case Builtin::BI_interlockedbittestandset_nf:
6282 case Builtin::BI_interlockedbittestandreset_acq:
6283 case Builtin::BI_interlockedbittestandreset_rel:
6284 case Builtin::BI_interlockedbittestandreset_nf:
6289 case Builtin::BI__iso_volatile_load8:
6290 case Builtin::BI__iso_volatile_load16:
6291 case Builtin::BI__iso_volatile_load32:
6292 case Builtin::BI__iso_volatile_load64:
6294 case Builtin::BI__iso_volatile_store8:
6295 case Builtin::BI__iso_volatile_store16:
6296 case Builtin::BI__iso_volatile_store32:
6297 case Builtin::BI__iso_volatile_store64:
6300 case Builtin::BI__builtin_ptrauth_sign_constant:
6303 case Builtin::BI__builtin_ptrauth_auth:
6304 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6305 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6306 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6307 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6308 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6309 case Builtin::BI__builtin_ptrauth_strip: {
6316 llvm::Type *OrigValueType = Args[0]->getType();
6317 if (OrigValueType->isPointerTy())
6320 switch (BuiltinID) {
6321 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6322 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6323 if (Args[4]->
getType()->isPointerTy())
6327 case Builtin::BI__builtin_ptrauth_auth:
6328 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6329 if (Args[2]->
getType()->isPointerTy())
6333 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6334 if (Args[1]->
getType()->isPointerTy())
6338 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6339 case Builtin::BI__builtin_ptrauth_strip:
6344 auto IntrinsicID = [&]() ->
unsigned {
6345 switch (BuiltinID) {
6346 case Builtin::BI__builtin_ptrauth_auth:
6347 return Intrinsic::ptrauth_auth;
6348 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6349 return Intrinsic::ptrauth_resign;
6350 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6351 return Intrinsic::ptrauth_resign_load_relative;
6352 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6353 return Intrinsic::ptrauth_blend;
6354 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6355 return Intrinsic::ptrauth_sign_generic;
6356 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6357 return Intrinsic::ptrauth_sign;
6358 case Builtin::BI__builtin_ptrauth_strip:
6359 return Intrinsic::ptrauth_strip;
6361 llvm_unreachable(
"bad ptrauth intrinsic");
6363 auto Intrinsic =
CGM.getIntrinsic(IntrinsicID);
6366 if (BuiltinID != Builtin::BI__builtin_ptrauth_sign_generic_data &&
6367 BuiltinID != Builtin::BI__builtin_ptrauth_blend_discriminator &&
6368 OrigValueType->isPointerTy()) {
6374 case Builtin::BI__builtin_get_vtable_pointer: {
6380 assert(ThisAddress.isValid());
6381 llvm::Value *VTablePointer =
6386 case Builtin::BI__exception_code:
6387 case Builtin::BI_exception_code:
6389 case Builtin::BI__exception_info:
6390 case Builtin::BI_exception_info:
6392 case Builtin::BI__abnormal_termination:
6393 case Builtin::BI_abnormal_termination:
6395 case Builtin::BI_setjmpex:
6400 case Builtin::BI_setjmp:
6412 case Builtin::BImove:
6413 case Builtin::BImove_if_noexcept:
6414 case Builtin::BIforward:
6415 case Builtin::BIforward_like:
6416 case Builtin::BIas_const:
6418 case Builtin::BI__GetExceptionInfo: {
6419 if (llvm::GlobalVariable *GV =
6425 case Builtin::BI__fastfail:
6428 case Builtin::BI__builtin_coro_id:
6430 case Builtin::BI__builtin_coro_promise:
6432 case Builtin::BI__builtin_coro_resume:
6435 case Builtin::BI__builtin_coro_frame:
6437 case Builtin::BI__builtin_coro_noop:
6439 case Builtin::BI__builtin_coro_free:
6441 case Builtin::BI__builtin_coro_destroy:
6444 case Builtin::BI__builtin_coro_done:
6446 case Builtin::BI__builtin_coro_alloc:
6448 case Builtin::BI__builtin_coro_begin:
6450 case Builtin::BI__builtin_coro_end:
6452 case Builtin::BI__builtin_coro_suspend:
6454 case Builtin::BI__builtin_coro_size:
6456 case Builtin::BI__builtin_coro_align:
6460 case Builtin::BIread_pipe:
6461 case Builtin::BIwrite_pipe: {
6469 unsigned GenericAS =
6471 llvm::Type *I8PTy = llvm::PointerType::get(
getLLVMContext(), GenericAS);
6475 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_2"
6480 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6481 Value *ACast =
Builder.CreateAddrSpaceCast(Arg1, I8PTy);
6484 {Arg0, ACast, PacketSize, PacketAlign}));
6487 "Illegal number of parameters to pipe function");
6488 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_4"
6491 llvm::Type *ArgTys[] = {Arg0->
getType(), Arg1->getType(),
Int32Ty, I8PTy,
6495 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6496 Value *ACast =
Builder.CreateAddrSpaceCast(Arg3, I8PTy);
6503 {Arg0, Arg1, Arg2, ACast, PacketSize, PacketAlign}));
6508 case Builtin::BIreserve_read_pipe:
6509 case Builtin::BIreserve_write_pipe:
6510 case Builtin::BIwork_group_reserve_read_pipe:
6511 case Builtin::BIwork_group_reserve_write_pipe:
6512 case Builtin::BIsub_group_reserve_read_pipe:
6513 case Builtin::BIsub_group_reserve_write_pipe: {
6516 if (BuiltinID == Builtin::BIreserve_read_pipe)
6517 Name =
"__reserve_read_pipe";
6518 else if (BuiltinID == Builtin::BIreserve_write_pipe)
6519 Name =
"__reserve_write_pipe";
6520 else if (BuiltinID == Builtin::BIwork_group_reserve_read_pipe)
6521 Name =
"__work_group_reserve_read_pipe";
6522 else if (BuiltinID == Builtin::BIwork_group_reserve_write_pipe)
6523 Name =
"__work_group_reserve_write_pipe";
6524 else if (BuiltinID == Builtin::BIsub_group_reserve_read_pipe)
6525 Name =
"__sub_group_reserve_read_pipe";
6527 Name =
"__sub_group_reserve_write_pipe";
6538 llvm::FunctionType *FTy =
6539 llvm::FunctionType::get(ReservedIDTy, ArgTys,
false);
6542 if (Arg1->getType() !=
Int32Ty)
6545 {Arg0, Arg1, PacketSize, PacketAlign}));
6549 case Builtin::BIcommit_read_pipe:
6550 case Builtin::BIcommit_write_pipe:
6551 case Builtin::BIwork_group_commit_read_pipe:
6552 case Builtin::BIwork_group_commit_write_pipe:
6553 case Builtin::BIsub_group_commit_read_pipe:
6554 case Builtin::BIsub_group_commit_write_pipe: {
6556 if (BuiltinID == Builtin::BIcommit_read_pipe)
6557 Name =
"__commit_read_pipe";
6558 else if (BuiltinID == Builtin::BIcommit_write_pipe)
6559 Name =
"__commit_write_pipe";
6560 else if (BuiltinID == Builtin::BIwork_group_commit_read_pipe)
6561 Name =
"__work_group_commit_read_pipe";
6562 else if (BuiltinID == Builtin::BIwork_group_commit_write_pipe)
6563 Name =
"__work_group_commit_write_pipe";
6564 else if (BuiltinID == Builtin::BIsub_group_commit_read_pipe)
6565 Name =
"__sub_group_commit_read_pipe";
6567 Name =
"__sub_group_commit_write_pipe";
6577 llvm::FunctionType *FTy = llvm::FunctionType::get(
6581 {Arg0, Arg1, PacketSize, PacketAlign}));
6584 case Builtin::BIget_pipe_num_packets:
6585 case Builtin::BIget_pipe_max_packets: {
6586 const char *BaseName;
6588 if (BuiltinID == Builtin::BIget_pipe_num_packets)
6589 BaseName =
"__get_pipe_num_packets";
6591 BaseName =
"__get_pipe_max_packets";
6592 std::string Name = std::string(BaseName) +
6593 std::string(PipeTy->isReadOnly() ?
"_ro" :
"_wo");
6601 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6604 {Arg0, PacketSize, PacketAlign}));
6608 case Builtin::BIto_global:
6609 case Builtin::BIto_local:
6610 case Builtin::BIto_private: {
6612 auto NewArgT = llvm::PointerType::get(
6615 auto NewRetT = llvm::PointerType::get(
6617 CGM.getContext().getTargetAddressSpace(
6619 auto FTy = llvm::FunctionType::get(NewRetT, {NewArgT},
false);
6620 llvm::Value *NewArg;
6621 if (Arg0->getType()->getPointerAddressSpace() !=
6622 NewArgT->getPointerAddressSpace())
6623 NewArg =
Builder.CreateAddrSpaceCast(Arg0, NewArgT);
6625 NewArg =
Builder.CreateBitOrPointerCast(Arg0, NewArgT);
6641 case Builtin::BIenqueue_kernel: {
6646 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6663 Range = Range->stripPointerCasts();
6665 llvm::Type *RangePtrTy = Range->getType();
6670 Name =
"__enqueue_kernel_basic";
6671 llvm::Type *ArgTys[] = {QueueTy,
Int32Ty, RangePtrTy, GenericVoidPtrTy,
6673 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6676 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6678 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6679 llvm::Value *
Block =
6680 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6683 {Queue, Flags, Range, Kernel, Block});
6686 assert(NumArgs >= 5 &&
"Invalid enqueue_kernel signature");
6690 auto CreateArrayForSizeVar =
6691 [=](
unsigned First) -> std::pair<llvm::Value *, llvm::Value *> {
6692 llvm::APInt ArraySize(32, NumArgs -
First);
6694 getContext().getSizeType(), ArraySize,
nullptr,
6698 llvm::Value *TmpPtr = Tmp.getPointer();
6703 llvm::Value *Alloca = TmpPtr->stripPointerCasts();
6704 llvm::Value *ElemPtr;
6708 auto *
Zero = llvm::ConstantInt::get(
IntTy, 0);
6709 for (
unsigned I =
First; I < NumArgs; ++I) {
6710 auto *Index = llvm::ConstantInt::get(
IntTy, I -
First);
6712 Builder.CreateGEP(Tmp.getElementType(), Alloca, {Zero, Index});
6718 V, GEP,
CGM.getDataLayout().getPrefTypeAlign(
SizeTy));
6722 return {ElemPtr, Alloca};
6728 Name =
"__enqueue_kernel_varargs";
6730 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6732 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6733 auto *
Block =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6734 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(4);
6738 llvm::Value *
const Args[] = {Queue, Flags,
6742 llvm::Type *
const ArgTys[] = {
6743 QueueTy,
IntTy, RangePtrTy, GenericVoidPtrTy,
6744 GenericVoidPtrTy,
IntTy, ElemPtr->getType()};
6746 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6754 llvm::PointerType *PtrTy = llvm::PointerType::get(
6755 CGM.getLLVMContext(),
6758 llvm::Value *NumEvents =
6764 llvm::Value *EventWaitList =
nullptr;
6767 EventWaitList = llvm::ConstantPointerNull::get(PtrTy);
6774 EventWaitList =
Builder.CreatePointerCast(EventWaitList, PtrTy);
6776 llvm::Value *EventRet =
nullptr;
6779 EventRet = llvm::ConstantPointerNull::get(PtrTy);
6786 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(6));
6788 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6789 llvm::Value *
Block =
6790 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6792 std::vector<llvm::Type *> ArgTys = {
6794 PtrTy, PtrTy, GenericVoidPtrTy, GenericVoidPtrTy};
6796 std::vector<llvm::Value *> Args = {Queue, Flags, Range,
6797 NumEvents, EventWaitList, EventRet,
6802 Name =
"__enqueue_kernel_basic_events";
6803 llvm::FunctionType *FTy =
6804 llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6810 Args.push_back(ConstantInt::get(
Int32Ty, NumArgs - 7));
6812 Name =
"__enqueue_kernel_events_varargs";
6814 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(7);
6815 Args.push_back(ElemPtr);
6816 ArgTys.push_back(ElemPtr->getType());
6818 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6824 llvm_unreachable(
"Unexpected enqueue_kernel signature");
6828 case Builtin::BIget_kernel_work_group_size: {
6829 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6832 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6834 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6835 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6837 CGM.CreateRuntimeFunction(
6838 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6840 "__get_kernel_work_group_size_impl"),
6843 case Builtin::BIget_kernel_preferred_work_group_size_multiple: {
6844 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6847 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6849 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6850 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6852 CGM.CreateRuntimeFunction(
6853 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6855 "__get_kernel_preferred_work_group_size_multiple_impl"),
6858 case Builtin::BIget_kernel_max_sub_group_size_for_ndrange:
6859 case Builtin::BIget_kernel_sub_group_count_for_ndrange: {
6860 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6865 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(1));
6867 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6870 BuiltinID == Builtin::BIget_kernel_max_sub_group_size_for_ndrange
6871 ?
"__get_kernel_max_sub_group_size_for_ndrange_impl"
6872 :
"__get_kernel_sub_group_count_for_ndrange_impl";
6874 CGM.CreateRuntimeFunction(
6875 llvm::FunctionType::get(
6876 IntTy, {NDRange->getType(), GenericVoidPtrTy, GenericVoidPtrTy},
6879 {NDRange, Kernel, Block}));
6881 case Builtin::BI__builtin_store_half:
6882 case Builtin::BI__builtin_store_halff: {
6890 case Builtin::BI__builtin_load_half: {
6895 case Builtin::BI__builtin_load_halff: {
6900 case Builtin::BI__builtin_printf:
6901 case Builtin::BIprintf:
6915 case Builtin::BI__builtin_canonicalize:
6916 case Builtin::BI__builtin_canonicalizef:
6917 case Builtin::BI__builtin_canonicalizef16:
6918 case Builtin::BI__builtin_canonicalizel:
6922 case Builtin::BI__builtin_thread_pointer: {
6923 if (!
getContext().getTargetInfo().isTLSSupported())
6924 CGM.ErrorUnsupported(E,
"__builtin_thread_pointer");
6927 {GlobalsInt8PtrTy}, {}));
6929 case Builtin::BI__builtin_os_log_format:
6932 case Builtin::BI__xray_customevent: {
6936 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6940 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6944 Function *F =
CGM.getIntrinsic(Intrinsic::xray_customevent);
6945 auto FTy = F->getFunctionType();
6946 auto Arg0 = E->
getArg(0);
6948 auto Arg0Ty = Arg0->getType();
6949 auto PTy0 = FTy->getParamType(0);
6950 if (PTy0 != Arg0Val->getType()) {
6951 if (Arg0Ty->isArrayType())
6954 Arg0Val =
Builder.CreatePointerCast(Arg0Val, PTy0);
6957 auto PTy1 = FTy->getParamType(1);
6958 if (PTy1 != Arg1->getType())
6959 Arg1 =
Builder.CreateTruncOrBitCast(Arg1, PTy1);
6963 case Builtin::BI__xray_typedevent: {
6970 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6974 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6978 Function *F =
CGM.getIntrinsic(Intrinsic::xray_typedevent);
6979 auto FTy = F->getFunctionType();
6981 auto PTy0 = FTy->getParamType(0);
6982 if (PTy0 != Arg0->getType())
6983 Arg0 =
Builder.CreateTruncOrBitCast(Arg0, PTy0);
6984 auto Arg1 = E->
getArg(1);
6986 auto Arg1Ty = Arg1->getType();
6987 auto PTy1 = FTy->getParamType(1);
6988 if (PTy1 != Arg1Val->getType()) {
6989 if (Arg1Ty->isArrayType())
6992 Arg1Val =
Builder.CreatePointerCast(Arg1Val, PTy1);
6995 auto PTy2 = FTy->getParamType(2);
6996 if (PTy2 != Arg2->getType())
6997 Arg2 =
Builder.CreateTruncOrBitCast(Arg2, PTy2);
7001 case Builtin::BI__builtin_ms_va_start:
7002 case Builtin::BI__builtin_ms_va_end:
7005 BuiltinID == Builtin::BI__builtin_ms_va_start));
7007 case Builtin::BI__builtin_ms_va_copy: {
7024 case Builtin::BI__builtin_get_device_side_mangled_name: {
7025 auto Name =
CGM.getCUDARuntime().getDeviceSideName(
7027 auto Str =
CGM.GetAddrOfConstantCString(Name,
"");
7037 BI.isLibFunction(BuiltinID))
7039 CGM.getBuiltinLibFunction(FD, BuiltinID));
7043 if (BI.isPredefinedLibFunction(BuiltinID))
7053 if (
unsigned VectorWidth =
getContext().BuiltinInfo.getRequiredVectorWidth(BuiltinID))
7054 LargestVectorWidth = std::max(LargestVectorWidth, VectorWidth);
7058 Intrinsic::ID IntrinsicID = Intrinsic::not_intrinsic;
7061 if (!Prefix.empty()) {
7062 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(Prefix.data(), Name);
7063 if (IntrinsicID == Intrinsic::not_intrinsic && Prefix ==
"spv" &&
7065 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(
"amdgcn", Name);
7069 if (IntrinsicID == Intrinsic::not_intrinsic)
7070 IntrinsicID = Intrinsic::getIntrinsicForMSBuiltin(Prefix.data(), Name);
7073 if (IntrinsicID != Intrinsic::not_intrinsic) {
7078 unsigned ICEArguments = 0;
7084 llvm::FunctionType *FTy = F->getFunctionType();
7086 for (
unsigned i = 0, e = E->
getNumArgs(); i != e; ++i) {
7090 llvm::Type *PTy = FTy->getParamType(i);
7091 if (PTy != ArgValue->
getType()) {
7093 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(PTy)) {
7094 if (PtrTy->getAddressSpace() !=
7095 ArgValue->
getType()->getPointerAddressSpace()) {
7096 ArgValue =
Builder.CreateAddrSpaceCast(
7098 PtrTy->getAddressSpace()));
7104 if (PTy->isX86_AMXTy())
7105 ArgValue =
Builder.CreateIntrinsic(Intrinsic::x86_cast_vector_to_tile,
7106 {ArgValue->
getType()}, {ArgValue});
7108 ArgValue =
Builder.CreateBitCast(ArgValue, PTy);
7111 Args.push_back(ArgValue);
7117 llvm::Type *RetTy =
VoidTy;
7121 if (RetTy !=
V->getType()) {
7123 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(RetTy)) {
7124 if (PtrTy->getAddressSpace() !=
V->getType()->getPointerAddressSpace()) {
7127 PtrTy->getAddressSpace()));
7133 if (
V->getType()->isX86_AMXTy())
7134 V =
Builder.CreateIntrinsic(Intrinsic::x86_cast_tile_to_vector, {RetTy},
7140 if (RetTy->isVoidTy())
7160 if (
V->getType()->isVoidTy())
7167 llvm_unreachable(
"No current target builtin returns complex");
7169 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");
7176 if (
V->getType()->isVoidTy())
7183 llvm_unreachable(
"No current hlsl builtin returns complex");
7185 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");