2935 assert(!
getContext().BuiltinInfo.isImmediate(BuiltinID) &&
2936 "Should not codegen for consteval builtins");
2943 !
Result.hasSideEffects()) {
2947 if (
Result.Val.isFloat())
2957 &
getTarget().getLongDoubleFormat() == &llvm::APFloat::IEEEquad())
2964 const unsigned BuiltinIDIfNoAsmLabel =
2965 FD->
hasAttr<AsmLabelAttr>() ? 0 : BuiltinID;
2967 std::optional<bool> ErrnoOverriden;
2973 if (OP.hasMathErrnoOverride())
2974 ErrnoOverriden = OP.getMathErrnoOverride();
2980 bool IsOptimizationEnabled =
CGM.getCodeGenOpts().OptimizationLevel != 0;
2982 bool GenerateFPMathIntrinsics =
2984 BuiltinID,
CGM.getTriple(), ErrnoOverriden,
getLangOpts().MathErrno,
2985 OptNone, IsOptimizationEnabled);
2987 if (GenerateFPMathIntrinsics) {
2988 switch (BuiltinIDIfNoAsmLabel) {
2989 case Builtin::BIacos:
2990 case Builtin::BIacosf:
2991 case Builtin::BIacosl:
2992 case Builtin::BI__builtin_acos:
2993 case Builtin::BI__builtin_acosf:
2994 case Builtin::BI__builtin_acosf16:
2995 case Builtin::BI__builtin_acosl:
2996 case Builtin::BI__builtin_acosf128:
2997 case Builtin::BI__builtin_elementwise_acos:
2999 *
this, E, Intrinsic::acos, Intrinsic::experimental_constrained_acos));
3001 case Builtin::BIasin:
3002 case Builtin::BIasinf:
3003 case Builtin::BIasinl:
3004 case Builtin::BI__builtin_asin:
3005 case Builtin::BI__builtin_asinf:
3006 case Builtin::BI__builtin_asinf16:
3007 case Builtin::BI__builtin_asinl:
3008 case Builtin::BI__builtin_asinf128:
3009 case Builtin::BI__builtin_elementwise_asin:
3011 *
this, E, Intrinsic::asin, Intrinsic::experimental_constrained_asin));
3013 case Builtin::BIatan:
3014 case Builtin::BIatanf:
3015 case Builtin::BIatanl:
3016 case Builtin::BI__builtin_atan:
3017 case Builtin::BI__builtin_atanf:
3018 case Builtin::BI__builtin_atanf16:
3019 case Builtin::BI__builtin_atanl:
3020 case Builtin::BI__builtin_atanf128:
3021 case Builtin::BI__builtin_elementwise_atan:
3023 *
this, E, Intrinsic::atan, Intrinsic::experimental_constrained_atan));
3025 case Builtin::BIatan2:
3026 case Builtin::BIatan2f:
3027 case Builtin::BIatan2l:
3028 case Builtin::BI__builtin_atan2:
3029 case Builtin::BI__builtin_atan2f:
3030 case Builtin::BI__builtin_atan2f16:
3031 case Builtin::BI__builtin_atan2l:
3032 case Builtin::BI__builtin_atan2f128:
3033 case Builtin::BI__builtin_elementwise_atan2:
3035 *
this, E, Intrinsic::atan2,
3036 Intrinsic::experimental_constrained_atan2));
3038 case Builtin::BIceil:
3039 case Builtin::BIceilf:
3040 case Builtin::BIceill:
3041 case Builtin::BI__builtin_ceil:
3042 case Builtin::BI__builtin_ceilf:
3043 case Builtin::BI__builtin_ceilf16:
3044 case Builtin::BI__builtin_ceill:
3045 case Builtin::BI__builtin_ceilf128:
3046 case Builtin::BI__builtin_elementwise_ceil:
3049 Intrinsic::experimental_constrained_ceil));
3051 case Builtin::BIcopysign:
3052 case Builtin::BIcopysignf:
3053 case Builtin::BIcopysignl:
3054 case Builtin::BI__builtin_copysign:
3055 case Builtin::BI__builtin_copysignf:
3056 case Builtin::BI__builtin_copysignf16:
3057 case Builtin::BI__builtin_copysignl:
3058 case Builtin::BI__builtin_copysignf128:
3062 case Builtin::BIcos:
3063 case Builtin::BIcosf:
3064 case Builtin::BIcosl:
3065 case Builtin::BI__builtin_cos:
3066 case Builtin::BI__builtin_cosf:
3067 case Builtin::BI__builtin_cosf16:
3068 case Builtin::BI__builtin_cosl:
3069 case Builtin::BI__builtin_cosf128:
3070 case Builtin::BI__builtin_elementwise_cos:
3073 Intrinsic::experimental_constrained_cos));
3075 case Builtin::BIcosh:
3076 case Builtin::BIcoshf:
3077 case Builtin::BIcoshl:
3078 case Builtin::BI__builtin_cosh:
3079 case Builtin::BI__builtin_coshf:
3080 case Builtin::BI__builtin_coshf16:
3081 case Builtin::BI__builtin_coshl:
3082 case Builtin::BI__builtin_coshf128:
3083 case Builtin::BI__builtin_elementwise_cosh:
3085 *
this, E, Intrinsic::cosh, Intrinsic::experimental_constrained_cosh));
3087 case Builtin::BIexp:
3088 case Builtin::BIexpf:
3089 case Builtin::BIexpl:
3090 case Builtin::BI__builtin_exp:
3091 case Builtin::BI__builtin_expf:
3092 case Builtin::BI__builtin_expf16:
3093 case Builtin::BI__builtin_expl:
3094 case Builtin::BI__builtin_expf128:
3095 case Builtin::BI__builtin_elementwise_exp:
3098 Intrinsic::experimental_constrained_exp));
3100 case Builtin::BIexp2:
3101 case Builtin::BIexp2f:
3102 case Builtin::BIexp2l:
3103 case Builtin::BI__builtin_exp2:
3104 case Builtin::BI__builtin_exp2f:
3105 case Builtin::BI__builtin_exp2f16:
3106 case Builtin::BI__builtin_exp2l:
3107 case Builtin::BI__builtin_exp2f128:
3108 case Builtin::BI__builtin_elementwise_exp2:
3111 Intrinsic::experimental_constrained_exp2));
3112 case Builtin::BI__builtin_exp10:
3113 case Builtin::BI__builtin_exp10f:
3114 case Builtin::BI__builtin_exp10f16:
3115 case Builtin::BI__builtin_exp10l:
3116 case Builtin::BI__builtin_exp10f128:
3117 case Builtin::BI__builtin_elementwise_exp10: {
3119 if (
Builder.getIsFPConstrained())
3124 case Builtin::BIfabs:
3125 case Builtin::BIfabsf:
3126 case Builtin::BIfabsl:
3127 case Builtin::BI__builtin_fabs:
3128 case Builtin::BI__builtin_fabsf:
3129 case Builtin::BI__builtin_fabsf16:
3130 case Builtin::BI__builtin_fabsl:
3131 case Builtin::BI__builtin_fabsf128:
3135 case Builtin::BIfloor:
3136 case Builtin::BIfloorf:
3137 case Builtin::BIfloorl:
3138 case Builtin::BI__builtin_floor:
3139 case Builtin::BI__builtin_floorf:
3140 case Builtin::BI__builtin_floorf16:
3141 case Builtin::BI__builtin_floorl:
3142 case Builtin::BI__builtin_floorf128:
3143 case Builtin::BI__builtin_elementwise_floor:
3146 Intrinsic::experimental_constrained_floor));
3148 case Builtin::BIfma:
3149 case Builtin::BIfmaf:
3150 case Builtin::BIfmal:
3151 case Builtin::BI__builtin_fma:
3152 case Builtin::BI__builtin_fmaf:
3153 case Builtin::BI__builtin_fmaf16:
3154 case Builtin::BI__builtin_fmal:
3155 case Builtin::BI__builtin_fmaf128:
3156 case Builtin::BI__builtin_elementwise_fma:
3159 Intrinsic::experimental_constrained_fma));
3161 case Builtin::BIfmax:
3162 case Builtin::BIfmaxf:
3163 case Builtin::BIfmaxl:
3164 case Builtin::BI__builtin_fmax:
3165 case Builtin::BI__builtin_fmaxf:
3166 case Builtin::BI__builtin_fmaxf16:
3167 case Builtin::BI__builtin_fmaxl:
3168 case Builtin::BI__builtin_fmaxf128: {
3169 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
3170 Builder.getFastMathFlags().setNoSignedZeros();
3172 *
this, E, Intrinsic::maxnum,
3173 Intrinsic::experimental_constrained_maxnum));
3176 case Builtin::BIfmin:
3177 case Builtin::BIfminf:
3178 case Builtin::BIfminl:
3179 case Builtin::BI__builtin_fmin:
3180 case Builtin::BI__builtin_fminf:
3181 case Builtin::BI__builtin_fminf16:
3182 case Builtin::BI__builtin_fminl:
3183 case Builtin::BI__builtin_fminf128: {
3184 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
3185 Builder.getFastMathFlags().setNoSignedZeros();
3187 *
this, E, Intrinsic::minnum,
3188 Intrinsic::experimental_constrained_minnum));
3191 case Builtin::BIfmaximum_num:
3192 case Builtin::BIfmaximum_numf:
3193 case Builtin::BIfmaximum_numl:
3194 case Builtin::BI__builtin_fmaximum_num:
3195 case Builtin::BI__builtin_fmaximum_numf:
3196 case Builtin::BI__builtin_fmaximum_numf16:
3197 case Builtin::BI__builtin_fmaximum_numl:
3198 case Builtin::BI__builtin_fmaximum_numf128:
3202 case Builtin::BIfminimum_num:
3203 case Builtin::BIfminimum_numf:
3204 case Builtin::BIfminimum_numl:
3205 case Builtin::BI__builtin_fminimum_num:
3206 case Builtin::BI__builtin_fminimum_numf:
3207 case Builtin::BI__builtin_fminimum_numf16:
3208 case Builtin::BI__builtin_fminimum_numl:
3209 case Builtin::BI__builtin_fminimum_numf128:
3215 case Builtin::BIfmod:
3216 case Builtin::BIfmodf:
3217 case Builtin::BIfmodl:
3218 case Builtin::BI__builtin_fmod:
3219 case Builtin::BI__builtin_fmodf:
3220 case Builtin::BI__builtin_fmodf16:
3221 case Builtin::BI__builtin_fmodl:
3222 case Builtin::BI__builtin_fmodf128:
3223 case Builtin::BI__builtin_elementwise_fmod: {
3227 if (
Builder.getIsFPConstrained()) {
3228 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_frem,
3236 case Builtin::BIlog:
3237 case Builtin::BIlogf:
3238 case Builtin::BIlogl:
3239 case Builtin::BI__builtin_log:
3240 case Builtin::BI__builtin_logf:
3241 case Builtin::BI__builtin_logf16:
3242 case Builtin::BI__builtin_logl:
3243 case Builtin::BI__builtin_logf128:
3244 case Builtin::BI__builtin_elementwise_log:
3247 Intrinsic::experimental_constrained_log));
3249 case Builtin::BIlog10:
3250 case Builtin::BIlog10f:
3251 case Builtin::BIlog10l:
3252 case Builtin::BI__builtin_log10:
3253 case Builtin::BI__builtin_log10f:
3254 case Builtin::BI__builtin_log10f16:
3255 case Builtin::BI__builtin_log10l:
3256 case Builtin::BI__builtin_log10f128:
3257 case Builtin::BI__builtin_elementwise_log10:
3260 Intrinsic::experimental_constrained_log10));
3262 case Builtin::BIlog2:
3263 case Builtin::BIlog2f:
3264 case Builtin::BIlog2l:
3265 case Builtin::BI__builtin_log2:
3266 case Builtin::BI__builtin_log2f:
3267 case Builtin::BI__builtin_log2f16:
3268 case Builtin::BI__builtin_log2l:
3269 case Builtin::BI__builtin_log2f128:
3270 case Builtin::BI__builtin_elementwise_log2:
3273 Intrinsic::experimental_constrained_log2));
3275 case Builtin::BInearbyint:
3276 case Builtin::BInearbyintf:
3277 case Builtin::BInearbyintl:
3278 case Builtin::BI__builtin_nearbyint:
3279 case Builtin::BI__builtin_nearbyintf:
3280 case Builtin::BI__builtin_nearbyintl:
3281 case Builtin::BI__builtin_nearbyintf128:
3282 case Builtin::BI__builtin_elementwise_nearbyint:
3284 Intrinsic::nearbyint,
3285 Intrinsic::experimental_constrained_nearbyint));
3287 case Builtin::BIpow:
3288 case Builtin::BIpowf:
3289 case Builtin::BIpowl:
3290 case Builtin::BI__builtin_pow:
3291 case Builtin::BI__builtin_powf:
3292 case Builtin::BI__builtin_powf16:
3293 case Builtin::BI__builtin_powl:
3294 case Builtin::BI__builtin_powf128:
3295 case Builtin::BI__builtin_elementwise_pow:
3298 Intrinsic::experimental_constrained_pow));
3300 case Builtin::BIrint:
3301 case Builtin::BIrintf:
3302 case Builtin::BIrintl:
3303 case Builtin::BI__builtin_rint:
3304 case Builtin::BI__builtin_rintf:
3305 case Builtin::BI__builtin_rintf16:
3306 case Builtin::BI__builtin_rintl:
3307 case Builtin::BI__builtin_rintf128:
3308 case Builtin::BI__builtin_elementwise_rint:
3311 Intrinsic::experimental_constrained_rint));
3313 case Builtin::BIround:
3314 case Builtin::BIroundf:
3315 case Builtin::BIroundl:
3316 case Builtin::BI__builtin_round:
3317 case Builtin::BI__builtin_roundf:
3318 case Builtin::BI__builtin_roundf16:
3319 case Builtin::BI__builtin_roundl:
3320 case Builtin::BI__builtin_roundf128:
3321 case Builtin::BI__builtin_elementwise_round:
3324 Intrinsic::experimental_constrained_round));
3326 case Builtin::BIroundeven:
3327 case Builtin::BIroundevenf:
3328 case Builtin::BIroundevenl:
3329 case Builtin::BI__builtin_roundeven:
3330 case Builtin::BI__builtin_roundevenf:
3331 case Builtin::BI__builtin_roundevenf16:
3332 case Builtin::BI__builtin_roundevenl:
3333 case Builtin::BI__builtin_roundevenf128:
3334 case Builtin::BI__builtin_elementwise_roundeven:
3336 Intrinsic::roundeven,
3337 Intrinsic::experimental_constrained_roundeven));
3339 case Builtin::BIsin:
3340 case Builtin::BIsinf:
3341 case Builtin::BIsinl:
3342 case Builtin::BI__builtin_sin:
3343 case Builtin::BI__builtin_sinf:
3344 case Builtin::BI__builtin_sinf16:
3345 case Builtin::BI__builtin_sinl:
3346 case Builtin::BI__builtin_sinf128:
3347 case Builtin::BI__builtin_elementwise_sin:
3350 Intrinsic::experimental_constrained_sin));
3352 case Builtin::BIsinh:
3353 case Builtin::BIsinhf:
3354 case Builtin::BIsinhl:
3355 case Builtin::BI__builtin_sinh:
3356 case Builtin::BI__builtin_sinhf:
3357 case Builtin::BI__builtin_sinhf16:
3358 case Builtin::BI__builtin_sinhl:
3359 case Builtin::BI__builtin_sinhf128:
3360 case Builtin::BI__builtin_elementwise_sinh:
3362 *
this, E, Intrinsic::sinh, Intrinsic::experimental_constrained_sinh));
3364 case Builtin::BI__builtin_sincospi:
3365 case Builtin::BI__builtin_sincospif:
3366 case Builtin::BI__builtin_sincospil:
3367 if (
Builder.getIsFPConstrained())
3372 case Builtin::BIsincos:
3373 case Builtin::BIsincosf:
3374 case Builtin::BIsincosl:
3375 case Builtin::BI__builtin_sincos:
3376 case Builtin::BI__builtin_sincosf:
3377 case Builtin::BI__builtin_sincosf16:
3378 case Builtin::BI__builtin_sincosl:
3379 case Builtin::BI__builtin_sincosf128:
3380 if (
Builder.getIsFPConstrained())
3385 case Builtin::BIsqrt:
3386 case Builtin::BIsqrtf:
3387 case Builtin::BIsqrtl:
3388 case Builtin::BI__builtin_sqrt:
3389 case Builtin::BI__builtin_sqrtf:
3390 case Builtin::BI__builtin_sqrtf16:
3391 case Builtin::BI__builtin_sqrtl:
3392 case Builtin::BI__builtin_sqrtf128:
3393 case Builtin::BI__builtin_elementwise_sqrt: {
3395 *
this, E, Intrinsic::sqrt, Intrinsic::experimental_constrained_sqrt);
3400 case Builtin::BItan:
3401 case Builtin::BItanf:
3402 case Builtin::BItanl:
3403 case Builtin::BI__builtin_tan:
3404 case Builtin::BI__builtin_tanf:
3405 case Builtin::BI__builtin_tanf16:
3406 case Builtin::BI__builtin_tanl:
3407 case Builtin::BI__builtin_tanf128:
3408 case Builtin::BI__builtin_elementwise_tan:
3410 *
this, E, Intrinsic::tan, Intrinsic::experimental_constrained_tan));
3412 case Builtin::BItanh:
3413 case Builtin::BItanhf:
3414 case Builtin::BItanhl:
3415 case Builtin::BI__builtin_tanh:
3416 case Builtin::BI__builtin_tanhf:
3417 case Builtin::BI__builtin_tanhf16:
3418 case Builtin::BI__builtin_tanhl:
3419 case Builtin::BI__builtin_tanhf128:
3420 case Builtin::BI__builtin_elementwise_tanh:
3422 *
this, E, Intrinsic::tanh, Intrinsic::experimental_constrained_tanh));
3424 case Builtin::BItrunc:
3425 case Builtin::BItruncf:
3426 case Builtin::BItruncl:
3427 case Builtin::BI__builtin_trunc:
3428 case Builtin::BI__builtin_truncf:
3429 case Builtin::BI__builtin_truncf16:
3430 case Builtin::BI__builtin_truncl:
3431 case Builtin::BI__builtin_truncf128:
3432 case Builtin::BI__builtin_elementwise_trunc:
3435 Intrinsic::experimental_constrained_trunc));
3437 case Builtin::BIlround:
3438 case Builtin::BIlroundf:
3439 case Builtin::BIlroundl:
3440 case Builtin::BI__builtin_lround:
3441 case Builtin::BI__builtin_lroundf:
3442 case Builtin::BI__builtin_lroundl:
3443 case Builtin::BI__builtin_lroundf128:
3445 *
this, E, Intrinsic::lround,
3446 Intrinsic::experimental_constrained_lround));
3448 case Builtin::BIllround:
3449 case Builtin::BIllroundf:
3450 case Builtin::BIllroundl:
3451 case Builtin::BI__builtin_llround:
3452 case Builtin::BI__builtin_llroundf:
3453 case Builtin::BI__builtin_llroundl:
3454 case Builtin::BI__builtin_llroundf128:
3456 *
this, E, Intrinsic::llround,
3457 Intrinsic::experimental_constrained_llround));
3459 case Builtin::BIlrint:
3460 case Builtin::BIlrintf:
3461 case Builtin::BIlrintl:
3462 case Builtin::BI__builtin_lrint:
3463 case Builtin::BI__builtin_lrintf:
3464 case Builtin::BI__builtin_lrintl:
3465 case Builtin::BI__builtin_lrintf128:
3467 *
this, E, Intrinsic::lrint,
3468 Intrinsic::experimental_constrained_lrint));
3470 case Builtin::BIllrint:
3471 case Builtin::BIllrintf:
3472 case Builtin::BIllrintl:
3473 case Builtin::BI__builtin_llrint:
3474 case Builtin::BI__builtin_llrintf:
3475 case Builtin::BI__builtin_llrintl:
3476 case Builtin::BI__builtin_llrintf128:
3478 *
this, E, Intrinsic::llrint,
3479 Intrinsic::experimental_constrained_llrint));
3480 case Builtin::BI__builtin_ldexp:
3481 case Builtin::BI__builtin_ldexpf:
3482 case Builtin::BI__builtin_ldexpl:
3483 case Builtin::BI__builtin_ldexpf16:
3484 case Builtin::BI__builtin_ldexpf128:
3485 case Builtin::BI__builtin_elementwise_ldexp:
3487 *
this, E, Intrinsic::ldexp,
3488 Intrinsic::experimental_constrained_ldexp));
3497 Value *Val = A.emitRawPointer(*
this);
3501 if (
SanOpts.has(SanitizerKind::Alignment)) {
3503 SkippedChecks.
set(SanitizerKind::All);
3504 SkippedChecks.
clear(SanitizerKind::Alignment);
3507 if (
auto *CE = dyn_cast<ImplicitCastExpr>(Arg))
3508 if (CE->getCastKind() == CK_BitCast)
3509 Arg = CE->getSubExpr();
3515 switch (BuiltinIDIfNoAsmLabel) {
3517 case Builtin::BI__builtin___CFStringMakeConstantString:
3518 case Builtin::BI__builtin___NSStringMakeConstantString:
3520 case Builtin::BI__builtin_stdarg_start:
3521 case Builtin::BI__builtin_va_start:
3522 case Builtin::BI__va_start:
3523 case Builtin::BI__builtin_c23_va_start:
3524 case Builtin::BI__builtin_va_end:
3528 BuiltinID != Builtin::BI__builtin_va_end);
3530 case Builtin::BI__builtin_va_copy: {
3533 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::vacopy, {DstPtr->getType()}),
3537 case Builtin::BIabs:
3538 case Builtin::BIlabs:
3539 case Builtin::BIllabs:
3540 case Builtin::BI__builtin_abs:
3541 case Builtin::BI__builtin_labs:
3542 case Builtin::BI__builtin_llabs: {
3543 bool SanitizeOverflow =
SanOpts.has(SanitizerKind::SignedIntegerOverflow);
3546 switch (
getLangOpts().getSignedOverflowBehavior()) {
3551 if (!SanitizeOverflow) {
3563 case Builtin::BI__builtin_complex: {
3568 case Builtin::BI__builtin_conj:
3569 case Builtin::BI__builtin_conjf:
3570 case Builtin::BI__builtin_conjl:
3571 case Builtin::BIconj:
3572 case Builtin::BIconjf:
3573 case Builtin::BIconjl: {
3575 Value *Real = ComplexVal.first;
3576 Value *Imag = ComplexVal.second;
3577 Imag =
Builder.CreateFNeg(Imag,
"neg");
3580 case Builtin::BI__builtin_creal:
3581 case Builtin::BI__builtin_crealf:
3582 case Builtin::BI__builtin_creall:
3583 case Builtin::BIcreal:
3584 case Builtin::BIcrealf:
3585 case Builtin::BIcreall: {
3590 case Builtin::BI__builtin_preserve_access_index: {
3595 CGM.Error(E->
getExprLoc(),
"using builtin_preserve_access_index() without -g");
3601 CGM.Error(E->
getExprLoc(),
"nested builtin_preserve_access_index() not supported");
3611 case Builtin::BI__builtin_cimag:
3612 case Builtin::BI__builtin_cimagf:
3613 case Builtin::BI__builtin_cimagl:
3614 case Builtin::BIcimag:
3615 case Builtin::BIcimagf:
3616 case Builtin::BIcimagl: {
3621 case Builtin::BI__builtin_clrsb:
3622 case Builtin::BI__builtin_clrsbl:
3623 case Builtin::BI__builtin_clrsbll: {
3634 Value *Tmp =
Builder.CreateSelect(IsNeg, Inverse, ArgValue);
3642 case Builtin::BI__builtin_ctzs:
3643 case Builtin::BI__builtin_ctz:
3644 case Builtin::BI__builtin_ctzl:
3645 case Builtin::BI__builtin_ctzll:
3646 case Builtin::BI__builtin_ctzg:
3647 case Builtin::BI__builtin_elementwise_ctzg: {
3649 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_ctzg ||
3650 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg) &&
3663 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3664 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg);
3666 if (
Result->getType() != ResultType)
3675 Value *ResultOrFallback =
3676 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"ctzg");
3679 case Builtin::BI__builtin_clzs:
3680 case Builtin::BI__builtin_clz:
3681 case Builtin::BI__builtin_clzl:
3682 case Builtin::BI__builtin_clzll:
3683 case Builtin::BI__builtin_clzg:
3684 case Builtin::BI__builtin_elementwise_clzg: {
3686 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_clzg ||
3687 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg) &&
3700 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3701 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg);
3703 if (
Result->getType() != ResultType)
3712 Value *ResultOrFallback =
3713 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"clzg");
3716 case Builtin::BI__builtin_ffs:
3717 case Builtin::BI__builtin_ffsl:
3718 case Builtin::BI__builtin_ffsll: {
3727 Builder.CreateAdd(
Builder.CreateCall(F, {ArgValue, Builder.getTrue()}),
3728 llvm::ConstantInt::get(
ArgType, 1));
3732 if (
Result->getType() != ResultType)
3737 case Builtin::BI__builtin_parity:
3738 case Builtin::BI__builtin_parityl:
3739 case Builtin::BI__builtin_parityll: {
3749 if (
Result->getType() != ResultType)
3754 case Builtin::BI__lzcnt16:
3755 case Builtin::BI__lzcnt:
3756 case Builtin::BI__lzcnt64: {
3764 if (
Result->getType() != ResultType)
3769 case Builtin::BI__popcnt16:
3770 case Builtin::BI__popcnt:
3771 case Builtin::BI__popcnt64:
3772 case Builtin::BI__builtin_popcount:
3773 case Builtin::BI__builtin_popcountl:
3774 case Builtin::BI__builtin_popcountll:
3775 case Builtin::BI__builtin_popcountg: {
3783 if (
Result->getType() != ResultType)
3788 case Builtin::BI__builtin_unpredictable: {
3794 case Builtin::BI__builtin_expect: {
3802 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3807 Builder.CreateCall(FnExpect, {ArgValue, ExpectedValue},
"expval");
3810 case Builtin::BI__builtin_expect_with_probability: {
3815 llvm::APFloat Probability(0.0);
3818 assert(EvalSucceed &&
"probability should be able to evaluate as float");
3820 bool LoseInfo =
false;
3821 Probability.convert(llvm::APFloat::IEEEdouble(),
3822 llvm::RoundingMode::Dynamic, &LoseInfo);
3824 Constant *Confidence = ConstantFP::get(Ty, Probability);
3828 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3832 CGM.getIntrinsic(Intrinsic::expect_with_probability,
ArgType);
3834 FnExpect, {ArgValue, ExpectedValue, Confidence},
"expval");
3837 case Builtin::BI__builtin_assume_aligned: {
3840 Value *OffsetValue =
3845 if (AlignmentCI->getValue().ugt(llvm::Value::MaximumAlignment))
3846 AlignmentCI = ConstantInt::get(AlignmentCI->getIntegerType(),
3847 llvm::Value::MaximumAlignment);
3851 AlignmentCI, OffsetValue);
3854 case Builtin::BI__builtin_assume_dereferenceable: {
3862 Builder.CreateDereferenceableAssumption(PtrValue, SizeValue);
3865 case Builtin::BI__assume:
3866 case Builtin::BI__builtin_assume: {
3871 Function *FnAssume =
CGM.getIntrinsic(Intrinsic::assume);
3872 Builder.CreateCall(FnAssume, ArgValue);
3875 case Builtin::BI__builtin_assume_separate_storage: {
3882 Value *Values[] = {Value0, Value1};
3883 OperandBundleDefT<Value *> OBD(
"separate_storage", Values);
3884 Builder.CreateAssumption({OBD});
3887 case Builtin::BI__builtin_allow_runtime_check: {
3890 LLVMContext &Ctx =
CGM.getLLVMContext();
3892 CGM.getIntrinsic(Intrinsic::allow_runtime_check),
3893 llvm::MetadataAsValue::get(Ctx, llvm::MDString::get(Ctx, Kind)));
3896 case Builtin::BI__builtin_allow_sanitize_check: {
3897 Intrinsic::ID IntrID = Intrinsic::not_intrinsic;
3905 if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Address |
3906 SanitizerKind::KernelAddress) &&
3907 (Name ==
"address" || Name ==
"kernel-address")) {
3908 IntrID = Intrinsic::allow_sanitize_address;
3909 }
else if (
getLangOpts().Sanitize.has(SanitizerKind::Thread) &&
3911 IntrID = Intrinsic::allow_sanitize_thread;
3912 }
else if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Memory |
3913 SanitizerKind::KernelMemory) &&
3914 (Name ==
"memory" || Name ==
"kernel-memory")) {
3915 IntrID = Intrinsic::allow_sanitize_memory;
3917 SanitizerKind::HWAddress | SanitizerKind::KernelHWAddress) &&
3918 (Name ==
"hwaddress" || Name ==
"kernel-hwaddress")) {
3919 IntrID = Intrinsic::allow_sanitize_hwaddress;
3922 if (IntrID != Intrinsic::not_intrinsic) {
3931 case Builtin::BI__arithmetic_fence: {
3935 llvm::FastMathFlags FMF =
Builder.getFastMathFlags();
3936 bool isArithmeticFenceEnabled =
3937 FMF.allowReassoc() &&
3940 if (
ArgType->isComplexType()) {
3941 if (isArithmeticFenceEnabled) {
3944 Value *Real =
Builder.CreateArithmeticFence(ComplexVal.first,
3946 Value *Imag =
Builder.CreateArithmeticFence(ComplexVal.second,
3951 Value *Real = ComplexVal.first;
3952 Value *Imag = ComplexVal.second;
3956 if (isArithmeticFenceEnabled)
3961 case Builtin::BI__builtin_bswapg: {
3964 assert(
IntTy &&
"LLVM's __builtin_bswapg only supports integer variants");
3965 if (
IntTy->getBitWidth() == 1 ||
IntTy->getBitWidth() == 8)
3967 assert(((
IntTy->getBitWidth() % 16 == 0 &&
IntTy->getBitWidth() != 0)) &&
3968 "LLVM's __builtin_bswapg only supports integer variants that has a "
3969 "multiple of 16 bits as well as a single byte");
3973 case Builtin::BI__builtin_bswap16:
3974 case Builtin::BI__builtin_bswap32:
3975 case Builtin::BI__builtin_bswap64:
3976 case Builtin::BI_byteswap_ushort:
3977 case Builtin::BI_byteswap_ulong:
3978 case Builtin::BI_byteswap_uint64: {
3982 case Builtin::BI__builtin_bitreverseg: {
3986 "LLVM's __builtin_bitreverseg only support integer variants");
3987 if (
IntTy->getBitWidth() == 1)
3992 case Builtin::BI__builtin_bitreverse8:
3993 case Builtin::BI__builtin_bitreverse16:
3994 case Builtin::BI__builtin_bitreverse32:
3995 case Builtin::BI__builtin_bitreverse64: {
3999 case Builtin::BI__builtin_rotateleft8:
4000 case Builtin::BI__builtin_rotateleft16:
4001 case Builtin::BI__builtin_rotateleft32:
4002 case Builtin::BI__builtin_rotateleft64:
4003 case Builtin::BI__builtin_stdc_rotate_left:
4004 case Builtin::BIstdc_rotate_left_uc:
4005 case Builtin::BIstdc_rotate_left_us:
4006 case Builtin::BIstdc_rotate_left_ui:
4007 case Builtin::BIstdc_rotate_left_ul:
4008 case Builtin::BIstdc_rotate_left_ull:
4009 case Builtin::BI_rotl8:
4010 case Builtin::BI_rotl16:
4011 case Builtin::BI_rotl:
4012 case Builtin::BI_lrotl:
4013 case Builtin::BI_rotl64:
4016 case Builtin::BI__builtin_rotateright8:
4017 case Builtin::BI__builtin_rotateright16:
4018 case Builtin::BI__builtin_rotateright32:
4019 case Builtin::BI__builtin_rotateright64:
4020 case Builtin::BI__builtin_stdc_rotate_right:
4021 case Builtin::BIstdc_rotate_right_uc:
4022 case Builtin::BIstdc_rotate_right_us:
4023 case Builtin::BIstdc_rotate_right_ui:
4024 case Builtin::BIstdc_rotate_right_ul:
4025 case Builtin::BIstdc_rotate_right_ull:
4026 case Builtin::BI_rotr8:
4027 case Builtin::BI_rotr16:
4028 case Builtin::BI_rotr:
4029 case Builtin::BI_lrotr:
4030 case Builtin::BI_rotr64:
4033 case Builtin::BIstdc_leading_zeros_uc:
4034 case Builtin::BIstdc_leading_zeros_us:
4035 case Builtin::BIstdc_leading_zeros_ui:
4036 case Builtin::BIstdc_leading_zeros_ul:
4037 case Builtin::BIstdc_leading_zeros_ull:
4038 case Builtin::BI__builtin_stdc_leading_zeros:
4040 case Builtin::BIstdc_leading_ones_uc:
4041 case Builtin::BIstdc_leading_ones_us:
4042 case Builtin::BIstdc_leading_ones_ui:
4043 case Builtin::BIstdc_leading_ones_ul:
4044 case Builtin::BIstdc_leading_ones_ull:
4045 case Builtin::BI__builtin_stdc_leading_ones:
4047 case Builtin::BIstdc_trailing_zeros_uc:
4048 case Builtin::BIstdc_trailing_zeros_us:
4049 case Builtin::BIstdc_trailing_zeros_ui:
4050 case Builtin::BIstdc_trailing_zeros_ul:
4051 case Builtin::BIstdc_trailing_zeros_ull:
4052 case Builtin::BI__builtin_stdc_trailing_zeros:
4054 case Builtin::BIstdc_trailing_ones_uc:
4055 case Builtin::BIstdc_trailing_ones_us:
4056 case Builtin::BIstdc_trailing_ones_ui:
4057 case Builtin::BIstdc_trailing_ones_ul:
4058 case Builtin::BIstdc_trailing_ones_ull:
4059 case Builtin::BI__builtin_stdc_trailing_ones:
4061 case Builtin::BIstdc_first_leading_zero_uc:
4062 case Builtin::BIstdc_first_leading_zero_us:
4063 case Builtin::BIstdc_first_leading_zero_ui:
4064 case Builtin::BIstdc_first_leading_zero_ul:
4065 case Builtin::BIstdc_first_leading_zero_ull:
4066 case Builtin::BI__builtin_stdc_first_leading_zero:
4068 case Builtin::BIstdc_first_leading_one_uc:
4069 case Builtin::BIstdc_first_leading_one_us:
4070 case Builtin::BIstdc_first_leading_one_ui:
4071 case Builtin::BIstdc_first_leading_one_ul:
4072 case Builtin::BIstdc_first_leading_one_ull:
4073 case Builtin::BI__builtin_stdc_first_leading_one:
4075 case Builtin::BIstdc_first_trailing_zero_uc:
4076 case Builtin::BIstdc_first_trailing_zero_us:
4077 case Builtin::BIstdc_first_trailing_zero_ui:
4078 case Builtin::BIstdc_first_trailing_zero_ul:
4079 case Builtin::BIstdc_first_trailing_zero_ull:
4080 case Builtin::BI__builtin_stdc_first_trailing_zero:
4082 case Builtin::BIstdc_first_trailing_one_uc:
4083 case Builtin::BIstdc_first_trailing_one_us:
4084 case Builtin::BIstdc_first_trailing_one_ui:
4085 case Builtin::BIstdc_first_trailing_one_ul:
4086 case Builtin::BIstdc_first_trailing_one_ull:
4087 case Builtin::BI__builtin_stdc_first_trailing_one:
4089 case Builtin::BIstdc_count_zeros_uc:
4090 case Builtin::BIstdc_count_zeros_us:
4091 case Builtin::BIstdc_count_zeros_ui:
4092 case Builtin::BIstdc_count_zeros_ul:
4093 case Builtin::BIstdc_count_zeros_ull:
4094 case Builtin::BI__builtin_stdc_count_zeros:
4096 case Builtin::BIstdc_count_ones_uc:
4097 case Builtin::BIstdc_count_ones_us:
4098 case Builtin::BIstdc_count_ones_ui:
4099 case Builtin::BIstdc_count_ones_ul:
4100 case Builtin::BIstdc_count_ones_ull:
4101 case Builtin::BI__builtin_stdc_count_ones:
4104 case Builtin::BIstdc_has_single_bit_uc:
4105 case Builtin::BIstdc_has_single_bit_us:
4106 case Builtin::BIstdc_has_single_bit_ui:
4107 case Builtin::BIstdc_has_single_bit_ul:
4108 case Builtin::BIstdc_has_single_bit_ull:
4109 case Builtin::BI__builtin_stdc_has_single_bit: {
4117 case Builtin::BIstdc_bit_width_uc:
4118 case Builtin::BIstdc_bit_width_us:
4119 case Builtin::BIstdc_bit_width_ui:
4120 case Builtin::BIstdc_bit_width_ul:
4121 case Builtin::BIstdc_bit_width_ull:
4122 case Builtin::BI__builtin_stdc_bit_width:
4124 case Builtin::BIstdc_bit_floor_uc:
4125 case Builtin::BIstdc_bit_floor_us:
4126 case Builtin::BIstdc_bit_floor_ui:
4127 case Builtin::BIstdc_bit_floor_ul:
4128 case Builtin::BIstdc_bit_floor_ull:
4129 case Builtin::BI__builtin_stdc_bit_floor: {
4132 unsigned BitWidth =
ArgType->getIntegerBitWidth();
4144 case Builtin::BIstdc_bit_ceil_uc:
4145 case Builtin::BIstdc_bit_ceil_us:
4146 case Builtin::BIstdc_bit_ceil_ui:
4147 case Builtin::BIstdc_bit_ceil_ul:
4148 case Builtin::BIstdc_bit_ceil_ull:
4149 case Builtin::BI__builtin_stdc_bit_ceil: {
4152 unsigned BitWidth =
ArgType->getIntegerBitWidth();
4156 Value *IsLEOne =
Builder.CreateICmpULE(ArgValue, One,
"isleone");
4158 BasicBlock *EntryBB =
Builder.GetInsertBlock();
4162 Builder.CreateCondBr(IsLEOne, MergeBB, CalcBB);
4164 Builder.SetInsertPoint(CalcBB);
4176 Builder.SetInsertPoint(MergeBB);
4178 Phi->addIncoming(One, EntryBB);
4179 Phi->addIncoming(Tmp, CalcBB);
4184 case Builtin::BIstdc_memreverse8u8:
4187 case Builtin::BIstdc_memreverse8u16:
4188 case Builtin::BIstdc_memreverse8u32:
4189 case Builtin::BIstdc_memreverse8u64:
4193 case Builtin::BIstdc_memreverse8:
4194 case Builtin::BI__builtin_stdc_memreverse8: {
4197 uint64_t Size = R.Val.getInt().getZExtValue();
4202 if (Size == 2 || Size == 4 || Size == 8) {
4218 case Builtin::BI__builtin_constant_p: {
4225 if (!
ArgType->isIntegralOrEnumerationType() && !
ArgType->isFloatingType() &&
4226 !
ArgType->isObjCObjectPointerType() && !
ArgType->isBlockPointerType())
4229 return RValue::get(ConstantInt::get(ResultType, 0));
4234 return RValue::get(ConstantInt::get(ResultType, 0));
4237 if (
ArgType->isObjCObjectPointerType()) {
4246 if (
Result->getType() != ResultType)
4250 case Builtin::BI__builtin_dynamic_object_size:
4251 case Builtin::BI__builtin_object_size: {
4258 bool IsDynamic = BuiltinID == Builtin::BI__builtin_dynamic_object_size;
4260 nullptr, IsDynamic));
4262 case Builtin::BI__builtin_counted_by_ref: {
4264 llvm::Value *
Result = llvm::ConstantPointerNull::get(
4269 if (
auto *UO = dyn_cast<UnaryOperator>(Arg);
4270 UO && UO->getOpcode() == UO_AddrOf) {
4273 if (
auto *ASE = dyn_cast<ArraySubscriptExpr>(Arg))
4277 if (
const MemberExpr *ME = dyn_cast_if_present<MemberExpr>(Arg)) {
4285 llvm::report_fatal_error(
"Cannot find the counted_by 'count' field");
4291 case Builtin::BI__builtin_prefetch: {
4293 unsigned ICEArguments = (1 << 1) | (1 << 2);
4296 : llvm::ConstantInt::get(
Int32Ty, 0);
4299 : llvm::ConstantInt::get(
Int32Ty, 3);
4305 case Builtin::BI__builtin_readcyclecounter: {
4306 Function *F =
CGM.getIntrinsic(Intrinsic::readcyclecounter);
4309 case Builtin::BI__builtin_readsteadycounter: {
4310 Function *F =
CGM.getIntrinsic(Intrinsic::readsteadycounter);
4313 case Builtin::BI__builtin___clear_cache: {
4316 Function *F =
CGM.getIntrinsic(Intrinsic::clear_cache, {
CGM.DefaultPtrTy});
4319 case Builtin::BI__builtin_trap:
4322 case Builtin::BI__builtin_verbose_trap: {
4323 llvm::DILocation *TrapLocation =
Builder.getCurrentDebugLocation();
4334 case Builtin::BI__debugbreak:
4337 case Builtin::BI__builtin_unreachable: {
4346 case Builtin::BI__builtin_powi:
4347 case Builtin::BI__builtin_powif:
4348 case Builtin::BI__builtin_powil: {
4352 if (
Builder.getIsFPConstrained()) {
4356 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_powi,
4362 { Src0->getType(), Src1->getType() });
4365 case Builtin::BI__builtin_frexpl: {
4369 if (&
getTarget().getLongDoubleFormat() == &llvm::APFloat::PPCDoubleDouble())
4373 case Builtin::BI__builtin_frexp:
4374 case Builtin::BI__builtin_frexpf:
4375 case Builtin::BI__builtin_frexpf128:
4376 case Builtin::BI__builtin_frexpf16:
4378 case Builtin::BImodf:
4379 case Builtin::BImodff:
4380 case Builtin::BImodfl:
4381 case Builtin::BI__builtin_modf:
4382 case Builtin::BI__builtin_modff:
4383 case Builtin::BI__builtin_modfl:
4384 if (
Builder.getIsFPConstrained())
4387 case Builtin::BI__builtin_isgreater:
4388 case Builtin::BI__builtin_isgreaterequal:
4389 case Builtin::BI__builtin_isless:
4390 case Builtin::BI__builtin_islessequal:
4391 case Builtin::BI__builtin_islessgreater:
4392 case Builtin::BI__builtin_isunordered: {
4399 switch (BuiltinID) {
4400 default: llvm_unreachable(
"Unknown ordered comparison");
4401 case Builtin::BI__builtin_isgreater:
4402 LHS =
Builder.CreateFCmpOGT(LHS, RHS,
"cmp");
4404 case Builtin::BI__builtin_isgreaterequal:
4405 LHS =
Builder.CreateFCmpOGE(LHS, RHS,
"cmp");
4407 case Builtin::BI__builtin_isless:
4408 LHS =
Builder.CreateFCmpOLT(LHS, RHS,
"cmp");
4410 case Builtin::BI__builtin_islessequal:
4411 LHS =
Builder.CreateFCmpOLE(LHS, RHS,
"cmp");
4413 case Builtin::BI__builtin_islessgreater:
4414 LHS =
Builder.CreateFCmpONE(LHS, RHS,
"cmp");
4416 case Builtin::BI__builtin_isunordered:
4417 LHS =
Builder.CreateFCmpUNO(LHS, RHS,
"cmp");
4424 case Builtin::BI__builtin_isnan: {
4434 case Builtin::BI__builtin_issignaling: {
4442 case Builtin::BI__builtin_isinf: {
4452 case Builtin::BIfinite:
4453 case Builtin::BI__finite:
4454 case Builtin::BIfinitef:
4455 case Builtin::BI__finitef:
4456 case Builtin::BIfinitel:
4457 case Builtin::BI__finitel:
4458 case Builtin::BI__builtin_isfinite: {
4468 case Builtin::BI__builtin_isnormal: {
4476 case Builtin::BI__builtin_issubnormal: {
4480 Builder.CreateZExt(
Builder.createIsFPClass(
V, FPClassTest::fcSubnormal),
4484 case Builtin::BI__builtin_iszero: {
4492 case Builtin::BI__builtin_isfpclass: {
4496 uint64_t Test =
Result.Val.getInt().getLimitedValue();
4503 case Builtin::BI__builtin_nondeterministic_value: {
4512 case Builtin::BI__builtin_elementwise_abs: {
4517 QT = VecTy->getElementType();
4521 nullptr,
"elt.abs");
4528 case Builtin::BI__builtin_elementwise_bitreverse:
4530 *
this, E, Intrinsic::bitreverse,
"elt.bitreverse"));
4531 case Builtin::BI__builtin_elementwise_popcount:
4533 *
this, E, Intrinsic::ctpop,
"elt.ctpop"));
4534 case Builtin::BI__builtin_elementwise_canonicalize:
4536 *
this, E, Intrinsic::canonicalize,
"elt.canonicalize"));
4537 case Builtin::BI__builtin_elementwise_copysign:
4540 case Builtin::BI__builtin_elementwise_fshl:
4543 case Builtin::BI__builtin_elementwise_fshr:
4546 case Builtin::BI__builtin_elementwise_clmul:
4549 case Builtin::BI__builtin_elementwise_pext:
4552 case Builtin::BI__builtin_elementwise_pdep:
4556 case Builtin::BI__builtin_elementwise_add_sat:
4557 case Builtin::BI__builtin_elementwise_sub_sat: {
4561 assert(Op0->
getType()->isIntOrIntVectorTy() &&
"integer type expected");
4564 Ty = VecTy->getElementType();
4567 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_add_sat)
4568 Opc = IsSigned ? Intrinsic::sadd_sat : Intrinsic::uadd_sat;
4570 Opc = IsSigned ? Intrinsic::ssub_sat : Intrinsic::usub_sat;
4571 Result =
Builder.CreateBinaryIntrinsic(Opc, Op0, Op1,
nullptr,
"elt.sat");
4575 case Builtin::BI__builtin_elementwise_max: {
4579 if (Op0->
getType()->isIntOrIntVectorTy()) {
4582 Ty = VecTy->getElementType();
4585 Op1,
nullptr,
"elt.max");
4587 Result =
Builder.CreateMaxNum(Op0, Op1,
nullptr,
"elt.max");
4590 case Builtin::BI__builtin_elementwise_min: {
4594 if (Op0->
getType()->isIntOrIntVectorTy()) {
4597 Ty = VecTy->getElementType();
4600 Op1,
nullptr,
"elt.min");
4602 Result =
Builder.CreateMinNum(Op0, Op1,
nullptr,
"elt.min");
4606 case Builtin::BI__builtin_elementwise_maxnum: {
4610 Op1,
nullptr,
"elt.maxnum");
4614 case Builtin::BI__builtin_elementwise_minnum: {
4618 Op1,
nullptr,
"elt.minnum");
4622 case Builtin::BI__builtin_elementwise_maximum: {
4626 nullptr,
"elt.maximum");
4630 case Builtin::BI__builtin_elementwise_minimum: {
4634 nullptr,
"elt.minimum");
4638 case Builtin::BI__builtin_elementwise_maximumnum: {
4642 Intrinsic::maximumnum, Op0, Op1,
nullptr,
"elt.maximumnum");
4646 case Builtin::BI__builtin_elementwise_minimumnum: {
4650 Intrinsic::minimumnum, Op0, Op1,
nullptr,
"elt.minimumnum");
4654 case Builtin::BI__builtin_reduce_max: {
4655 auto GetIntrinsicID = [
this](
QualType QT) {
4657 QT = VecTy->getElementType();
4658 else if (QT->isSizelessVectorType())
4659 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4661 if (QT->isSignedIntegerType())
4662 return Intrinsic::vector_reduce_smax;
4663 if (QT->isUnsignedIntegerType())
4664 return Intrinsic::vector_reduce_umax;
4665 assert(QT->isFloatingType() &&
"must have a float here");
4666 return Intrinsic::vector_reduce_fmax;
4669 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4672 case Builtin::BI__builtin_reduce_min: {
4673 auto GetIntrinsicID = [
this](
QualType QT) {
4675 QT = VecTy->getElementType();
4676 else if (QT->isSizelessVectorType())
4677 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4679 if (QT->isSignedIntegerType())
4680 return Intrinsic::vector_reduce_smin;
4681 if (QT->isUnsignedIntegerType())
4682 return Intrinsic::vector_reduce_umin;
4683 assert(QT->isFloatingType() &&
"must have a float here");
4684 return Intrinsic::vector_reduce_fmin;
4688 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4691 case Builtin::BI__builtin_reduce_add:
4693 *
this, E, Intrinsic::vector_reduce_add,
"rdx.add"));
4694 case Builtin::BI__builtin_reduce_mul:
4696 *
this, E, Intrinsic::vector_reduce_mul,
"rdx.mul"));
4697 case Builtin::BI__builtin_reduce_xor:
4699 *
this, E, Intrinsic::vector_reduce_xor,
"rdx.xor"));
4700 case Builtin::BI__builtin_reduce_or:
4702 *
this, E, Intrinsic::vector_reduce_or,
"rdx.or"));
4703 case Builtin::BI__builtin_reduce_and:
4705 *
this, E, Intrinsic::vector_reduce_and,
"rdx.and"));
4706 case Builtin::BI__builtin_reduce_maximum:
4708 *
this, E, Intrinsic::vector_reduce_fmaximum,
"rdx.maximum"));
4709 case Builtin::BI__builtin_reduce_minimum:
4711 *
this, E, Intrinsic::vector_reduce_fminimum,
"rdx.minimum"));
4712 case Builtin::BI__builtin_reduce_assoc_fadd:
4713 case Builtin::BI__builtin_reduce_in_order_fadd: {
4715 llvm::Type *ScalarTy =
Vector->getType()->getScalarType();
4716 llvm::Value *StartValue =
nullptr;
4719 llvm::Value *Args[] = {StartValue
4721 : llvm::ConstantFP::get(ScalarTy, -0.0F),
4724 CGM.getIntrinsic(Intrinsic::vector_reduce_fadd,
Vector->getType());
4725 llvm::CallBase *Reduce =
Builder.CreateCall(F, Args,
"rdx.addf");
4726 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_reduce_assoc_fadd) {
4729 llvm::FastMathFlags FMF;
4730 FMF.setAllowReassoc();
4736 case Builtin::BI__builtin_matrix_transpose: {
4740 Value *
Result = MB.CreateMatrixTranspose(MatValue, MatrixTy->getNumRows(),
4741 MatrixTy->getNumColumns());
4745 case Builtin::BI__builtin_matrix_column_major_load: {
4751 assert(PtrTy &&
"arg0 must be of pointer type");
4752 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4761 ResultTy->getNumRows(), ResultTy->getNumColumns(),
"matrix");
4765 case Builtin::BI__builtin_matrix_column_major_store: {
4773 assert(PtrTy &&
"arg1 must be of pointer type");
4774 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4782 MatrixTy->getNumRows(), MatrixTy->getNumColumns());
4787 case Builtin::BI__builtin_masked_load:
4788 case Builtin::BI__builtin_masked_expand_load: {
4792 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4793 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4801 if (BuiltinID == Builtin::BI__builtin_masked_load)
4803 PassThru,
"masked_load");
4805 Result =
Builder.CreateMaskedExpandLoad(RetTy, Ptr, MaybeAlign(), Mask,
4806 PassThru,
"masked_expand_load");
4810 case Builtin::BI__builtin_masked_gather: {
4815 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4819 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4823 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4825 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4828 RetTy, PtrVec, Align.
getAsAlign(), Mask, PassThru,
"masked_gather");
4831 case Builtin::BI__builtin_masked_store:
4832 case Builtin::BI__builtin_masked_compress_store: {
4841 if (BuiltinID == Builtin::BI__builtin_masked_store)
4844 Builder.CreateMaskedCompressStore(Val, Ptr, MaybeAlign(), Mask);
4848 case Builtin::BI__builtin_masked_scatter: {
4858 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4860 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4865 case Builtin::BI__builtin_isinf_sign: {
4872 AbsArg, ConstantFP::getInfinity(Arg->
getType()),
"isinf");
4878 Value *NegativeOne = ConstantInt::getAllOnesValue(
IntTy);
4879 Value *SignResult =
Builder.CreateSelect(IsNeg, NegativeOne, One);
4884 case Builtin::BI__builtin_flt_rounds: {
4885 Function *F =
CGM.getIntrinsic(Intrinsic::get_rounding);
4889 if (
Result->getType() != ResultType)
4895 case Builtin::BI__builtin_set_flt_rounds: {
4896 Function *F =
CGM.getIntrinsic(Intrinsic::set_rounding);
4903 case Builtin::BI__builtin_fpclassify: {
4910 BasicBlock *Begin =
Builder.GetInsertBlock();
4915 "fpclassify_result");
4918 Builder.SetInsertPoint(Begin);
4919 Value *IsZero =
Builder.CreateFCmpOEQ(
V, Constant::getNullValue(Ty),
4923 Builder.CreateCondBr(IsZero, End, NotZero);
4924 Result->addIncoming(ZeroLiteral, Begin);
4927 Builder.SetInsertPoint(NotZero);
4931 Builder.CreateCondBr(IsNan, End, NotNan);
4932 Result->addIncoming(NanLiteral, NotZero);
4935 Builder.SetInsertPoint(NotNan);
4938 Builder.CreateFCmpOEQ(VAbs, ConstantFP::getInfinity(
V->getType()),
4942 Builder.CreateCondBr(IsInf, End, NotInf);
4943 Result->addIncoming(InfLiteral, NotNan);
4946 Builder.SetInsertPoint(NotInf);
4947 APFloat Smallest = APFloat::getSmallestNormalized(
4950 Builder.CreateFCmpUGE(VAbs, ConstantFP::get(
V->getContext(), Smallest),
4952 Value *NormalResult =
4956 Result->addIncoming(NormalResult, NotInf);
4969 case Builtin::BIalloca:
4970 case Builtin::BI_alloca:
4971 case Builtin::BI__builtin_alloca_uninitialized:
4972 case Builtin::BI__builtin_alloca: {
4976 const Align SuitableAlignmentInBytes =
4980 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
4981 AI->setAlignment(SuitableAlignmentInBytes);
4982 if (BuiltinID != Builtin::BI__builtin_alloca_uninitialized)
4984 if (AI->getAddressSpace() !=
4985 CGM.getContext().getTargetAddressSpace(
4987 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
4993 case Builtin::BI__builtin_alloca_with_align_uninitialized:
4994 case Builtin::BI__builtin_alloca_with_align: {
4998 unsigned AlignmentInBits = AlignmentInBitsCI->getZExtValue();
4999 const Align AlignmentInBytes =
5000 CGM.getContext().toCharUnitsFromBits(AlignmentInBits).getAsAlign();
5001 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
5002 AI->setAlignment(AlignmentInBytes);
5003 if (BuiltinID != Builtin::BI__builtin_alloca_with_align_uninitialized)
5005 if (AI->getAddressSpace() !=
5006 CGM.getContext().getTargetAddressSpace(
5008 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
5014 case Builtin::BI__builtin_infer_alloc_token: {
5018 CGM.getIntrinsic(llvm::Intrinsic::alloc_token_id, {
IntPtrTy});
5019 llvm::CallBase *TokenID =
Builder.CreateCall(F, MDV);
5023 case Builtin::BIbzero:
5024 case Builtin::BI__builtin_bzero: {
5029 auto *I =
Builder.CreateMemSet(Dest,
Builder.getInt8(0), SizeVal,
false);
5034 case Builtin::BIbcopy:
5035 case Builtin::BI__builtin_bcopy: {
5045 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5050 case Builtin::BImemcpy:
5051 case Builtin::BI__builtin_memcpy:
5052 case Builtin::BImempcpy:
5053 case Builtin::BI__builtin_mempcpy: {
5059 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
5061 if (BuiltinID == Builtin::BImempcpy ||
5062 BuiltinID == Builtin::BI__builtin_mempcpy)
5069 case Builtin::BI__builtin_memcpy_inline: {
5076 auto *I =
Builder.CreateMemCpyInline(Dest, Src, Size);
5081 case Builtin::BI__builtin_char_memchr:
5082 BuiltinID = Builtin::BI__builtin_memchr;
5085 case Builtin::BI__builtin___memcpy_chk: {
5091 llvm::APSInt Size = SizeResult.
Val.
getInt();
5092 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5093 if (Size.ugt(DstSize))
5097 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5098 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
5103 case Builtin::BI__builtin_objc_memmove_collectable: {
5107 CGM.getObjCRuntime().EmitGCMemmoveCollectable(*
this,
5108 DestAddr, SrcAddr, SizeVal);
5112 case Builtin::BI__builtin___memmove_chk: {
5118 llvm::APSInt Size = SizeResult.
Val.
getInt();
5119 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5120 if (Size.ugt(DstSize))
5124 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5125 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5130 case Builtin::BI__builtin_trivially_relocate:
5131 case Builtin::BImemmove:
5132 case Builtin::BI__builtin_memmove: {
5136 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_trivially_relocate)
5146 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
5150 case Builtin::BImemset:
5151 case Builtin::BI__builtin_memset: {
5158 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
5162 case Builtin::BI__builtin_memset_inline: {
5171 auto *I =
Builder.CreateMemSetInline(Dest, ByteVal, Size);
5175 case Builtin::BI__builtin___memset_chk: {
5181 llvm::APSInt Size = SizeResult.
Val.
getInt();
5182 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
5183 if (Size.ugt(DstSize))
5188 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
5189 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
5193 case Builtin::BI__builtin_wmemchr: {
5204 BasicBlock *Entry =
Builder.GetInsertBlock();
5209 Builder.CreateCondBr(SizeEq0, Exit, CmpEq);
5213 StrPhi->addIncoming(Str, Entry);
5215 SizePhi->addIncoming(Size, Entry);
5218 Value *StrCh =
Builder.CreateAlignedLoad(WCharTy, StrPhi, WCharAlign);
5219 Value *FoundChr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 0);
5224 Value *NextStr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 1);
5226 Value *NextSizeEq0 =
5227 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
5228 Builder.CreateCondBr(NextSizeEq0, Exit, CmpEq);
5229 StrPhi->addIncoming(NextStr,
Next);
5230 SizePhi->addIncoming(NextSize,
Next);
5234 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()), Entry);
5235 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()),
Next);
5236 Ret->addIncoming(FoundChr, CmpEq);
5239 case Builtin::BI__builtin_wmemcmp: {
5251 BasicBlock *Entry =
Builder.GetInsertBlock();
5257 Builder.CreateCondBr(SizeEq0, Exit, CmpGT);
5261 DstPhi->addIncoming(Dst, Entry);
5263 SrcPhi->addIncoming(Src, Entry);
5265 SizePhi->addIncoming(Size, Entry);
5268 Value *DstCh =
Builder.CreateAlignedLoad(WCharTy, DstPhi, WCharAlign);
5269 Value *SrcCh =
Builder.CreateAlignedLoad(WCharTy, SrcPhi, WCharAlign);
5271 Builder.CreateCondBr(DstGtSrc, Exit, CmpLT);
5278 Value *NextDst =
Builder.CreateConstInBoundsGEP1_32(WCharTy, DstPhi, 1);
5279 Value *NextSrc =
Builder.CreateConstInBoundsGEP1_32(WCharTy, SrcPhi, 1);
5281 Value *NextSizeEq0 =
5282 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
5283 Builder.CreateCondBr(NextSizeEq0, Exit, CmpGT);
5284 DstPhi->addIncoming(NextDst,
Next);
5285 SrcPhi->addIncoming(NextSrc,
Next);
5286 SizePhi->addIncoming(NextSize,
Next);
5290 Ret->addIncoming(ConstantInt::get(
IntTy, 0), Entry);
5291 Ret->addIncoming(ConstantInt::get(
IntTy, 1), CmpGT);
5292 Ret->addIncoming(ConstantInt::getAllOnesValue(
IntTy), CmpLT);
5293 Ret->addIncoming(ConstantInt::get(
IntTy, 0),
Next);
5296 case Builtin::BI__builtin_dwarf_cfa: {
5307 Function *F =
CGM.getIntrinsic(Intrinsic::eh_dwarf_cfa);
5309 llvm::ConstantInt::get(
Int32Ty, Offset)));
5311 case Builtin::BI__builtin_return_address: {
5315 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5318 case Builtin::BI_ReturnAddress: {
5320 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5323 case Builtin::BI__builtin_frame_address: {
5329 case Builtin::BI__builtin_stack_address: {
5333 case Builtin::BI__builtin_extract_return_addr: {
5338 case Builtin::BI__builtin_frob_return_addr: {
5343 case Builtin::BI__builtin_dwarf_sp_column: {
5344 llvm::IntegerType *Ty
5348 CGM.ErrorUnsupported(E,
"__builtin_dwarf_sp_column");
5353 case Builtin::BI__builtin_init_dwarf_reg_size_table: {
5356 CGM.ErrorUnsupported(E,
"__builtin_init_dwarf_reg_size_table");
5359 case Builtin::BI__builtin_eh_return: {
5364 assert((
IntTy->getBitWidth() == 32 ||
IntTy->getBitWidth() == 64) &&
5365 "LLVM's __builtin_eh_return only supports 32- and 64-bit variants");
5367 CGM.getIntrinsic(
IntTy->getBitWidth() == 32 ? Intrinsic::eh_return_i32
5368 : Intrinsic::eh_return_i64);
5369 Builder.CreateCall(F, {Int, Ptr});
5377 case Builtin::BI__builtin_unwind_init: {
5378 Function *F =
CGM.getIntrinsic(Intrinsic::eh_unwind_init);
5382 case Builtin::BI__builtin_extend_pointer: {
5407 case Builtin::BI__builtin_setjmp: {
5415 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5422 ConstantInt::get(
Int32Ty, 0));
5423 Builder.CreateStore(FrameAddr, Buf);
5430 Builder.CreateStore(StackAddr, StackSaveSlot);
5433 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5436 case Builtin::BI__builtin_longjmp: {
5440 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::eh_sjlj_longjmp), Buf);
5450 case Builtin::BI__builtin_launder: {
5455 Ptr =
Builder.CreateLaunderInvariantGroup(Ptr);
5459 case Builtin::BI__builtin_clear_padding: {
5462 PaddingClearer clearer{*
this};
5463 clearer.run(Src, PointeeTy);
5466 case Builtin::BI__sync_fetch_and_add:
5467 case Builtin::BI__sync_fetch_and_sub:
5468 case Builtin::BI__sync_fetch_and_or:
5469 case Builtin::BI__sync_fetch_and_and:
5470 case Builtin::BI__sync_fetch_and_xor:
5471 case Builtin::BI__sync_fetch_and_nand:
5472 case Builtin::BI__sync_add_and_fetch:
5473 case Builtin::BI__sync_sub_and_fetch:
5474 case Builtin::BI__sync_and_and_fetch:
5475 case Builtin::BI__sync_or_and_fetch:
5476 case Builtin::BI__sync_xor_and_fetch:
5477 case Builtin::BI__sync_nand_and_fetch:
5478 case Builtin::BI__sync_val_compare_and_swap:
5479 case Builtin::BI__sync_bool_compare_and_swap:
5480 case Builtin::BI__sync_lock_test_and_set:
5481 case Builtin::BI__sync_lock_release:
5482 case Builtin::BI__sync_swap:
5483 llvm_unreachable(
"Shouldn't make it through sema");
5484 case Builtin::BI__sync_fetch_and_add_1:
5485 case Builtin::BI__sync_fetch_and_add_2:
5486 case Builtin::BI__sync_fetch_and_add_4:
5487 case Builtin::BI__sync_fetch_and_add_8:
5488 case Builtin::BI__sync_fetch_and_add_16:
5490 case Builtin::BI__sync_fetch_and_sub_1:
5491 case Builtin::BI__sync_fetch_and_sub_2:
5492 case Builtin::BI__sync_fetch_and_sub_4:
5493 case Builtin::BI__sync_fetch_and_sub_8:
5494 case Builtin::BI__sync_fetch_and_sub_16:
5496 case Builtin::BI__sync_fetch_and_or_1:
5497 case Builtin::BI__sync_fetch_and_or_2:
5498 case Builtin::BI__sync_fetch_and_or_4:
5499 case Builtin::BI__sync_fetch_and_or_8:
5500 case Builtin::BI__sync_fetch_and_or_16:
5502 case Builtin::BI__sync_fetch_and_and_1:
5503 case Builtin::BI__sync_fetch_and_and_2:
5504 case Builtin::BI__sync_fetch_and_and_4:
5505 case Builtin::BI__sync_fetch_and_and_8:
5506 case Builtin::BI__sync_fetch_and_and_16:
5508 case Builtin::BI__sync_fetch_and_xor_1:
5509 case Builtin::BI__sync_fetch_and_xor_2:
5510 case Builtin::BI__sync_fetch_and_xor_4:
5511 case Builtin::BI__sync_fetch_and_xor_8:
5512 case Builtin::BI__sync_fetch_and_xor_16:
5514 case Builtin::BI__sync_fetch_and_nand_1:
5515 case Builtin::BI__sync_fetch_and_nand_2:
5516 case Builtin::BI__sync_fetch_and_nand_4:
5517 case Builtin::BI__sync_fetch_and_nand_8:
5518 case Builtin::BI__sync_fetch_and_nand_16:
5522 case Builtin::BI__sync_fetch_and_min:
5524 case Builtin::BI__sync_fetch_and_max:
5526 case Builtin::BI__sync_fetch_and_umin:
5528 case Builtin::BI__sync_fetch_and_umax:
5531 case Builtin::BI__sync_add_and_fetch_1:
5532 case Builtin::BI__sync_add_and_fetch_2:
5533 case Builtin::BI__sync_add_and_fetch_4:
5534 case Builtin::BI__sync_add_and_fetch_8:
5535 case Builtin::BI__sync_add_and_fetch_16:
5537 llvm::Instruction::Add);
5538 case Builtin::BI__sync_sub_and_fetch_1:
5539 case Builtin::BI__sync_sub_and_fetch_2:
5540 case Builtin::BI__sync_sub_and_fetch_4:
5541 case Builtin::BI__sync_sub_and_fetch_8:
5542 case Builtin::BI__sync_sub_and_fetch_16:
5544 llvm::Instruction::Sub);
5545 case Builtin::BI__sync_and_and_fetch_1:
5546 case Builtin::BI__sync_and_and_fetch_2:
5547 case Builtin::BI__sync_and_and_fetch_4:
5548 case Builtin::BI__sync_and_and_fetch_8:
5549 case Builtin::BI__sync_and_and_fetch_16:
5551 llvm::Instruction::And);
5552 case Builtin::BI__sync_or_and_fetch_1:
5553 case Builtin::BI__sync_or_and_fetch_2:
5554 case Builtin::BI__sync_or_and_fetch_4:
5555 case Builtin::BI__sync_or_and_fetch_8:
5556 case Builtin::BI__sync_or_and_fetch_16:
5558 llvm::Instruction::Or);
5559 case Builtin::BI__sync_xor_and_fetch_1:
5560 case Builtin::BI__sync_xor_and_fetch_2:
5561 case Builtin::BI__sync_xor_and_fetch_4:
5562 case Builtin::BI__sync_xor_and_fetch_8:
5563 case Builtin::BI__sync_xor_and_fetch_16:
5565 llvm::Instruction::Xor);
5566 case Builtin::BI__sync_nand_and_fetch_1:
5567 case Builtin::BI__sync_nand_and_fetch_2:
5568 case Builtin::BI__sync_nand_and_fetch_4:
5569 case Builtin::BI__sync_nand_and_fetch_8:
5570 case Builtin::BI__sync_nand_and_fetch_16:
5572 llvm::Instruction::And,
true);
5574 case Builtin::BI__sync_val_compare_and_swap_1:
5575 case Builtin::BI__sync_val_compare_and_swap_2:
5576 case Builtin::BI__sync_val_compare_and_swap_4:
5577 case Builtin::BI__sync_val_compare_and_swap_8:
5578 case Builtin::BI__sync_val_compare_and_swap_16:
5580 *
this, E,
false, AtomicOrdering::SequentiallyConsistent,
5581 AtomicOrdering::SequentiallyConsistent));
5583 case Builtin::BI__sync_bool_compare_and_swap_1:
5584 case Builtin::BI__sync_bool_compare_and_swap_2:
5585 case Builtin::BI__sync_bool_compare_and_swap_4:
5586 case Builtin::BI__sync_bool_compare_and_swap_8:
5587 case Builtin::BI__sync_bool_compare_and_swap_16:
5589 *
this, E,
true, AtomicOrdering::SequentiallyConsistent,
5590 AtomicOrdering::SequentiallyConsistent));
5592 case Builtin::BI__sync_swap_1:
5593 case Builtin::BI__sync_swap_2:
5594 case Builtin::BI__sync_swap_4:
5595 case Builtin::BI__sync_swap_8:
5596 case Builtin::BI__sync_swap_16:
5599 case Builtin::BI__sync_lock_test_and_set_1:
5600 case Builtin::BI__sync_lock_test_and_set_2:
5601 case Builtin::BI__sync_lock_test_and_set_4:
5602 case Builtin::BI__sync_lock_test_and_set_8:
5603 case Builtin::BI__sync_lock_test_and_set_16:
5606 case Builtin::BI__sync_lock_release_1:
5607 case Builtin::BI__sync_lock_release_2:
5608 case Builtin::BI__sync_lock_release_4:
5609 case Builtin::BI__sync_lock_release_8:
5610 case Builtin::BI__sync_lock_release_16: {
5616 llvm::StoreInst *Store =
5617 Builder.CreateStore(llvm::Constant::getNullValue(ITy), Ptr);
5618 Store->setAtomic(llvm::AtomicOrdering::Release);
5622 case Builtin::BI__sync_synchronize: {
5630 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent);
5634 case Builtin::BI__builtin_nontemporal_load:
5636 case Builtin::BI__builtin_nontemporal_store:
5638 case Builtin::BI__c11_atomic_is_lock_free:
5639 case Builtin::BI__atomic_is_lock_free: {
5643 const char *LibCallName =
"__atomic_is_lock_free";
5647 if (BuiltinID == Builtin::BI__atomic_is_lock_free)
5654 CGM.getTypes().arrangeBuiltinFunctionCall(E->
getType(), Args);
5655 llvm::FunctionType *FTy =
CGM.getTypes().GetFunctionType(FuncInfo);
5656 llvm::FunctionCallee
Func =
CGM.CreateRuntimeFunction(FTy, LibCallName);
5661 case Builtin::BI__atomic_thread_fence:
5662 case Builtin::BI__atomic_signal_fence:
5663 case Builtin::BI__c11_atomic_thread_fence:
5664 case Builtin::BI__c11_atomic_signal_fence: {
5665 llvm::SyncScope::ID SSID;
5666 if (BuiltinID == Builtin::BI__atomic_signal_fence ||
5667 BuiltinID == Builtin::BI__c11_atomic_signal_fence)
5668 SSID = llvm::SyncScope::SingleThread;
5670 SSID = llvm::SyncScope::System;
5680 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5683 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5686 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5689 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5695 llvm::BasicBlock *AcquireBB, *ReleaseBB, *AcqRelBB, *SeqCstBB;
5702 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5703 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5705 Builder.SetInsertPoint(AcquireBB);
5706 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5708 SI->addCase(
Builder.getInt32(1), AcquireBB);
5709 SI->addCase(
Builder.getInt32(2), AcquireBB);
5711 Builder.SetInsertPoint(ReleaseBB);
5712 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5714 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5716 Builder.SetInsertPoint(AcqRelBB);
5717 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5719 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5721 Builder.SetInsertPoint(SeqCstBB);
5722 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5724 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5726 Builder.SetInsertPoint(ContBB);
5729 case Builtin::BI__scoped_atomic_thread_fence: {
5734 auto Ord = dyn_cast<llvm::ConstantInt>(Order);
5735 auto Scp = dyn_cast<llvm::ConstantInt>(
Scope);
5737 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5738 ? ScopeModel->map(Scp->getZExtValue())
5739 : ScopeModel->map(ScopeModel->getFallBackValue());
5740 switch (Ord->getZExtValue()) {
5747 llvm::AtomicOrdering::Acquire,
5749 llvm::AtomicOrdering::Acquire,
5754 llvm::AtomicOrdering::Release,
5756 llvm::AtomicOrdering::Release,
5760 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease,
5763 llvm::AtomicOrdering::AcquireRelease,
5767 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent,
5770 llvm::AtomicOrdering::SequentiallyConsistent,
5782 switch (Ord->getZExtValue()) {
5785 ContBB->eraseFromParent();
5789 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5790 llvm::AtomicOrdering::Acquire);
5793 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5794 llvm::AtomicOrdering::Release);
5797 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5798 llvm::AtomicOrdering::AcquireRelease);
5801 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5802 llvm::AtomicOrdering::SequentiallyConsistent);
5811 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5812 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5813 SI->addCase(
Builder.getInt32(1), AcquireBB);
5814 SI->addCase(
Builder.getInt32(2), AcquireBB);
5815 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5816 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5817 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5819 OrderBBs.emplace_back(AcquireBB, llvm::AtomicOrdering::Acquire);
5820 OrderBBs.emplace_back(ReleaseBB, llvm::AtomicOrdering::Release);
5821 OrderBBs.emplace_back(AcqRelBB, llvm::AtomicOrdering::AcquireRelease);
5822 OrderBBs.emplace_back(SeqCstBB,
5823 llvm::AtomicOrdering::SequentiallyConsistent);
5826 for (
auto &[OrderBB, Ordering] : OrderBBs) {
5827 Builder.SetInsertPoint(OrderBB);
5829 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5830 ? ScopeModel->map(Scp->getZExtValue())
5831 : ScopeModel->map(ScopeModel->getFallBackValue());
5837 llvm::DenseMap<unsigned, llvm::BasicBlock *> BBs;
5838 for (
unsigned Scp : ScopeModel->getRuntimeValues())
5842 llvm::SwitchInst *SI =
Builder.CreateSwitch(SC, ContBB);
5843 for (
unsigned Scp : ScopeModel->getRuntimeValues()) {
5845 SI->addCase(
Builder.getInt32(Scp), B);
5856 Builder.SetInsertPoint(ContBB);
5860 case Builtin::BI__builtin_signbit:
5861 case Builtin::BI__builtin_signbitf:
5862 case Builtin::BI__builtin_signbitl: {
5867 case Builtin::BI__warn_memset_zero_len:
5869 case Builtin::BI__annotation: {
5874 assert(Str->getCharByteWidth() == 2 || Str->getCharByteWidth() == 4);
5875 StringRef WideBytes = Str->getBytes();
5876 std::string StrUtf8;
5878 (Str->getCharByteWidth() == 2)
5879 ? convertUTF16ToUTF8String(
5880 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8)
5881 : convertUTF32ToUTF8String(
5882 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8);
5884 CGM.ErrorUnsupported(E,
"non-Unicode __annotation argument");
5887 Strings.push_back(llvm::MDString::get(
getLLVMContext(), StrUtf8));
5891 llvm::Function *F =
CGM.getIntrinsic(Intrinsic::codeview_annotation, {});
5896 case Builtin::BI__builtin_annotation: {
5898 llvm::Function *F =
CGM.getIntrinsic(
5899 Intrinsic::annotation, {AnnVal->getType(),
CGM.ConstGlobalsPtrTy});
5908 case Builtin::BI__builtin_addcb:
5909 case Builtin::BI__builtin_addcs:
5910 case Builtin::BI__builtin_addc:
5911 case Builtin::BI__builtin_addcl:
5912 case Builtin::BI__builtin_addcll:
5913 case Builtin::BI__builtin_subcb:
5914 case Builtin::BI__builtin_subcs:
5915 case Builtin::BI__builtin_subc:
5916 case Builtin::BI__builtin_subcl:
5917 case Builtin::BI__builtin_subcll: {
5943 Intrinsic::ID IntrinsicId;
5944 switch (BuiltinID) {
5945 default: llvm_unreachable(
"Unknown multiprecision builtin id.");
5946 case Builtin::BI__builtin_addcb:
5947 case Builtin::BI__builtin_addcs:
5948 case Builtin::BI__builtin_addc:
5949 case Builtin::BI__builtin_addcl:
5950 case Builtin::BI__builtin_addcll:
5951 IntrinsicId = Intrinsic::uadd_with_overflow;
5953 case Builtin::BI__builtin_subcb:
5954 case Builtin::BI__builtin_subcs:
5955 case Builtin::BI__builtin_subc:
5956 case Builtin::BI__builtin_subcl:
5957 case Builtin::BI__builtin_subcll:
5958 IntrinsicId = Intrinsic::usub_with_overflow;
5963 llvm::Value *Carry1;
5966 llvm::Value *Carry2;
5968 Sum1, Carryin, Carry2);
5969 llvm::Value *CarryOut =
Builder.CreateZExt(
Builder.CreateOr(Carry1, Carry2),
5971 Builder.CreateStore(CarryOut, CarryOutPtr);
5975 case Builtin::BI__builtin_add_overflow:
5976 case Builtin::BI__builtin_sub_overflow:
5977 case Builtin::BI__builtin_mul_overflow: {
5985 WidthAndSignedness LeftInfo =
5987 WidthAndSignedness RightInfo =
5989 WidthAndSignedness ResultInfo =
5996 RightInfo, ResultArg, ResultQTy,
6002 *
this, LeftArg, LeftInfo, RightArg, RightInfo, ResultArg, ResultQTy,
6005 WidthAndSignedness EncompassingInfo =
6008 llvm::Type *EncompassingLLVMTy =
6009 llvm::IntegerType::get(
CGM.getLLVMContext(), EncompassingInfo.Width);
6011 llvm::Type *ResultLLVMTy =
CGM.getTypes().ConvertType(ResultQTy);
6013 Intrinsic::ID IntrinsicId;
6014 switch (BuiltinID) {
6016 llvm_unreachable(
"Unknown overflow builtin id.");
6017 case Builtin::BI__builtin_add_overflow:
6018 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::sadd_with_overflow
6019 : Intrinsic::uadd_with_overflow;
6021 case Builtin::BI__builtin_sub_overflow:
6022 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::ssub_with_overflow
6023 : Intrinsic::usub_with_overflow;
6025 case Builtin::BI__builtin_mul_overflow:
6026 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::smul_with_overflow
6027 : Intrinsic::umul_with_overflow;
6036 Left =
Builder.CreateIntCast(Left, EncompassingLLVMTy, LeftInfo.Signed);
6037 Right =
Builder.CreateIntCast(Right, EncompassingLLVMTy, RightInfo.Signed);
6040 llvm::Value *Overflow, *
Result;
6043 if (EncompassingInfo.Width > ResultInfo.Width) {
6046 llvm::Value *ResultTrunc =
Builder.CreateTrunc(
Result, ResultLLVMTy);
6050 llvm::Value *ResultTruncExt =
Builder.CreateIntCast(
6051 ResultTrunc, EncompassingLLVMTy, ResultInfo.Signed);
6052 llvm::Value *TruncationOverflow =
6055 Overflow =
Builder.CreateOr(Overflow, TruncationOverflow);
6067 case Builtin::BI__builtin_uadd_overflow:
6068 case Builtin::BI__builtin_uaddl_overflow:
6069 case Builtin::BI__builtin_uaddll_overflow:
6070 case Builtin::BI__builtin_usub_overflow:
6071 case Builtin::BI__builtin_usubl_overflow:
6072 case Builtin::BI__builtin_usubll_overflow:
6073 case Builtin::BI__builtin_umul_overflow:
6074 case Builtin::BI__builtin_umull_overflow:
6075 case Builtin::BI__builtin_umulll_overflow:
6076 case Builtin::BI__builtin_sadd_overflow:
6077 case Builtin::BI__builtin_saddl_overflow:
6078 case Builtin::BI__builtin_saddll_overflow:
6079 case Builtin::BI__builtin_ssub_overflow:
6080 case Builtin::BI__builtin_ssubl_overflow:
6081 case Builtin::BI__builtin_ssubll_overflow:
6082 case Builtin::BI__builtin_smul_overflow:
6083 case Builtin::BI__builtin_smull_overflow:
6084 case Builtin::BI__builtin_smulll_overflow: {
6094 Intrinsic::ID IntrinsicId;
6095 switch (BuiltinID) {
6096 default: llvm_unreachable(
"Unknown overflow builtin id.");
6097 case Builtin::BI__builtin_uadd_overflow:
6098 case Builtin::BI__builtin_uaddl_overflow:
6099 case Builtin::BI__builtin_uaddll_overflow:
6100 IntrinsicId = Intrinsic::uadd_with_overflow;
6102 case Builtin::BI__builtin_usub_overflow:
6103 case Builtin::BI__builtin_usubl_overflow:
6104 case Builtin::BI__builtin_usubll_overflow:
6105 IntrinsicId = Intrinsic::usub_with_overflow;
6107 case Builtin::BI__builtin_umul_overflow:
6108 case Builtin::BI__builtin_umull_overflow:
6109 case Builtin::BI__builtin_umulll_overflow:
6110 IntrinsicId = Intrinsic::umul_with_overflow;
6112 case Builtin::BI__builtin_sadd_overflow:
6113 case Builtin::BI__builtin_saddl_overflow:
6114 case Builtin::BI__builtin_saddll_overflow:
6115 IntrinsicId = Intrinsic::sadd_with_overflow;
6117 case Builtin::BI__builtin_ssub_overflow:
6118 case Builtin::BI__builtin_ssubl_overflow:
6119 case Builtin::BI__builtin_ssubll_overflow:
6120 IntrinsicId = Intrinsic::ssub_with_overflow;
6122 case Builtin::BI__builtin_smul_overflow:
6123 case Builtin::BI__builtin_smull_overflow:
6124 case Builtin::BI__builtin_smulll_overflow:
6125 IntrinsicId = Intrinsic::smul_with_overflow;
6132 Builder.CreateStore(Sum, SumOutPtr);
6136 case Builtin::BIaddressof:
6137 case Builtin::BI__addressof:
6138 case Builtin::BI__builtin_addressof:
6140 case Builtin::BI__builtin_function_start:
6143 case Builtin::BI__builtin_operator_new:
6146 case Builtin::BI__builtin_operator_delete:
6151 case Builtin::BI__builtin_is_aligned:
6153 case Builtin::BI__builtin_align_up:
6155 case Builtin::BI__builtin_align_down:
6158 case Builtin::BI__noop:
6161 case Builtin::BI__builtin_call_with_static_chain: {
6168 case Builtin::BI_InterlockedExchange8:
6169 case Builtin::BI_InterlockedExchange16:
6170 case Builtin::BI_InterlockedExchange:
6171 case Builtin::BI_InterlockedExchangePointer:
6174 case Builtin::BI_InterlockedCompareExchangePointer:
6177 case Builtin::BI_InterlockedCompareExchangePointer_nf:
6180 case Builtin::BI_InterlockedCompareExchange8:
6181 case Builtin::BI_InterlockedCompareExchange16:
6182 case Builtin::BI_InterlockedCompareExchange:
6183 case Builtin::BI_InterlockedCompareExchange64:
6185 case Builtin::BI_InterlockedIncrement16:
6186 case Builtin::BI_InterlockedIncrement:
6189 case Builtin::BI_InterlockedDecrement16:
6190 case Builtin::BI_InterlockedDecrement:
6193 case Builtin::BI_InterlockedAnd8:
6194 case Builtin::BI_InterlockedAnd16:
6195 case Builtin::BI_InterlockedAnd:
6197 case Builtin::BI_InterlockedExchangeAdd8:
6198 case Builtin::BI_InterlockedExchangeAdd16:
6199 case Builtin::BI_InterlockedExchangeAdd:
6202 case Builtin::BI_InterlockedExchangeSub8:
6203 case Builtin::BI_InterlockedExchangeSub16:
6204 case Builtin::BI_InterlockedExchangeSub:
6207 case Builtin::BI_InterlockedOr8:
6208 case Builtin::BI_InterlockedOr16:
6209 case Builtin::BI_InterlockedOr:
6211 case Builtin::BI_InterlockedXor8:
6212 case Builtin::BI_InterlockedXor16:
6213 case Builtin::BI_InterlockedXor:
6216 case Builtin::BI_bittest64:
6217 case Builtin::BI_bittest:
6218 case Builtin::BI_bittestandcomplement64:
6219 case Builtin::BI_bittestandcomplement:
6220 case Builtin::BI_bittestandreset64:
6221 case Builtin::BI_bittestandreset:
6222 case Builtin::BI_bittestandset64:
6223 case Builtin::BI_bittestandset:
6224 case Builtin::BI_interlockedbittestandreset:
6225 case Builtin::BI_interlockedbittestandreset64:
6226 case Builtin::BI_interlockedbittestandreset64_acq:
6227 case Builtin::BI_interlockedbittestandreset64_rel:
6228 case Builtin::BI_interlockedbittestandreset64_nf:
6229 case Builtin::BI_interlockedbittestandset64:
6230 case Builtin::BI_interlockedbittestandset64_acq:
6231 case Builtin::BI_interlockedbittestandset64_rel:
6232 case Builtin::BI_interlockedbittestandset64_nf:
6233 case Builtin::BI_interlockedbittestandset:
6234 case Builtin::BI_interlockedbittestandset_acq:
6235 case Builtin::BI_interlockedbittestandset_rel:
6236 case Builtin::BI_interlockedbittestandset_nf:
6237 case Builtin::BI_interlockedbittestandreset_acq:
6238 case Builtin::BI_interlockedbittestandreset_rel:
6239 case Builtin::BI_interlockedbittestandreset_nf:
6244 case Builtin::BI__iso_volatile_load8:
6245 case Builtin::BI__iso_volatile_load16:
6246 case Builtin::BI__iso_volatile_load32:
6247 case Builtin::BI__iso_volatile_load64:
6249 case Builtin::BI__iso_volatile_store8:
6250 case Builtin::BI__iso_volatile_store16:
6251 case Builtin::BI__iso_volatile_store32:
6252 case Builtin::BI__iso_volatile_store64:
6255 case Builtin::BI__builtin_ptrauth_sign_constant:
6258 case Builtin::BI__builtin_ptrauth_auth:
6259 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6260 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6261 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6262 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6263 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6264 case Builtin::BI__builtin_ptrauth_strip: {
6271 llvm::Type *OrigValueType = Args[0]->getType();
6272 if (OrigValueType->isPointerTy())
6275 switch (BuiltinID) {
6276 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6277 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6278 if (Args[4]->
getType()->isPointerTy())
6282 case Builtin::BI__builtin_ptrauth_auth:
6283 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6284 if (Args[2]->
getType()->isPointerTy())
6288 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6289 if (Args[1]->
getType()->isPointerTy())
6293 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6294 case Builtin::BI__builtin_ptrauth_strip:
6299 auto IntrinsicID = [&]() ->
unsigned {
6300 switch (BuiltinID) {
6301 case Builtin::BI__builtin_ptrauth_auth:
6302 return Intrinsic::ptrauth_auth;
6303 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6304 return Intrinsic::ptrauth_resign;
6305 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6306 return Intrinsic::ptrauth_resign_load_relative;
6307 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6308 return Intrinsic::ptrauth_blend;
6309 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6310 return Intrinsic::ptrauth_sign_generic;
6311 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6312 return Intrinsic::ptrauth_sign;
6313 case Builtin::BI__builtin_ptrauth_strip:
6314 return Intrinsic::ptrauth_strip;
6316 llvm_unreachable(
"bad ptrauth intrinsic");
6318 auto Intrinsic =
CGM.getIntrinsic(IntrinsicID);
6321 if (BuiltinID != Builtin::BI__builtin_ptrauth_sign_generic_data &&
6322 BuiltinID != Builtin::BI__builtin_ptrauth_blend_discriminator &&
6323 OrigValueType->isPointerTy()) {
6329 case Builtin::BI__builtin_get_vtable_pointer: {
6335 assert(ThisAddress.isValid());
6336 llvm::Value *VTablePointer =
6341 case Builtin::BI__exception_code:
6342 case Builtin::BI_exception_code:
6344 case Builtin::BI__exception_info:
6345 case Builtin::BI_exception_info:
6347 case Builtin::BI__abnormal_termination:
6348 case Builtin::BI_abnormal_termination:
6350 case Builtin::BI_setjmpex:
6355 case Builtin::BI_setjmp:
6367 case Builtin::BImove:
6368 case Builtin::BImove_if_noexcept:
6369 case Builtin::BIforward:
6370 case Builtin::BIforward_like:
6371 case Builtin::BIas_const:
6373 case Builtin::BI__GetExceptionInfo: {
6374 if (llvm::GlobalVariable *GV =
6380 case Builtin::BI__fastfail:
6383 case Builtin::BI__builtin_coro_id:
6385 case Builtin::BI__builtin_coro_promise:
6387 case Builtin::BI__builtin_coro_resume:
6390 case Builtin::BI__builtin_coro_frame:
6392 case Builtin::BI__builtin_coro_noop:
6394 case Builtin::BI__builtin_coro_free:
6396 case Builtin::BI__builtin_coro_destroy:
6399 case Builtin::BI__builtin_coro_done:
6401 case Builtin::BI__builtin_coro_alloc:
6403 case Builtin::BI__builtin_coro_begin:
6405 case Builtin::BI__builtin_coro_end:
6407 case Builtin::BI__builtin_coro_suspend:
6409 case Builtin::BI__builtin_coro_size:
6411 case Builtin::BI__builtin_coro_align:
6415 case Builtin::BIread_pipe:
6416 case Builtin::BIwrite_pipe: {
6424 unsigned GenericAS =
6426 llvm::Type *I8PTy = llvm::PointerType::get(
getLLVMContext(), GenericAS);
6430 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_2"
6435 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6436 Value *ACast =
Builder.CreateAddrSpaceCast(Arg1, I8PTy);
6439 {Arg0, ACast, PacketSize, PacketAlign}));
6442 "Illegal number of parameters to pipe function");
6443 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_4"
6446 llvm::Type *ArgTys[] = {Arg0->
getType(), Arg1->getType(),
Int32Ty, I8PTy,
6450 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6451 Value *ACast =
Builder.CreateAddrSpaceCast(Arg3, I8PTy);
6458 {Arg0, Arg1, Arg2, ACast, PacketSize, PacketAlign}));
6463 case Builtin::BIreserve_read_pipe:
6464 case Builtin::BIreserve_write_pipe:
6465 case Builtin::BIwork_group_reserve_read_pipe:
6466 case Builtin::BIwork_group_reserve_write_pipe:
6467 case Builtin::BIsub_group_reserve_read_pipe:
6468 case Builtin::BIsub_group_reserve_write_pipe: {
6471 if (BuiltinID == Builtin::BIreserve_read_pipe)
6472 Name =
"__reserve_read_pipe";
6473 else if (BuiltinID == Builtin::BIreserve_write_pipe)
6474 Name =
"__reserve_write_pipe";
6475 else if (BuiltinID == Builtin::BIwork_group_reserve_read_pipe)
6476 Name =
"__work_group_reserve_read_pipe";
6477 else if (BuiltinID == Builtin::BIwork_group_reserve_write_pipe)
6478 Name =
"__work_group_reserve_write_pipe";
6479 else if (BuiltinID == Builtin::BIsub_group_reserve_read_pipe)
6480 Name =
"__sub_group_reserve_read_pipe";
6482 Name =
"__sub_group_reserve_write_pipe";
6493 llvm::FunctionType *FTy =
6494 llvm::FunctionType::get(ReservedIDTy, ArgTys,
false);
6497 if (Arg1->getType() !=
Int32Ty)
6500 {Arg0, Arg1, PacketSize, PacketAlign}));
6504 case Builtin::BIcommit_read_pipe:
6505 case Builtin::BIcommit_write_pipe:
6506 case Builtin::BIwork_group_commit_read_pipe:
6507 case Builtin::BIwork_group_commit_write_pipe:
6508 case Builtin::BIsub_group_commit_read_pipe:
6509 case Builtin::BIsub_group_commit_write_pipe: {
6511 if (BuiltinID == Builtin::BIcommit_read_pipe)
6512 Name =
"__commit_read_pipe";
6513 else if (BuiltinID == Builtin::BIcommit_write_pipe)
6514 Name =
"__commit_write_pipe";
6515 else if (BuiltinID == Builtin::BIwork_group_commit_read_pipe)
6516 Name =
"__work_group_commit_read_pipe";
6517 else if (BuiltinID == Builtin::BIwork_group_commit_write_pipe)
6518 Name =
"__work_group_commit_write_pipe";
6519 else if (BuiltinID == Builtin::BIsub_group_commit_read_pipe)
6520 Name =
"__sub_group_commit_read_pipe";
6522 Name =
"__sub_group_commit_write_pipe";
6532 llvm::FunctionType *FTy = llvm::FunctionType::get(
6536 {Arg0, Arg1, PacketSize, PacketAlign}));
6539 case Builtin::BIget_pipe_num_packets:
6540 case Builtin::BIget_pipe_max_packets: {
6541 const char *BaseName;
6543 if (BuiltinID == Builtin::BIget_pipe_num_packets)
6544 BaseName =
"__get_pipe_num_packets";
6546 BaseName =
"__get_pipe_max_packets";
6547 std::string Name = std::string(BaseName) +
6548 std::string(PipeTy->isReadOnly() ?
"_ro" :
"_wo");
6556 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6559 {Arg0, PacketSize, PacketAlign}));
6563 case Builtin::BIto_global:
6564 case Builtin::BIto_local:
6565 case Builtin::BIto_private: {
6567 auto NewArgT = llvm::PointerType::get(
6570 auto NewRetT = llvm::PointerType::get(
6572 CGM.getContext().getTargetAddressSpace(
6574 auto FTy = llvm::FunctionType::get(NewRetT, {NewArgT},
false);
6575 llvm::Value *NewArg;
6576 if (Arg0->getType()->getPointerAddressSpace() !=
6577 NewArgT->getPointerAddressSpace())
6578 NewArg =
Builder.CreateAddrSpaceCast(Arg0, NewArgT);
6580 NewArg =
Builder.CreateBitOrPointerCast(Arg0, NewArgT);
6596 case Builtin::BIenqueue_kernel: {
6601 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6618 Range = Range->stripPointerCasts();
6620 llvm::Type *RangePtrTy = Range->getType();
6625 Name =
"__enqueue_kernel_basic";
6626 llvm::Type *ArgTys[] = {QueueTy,
Int32Ty, RangePtrTy, GenericVoidPtrTy,
6628 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6631 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6633 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6634 llvm::Value *
Block =
6635 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6638 {Queue, Flags, Range, Kernel, Block});
6641 assert(NumArgs >= 5 &&
"Invalid enqueue_kernel signature");
6645 auto CreateArrayForSizeVar =
6646 [=](
unsigned First) -> std::pair<llvm::Value *, llvm::Value *> {
6647 llvm::APInt ArraySize(32, NumArgs -
First);
6649 getContext().getSizeType(), ArraySize,
nullptr,
6653 llvm::Value *Alloca = Tmp.getPointer();
6654 llvm::Value *ElemPtr;
6658 auto *
Zero = llvm::ConstantInt::get(
IntTy, 0);
6659 for (
unsigned I =
First; I < NumArgs; ++I) {
6660 auto *Index = llvm::ConstantInt::get(
IntTy, I -
First);
6662 Builder.CreateGEP(Tmp.getElementType(), Alloca, {Zero, Index});
6668 V, GEP,
CGM.getDataLayout().getPrefTypeAlign(
SizeTy));
6670 return {ElemPtr, Alloca};
6676 Name =
"__enqueue_kernel_varargs";
6678 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6680 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6681 auto *
Block =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6682 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(4);
6686 llvm::Value *
const Args[] = {Queue, Flags,
6690 llvm::Type *
const ArgTys[] = {
6691 QueueTy,
IntTy, RangePtrTy, GenericVoidPtrTy,
6692 GenericVoidPtrTy,
IntTy, ElemPtr->getType()};
6694 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6702 llvm::PointerType *PtrTy = llvm::PointerType::get(
6703 CGM.getLLVMContext(),
6706 llvm::Value *NumEvents =
6712 llvm::Value *EventWaitList =
nullptr;
6715 EventWaitList = llvm::ConstantPointerNull::get(PtrTy);
6722 EventWaitList =
Builder.CreatePointerCast(EventWaitList, PtrTy);
6724 llvm::Value *EventRet =
nullptr;
6727 EventRet = llvm::ConstantPointerNull::get(PtrTy);
6734 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(6));
6736 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6737 llvm::Value *
Block =
6738 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6740 std::vector<llvm::Type *> ArgTys = {
6742 PtrTy, PtrTy, GenericVoidPtrTy, GenericVoidPtrTy};
6744 std::vector<llvm::Value *> Args = {Queue, Flags, Range,
6745 NumEvents, EventWaitList, EventRet,
6750 Name =
"__enqueue_kernel_basic_events";
6751 llvm::FunctionType *FTy =
6752 llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6758 Args.push_back(ConstantInt::get(
Int32Ty, NumArgs - 7));
6760 Name =
"__enqueue_kernel_events_varargs";
6762 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(7);
6763 Args.push_back(ElemPtr);
6764 ArgTys.push_back(ElemPtr->getType());
6766 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6772 llvm_unreachable(
"Unexpected enqueue_kernel signature");
6776 case Builtin::BIget_kernel_work_group_size: {
6777 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6780 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6782 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6783 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6785 CGM.CreateRuntimeFunction(
6786 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6788 "__get_kernel_work_group_size_impl"),
6791 case Builtin::BIget_kernel_preferred_work_group_size_multiple: {
6792 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6795 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6797 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6798 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6800 CGM.CreateRuntimeFunction(
6801 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6803 "__get_kernel_preferred_work_group_size_multiple_impl"),
6806 case Builtin::BIget_kernel_max_sub_group_size_for_ndrange:
6807 case Builtin::BIget_kernel_sub_group_count_for_ndrange: {
6808 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6813 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(1));
6815 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6818 BuiltinID == Builtin::BIget_kernel_max_sub_group_size_for_ndrange
6819 ?
"__get_kernel_max_sub_group_size_for_ndrange_impl"
6820 :
"__get_kernel_sub_group_count_for_ndrange_impl";
6822 CGM.CreateRuntimeFunction(
6823 llvm::FunctionType::get(
6824 IntTy, {NDRange->getType(), GenericVoidPtrTy, GenericVoidPtrTy},
6827 {NDRange, Kernel, Block}));
6829 case Builtin::BI__builtin_store_half:
6830 case Builtin::BI__builtin_store_halff: {
6838 case Builtin::BI__builtin_load_half: {
6843 case Builtin::BI__builtin_load_halff: {
6848 case Builtin::BI__builtin_printf:
6849 case Builtin::BIprintf:
6863 case Builtin::BI__builtin_canonicalize:
6864 case Builtin::BI__builtin_canonicalizef:
6865 case Builtin::BI__builtin_canonicalizef16:
6866 case Builtin::BI__builtin_canonicalizel:
6870 case Builtin::BI__builtin_thread_pointer: {
6871 if (!
getContext().getTargetInfo().isTLSSupported())
6872 CGM.ErrorUnsupported(E,
"__builtin_thread_pointer");
6875 {GlobalsInt8PtrTy}, {}));
6877 case Builtin::BI__builtin_os_log_format:
6880 case Builtin::BI__xray_customevent: {
6884 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6888 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6892 Function *F =
CGM.getIntrinsic(Intrinsic::xray_customevent);
6893 auto FTy = F->getFunctionType();
6894 auto Arg0 = E->
getArg(0);
6896 auto Arg0Ty = Arg0->getType();
6897 auto PTy0 = FTy->getParamType(0);
6898 if (PTy0 != Arg0Val->getType()) {
6899 if (Arg0Ty->isArrayType())
6902 Arg0Val =
Builder.CreatePointerCast(Arg0Val, PTy0);
6905 auto PTy1 = FTy->getParamType(1);
6906 if (PTy1 != Arg1->getType())
6907 Arg1 =
Builder.CreateTruncOrBitCast(Arg1, PTy1);
6911 case Builtin::BI__xray_typedevent: {
6918 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6922 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6926 Function *F =
CGM.getIntrinsic(Intrinsic::xray_typedevent);
6927 auto FTy = F->getFunctionType();
6929 auto PTy0 = FTy->getParamType(0);
6930 if (PTy0 != Arg0->getType())
6931 Arg0 =
Builder.CreateTruncOrBitCast(Arg0, PTy0);
6932 auto Arg1 = E->
getArg(1);
6934 auto Arg1Ty = Arg1->getType();
6935 auto PTy1 = FTy->getParamType(1);
6936 if (PTy1 != Arg1Val->getType()) {
6937 if (Arg1Ty->isArrayType())
6940 Arg1Val =
Builder.CreatePointerCast(Arg1Val, PTy1);
6943 auto PTy2 = FTy->getParamType(2);
6944 if (PTy2 != Arg2->getType())
6945 Arg2 =
Builder.CreateTruncOrBitCast(Arg2, PTy2);
6949 case Builtin::BI__builtin_ms_va_start:
6950 case Builtin::BI__builtin_ms_va_end:
6953 BuiltinID == Builtin::BI__builtin_ms_va_start));
6955 case Builtin::BI__builtin_ms_va_copy: {
6972 case Builtin::BI__builtin_get_device_side_mangled_name: {
6973 auto Name =
CGM.getCUDARuntime().getDeviceSideName(
6975 auto Str =
CGM.GetAddrOfConstantCString(Name,
"");
6985 BI.isLibFunction(BuiltinID))
6987 CGM.getBuiltinLibFunction(FD, BuiltinID));
6991 if (BI.isPredefinedLibFunction(BuiltinID))
7001 if (
unsigned VectorWidth =
getContext().BuiltinInfo.getRequiredVectorWidth(BuiltinID))
7002 LargestVectorWidth = std::max(LargestVectorWidth, VectorWidth);
7006 Intrinsic::ID IntrinsicID = Intrinsic::not_intrinsic;
7009 if (!Prefix.empty()) {
7010 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(Prefix.data(), Name);
7011 if (IntrinsicID == Intrinsic::not_intrinsic && Prefix ==
"spv" &&
7013 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(
"amdgcn", Name);
7017 if (IntrinsicID == Intrinsic::not_intrinsic)
7018 IntrinsicID = Intrinsic::getIntrinsicForMSBuiltin(Prefix.data(), Name);
7021 if (IntrinsicID != Intrinsic::not_intrinsic) {
7026 unsigned ICEArguments = 0;
7032 llvm::FunctionType *FTy = F->getFunctionType();
7034 for (
unsigned i = 0, e = E->
getNumArgs(); i != e; ++i) {
7038 llvm::Type *PTy = FTy->getParamType(i);
7039 if (PTy != ArgValue->
getType()) {
7041 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(PTy)) {
7042 if (PtrTy->getAddressSpace() !=
7043 ArgValue->
getType()->getPointerAddressSpace()) {
7044 ArgValue =
Builder.CreateAddrSpaceCast(
7046 PtrTy->getAddressSpace()));
7052 if (PTy->isX86_AMXTy())
7053 ArgValue =
Builder.CreateIntrinsic(Intrinsic::x86_cast_vector_to_tile,
7054 {ArgValue->
getType()}, {ArgValue});
7056 ArgValue =
Builder.CreateBitCast(ArgValue, PTy);
7059 Args.push_back(ArgValue);
7065 llvm::Type *RetTy =
VoidTy;
7069 if (RetTy !=
V->getType()) {
7071 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(RetTy)) {
7072 if (PtrTy->getAddressSpace() !=
V->getType()->getPointerAddressSpace()) {
7075 PtrTy->getAddressSpace()));
7081 if (
V->getType()->isX86_AMXTy())
7082 V =
Builder.CreateIntrinsic(Intrinsic::x86_cast_tile_to_vector, {RetTy},
7088 if (RetTy->isVoidTy())
7108 if (
V->getType()->isVoidTy())
7115 llvm_unreachable(
"No current target builtin returns complex");
7117 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");
7124 if (
V->getType()->isVoidTy())
7131 llvm_unreachable(
"No current hlsl builtin returns complex");
7133 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");