2704 assert(!
getContext().BuiltinInfo.isImmediate(BuiltinID) &&
2705 "Should not codegen for consteval builtins");
2712 !
Result.hasSideEffects()) {
2716 if (
Result.Val.isFloat())
2726 &
getTarget().getLongDoubleFormat() == &llvm::APFloat::IEEEquad())
2733 const unsigned BuiltinIDIfNoAsmLabel =
2734 FD->
hasAttr<AsmLabelAttr>() ? 0 : BuiltinID;
2736 std::optional<bool> ErrnoOverriden;
2742 if (OP.hasMathErrnoOverride())
2743 ErrnoOverriden = OP.getMathErrnoOverride();
2749 bool IsOptimizationEnabled =
CGM.getCodeGenOpts().OptimizationLevel != 0;
2751 bool GenerateFPMathIntrinsics =
2753 BuiltinID,
CGM.getTriple(), ErrnoOverriden,
getLangOpts().MathErrno,
2754 OptNone, IsOptimizationEnabled);
2756 if (GenerateFPMathIntrinsics) {
2757 switch (BuiltinIDIfNoAsmLabel) {
2758 case Builtin::BIacos:
2759 case Builtin::BIacosf:
2760 case Builtin::BIacosl:
2761 case Builtin::BI__builtin_acos:
2762 case Builtin::BI__builtin_acosf:
2763 case Builtin::BI__builtin_acosf16:
2764 case Builtin::BI__builtin_acosl:
2765 case Builtin::BI__builtin_acosf128:
2766 case Builtin::BI__builtin_elementwise_acos:
2768 *
this, E, Intrinsic::acos, Intrinsic::experimental_constrained_acos));
2770 case Builtin::BIasin:
2771 case Builtin::BIasinf:
2772 case Builtin::BIasinl:
2773 case Builtin::BI__builtin_asin:
2774 case Builtin::BI__builtin_asinf:
2775 case Builtin::BI__builtin_asinf16:
2776 case Builtin::BI__builtin_asinl:
2777 case Builtin::BI__builtin_asinf128:
2778 case Builtin::BI__builtin_elementwise_asin:
2780 *
this, E, Intrinsic::asin, Intrinsic::experimental_constrained_asin));
2782 case Builtin::BIatan:
2783 case Builtin::BIatanf:
2784 case Builtin::BIatanl:
2785 case Builtin::BI__builtin_atan:
2786 case Builtin::BI__builtin_atanf:
2787 case Builtin::BI__builtin_atanf16:
2788 case Builtin::BI__builtin_atanl:
2789 case Builtin::BI__builtin_atanf128:
2790 case Builtin::BI__builtin_elementwise_atan:
2792 *
this, E, Intrinsic::atan, Intrinsic::experimental_constrained_atan));
2794 case Builtin::BIatan2:
2795 case Builtin::BIatan2f:
2796 case Builtin::BIatan2l:
2797 case Builtin::BI__builtin_atan2:
2798 case Builtin::BI__builtin_atan2f:
2799 case Builtin::BI__builtin_atan2f16:
2800 case Builtin::BI__builtin_atan2l:
2801 case Builtin::BI__builtin_atan2f128:
2802 case Builtin::BI__builtin_elementwise_atan2:
2804 *
this, E, Intrinsic::atan2,
2805 Intrinsic::experimental_constrained_atan2));
2807 case Builtin::BIceil:
2808 case Builtin::BIceilf:
2809 case Builtin::BIceill:
2810 case Builtin::BI__builtin_ceil:
2811 case Builtin::BI__builtin_ceilf:
2812 case Builtin::BI__builtin_ceilf16:
2813 case Builtin::BI__builtin_ceill:
2814 case Builtin::BI__builtin_ceilf128:
2815 case Builtin::BI__builtin_elementwise_ceil:
2818 Intrinsic::experimental_constrained_ceil));
2820 case Builtin::BIcopysign:
2821 case Builtin::BIcopysignf:
2822 case Builtin::BIcopysignl:
2823 case Builtin::BI__builtin_copysign:
2824 case Builtin::BI__builtin_copysignf:
2825 case Builtin::BI__builtin_copysignf16:
2826 case Builtin::BI__builtin_copysignl:
2827 case Builtin::BI__builtin_copysignf128:
2831 case Builtin::BIcos:
2832 case Builtin::BIcosf:
2833 case Builtin::BIcosl:
2834 case Builtin::BI__builtin_cos:
2835 case Builtin::BI__builtin_cosf:
2836 case Builtin::BI__builtin_cosf16:
2837 case Builtin::BI__builtin_cosl:
2838 case Builtin::BI__builtin_cosf128:
2839 case Builtin::BI__builtin_elementwise_cos:
2842 Intrinsic::experimental_constrained_cos));
2844 case Builtin::BIcosh:
2845 case Builtin::BIcoshf:
2846 case Builtin::BIcoshl:
2847 case Builtin::BI__builtin_cosh:
2848 case Builtin::BI__builtin_coshf:
2849 case Builtin::BI__builtin_coshf16:
2850 case Builtin::BI__builtin_coshl:
2851 case Builtin::BI__builtin_coshf128:
2852 case Builtin::BI__builtin_elementwise_cosh:
2854 *
this, E, Intrinsic::cosh, Intrinsic::experimental_constrained_cosh));
2856 case Builtin::BIexp:
2857 case Builtin::BIexpf:
2858 case Builtin::BIexpl:
2859 case Builtin::BI__builtin_exp:
2860 case Builtin::BI__builtin_expf:
2861 case Builtin::BI__builtin_expf16:
2862 case Builtin::BI__builtin_expl:
2863 case Builtin::BI__builtin_expf128:
2864 case Builtin::BI__builtin_elementwise_exp:
2867 Intrinsic::experimental_constrained_exp));
2869 case Builtin::BIexp2:
2870 case Builtin::BIexp2f:
2871 case Builtin::BIexp2l:
2872 case Builtin::BI__builtin_exp2:
2873 case Builtin::BI__builtin_exp2f:
2874 case Builtin::BI__builtin_exp2f16:
2875 case Builtin::BI__builtin_exp2l:
2876 case Builtin::BI__builtin_exp2f128:
2877 case Builtin::BI__builtin_elementwise_exp2:
2880 Intrinsic::experimental_constrained_exp2));
2881 case Builtin::BI__builtin_exp10:
2882 case Builtin::BI__builtin_exp10f:
2883 case Builtin::BI__builtin_exp10f16:
2884 case Builtin::BI__builtin_exp10l:
2885 case Builtin::BI__builtin_exp10f128:
2886 case Builtin::BI__builtin_elementwise_exp10: {
2888 if (
Builder.getIsFPConstrained())
2893 case Builtin::BIfabs:
2894 case Builtin::BIfabsf:
2895 case Builtin::BIfabsl:
2896 case Builtin::BI__builtin_fabs:
2897 case Builtin::BI__builtin_fabsf:
2898 case Builtin::BI__builtin_fabsf16:
2899 case Builtin::BI__builtin_fabsl:
2900 case Builtin::BI__builtin_fabsf128:
2904 case Builtin::BIfloor:
2905 case Builtin::BIfloorf:
2906 case Builtin::BIfloorl:
2907 case Builtin::BI__builtin_floor:
2908 case Builtin::BI__builtin_floorf:
2909 case Builtin::BI__builtin_floorf16:
2910 case Builtin::BI__builtin_floorl:
2911 case Builtin::BI__builtin_floorf128:
2912 case Builtin::BI__builtin_elementwise_floor:
2915 Intrinsic::experimental_constrained_floor));
2917 case Builtin::BIfma:
2918 case Builtin::BIfmaf:
2919 case Builtin::BIfmal:
2920 case Builtin::BI__builtin_fma:
2921 case Builtin::BI__builtin_fmaf:
2922 case Builtin::BI__builtin_fmaf16:
2923 case Builtin::BI__builtin_fmal:
2924 case Builtin::BI__builtin_fmaf128:
2925 case Builtin::BI__builtin_elementwise_fma:
2928 Intrinsic::experimental_constrained_fma));
2930 case Builtin::BIfmax:
2931 case Builtin::BIfmaxf:
2932 case Builtin::BIfmaxl:
2933 case Builtin::BI__builtin_fmax:
2934 case Builtin::BI__builtin_fmaxf:
2935 case Builtin::BI__builtin_fmaxf16:
2936 case Builtin::BI__builtin_fmaxl:
2937 case Builtin::BI__builtin_fmaxf128: {
2938 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
2939 Builder.getFastMathFlags().setNoSignedZeros();
2941 *
this, E, Intrinsic::maxnum,
2942 Intrinsic::experimental_constrained_maxnum));
2945 case Builtin::BIfmin:
2946 case Builtin::BIfminf:
2947 case Builtin::BIfminl:
2948 case Builtin::BI__builtin_fmin:
2949 case Builtin::BI__builtin_fminf:
2950 case Builtin::BI__builtin_fminf16:
2951 case Builtin::BI__builtin_fminl:
2952 case Builtin::BI__builtin_fminf128: {
2953 IRBuilder<>::FastMathFlagGuard FMFGuard(
Builder);
2954 Builder.getFastMathFlags().setNoSignedZeros();
2956 *
this, E, Intrinsic::minnum,
2957 Intrinsic::experimental_constrained_minnum));
2960 case Builtin::BIfmaximum_num:
2961 case Builtin::BIfmaximum_numf:
2962 case Builtin::BIfmaximum_numl:
2963 case Builtin::BI__builtin_fmaximum_num:
2964 case Builtin::BI__builtin_fmaximum_numf:
2965 case Builtin::BI__builtin_fmaximum_numf16:
2966 case Builtin::BI__builtin_fmaximum_numl:
2967 case Builtin::BI__builtin_fmaximum_numf128:
2971 case Builtin::BIfminimum_num:
2972 case Builtin::BIfminimum_numf:
2973 case Builtin::BIfminimum_numl:
2974 case Builtin::BI__builtin_fminimum_num:
2975 case Builtin::BI__builtin_fminimum_numf:
2976 case Builtin::BI__builtin_fminimum_numf16:
2977 case Builtin::BI__builtin_fminimum_numl:
2978 case Builtin::BI__builtin_fminimum_numf128:
2984 case Builtin::BIfmod:
2985 case Builtin::BIfmodf:
2986 case Builtin::BIfmodl:
2987 case Builtin::BI__builtin_fmod:
2988 case Builtin::BI__builtin_fmodf:
2989 case Builtin::BI__builtin_fmodf16:
2990 case Builtin::BI__builtin_fmodl:
2991 case Builtin::BI__builtin_fmodf128:
2992 case Builtin::BI__builtin_elementwise_fmod: {
2996 if (
Builder.getIsFPConstrained()) {
2997 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_frem,
3005 case Builtin::BIlog:
3006 case Builtin::BIlogf:
3007 case Builtin::BIlogl:
3008 case Builtin::BI__builtin_log:
3009 case Builtin::BI__builtin_logf:
3010 case Builtin::BI__builtin_logf16:
3011 case Builtin::BI__builtin_logl:
3012 case Builtin::BI__builtin_logf128:
3013 case Builtin::BI__builtin_elementwise_log:
3016 Intrinsic::experimental_constrained_log));
3018 case Builtin::BIlog10:
3019 case Builtin::BIlog10f:
3020 case Builtin::BIlog10l:
3021 case Builtin::BI__builtin_log10:
3022 case Builtin::BI__builtin_log10f:
3023 case Builtin::BI__builtin_log10f16:
3024 case Builtin::BI__builtin_log10l:
3025 case Builtin::BI__builtin_log10f128:
3026 case Builtin::BI__builtin_elementwise_log10:
3029 Intrinsic::experimental_constrained_log10));
3031 case Builtin::BIlog2:
3032 case Builtin::BIlog2f:
3033 case Builtin::BIlog2l:
3034 case Builtin::BI__builtin_log2:
3035 case Builtin::BI__builtin_log2f:
3036 case Builtin::BI__builtin_log2f16:
3037 case Builtin::BI__builtin_log2l:
3038 case Builtin::BI__builtin_log2f128:
3039 case Builtin::BI__builtin_elementwise_log2:
3042 Intrinsic::experimental_constrained_log2));
3044 case Builtin::BInearbyint:
3045 case Builtin::BInearbyintf:
3046 case Builtin::BInearbyintl:
3047 case Builtin::BI__builtin_nearbyint:
3048 case Builtin::BI__builtin_nearbyintf:
3049 case Builtin::BI__builtin_nearbyintl:
3050 case Builtin::BI__builtin_nearbyintf128:
3051 case Builtin::BI__builtin_elementwise_nearbyint:
3053 Intrinsic::nearbyint,
3054 Intrinsic::experimental_constrained_nearbyint));
3056 case Builtin::BIpow:
3057 case Builtin::BIpowf:
3058 case Builtin::BIpowl:
3059 case Builtin::BI__builtin_pow:
3060 case Builtin::BI__builtin_powf:
3061 case Builtin::BI__builtin_powf16:
3062 case Builtin::BI__builtin_powl:
3063 case Builtin::BI__builtin_powf128:
3064 case Builtin::BI__builtin_elementwise_pow:
3067 Intrinsic::experimental_constrained_pow));
3069 case Builtin::BIrint:
3070 case Builtin::BIrintf:
3071 case Builtin::BIrintl:
3072 case Builtin::BI__builtin_rint:
3073 case Builtin::BI__builtin_rintf:
3074 case Builtin::BI__builtin_rintf16:
3075 case Builtin::BI__builtin_rintl:
3076 case Builtin::BI__builtin_rintf128:
3077 case Builtin::BI__builtin_elementwise_rint:
3080 Intrinsic::experimental_constrained_rint));
3082 case Builtin::BIround:
3083 case Builtin::BIroundf:
3084 case Builtin::BIroundl:
3085 case Builtin::BI__builtin_round:
3086 case Builtin::BI__builtin_roundf:
3087 case Builtin::BI__builtin_roundf16:
3088 case Builtin::BI__builtin_roundl:
3089 case Builtin::BI__builtin_roundf128:
3090 case Builtin::BI__builtin_elementwise_round:
3093 Intrinsic::experimental_constrained_round));
3095 case Builtin::BIroundeven:
3096 case Builtin::BIroundevenf:
3097 case Builtin::BIroundevenl:
3098 case Builtin::BI__builtin_roundeven:
3099 case Builtin::BI__builtin_roundevenf:
3100 case Builtin::BI__builtin_roundevenf16:
3101 case Builtin::BI__builtin_roundevenl:
3102 case Builtin::BI__builtin_roundevenf128:
3103 case Builtin::BI__builtin_elementwise_roundeven:
3105 Intrinsic::roundeven,
3106 Intrinsic::experimental_constrained_roundeven));
3108 case Builtin::BIsin:
3109 case Builtin::BIsinf:
3110 case Builtin::BIsinl:
3111 case Builtin::BI__builtin_sin:
3112 case Builtin::BI__builtin_sinf:
3113 case Builtin::BI__builtin_sinf16:
3114 case Builtin::BI__builtin_sinl:
3115 case Builtin::BI__builtin_sinf128:
3116 case Builtin::BI__builtin_elementwise_sin:
3119 Intrinsic::experimental_constrained_sin));
3121 case Builtin::BIsinh:
3122 case Builtin::BIsinhf:
3123 case Builtin::BIsinhl:
3124 case Builtin::BI__builtin_sinh:
3125 case Builtin::BI__builtin_sinhf:
3126 case Builtin::BI__builtin_sinhf16:
3127 case Builtin::BI__builtin_sinhl:
3128 case Builtin::BI__builtin_sinhf128:
3129 case Builtin::BI__builtin_elementwise_sinh:
3131 *
this, E, Intrinsic::sinh, Intrinsic::experimental_constrained_sinh));
3133 case Builtin::BI__builtin_sincospi:
3134 case Builtin::BI__builtin_sincospif:
3135 case Builtin::BI__builtin_sincospil:
3136 if (
Builder.getIsFPConstrained())
3141 case Builtin::BIsincos:
3142 case Builtin::BIsincosf:
3143 case Builtin::BIsincosl:
3144 case Builtin::BI__builtin_sincos:
3145 case Builtin::BI__builtin_sincosf:
3146 case Builtin::BI__builtin_sincosf16:
3147 case Builtin::BI__builtin_sincosl:
3148 case Builtin::BI__builtin_sincosf128:
3149 if (
Builder.getIsFPConstrained())
3154 case Builtin::BIsqrt:
3155 case Builtin::BIsqrtf:
3156 case Builtin::BIsqrtl:
3157 case Builtin::BI__builtin_sqrt:
3158 case Builtin::BI__builtin_sqrtf:
3159 case Builtin::BI__builtin_sqrtf16:
3160 case Builtin::BI__builtin_sqrtl:
3161 case Builtin::BI__builtin_sqrtf128:
3162 case Builtin::BI__builtin_elementwise_sqrt: {
3164 *
this, E, Intrinsic::sqrt, Intrinsic::experimental_constrained_sqrt);
3169 case Builtin::BItan:
3170 case Builtin::BItanf:
3171 case Builtin::BItanl:
3172 case Builtin::BI__builtin_tan:
3173 case Builtin::BI__builtin_tanf:
3174 case Builtin::BI__builtin_tanf16:
3175 case Builtin::BI__builtin_tanl:
3176 case Builtin::BI__builtin_tanf128:
3177 case Builtin::BI__builtin_elementwise_tan:
3179 *
this, E, Intrinsic::tan, Intrinsic::experimental_constrained_tan));
3181 case Builtin::BItanh:
3182 case Builtin::BItanhf:
3183 case Builtin::BItanhl:
3184 case Builtin::BI__builtin_tanh:
3185 case Builtin::BI__builtin_tanhf:
3186 case Builtin::BI__builtin_tanhf16:
3187 case Builtin::BI__builtin_tanhl:
3188 case Builtin::BI__builtin_tanhf128:
3189 case Builtin::BI__builtin_elementwise_tanh:
3191 *
this, E, Intrinsic::tanh, Intrinsic::experimental_constrained_tanh));
3193 case Builtin::BItrunc:
3194 case Builtin::BItruncf:
3195 case Builtin::BItruncl:
3196 case Builtin::BI__builtin_trunc:
3197 case Builtin::BI__builtin_truncf:
3198 case Builtin::BI__builtin_truncf16:
3199 case Builtin::BI__builtin_truncl:
3200 case Builtin::BI__builtin_truncf128:
3201 case Builtin::BI__builtin_elementwise_trunc:
3204 Intrinsic::experimental_constrained_trunc));
3206 case Builtin::BIlround:
3207 case Builtin::BIlroundf:
3208 case Builtin::BIlroundl:
3209 case Builtin::BI__builtin_lround:
3210 case Builtin::BI__builtin_lroundf:
3211 case Builtin::BI__builtin_lroundl:
3212 case Builtin::BI__builtin_lroundf128:
3214 *
this, E, Intrinsic::lround,
3215 Intrinsic::experimental_constrained_lround));
3217 case Builtin::BIllround:
3218 case Builtin::BIllroundf:
3219 case Builtin::BIllroundl:
3220 case Builtin::BI__builtin_llround:
3221 case Builtin::BI__builtin_llroundf:
3222 case Builtin::BI__builtin_llroundl:
3223 case Builtin::BI__builtin_llroundf128:
3225 *
this, E, Intrinsic::llround,
3226 Intrinsic::experimental_constrained_llround));
3228 case Builtin::BIlrint:
3229 case Builtin::BIlrintf:
3230 case Builtin::BIlrintl:
3231 case Builtin::BI__builtin_lrint:
3232 case Builtin::BI__builtin_lrintf:
3233 case Builtin::BI__builtin_lrintl:
3234 case Builtin::BI__builtin_lrintf128:
3236 *
this, E, Intrinsic::lrint,
3237 Intrinsic::experimental_constrained_lrint));
3239 case Builtin::BIllrint:
3240 case Builtin::BIllrintf:
3241 case Builtin::BIllrintl:
3242 case Builtin::BI__builtin_llrint:
3243 case Builtin::BI__builtin_llrintf:
3244 case Builtin::BI__builtin_llrintl:
3245 case Builtin::BI__builtin_llrintf128:
3247 *
this, E, Intrinsic::llrint,
3248 Intrinsic::experimental_constrained_llrint));
3249 case Builtin::BI__builtin_ldexp:
3250 case Builtin::BI__builtin_ldexpf:
3251 case Builtin::BI__builtin_ldexpl:
3252 case Builtin::BI__builtin_ldexpf16:
3253 case Builtin::BI__builtin_ldexpf128:
3254 case Builtin::BI__builtin_elementwise_ldexp:
3256 *
this, E, Intrinsic::ldexp,
3257 Intrinsic::experimental_constrained_ldexp));
3266 Value *Val = A.emitRawPointer(*
this);
3270 if (
SanOpts.has(SanitizerKind::Alignment)) {
3272 SkippedChecks.
set(SanitizerKind::All);
3273 SkippedChecks.
clear(SanitizerKind::Alignment);
3276 if (
auto *CE = dyn_cast<ImplicitCastExpr>(Arg))
3277 if (CE->getCastKind() == CK_BitCast)
3278 Arg = CE->getSubExpr();
3284 switch (BuiltinIDIfNoAsmLabel) {
3286 case Builtin::BI__builtin___CFStringMakeConstantString:
3287 case Builtin::BI__builtin___NSStringMakeConstantString:
3289 case Builtin::BI__builtin_stdarg_start:
3290 case Builtin::BI__builtin_va_start:
3291 case Builtin::BI__va_start:
3292 case Builtin::BI__builtin_c23_va_start:
3293 case Builtin::BI__builtin_va_end:
3297 BuiltinID != Builtin::BI__builtin_va_end);
3299 case Builtin::BI__builtin_va_copy: {
3302 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::vacopy, {DstPtr->getType()}),
3306 case Builtin::BIabs:
3307 case Builtin::BIlabs:
3308 case Builtin::BIllabs:
3309 case Builtin::BI__builtin_abs:
3310 case Builtin::BI__builtin_labs:
3311 case Builtin::BI__builtin_llabs: {
3312 bool SanitizeOverflow =
SanOpts.has(SanitizerKind::SignedIntegerOverflow);
3315 switch (
getLangOpts().getSignedOverflowBehavior()) {
3320 if (!SanitizeOverflow) {
3332 case Builtin::BI__builtin_complex: {
3337 case Builtin::BI__builtin_conj:
3338 case Builtin::BI__builtin_conjf:
3339 case Builtin::BI__builtin_conjl:
3340 case Builtin::BIconj:
3341 case Builtin::BIconjf:
3342 case Builtin::BIconjl: {
3344 Value *Real = ComplexVal.first;
3345 Value *Imag = ComplexVal.second;
3346 Imag =
Builder.CreateFNeg(Imag,
"neg");
3349 case Builtin::BI__builtin_creal:
3350 case Builtin::BI__builtin_crealf:
3351 case Builtin::BI__builtin_creall:
3352 case Builtin::BIcreal:
3353 case Builtin::BIcrealf:
3354 case Builtin::BIcreall: {
3359 case Builtin::BI__builtin_preserve_access_index: {
3364 CGM.Error(E->
getExprLoc(),
"using builtin_preserve_access_index() without -g");
3370 CGM.Error(E->
getExprLoc(),
"nested builtin_preserve_access_index() not supported");
3380 case Builtin::BI__builtin_cimag:
3381 case Builtin::BI__builtin_cimagf:
3382 case Builtin::BI__builtin_cimagl:
3383 case Builtin::BIcimag:
3384 case Builtin::BIcimagf:
3385 case Builtin::BIcimagl: {
3390 case Builtin::BI__builtin_clrsb:
3391 case Builtin::BI__builtin_clrsbl:
3392 case Builtin::BI__builtin_clrsbll: {
3403 Value *Tmp =
Builder.CreateSelect(IsNeg, Inverse, ArgValue);
3411 case Builtin::BI__builtin_ctzs:
3412 case Builtin::BI__builtin_ctz:
3413 case Builtin::BI__builtin_ctzl:
3414 case Builtin::BI__builtin_ctzll:
3415 case Builtin::BI__builtin_ctzg:
3416 case Builtin::BI__builtin_elementwise_ctzg: {
3418 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_ctzg ||
3419 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg) &&
3432 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3433 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_ctzg);
3435 if (
Result->getType() != ResultType)
3444 Value *ResultOrFallback =
3445 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"ctzg");
3448 case Builtin::BI__builtin_clzs:
3449 case Builtin::BI__builtin_clz:
3450 case Builtin::BI__builtin_clzl:
3451 case Builtin::BI__builtin_clzll:
3452 case Builtin::BI__builtin_clzg:
3453 case Builtin::BI__builtin_elementwise_clzg: {
3455 (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_clzg ||
3456 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg) &&
3469 HasFallback ||
getTarget().isCLZForZeroUndef() ||
3470 BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_clzg);
3472 if (
Result->getType() != ResultType)
3481 Value *ResultOrFallback =
3482 Builder.CreateSelect(IsZero, FallbackValue,
Result,
"clzg");
3485 case Builtin::BI__builtin_ffs:
3486 case Builtin::BI__builtin_ffsl:
3487 case Builtin::BI__builtin_ffsll: {
3496 Builder.CreateAdd(
Builder.CreateCall(F, {ArgValue, Builder.getTrue()}),
3497 llvm::ConstantInt::get(
ArgType, 1));
3501 if (
Result->getType() != ResultType)
3506 case Builtin::BI__builtin_parity:
3507 case Builtin::BI__builtin_parityl:
3508 case Builtin::BI__builtin_parityll: {
3518 if (
Result->getType() != ResultType)
3523 case Builtin::BI__lzcnt16:
3524 case Builtin::BI__lzcnt:
3525 case Builtin::BI__lzcnt64: {
3533 if (
Result->getType() != ResultType)
3538 case Builtin::BI__popcnt16:
3539 case Builtin::BI__popcnt:
3540 case Builtin::BI__popcnt64:
3541 case Builtin::BI__builtin_popcount:
3542 case Builtin::BI__builtin_popcountl:
3543 case Builtin::BI__builtin_popcountll:
3544 case Builtin::BI__builtin_popcountg: {
3552 if (
Result->getType() != ResultType)
3557 case Builtin::BI__builtin_unpredictable: {
3563 case Builtin::BI__builtin_expect: {
3571 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3576 Builder.CreateCall(FnExpect, {ArgValue, ExpectedValue},
"expval");
3579 case Builtin::BI__builtin_expect_with_probability: {
3584 llvm::APFloat Probability(0.0);
3587 assert(EvalSucceed &&
"probability should be able to evaluate as float");
3589 bool LoseInfo =
false;
3590 Probability.convert(llvm::APFloat::IEEEdouble(),
3591 llvm::RoundingMode::Dynamic, &LoseInfo);
3593 Constant *Confidence = ConstantFP::get(Ty, Probability);
3597 if (
CGM.getCodeGenOpts().OptimizationLevel == 0)
3601 CGM.getIntrinsic(Intrinsic::expect_with_probability,
ArgType);
3603 FnExpect, {ArgValue, ExpectedValue, Confidence},
"expval");
3606 case Builtin::BI__builtin_assume_aligned: {
3609 Value *OffsetValue =
3614 if (AlignmentCI->getValue().ugt(llvm::Value::MaximumAlignment))
3615 AlignmentCI = ConstantInt::get(AlignmentCI->getIntegerType(),
3616 llvm::Value::MaximumAlignment);
3620 AlignmentCI, OffsetValue);
3623 case Builtin::BI__builtin_assume_dereferenceable: {
3631 Builder.CreateDereferenceableAssumption(PtrValue, SizeValue);
3634 case Builtin::BI__assume:
3635 case Builtin::BI__builtin_assume: {
3640 Function *FnAssume =
CGM.getIntrinsic(Intrinsic::assume);
3641 Builder.CreateCall(FnAssume, ArgValue);
3644 case Builtin::BI__builtin_assume_separate_storage: {
3651 Value *Values[] = {Value0, Value1};
3652 OperandBundleDefT<Value *> OBD(
"separate_storage", Values);
3653 Builder.CreateAssumption({OBD});
3656 case Builtin::BI__builtin_allow_runtime_check: {
3659 LLVMContext &Ctx =
CGM.getLLVMContext();
3661 CGM.getIntrinsic(Intrinsic::allow_runtime_check),
3662 llvm::MetadataAsValue::get(Ctx, llvm::MDString::get(Ctx, Kind)));
3665 case Builtin::BI__builtin_allow_sanitize_check: {
3666 Intrinsic::ID IntrID = Intrinsic::not_intrinsic;
3674 if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Address |
3675 SanitizerKind::KernelAddress) &&
3676 (Name ==
"address" || Name ==
"kernel-address")) {
3677 IntrID = Intrinsic::allow_sanitize_address;
3678 }
else if (
getLangOpts().Sanitize.has(SanitizerKind::Thread) &&
3680 IntrID = Intrinsic::allow_sanitize_thread;
3681 }
else if (
getLangOpts().Sanitize.hasOneOf(SanitizerKind::Memory |
3682 SanitizerKind::KernelMemory) &&
3683 (Name ==
"memory" || Name ==
"kernel-memory")) {
3684 IntrID = Intrinsic::allow_sanitize_memory;
3686 SanitizerKind::HWAddress | SanitizerKind::KernelHWAddress) &&
3687 (Name ==
"hwaddress" || Name ==
"kernel-hwaddress")) {
3688 IntrID = Intrinsic::allow_sanitize_hwaddress;
3691 if (IntrID != Intrinsic::not_intrinsic) {
3700 case Builtin::BI__arithmetic_fence: {
3704 llvm::FastMathFlags FMF =
Builder.getFastMathFlags();
3705 bool isArithmeticFenceEnabled =
3706 FMF.allowReassoc() &&
3709 if (
ArgType->isComplexType()) {
3710 if (isArithmeticFenceEnabled) {
3713 Value *Real =
Builder.CreateArithmeticFence(ComplexVal.first,
3715 Value *Imag =
Builder.CreateArithmeticFence(ComplexVal.second,
3720 Value *Real = ComplexVal.first;
3721 Value *Imag = ComplexVal.second;
3725 if (isArithmeticFenceEnabled)
3730 case Builtin::BI__builtin_bswapg: {
3733 assert(
IntTy &&
"LLVM's __builtin_bswapg only supports integer variants");
3734 if (
IntTy->getBitWidth() == 1 ||
IntTy->getBitWidth() == 8)
3736 assert(((
IntTy->getBitWidth() % 16 == 0 &&
IntTy->getBitWidth() != 0)) &&
3737 "LLVM's __builtin_bswapg only supports integer variants that has a "
3738 "multiple of 16 bits as well as a single byte");
3742 case Builtin::BI__builtin_bswap16:
3743 case Builtin::BI__builtin_bswap32:
3744 case Builtin::BI__builtin_bswap64:
3745 case Builtin::BI_byteswap_ushort:
3746 case Builtin::BI_byteswap_ulong:
3747 case Builtin::BI_byteswap_uint64: {
3751 case Builtin::BI__builtin_bitreverseg: {
3755 "LLVM's __builtin_bitreverseg only support integer variants");
3756 if (
IntTy->getBitWidth() == 1)
3761 case Builtin::BI__builtin_bitreverse8:
3762 case Builtin::BI__builtin_bitreverse16:
3763 case Builtin::BI__builtin_bitreverse32:
3764 case Builtin::BI__builtin_bitreverse64: {
3768 case Builtin::BI__builtin_rotateleft8:
3769 case Builtin::BI__builtin_rotateleft16:
3770 case Builtin::BI__builtin_rotateleft32:
3771 case Builtin::BI__builtin_rotateleft64:
3772 case Builtin::BI__builtin_stdc_rotate_left:
3773 case Builtin::BIstdc_rotate_left_uc:
3774 case Builtin::BIstdc_rotate_left_us:
3775 case Builtin::BIstdc_rotate_left_ui:
3776 case Builtin::BIstdc_rotate_left_ul:
3777 case Builtin::BIstdc_rotate_left_ull:
3778 case Builtin::BI_rotl8:
3779 case Builtin::BI_rotl16:
3780 case Builtin::BI_rotl:
3781 case Builtin::BI_lrotl:
3782 case Builtin::BI_rotl64:
3785 case Builtin::BI__builtin_rotateright8:
3786 case Builtin::BI__builtin_rotateright16:
3787 case Builtin::BI__builtin_rotateright32:
3788 case Builtin::BI__builtin_rotateright64:
3789 case Builtin::BI__builtin_stdc_rotate_right:
3790 case Builtin::BIstdc_rotate_right_uc:
3791 case Builtin::BIstdc_rotate_right_us:
3792 case Builtin::BIstdc_rotate_right_ui:
3793 case Builtin::BIstdc_rotate_right_ul:
3794 case Builtin::BIstdc_rotate_right_ull:
3795 case Builtin::BI_rotr8:
3796 case Builtin::BI_rotr16:
3797 case Builtin::BI_rotr:
3798 case Builtin::BI_lrotr:
3799 case Builtin::BI_rotr64:
3802 case Builtin::BIstdc_leading_zeros_uc:
3803 case Builtin::BIstdc_leading_zeros_us:
3804 case Builtin::BIstdc_leading_zeros_ui:
3805 case Builtin::BIstdc_leading_zeros_ul:
3806 case Builtin::BIstdc_leading_zeros_ull:
3807 case Builtin::BI__builtin_stdc_leading_zeros:
3809 case Builtin::BIstdc_leading_ones_uc:
3810 case Builtin::BIstdc_leading_ones_us:
3811 case Builtin::BIstdc_leading_ones_ui:
3812 case Builtin::BIstdc_leading_ones_ul:
3813 case Builtin::BIstdc_leading_ones_ull:
3814 case Builtin::BI__builtin_stdc_leading_ones:
3816 case Builtin::BIstdc_trailing_zeros_uc:
3817 case Builtin::BIstdc_trailing_zeros_us:
3818 case Builtin::BIstdc_trailing_zeros_ui:
3819 case Builtin::BIstdc_trailing_zeros_ul:
3820 case Builtin::BIstdc_trailing_zeros_ull:
3821 case Builtin::BI__builtin_stdc_trailing_zeros:
3823 case Builtin::BIstdc_trailing_ones_uc:
3824 case Builtin::BIstdc_trailing_ones_us:
3825 case Builtin::BIstdc_trailing_ones_ui:
3826 case Builtin::BIstdc_trailing_ones_ul:
3827 case Builtin::BIstdc_trailing_ones_ull:
3828 case Builtin::BI__builtin_stdc_trailing_ones:
3830 case Builtin::BIstdc_first_leading_zero_uc:
3831 case Builtin::BIstdc_first_leading_zero_us:
3832 case Builtin::BIstdc_first_leading_zero_ui:
3833 case Builtin::BIstdc_first_leading_zero_ul:
3834 case Builtin::BIstdc_first_leading_zero_ull:
3835 case Builtin::BI__builtin_stdc_first_leading_zero:
3837 case Builtin::BIstdc_first_leading_one_uc:
3838 case Builtin::BIstdc_first_leading_one_us:
3839 case Builtin::BIstdc_first_leading_one_ui:
3840 case Builtin::BIstdc_first_leading_one_ul:
3841 case Builtin::BIstdc_first_leading_one_ull:
3842 case Builtin::BI__builtin_stdc_first_leading_one:
3844 case Builtin::BIstdc_first_trailing_zero_uc:
3845 case Builtin::BIstdc_first_trailing_zero_us:
3846 case Builtin::BIstdc_first_trailing_zero_ui:
3847 case Builtin::BIstdc_first_trailing_zero_ul:
3848 case Builtin::BIstdc_first_trailing_zero_ull:
3849 case Builtin::BI__builtin_stdc_first_trailing_zero:
3851 case Builtin::BIstdc_first_trailing_one_uc:
3852 case Builtin::BIstdc_first_trailing_one_us:
3853 case Builtin::BIstdc_first_trailing_one_ui:
3854 case Builtin::BIstdc_first_trailing_one_ul:
3855 case Builtin::BIstdc_first_trailing_one_ull:
3856 case Builtin::BI__builtin_stdc_first_trailing_one:
3858 case Builtin::BIstdc_count_zeros_uc:
3859 case Builtin::BIstdc_count_zeros_us:
3860 case Builtin::BIstdc_count_zeros_ui:
3861 case Builtin::BIstdc_count_zeros_ul:
3862 case Builtin::BIstdc_count_zeros_ull:
3863 case Builtin::BI__builtin_stdc_count_zeros:
3865 case Builtin::BIstdc_count_ones_uc:
3866 case Builtin::BIstdc_count_ones_us:
3867 case Builtin::BIstdc_count_ones_ui:
3868 case Builtin::BIstdc_count_ones_ul:
3869 case Builtin::BIstdc_count_ones_ull:
3870 case Builtin::BI__builtin_stdc_count_ones:
3873 case Builtin::BIstdc_has_single_bit_uc:
3874 case Builtin::BIstdc_has_single_bit_us:
3875 case Builtin::BIstdc_has_single_bit_ui:
3876 case Builtin::BIstdc_has_single_bit_ul:
3877 case Builtin::BIstdc_has_single_bit_ull:
3878 case Builtin::BI__builtin_stdc_has_single_bit: {
3886 case Builtin::BIstdc_bit_width_uc:
3887 case Builtin::BIstdc_bit_width_us:
3888 case Builtin::BIstdc_bit_width_ui:
3889 case Builtin::BIstdc_bit_width_ul:
3890 case Builtin::BIstdc_bit_width_ull:
3891 case Builtin::BI__builtin_stdc_bit_width:
3893 case Builtin::BIstdc_bit_floor_uc:
3894 case Builtin::BIstdc_bit_floor_us:
3895 case Builtin::BIstdc_bit_floor_ui:
3896 case Builtin::BIstdc_bit_floor_ul:
3897 case Builtin::BIstdc_bit_floor_ull:
3898 case Builtin::BI__builtin_stdc_bit_floor: {
3901 unsigned BitWidth =
ArgType->getIntegerBitWidth();
3913 case Builtin::BIstdc_bit_ceil_uc:
3914 case Builtin::BIstdc_bit_ceil_us:
3915 case Builtin::BIstdc_bit_ceil_ui:
3916 case Builtin::BIstdc_bit_ceil_ul:
3917 case Builtin::BIstdc_bit_ceil_ull:
3918 case Builtin::BI__builtin_stdc_bit_ceil: {
3921 unsigned BitWidth =
ArgType->getIntegerBitWidth();
3925 Value *IsLEOne =
Builder.CreateICmpULE(ArgValue, One,
"isleone");
3927 BasicBlock *EntryBB =
Builder.GetInsertBlock();
3931 Builder.CreateCondBr(IsLEOne, MergeBB, CalcBB);
3933 Builder.SetInsertPoint(CalcBB);
3945 Builder.SetInsertPoint(MergeBB);
3947 Phi->addIncoming(One, EntryBB);
3948 Phi->addIncoming(Tmp, CalcBB);
3952 case Builtin::BI__builtin_constant_p: {
3959 if (!
ArgType->isIntegralOrEnumerationType() && !
ArgType->isFloatingType() &&
3960 !
ArgType->isObjCObjectPointerType() && !
ArgType->isBlockPointerType())
3963 return RValue::get(ConstantInt::get(ResultType, 0));
3968 return RValue::get(ConstantInt::get(ResultType, 0));
3971 if (
ArgType->isObjCObjectPointerType()) {
3980 if (
Result->getType() != ResultType)
3984 case Builtin::BI__builtin_dynamic_object_size:
3985 case Builtin::BI__builtin_object_size: {
3992 bool IsDynamic = BuiltinID == Builtin::BI__builtin_dynamic_object_size;
3994 nullptr, IsDynamic));
3996 case Builtin::BI__builtin_counted_by_ref: {
3998 llvm::Value *
Result = llvm::ConstantPointerNull::get(
4003 if (
auto *UO = dyn_cast<UnaryOperator>(Arg);
4004 UO && UO->getOpcode() == UO_AddrOf) {
4007 if (
auto *ASE = dyn_cast<ArraySubscriptExpr>(Arg))
4011 if (
const MemberExpr *ME = dyn_cast_if_present<MemberExpr>(Arg)) {
4019 llvm::report_fatal_error(
"Cannot find the counted_by 'count' field");
4025 case Builtin::BI__builtin_prefetch: {
4029 llvm::ConstantInt::get(
Int32Ty, 0);
4031 llvm::ConstantInt::get(
Int32Ty, 3);
4037 case Builtin::BI__builtin_readcyclecounter: {
4038 Function *F =
CGM.getIntrinsic(Intrinsic::readcyclecounter);
4041 case Builtin::BI__builtin_readsteadycounter: {
4042 Function *F =
CGM.getIntrinsic(Intrinsic::readsteadycounter);
4045 case Builtin::BI__builtin___clear_cache: {
4048 Function *F =
CGM.getIntrinsic(Intrinsic::clear_cache, {
CGM.DefaultPtrTy});
4051 case Builtin::BI__builtin_trap:
4054 case Builtin::BI__builtin_verbose_trap: {
4055 llvm::DILocation *TrapLocation =
Builder.getCurrentDebugLocation();
4066 case Builtin::BI__debugbreak:
4069 case Builtin::BI__builtin_unreachable: {
4078 case Builtin::BI__builtin_powi:
4079 case Builtin::BI__builtin_powif:
4080 case Builtin::BI__builtin_powil: {
4084 if (
Builder.getIsFPConstrained()) {
4088 Function *F =
CGM.getIntrinsic(Intrinsic::experimental_constrained_powi,
4094 { Src0->getType(), Src1->getType() });
4097 case Builtin::BI__builtin_frexpl: {
4101 if (&
getTarget().getLongDoubleFormat() == &llvm::APFloat::PPCDoubleDouble())
4105 case Builtin::BI__builtin_frexp:
4106 case Builtin::BI__builtin_frexpf:
4107 case Builtin::BI__builtin_frexpf128:
4108 case Builtin::BI__builtin_frexpf16:
4110 case Builtin::BImodf:
4111 case Builtin::BImodff:
4112 case Builtin::BImodfl:
4113 case Builtin::BI__builtin_modf:
4114 case Builtin::BI__builtin_modff:
4115 case Builtin::BI__builtin_modfl:
4116 if (
Builder.getIsFPConstrained())
4119 case Builtin::BI__builtin_isgreater:
4120 case Builtin::BI__builtin_isgreaterequal:
4121 case Builtin::BI__builtin_isless:
4122 case Builtin::BI__builtin_islessequal:
4123 case Builtin::BI__builtin_islessgreater:
4124 case Builtin::BI__builtin_isunordered: {
4131 switch (BuiltinID) {
4132 default: llvm_unreachable(
"Unknown ordered comparison");
4133 case Builtin::BI__builtin_isgreater:
4134 LHS =
Builder.CreateFCmpOGT(LHS, RHS,
"cmp");
4136 case Builtin::BI__builtin_isgreaterequal:
4137 LHS =
Builder.CreateFCmpOGE(LHS, RHS,
"cmp");
4139 case Builtin::BI__builtin_isless:
4140 LHS =
Builder.CreateFCmpOLT(LHS, RHS,
"cmp");
4142 case Builtin::BI__builtin_islessequal:
4143 LHS =
Builder.CreateFCmpOLE(LHS, RHS,
"cmp");
4145 case Builtin::BI__builtin_islessgreater:
4146 LHS =
Builder.CreateFCmpONE(LHS, RHS,
"cmp");
4148 case Builtin::BI__builtin_isunordered:
4149 LHS =
Builder.CreateFCmpUNO(LHS, RHS,
"cmp");
4156 case Builtin::BI__builtin_isnan: {
4166 case Builtin::BI__builtin_issignaling: {
4174 case Builtin::BI__builtin_isinf: {
4184 case Builtin::BIfinite:
4185 case Builtin::BI__finite:
4186 case Builtin::BIfinitef:
4187 case Builtin::BI__finitef:
4188 case Builtin::BIfinitel:
4189 case Builtin::BI__finitel:
4190 case Builtin::BI__builtin_isfinite: {
4200 case Builtin::BI__builtin_isnormal: {
4208 case Builtin::BI__builtin_issubnormal: {
4212 Builder.CreateZExt(
Builder.createIsFPClass(
V, FPClassTest::fcSubnormal),
4216 case Builtin::BI__builtin_iszero: {
4224 case Builtin::BI__builtin_isfpclass: {
4228 uint64_t Test =
Result.Val.getInt().getLimitedValue();
4235 case Builtin::BI__builtin_nondeterministic_value: {
4244 case Builtin::BI__builtin_elementwise_abs: {
4249 QT = VecTy->getElementType();
4253 nullptr,
"elt.abs");
4260 case Builtin::BI__builtin_elementwise_bitreverse:
4262 *
this, E, Intrinsic::bitreverse,
"elt.bitreverse"));
4263 case Builtin::BI__builtin_elementwise_popcount:
4265 *
this, E, Intrinsic::ctpop,
"elt.ctpop"));
4266 case Builtin::BI__builtin_elementwise_canonicalize:
4268 *
this, E, Intrinsic::canonicalize,
"elt.canonicalize"));
4269 case Builtin::BI__builtin_elementwise_copysign:
4272 case Builtin::BI__builtin_elementwise_fshl:
4275 case Builtin::BI__builtin_elementwise_fshr:
4279 case Builtin::BI__builtin_elementwise_add_sat:
4280 case Builtin::BI__builtin_elementwise_sub_sat: {
4284 assert(Op0->
getType()->isIntOrIntVectorTy() &&
"integer type expected");
4287 Ty = VecTy->getElementType();
4290 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_elementwise_add_sat)
4291 Opc = IsSigned ? Intrinsic::sadd_sat : Intrinsic::uadd_sat;
4293 Opc = IsSigned ? Intrinsic::ssub_sat : Intrinsic::usub_sat;
4294 Result =
Builder.CreateBinaryIntrinsic(Opc, Op0, Op1,
nullptr,
"elt.sat");
4298 case Builtin::BI__builtin_elementwise_max: {
4302 if (Op0->
getType()->isIntOrIntVectorTy()) {
4305 Ty = VecTy->getElementType();
4308 Op1,
nullptr,
"elt.max");
4310 Result =
Builder.CreateMaxNum(Op0, Op1,
nullptr,
"elt.max");
4313 case Builtin::BI__builtin_elementwise_min: {
4317 if (Op0->
getType()->isIntOrIntVectorTy()) {
4320 Ty = VecTy->getElementType();
4323 Op1,
nullptr,
"elt.min");
4325 Result =
Builder.CreateMinNum(Op0, Op1,
nullptr,
"elt.min");
4329 case Builtin::BI__builtin_elementwise_maxnum: {
4333 Op1,
nullptr,
"elt.maxnum");
4337 case Builtin::BI__builtin_elementwise_minnum: {
4341 Op1,
nullptr,
"elt.minnum");
4345 case Builtin::BI__builtin_elementwise_maximum: {
4349 nullptr,
"elt.maximum");
4353 case Builtin::BI__builtin_elementwise_minimum: {
4357 nullptr,
"elt.minimum");
4361 case Builtin::BI__builtin_elementwise_maximumnum: {
4365 Intrinsic::maximumnum, Op0, Op1,
nullptr,
"elt.maximumnum");
4369 case Builtin::BI__builtin_elementwise_minimumnum: {
4373 Intrinsic::minimumnum, Op0, Op1,
nullptr,
"elt.minimumnum");
4377 case Builtin::BI__builtin_reduce_max: {
4378 auto GetIntrinsicID = [
this](
QualType QT) {
4380 QT = VecTy->getElementType();
4381 else if (QT->isSizelessVectorType())
4382 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4384 if (QT->isSignedIntegerType())
4385 return Intrinsic::vector_reduce_smax;
4386 if (QT->isUnsignedIntegerType())
4387 return Intrinsic::vector_reduce_umax;
4388 assert(QT->isFloatingType() &&
"must have a float here");
4389 return Intrinsic::vector_reduce_fmax;
4392 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4395 case Builtin::BI__builtin_reduce_min: {
4396 auto GetIntrinsicID = [
this](
QualType QT) {
4398 QT = VecTy->getElementType();
4399 else if (QT->isSizelessVectorType())
4400 QT = QT->getSizelessVectorEltType(
CGM.getContext());
4402 if (QT->isSignedIntegerType())
4403 return Intrinsic::vector_reduce_smin;
4404 if (QT->isUnsignedIntegerType())
4405 return Intrinsic::vector_reduce_umin;
4406 assert(QT->isFloatingType() &&
"must have a float here");
4407 return Intrinsic::vector_reduce_fmin;
4411 *
this, E, GetIntrinsicID(E->
getArg(0)->
getType()),
"rdx.min"));
4414 case Builtin::BI__builtin_reduce_add:
4416 *
this, E, Intrinsic::vector_reduce_add,
"rdx.add"));
4417 case Builtin::BI__builtin_reduce_mul:
4419 *
this, E, Intrinsic::vector_reduce_mul,
"rdx.mul"));
4420 case Builtin::BI__builtin_reduce_xor:
4422 *
this, E, Intrinsic::vector_reduce_xor,
"rdx.xor"));
4423 case Builtin::BI__builtin_reduce_or:
4425 *
this, E, Intrinsic::vector_reduce_or,
"rdx.or"));
4426 case Builtin::BI__builtin_reduce_and:
4428 *
this, E, Intrinsic::vector_reduce_and,
"rdx.and"));
4429 case Builtin::BI__builtin_reduce_maximum:
4431 *
this, E, Intrinsic::vector_reduce_fmaximum,
"rdx.maximum"));
4432 case Builtin::BI__builtin_reduce_minimum:
4434 *
this, E, Intrinsic::vector_reduce_fminimum,
"rdx.minimum"));
4435 case Builtin::BI__builtin_reduce_assoc_fadd:
4436 case Builtin::BI__builtin_reduce_in_order_fadd: {
4438 llvm::Type *ScalarTy =
Vector->getType()->getScalarType();
4439 llvm::Value *StartValue =
nullptr;
4442 llvm::Value *Args[] = {StartValue
4444 : llvm::ConstantFP::get(ScalarTy, -0.0F),
4447 CGM.getIntrinsic(Intrinsic::vector_reduce_fadd,
Vector->getType());
4448 llvm::CallBase *Reduce =
Builder.CreateCall(F, Args,
"rdx.addf");
4449 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_reduce_assoc_fadd) {
4452 llvm::FastMathFlags FMF;
4453 FMF.setAllowReassoc();
4459 case Builtin::BI__builtin_matrix_transpose: {
4463 Value *
Result = MB.CreateMatrixTranspose(MatValue, MatrixTy->getNumRows(),
4464 MatrixTy->getNumColumns());
4468 case Builtin::BI__builtin_matrix_column_major_load: {
4474 assert(PtrTy &&
"arg0 must be of pointer type");
4475 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4484 ResultTy->getNumRows(), ResultTy->getNumColumns(),
"matrix");
4488 case Builtin::BI__builtin_matrix_column_major_store: {
4496 assert(PtrTy &&
"arg1 must be of pointer type");
4497 bool IsVolatile = PtrTy->getPointeeType().isVolatileQualified();
4505 MatrixTy->getNumRows(), MatrixTy->getNumColumns());
4510 case Builtin::BI__builtin_masked_load:
4511 case Builtin::BI__builtin_masked_expand_load: {
4515 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4516 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4524 if (BuiltinID == Builtin::BI__builtin_masked_load) {
4526 PassThru,
"masked_load");
4528 Function *F =
CGM.getIntrinsic(Intrinsic::masked_expandload, {RetTy});
4530 Builder.CreateCall(F, {Ptr, Mask, PassThru},
"masked_expand_load");
4534 case Builtin::BI__builtin_masked_gather: {
4539 llvm::Type *RetTy =
CGM.getTypes().ConvertType(E->
getType());
4543 llvm::Value *PassThru = llvm::PoisonValue::get(RetTy);
4547 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4549 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4552 RetTy, PtrVec, Align.
getAsAlign(), Mask, PassThru,
"masked_gather");
4555 case Builtin::BI__builtin_masked_store:
4556 case Builtin::BI__builtin_masked_compress_store: {
4562 llvm::Type *ValLLTy =
CGM.getTypes().ConvertType(ValTy);
4568 if (BuiltinID == Builtin::BI__builtin_masked_store) {
4572 CGM.getIntrinsic(llvm::Intrinsic::masked_compressstore, {ValLLTy});
4573 Builder.CreateCall(F, {Val, Ptr, Mask});
4577 case Builtin::BI__builtin_masked_scatter: {
4587 llvm::Type *ElemTy =
CGM.getTypes().ConvertType(
4589 llvm::Value *PtrVec =
Builder.CreateGEP(ElemTy, Ptr, Idx);
4594 case Builtin::BI__builtin_isinf_sign: {
4601 AbsArg, ConstantFP::getInfinity(Arg->
getType()),
"isinf");
4607 Value *NegativeOne = ConstantInt::getAllOnesValue(
IntTy);
4608 Value *SignResult =
Builder.CreateSelect(IsNeg, NegativeOne, One);
4613 case Builtin::BI__builtin_flt_rounds: {
4614 Function *F =
CGM.getIntrinsic(Intrinsic::get_rounding);
4618 if (
Result->getType() != ResultType)
4624 case Builtin::BI__builtin_set_flt_rounds: {
4625 Function *F =
CGM.getIntrinsic(Intrinsic::set_rounding);
4632 case Builtin::BI__builtin_fpclassify: {
4639 BasicBlock *Begin =
Builder.GetInsertBlock();
4644 "fpclassify_result");
4647 Builder.SetInsertPoint(Begin);
4648 Value *IsZero =
Builder.CreateFCmpOEQ(
V, Constant::getNullValue(Ty),
4652 Builder.CreateCondBr(IsZero, End, NotZero);
4653 Result->addIncoming(ZeroLiteral, Begin);
4656 Builder.SetInsertPoint(NotZero);
4660 Builder.CreateCondBr(IsNan, End, NotNan);
4661 Result->addIncoming(NanLiteral, NotZero);
4664 Builder.SetInsertPoint(NotNan);
4667 Builder.CreateFCmpOEQ(VAbs, ConstantFP::getInfinity(
V->getType()),
4671 Builder.CreateCondBr(IsInf, End, NotInf);
4672 Result->addIncoming(InfLiteral, NotNan);
4675 Builder.SetInsertPoint(NotInf);
4676 APFloat Smallest = APFloat::getSmallestNormalized(
4679 Builder.CreateFCmpUGE(VAbs, ConstantFP::get(
V->getContext(), Smallest),
4681 Value *NormalResult =
4685 Result->addIncoming(NormalResult, NotInf);
4698 case Builtin::BIalloca:
4699 case Builtin::BI_alloca:
4700 case Builtin::BI__builtin_alloca_uninitialized:
4701 case Builtin::BI__builtin_alloca: {
4705 const Align SuitableAlignmentInBytes =
4709 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
4710 AI->setAlignment(SuitableAlignmentInBytes);
4711 if (BuiltinID != Builtin::BI__builtin_alloca_uninitialized)
4713 if (AI->getAddressSpace() !=
4714 CGM.getContext().getTargetAddressSpace(
4716 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
4722 case Builtin::BI__builtin_alloca_with_align_uninitialized:
4723 case Builtin::BI__builtin_alloca_with_align: {
4727 unsigned AlignmentInBits = AlignmentInBitsCI->getZExtValue();
4728 const Align AlignmentInBytes =
4729 CGM.getContext().toCharUnitsFromBits(AlignmentInBits).getAsAlign();
4730 AllocaInst *AI =
Builder.CreateAlloca(
Builder.getInt8Ty(), Size);
4731 AI->setAlignment(AlignmentInBytes);
4732 if (BuiltinID != Builtin::BI__builtin_alloca_with_align_uninitialized)
4734 if (AI->getAddressSpace() !=
4735 CGM.getContext().getTargetAddressSpace(
4737 llvm::Type *Ty =
CGM.getTypes().ConvertType(E->
getType());
4743 case Builtin::BI__builtin_infer_alloc_token: {
4747 CGM.getIntrinsic(llvm::Intrinsic::alloc_token_id, {
IntPtrTy});
4748 llvm::CallBase *TokenID =
Builder.CreateCall(F, MDV);
4752 case Builtin::BIbzero:
4753 case Builtin::BI__builtin_bzero: {
4758 auto *I =
Builder.CreateMemSet(Dest,
Builder.getInt8(0), SizeVal,
false);
4763 case Builtin::BIbcopy:
4764 case Builtin::BI__builtin_bcopy: {
4774 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
4779 case Builtin::BImemcpy:
4780 case Builtin::BI__builtin_memcpy:
4781 case Builtin::BImempcpy:
4782 case Builtin::BI__builtin_mempcpy: {
4788 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
4790 if (BuiltinID == Builtin::BImempcpy ||
4791 BuiltinID == Builtin::BI__builtin_mempcpy)
4798 case Builtin::BI__builtin_memcpy_inline: {
4805 auto *I =
Builder.CreateMemCpyInline(Dest, Src, Size);
4810 case Builtin::BI__builtin_char_memchr:
4811 BuiltinID = Builtin::BI__builtin_memchr;
4814 case Builtin::BI__builtin___memcpy_chk: {
4820 llvm::APSInt Size = SizeResult.
Val.
getInt();
4821 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
4822 if (Size.ugt(DstSize))
4826 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
4827 auto *I =
Builder.CreateMemCpy(Dest, Src, SizeVal,
false);
4832 case Builtin::BI__builtin_objc_memmove_collectable: {
4836 CGM.getObjCRuntime().EmitGCMemmoveCollectable(*
this,
4837 DestAddr, SrcAddr, SizeVal);
4841 case Builtin::BI__builtin___memmove_chk: {
4847 llvm::APSInt Size = SizeResult.
Val.
getInt();
4848 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
4849 if (Size.ugt(DstSize))
4853 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
4854 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
4859 case Builtin::BI__builtin_trivially_relocate:
4860 case Builtin::BImemmove:
4861 case Builtin::BI__builtin_memmove: {
4865 if (BuiltinIDIfNoAsmLabel == Builtin::BI__builtin_trivially_relocate)
4875 auto *I =
Builder.CreateMemMove(Dest, Src, SizeVal,
false);
4879 case Builtin::BImemset:
4880 case Builtin::BI__builtin_memset: {
4887 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
4891 case Builtin::BI__builtin_memset_inline: {
4900 auto *I =
Builder.CreateMemSetInline(Dest, ByteVal, Size);
4904 case Builtin::BI__builtin___memset_chk: {
4910 llvm::APSInt Size = SizeResult.
Val.
getInt();
4911 llvm::APSInt DstSize = DstSizeResult.
Val.
getInt();
4912 if (Size.ugt(DstSize))
4917 Value *SizeVal = llvm::ConstantInt::get(
Builder.getContext(), Size);
4918 auto *I =
Builder.CreateMemSet(Dest, ByteVal, SizeVal,
false);
4922 case Builtin::BI__builtin_wmemchr: {
4933 BasicBlock *Entry =
Builder.GetInsertBlock();
4938 Builder.CreateCondBr(SizeEq0, Exit, CmpEq);
4942 StrPhi->addIncoming(Str, Entry);
4944 SizePhi->addIncoming(Size, Entry);
4947 Value *StrCh =
Builder.CreateAlignedLoad(WCharTy, StrPhi, WCharAlign);
4948 Value *FoundChr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 0);
4953 Value *NextStr =
Builder.CreateConstInBoundsGEP1_32(WCharTy, StrPhi, 1);
4955 Value *NextSizeEq0 =
4956 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
4957 Builder.CreateCondBr(NextSizeEq0, Exit, CmpEq);
4958 StrPhi->addIncoming(NextStr,
Next);
4959 SizePhi->addIncoming(NextSize,
Next);
4963 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()), Entry);
4964 Ret->addIncoming(llvm::Constant::getNullValue(Str->
getType()),
Next);
4965 Ret->addIncoming(FoundChr, CmpEq);
4968 case Builtin::BI__builtin_wmemcmp: {
4980 BasicBlock *Entry =
Builder.GetInsertBlock();
4986 Builder.CreateCondBr(SizeEq0, Exit, CmpGT);
4990 DstPhi->addIncoming(Dst, Entry);
4992 SrcPhi->addIncoming(Src, Entry);
4994 SizePhi->addIncoming(Size, Entry);
4997 Value *DstCh =
Builder.CreateAlignedLoad(WCharTy, DstPhi, WCharAlign);
4998 Value *SrcCh =
Builder.CreateAlignedLoad(WCharTy, SrcPhi, WCharAlign);
5000 Builder.CreateCondBr(DstGtSrc, Exit, CmpLT);
5007 Value *NextDst =
Builder.CreateConstInBoundsGEP1_32(WCharTy, DstPhi, 1);
5008 Value *NextSrc =
Builder.CreateConstInBoundsGEP1_32(WCharTy, SrcPhi, 1);
5010 Value *NextSizeEq0 =
5011 Builder.CreateICmpEQ(NextSize, ConstantInt::get(
SizeTy, 0));
5012 Builder.CreateCondBr(NextSizeEq0, Exit, CmpGT);
5013 DstPhi->addIncoming(NextDst,
Next);
5014 SrcPhi->addIncoming(NextSrc,
Next);
5015 SizePhi->addIncoming(NextSize,
Next);
5019 Ret->addIncoming(ConstantInt::get(
IntTy, 0), Entry);
5020 Ret->addIncoming(ConstantInt::get(
IntTy, 1), CmpGT);
5021 Ret->addIncoming(ConstantInt::getAllOnesValue(
IntTy), CmpLT);
5022 Ret->addIncoming(ConstantInt::get(
IntTy, 0),
Next);
5025 case Builtin::BI__builtin_dwarf_cfa: {
5036 Function *F =
CGM.getIntrinsic(Intrinsic::eh_dwarf_cfa);
5038 llvm::ConstantInt::get(
Int32Ty, Offset)));
5040 case Builtin::BI__builtin_return_address: {
5044 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5047 case Builtin::BI_ReturnAddress: {
5049 CGM.getIntrinsic(Intrinsic::returnaddress, {
CGM.ProgramPtrTy});
5052 case Builtin::BI__builtin_frame_address: {
5058 case Builtin::BI__builtin_stack_address: {
5062 case Builtin::BI__builtin_extract_return_addr: {
5067 case Builtin::BI__builtin_frob_return_addr: {
5072 case Builtin::BI__builtin_dwarf_sp_column: {
5073 llvm::IntegerType *Ty
5077 CGM.ErrorUnsupported(E,
"__builtin_dwarf_sp_column");
5082 case Builtin::BI__builtin_init_dwarf_reg_size_table: {
5085 CGM.ErrorUnsupported(E,
"__builtin_init_dwarf_reg_size_table");
5088 case Builtin::BI__builtin_eh_return: {
5093 assert((
IntTy->getBitWidth() == 32 ||
IntTy->getBitWidth() == 64) &&
5094 "LLVM's __builtin_eh_return only supports 32- and 64-bit variants");
5096 CGM.getIntrinsic(
IntTy->getBitWidth() == 32 ? Intrinsic::eh_return_i32
5097 : Intrinsic::eh_return_i64);
5098 Builder.CreateCall(F, {Int, Ptr});
5106 case Builtin::BI__builtin_unwind_init: {
5107 Function *F =
CGM.getIntrinsic(Intrinsic::eh_unwind_init);
5111 case Builtin::BI__builtin_extend_pointer: {
5136 case Builtin::BI__builtin_setjmp: {
5144 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5151 ConstantInt::get(
Int32Ty, 0));
5152 Builder.CreateStore(FrameAddr, Buf);
5159 Builder.CreateStore(StackAddr, StackSaveSlot);
5162 Function *F =
CGM.getIntrinsic(Intrinsic::eh_sjlj_setjmp);
5165 case Builtin::BI__builtin_longjmp: {
5169 Builder.CreateCall(
CGM.getIntrinsic(Intrinsic::eh_sjlj_longjmp), Buf);
5179 case Builtin::BI__builtin_launder: {
5184 Ptr =
Builder.CreateLaunderInvariantGroup(Ptr);
5188 case Builtin::BI__sync_fetch_and_add:
5189 case Builtin::BI__sync_fetch_and_sub:
5190 case Builtin::BI__sync_fetch_and_or:
5191 case Builtin::BI__sync_fetch_and_and:
5192 case Builtin::BI__sync_fetch_and_xor:
5193 case Builtin::BI__sync_fetch_and_nand:
5194 case Builtin::BI__sync_add_and_fetch:
5195 case Builtin::BI__sync_sub_and_fetch:
5196 case Builtin::BI__sync_and_and_fetch:
5197 case Builtin::BI__sync_or_and_fetch:
5198 case Builtin::BI__sync_xor_and_fetch:
5199 case Builtin::BI__sync_nand_and_fetch:
5200 case Builtin::BI__sync_val_compare_and_swap:
5201 case Builtin::BI__sync_bool_compare_and_swap:
5202 case Builtin::BI__sync_lock_test_and_set:
5203 case Builtin::BI__sync_lock_release:
5204 case Builtin::BI__sync_swap:
5205 llvm_unreachable(
"Shouldn't make it through sema");
5206 case Builtin::BI__sync_fetch_and_add_1:
5207 case Builtin::BI__sync_fetch_and_add_2:
5208 case Builtin::BI__sync_fetch_and_add_4:
5209 case Builtin::BI__sync_fetch_and_add_8:
5210 case Builtin::BI__sync_fetch_and_add_16:
5212 case Builtin::BI__sync_fetch_and_sub_1:
5213 case Builtin::BI__sync_fetch_and_sub_2:
5214 case Builtin::BI__sync_fetch_and_sub_4:
5215 case Builtin::BI__sync_fetch_and_sub_8:
5216 case Builtin::BI__sync_fetch_and_sub_16:
5218 case Builtin::BI__sync_fetch_and_or_1:
5219 case Builtin::BI__sync_fetch_and_or_2:
5220 case Builtin::BI__sync_fetch_and_or_4:
5221 case Builtin::BI__sync_fetch_and_or_8:
5222 case Builtin::BI__sync_fetch_and_or_16:
5224 case Builtin::BI__sync_fetch_and_and_1:
5225 case Builtin::BI__sync_fetch_and_and_2:
5226 case Builtin::BI__sync_fetch_and_and_4:
5227 case Builtin::BI__sync_fetch_and_and_8:
5228 case Builtin::BI__sync_fetch_and_and_16:
5230 case Builtin::BI__sync_fetch_and_xor_1:
5231 case Builtin::BI__sync_fetch_and_xor_2:
5232 case Builtin::BI__sync_fetch_and_xor_4:
5233 case Builtin::BI__sync_fetch_and_xor_8:
5234 case Builtin::BI__sync_fetch_and_xor_16:
5236 case Builtin::BI__sync_fetch_and_nand_1:
5237 case Builtin::BI__sync_fetch_and_nand_2:
5238 case Builtin::BI__sync_fetch_and_nand_4:
5239 case Builtin::BI__sync_fetch_and_nand_8:
5240 case Builtin::BI__sync_fetch_and_nand_16:
5244 case Builtin::BI__sync_fetch_and_min:
5246 case Builtin::BI__sync_fetch_and_max:
5248 case Builtin::BI__sync_fetch_and_umin:
5250 case Builtin::BI__sync_fetch_and_umax:
5253 case Builtin::BI__sync_add_and_fetch_1:
5254 case Builtin::BI__sync_add_and_fetch_2:
5255 case Builtin::BI__sync_add_and_fetch_4:
5256 case Builtin::BI__sync_add_and_fetch_8:
5257 case Builtin::BI__sync_add_and_fetch_16:
5259 llvm::Instruction::Add);
5260 case Builtin::BI__sync_sub_and_fetch_1:
5261 case Builtin::BI__sync_sub_and_fetch_2:
5262 case Builtin::BI__sync_sub_and_fetch_4:
5263 case Builtin::BI__sync_sub_and_fetch_8:
5264 case Builtin::BI__sync_sub_and_fetch_16:
5266 llvm::Instruction::Sub);
5267 case Builtin::BI__sync_and_and_fetch_1:
5268 case Builtin::BI__sync_and_and_fetch_2:
5269 case Builtin::BI__sync_and_and_fetch_4:
5270 case Builtin::BI__sync_and_and_fetch_8:
5271 case Builtin::BI__sync_and_and_fetch_16:
5273 llvm::Instruction::And);
5274 case Builtin::BI__sync_or_and_fetch_1:
5275 case Builtin::BI__sync_or_and_fetch_2:
5276 case Builtin::BI__sync_or_and_fetch_4:
5277 case Builtin::BI__sync_or_and_fetch_8:
5278 case Builtin::BI__sync_or_and_fetch_16:
5280 llvm::Instruction::Or);
5281 case Builtin::BI__sync_xor_and_fetch_1:
5282 case Builtin::BI__sync_xor_and_fetch_2:
5283 case Builtin::BI__sync_xor_and_fetch_4:
5284 case Builtin::BI__sync_xor_and_fetch_8:
5285 case Builtin::BI__sync_xor_and_fetch_16:
5287 llvm::Instruction::Xor);
5288 case Builtin::BI__sync_nand_and_fetch_1:
5289 case Builtin::BI__sync_nand_and_fetch_2:
5290 case Builtin::BI__sync_nand_and_fetch_4:
5291 case Builtin::BI__sync_nand_and_fetch_8:
5292 case Builtin::BI__sync_nand_and_fetch_16:
5294 llvm::Instruction::And,
true);
5296 case Builtin::BI__sync_val_compare_and_swap_1:
5297 case Builtin::BI__sync_val_compare_and_swap_2:
5298 case Builtin::BI__sync_val_compare_and_swap_4:
5299 case Builtin::BI__sync_val_compare_and_swap_8:
5300 case Builtin::BI__sync_val_compare_and_swap_16:
5302 *
this, E,
false, AtomicOrdering::SequentiallyConsistent,
5303 AtomicOrdering::SequentiallyConsistent));
5305 case Builtin::BI__sync_bool_compare_and_swap_1:
5306 case Builtin::BI__sync_bool_compare_and_swap_2:
5307 case Builtin::BI__sync_bool_compare_and_swap_4:
5308 case Builtin::BI__sync_bool_compare_and_swap_8:
5309 case Builtin::BI__sync_bool_compare_and_swap_16:
5311 *
this, E,
true, AtomicOrdering::SequentiallyConsistent,
5312 AtomicOrdering::SequentiallyConsistent));
5314 case Builtin::BI__sync_swap_1:
5315 case Builtin::BI__sync_swap_2:
5316 case Builtin::BI__sync_swap_4:
5317 case Builtin::BI__sync_swap_8:
5318 case Builtin::BI__sync_swap_16:
5321 case Builtin::BI__sync_lock_test_and_set_1:
5322 case Builtin::BI__sync_lock_test_and_set_2:
5323 case Builtin::BI__sync_lock_test_and_set_4:
5324 case Builtin::BI__sync_lock_test_and_set_8:
5325 case Builtin::BI__sync_lock_test_and_set_16:
5328 case Builtin::BI__sync_lock_release_1:
5329 case Builtin::BI__sync_lock_release_2:
5330 case Builtin::BI__sync_lock_release_4:
5331 case Builtin::BI__sync_lock_release_8:
5332 case Builtin::BI__sync_lock_release_16: {
5338 llvm::StoreInst *Store =
5339 Builder.CreateStore(llvm::Constant::getNullValue(ITy), Ptr);
5340 Store->setAtomic(llvm::AtomicOrdering::Release);
5344 case Builtin::BI__sync_synchronize: {
5352 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent);
5356 case Builtin::BI__builtin_nontemporal_load:
5358 case Builtin::BI__builtin_nontemporal_store:
5360 case Builtin::BI__c11_atomic_is_lock_free:
5361 case Builtin::BI__atomic_is_lock_free: {
5365 const char *LibCallName =
"__atomic_is_lock_free";
5369 if (BuiltinID == Builtin::BI__atomic_is_lock_free)
5376 CGM.getTypes().arrangeBuiltinFunctionCall(E->
getType(), Args);
5377 llvm::FunctionType *FTy =
CGM.getTypes().GetFunctionType(FuncInfo);
5378 llvm::FunctionCallee
Func =
CGM.CreateRuntimeFunction(FTy, LibCallName);
5383 case Builtin::BI__atomic_thread_fence:
5384 case Builtin::BI__atomic_signal_fence:
5385 case Builtin::BI__c11_atomic_thread_fence:
5386 case Builtin::BI__c11_atomic_signal_fence: {
5387 llvm::SyncScope::ID SSID;
5388 if (BuiltinID == Builtin::BI__atomic_signal_fence ||
5389 BuiltinID == Builtin::BI__c11_atomic_signal_fence)
5390 SSID = llvm::SyncScope::SingleThread;
5392 SSID = llvm::SyncScope::System;
5402 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5405 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5408 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5411 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5417 llvm::BasicBlock *AcquireBB, *ReleaseBB, *AcqRelBB, *SeqCstBB;
5424 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5425 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5427 Builder.SetInsertPoint(AcquireBB);
5428 Builder.CreateFence(llvm::AtomicOrdering::Acquire, SSID);
5430 SI->addCase(
Builder.getInt32(1), AcquireBB);
5431 SI->addCase(
Builder.getInt32(2), AcquireBB);
5433 Builder.SetInsertPoint(ReleaseBB);
5434 Builder.CreateFence(llvm::AtomicOrdering::Release, SSID);
5436 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5438 Builder.SetInsertPoint(AcqRelBB);
5439 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease, SSID);
5441 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5443 Builder.SetInsertPoint(SeqCstBB);
5444 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent, SSID);
5446 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5448 Builder.SetInsertPoint(ContBB);
5451 case Builtin::BI__scoped_atomic_thread_fence: {
5456 auto Ord = dyn_cast<llvm::ConstantInt>(Order);
5457 auto Scp = dyn_cast<llvm::ConstantInt>(
Scope);
5459 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5460 ? ScopeModel->map(Scp->getZExtValue())
5461 : ScopeModel->map(ScopeModel->getFallBackValue());
5462 switch (Ord->getZExtValue()) {
5469 llvm::AtomicOrdering::Acquire,
5471 llvm::AtomicOrdering::Acquire,
5476 llvm::AtomicOrdering::Release,
5478 llvm::AtomicOrdering::Release,
5482 Builder.CreateFence(llvm::AtomicOrdering::AcquireRelease,
5485 llvm::AtomicOrdering::AcquireRelease,
5489 Builder.CreateFence(llvm::AtomicOrdering::SequentiallyConsistent,
5492 llvm::AtomicOrdering::SequentiallyConsistent,
5504 switch (Ord->getZExtValue()) {
5507 ContBB->eraseFromParent();
5511 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5512 llvm::AtomicOrdering::Acquire);
5515 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5516 llvm::AtomicOrdering::Release);
5519 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5520 llvm::AtomicOrdering::AcquireRelease);
5523 OrderBBs.emplace_back(
Builder.GetInsertBlock(),
5524 llvm::AtomicOrdering::SequentiallyConsistent);
5533 Order =
Builder.CreateIntCast(Order,
Builder.getInt32Ty(),
false);
5534 llvm::SwitchInst *SI =
Builder.CreateSwitch(Order, ContBB);
5535 SI->addCase(
Builder.getInt32(1), AcquireBB);
5536 SI->addCase(
Builder.getInt32(2), AcquireBB);
5537 SI->addCase(
Builder.getInt32(3), ReleaseBB);
5538 SI->addCase(
Builder.getInt32(4), AcqRelBB);
5539 SI->addCase(
Builder.getInt32(5), SeqCstBB);
5541 OrderBBs.emplace_back(AcquireBB, llvm::AtomicOrdering::Acquire);
5542 OrderBBs.emplace_back(ReleaseBB, llvm::AtomicOrdering::Release);
5543 OrderBBs.emplace_back(AcqRelBB, llvm::AtomicOrdering::AcquireRelease);
5544 OrderBBs.emplace_back(SeqCstBB,
5545 llvm::AtomicOrdering::SequentiallyConsistent);
5548 for (
auto &[OrderBB, Ordering] : OrderBBs) {
5549 Builder.SetInsertPoint(OrderBB);
5551 SyncScope SS = ScopeModel->isValid(Scp->getZExtValue())
5552 ? ScopeModel->map(Scp->getZExtValue())
5553 : ScopeModel->map(ScopeModel->getFallBackValue());
5559 llvm::DenseMap<unsigned, llvm::BasicBlock *> BBs;
5560 for (
unsigned Scp : ScopeModel->getRuntimeValues())
5564 llvm::SwitchInst *SI =
Builder.CreateSwitch(SC, ContBB);
5565 for (
unsigned Scp : ScopeModel->getRuntimeValues()) {
5567 SI->addCase(
Builder.getInt32(Scp), B);
5578 Builder.SetInsertPoint(ContBB);
5582 case Builtin::BI__builtin_signbit:
5583 case Builtin::BI__builtin_signbitf:
5584 case Builtin::BI__builtin_signbitl: {
5589 case Builtin::BI__warn_memset_zero_len:
5591 case Builtin::BI__annotation: {
5596 assert(Str->getCharByteWidth() == 2 || Str->getCharByteWidth() == 4);
5597 StringRef WideBytes = Str->getBytes();
5598 std::string StrUtf8;
5600 (Str->getCharByteWidth() == 2)
5601 ? convertUTF16ToUTF8String(
5602 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8)
5603 : convertUTF32ToUTF8String(
5604 ArrayRef(WideBytes.data(), WideBytes.size()), StrUtf8);
5606 CGM.ErrorUnsupported(E,
"non-Unicode __annotation argument");
5609 Strings.push_back(llvm::MDString::get(
getLLVMContext(), StrUtf8));
5613 llvm::Function *F =
CGM.getIntrinsic(Intrinsic::codeview_annotation, {});
5618 case Builtin::BI__builtin_annotation: {
5620 llvm::Function *F =
CGM.getIntrinsic(
5621 Intrinsic::annotation, {AnnVal->getType(),
CGM.ConstGlobalsPtrTy});
5630 case Builtin::BI__builtin_addcb:
5631 case Builtin::BI__builtin_addcs:
5632 case Builtin::BI__builtin_addc:
5633 case Builtin::BI__builtin_addcl:
5634 case Builtin::BI__builtin_addcll:
5635 case Builtin::BI__builtin_subcb:
5636 case Builtin::BI__builtin_subcs:
5637 case Builtin::BI__builtin_subc:
5638 case Builtin::BI__builtin_subcl:
5639 case Builtin::BI__builtin_subcll: {
5665 Intrinsic::ID IntrinsicId;
5666 switch (BuiltinID) {
5667 default: llvm_unreachable(
"Unknown multiprecision builtin id.");
5668 case Builtin::BI__builtin_addcb:
5669 case Builtin::BI__builtin_addcs:
5670 case Builtin::BI__builtin_addc:
5671 case Builtin::BI__builtin_addcl:
5672 case Builtin::BI__builtin_addcll:
5673 IntrinsicId = Intrinsic::uadd_with_overflow;
5675 case Builtin::BI__builtin_subcb:
5676 case Builtin::BI__builtin_subcs:
5677 case Builtin::BI__builtin_subc:
5678 case Builtin::BI__builtin_subcl:
5679 case Builtin::BI__builtin_subcll:
5680 IntrinsicId = Intrinsic::usub_with_overflow;
5685 llvm::Value *Carry1;
5688 llvm::Value *Carry2;
5690 Sum1, Carryin, Carry2);
5691 llvm::Value *CarryOut =
Builder.CreateZExt(
Builder.CreateOr(Carry1, Carry2),
5693 Builder.CreateStore(CarryOut, CarryOutPtr);
5697 case Builtin::BI__builtin_add_overflow:
5698 case Builtin::BI__builtin_sub_overflow:
5699 case Builtin::BI__builtin_mul_overflow: {
5707 WidthAndSignedness LeftInfo =
5709 WidthAndSignedness RightInfo =
5711 WidthAndSignedness ResultInfo =
5718 RightInfo, ResultArg, ResultQTy,
5724 *
this, LeftArg, LeftInfo, RightArg, RightInfo, ResultArg, ResultQTy,
5727 WidthAndSignedness EncompassingInfo =
5730 llvm::Type *EncompassingLLVMTy =
5731 llvm::IntegerType::get(
CGM.getLLVMContext(), EncompassingInfo.Width);
5733 llvm::Type *ResultLLVMTy =
CGM.getTypes().ConvertType(ResultQTy);
5735 Intrinsic::ID IntrinsicId;
5736 switch (BuiltinID) {
5738 llvm_unreachable(
"Unknown overflow builtin id.");
5739 case Builtin::BI__builtin_add_overflow:
5740 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::sadd_with_overflow
5741 : Intrinsic::uadd_with_overflow;
5743 case Builtin::BI__builtin_sub_overflow:
5744 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::ssub_with_overflow
5745 : Intrinsic::usub_with_overflow;
5747 case Builtin::BI__builtin_mul_overflow:
5748 IntrinsicId = EncompassingInfo.Signed ? Intrinsic::smul_with_overflow
5749 : Intrinsic::umul_with_overflow;
5758 Left =
Builder.CreateIntCast(Left, EncompassingLLVMTy, LeftInfo.Signed);
5759 Right =
Builder.CreateIntCast(Right, EncompassingLLVMTy, RightInfo.Signed);
5762 llvm::Value *Overflow, *
Result;
5765 if (EncompassingInfo.Width > ResultInfo.Width) {
5768 llvm::Value *ResultTrunc =
Builder.CreateTrunc(
Result, ResultLLVMTy);
5772 llvm::Value *ResultTruncExt =
Builder.CreateIntCast(
5773 ResultTrunc, EncompassingLLVMTy, ResultInfo.Signed);
5774 llvm::Value *TruncationOverflow =
5777 Overflow =
Builder.CreateOr(Overflow, TruncationOverflow);
5789 case Builtin::BI__builtin_uadd_overflow:
5790 case Builtin::BI__builtin_uaddl_overflow:
5791 case Builtin::BI__builtin_uaddll_overflow:
5792 case Builtin::BI__builtin_usub_overflow:
5793 case Builtin::BI__builtin_usubl_overflow:
5794 case Builtin::BI__builtin_usubll_overflow:
5795 case Builtin::BI__builtin_umul_overflow:
5796 case Builtin::BI__builtin_umull_overflow:
5797 case Builtin::BI__builtin_umulll_overflow:
5798 case Builtin::BI__builtin_sadd_overflow:
5799 case Builtin::BI__builtin_saddl_overflow:
5800 case Builtin::BI__builtin_saddll_overflow:
5801 case Builtin::BI__builtin_ssub_overflow:
5802 case Builtin::BI__builtin_ssubl_overflow:
5803 case Builtin::BI__builtin_ssubll_overflow:
5804 case Builtin::BI__builtin_smul_overflow:
5805 case Builtin::BI__builtin_smull_overflow:
5806 case Builtin::BI__builtin_smulll_overflow: {
5816 Intrinsic::ID IntrinsicId;
5817 switch (BuiltinID) {
5818 default: llvm_unreachable(
"Unknown overflow builtin id.");
5819 case Builtin::BI__builtin_uadd_overflow:
5820 case Builtin::BI__builtin_uaddl_overflow:
5821 case Builtin::BI__builtin_uaddll_overflow:
5822 IntrinsicId = Intrinsic::uadd_with_overflow;
5824 case Builtin::BI__builtin_usub_overflow:
5825 case Builtin::BI__builtin_usubl_overflow:
5826 case Builtin::BI__builtin_usubll_overflow:
5827 IntrinsicId = Intrinsic::usub_with_overflow;
5829 case Builtin::BI__builtin_umul_overflow:
5830 case Builtin::BI__builtin_umull_overflow:
5831 case Builtin::BI__builtin_umulll_overflow:
5832 IntrinsicId = Intrinsic::umul_with_overflow;
5834 case Builtin::BI__builtin_sadd_overflow:
5835 case Builtin::BI__builtin_saddl_overflow:
5836 case Builtin::BI__builtin_saddll_overflow:
5837 IntrinsicId = Intrinsic::sadd_with_overflow;
5839 case Builtin::BI__builtin_ssub_overflow:
5840 case Builtin::BI__builtin_ssubl_overflow:
5841 case Builtin::BI__builtin_ssubll_overflow:
5842 IntrinsicId = Intrinsic::ssub_with_overflow;
5844 case Builtin::BI__builtin_smul_overflow:
5845 case Builtin::BI__builtin_smull_overflow:
5846 case Builtin::BI__builtin_smulll_overflow:
5847 IntrinsicId = Intrinsic::smul_with_overflow;
5854 Builder.CreateStore(Sum, SumOutPtr);
5858 case Builtin::BIaddressof:
5859 case Builtin::BI__addressof:
5860 case Builtin::BI__builtin_addressof:
5862 case Builtin::BI__builtin_function_start:
5865 case Builtin::BI__builtin_operator_new:
5868 case Builtin::BI__builtin_operator_delete:
5873 case Builtin::BI__builtin_is_aligned:
5875 case Builtin::BI__builtin_align_up:
5877 case Builtin::BI__builtin_align_down:
5880 case Builtin::BI__noop:
5883 case Builtin::BI__builtin_call_with_static_chain: {
5890 case Builtin::BI_InterlockedExchange8:
5891 case Builtin::BI_InterlockedExchange16:
5892 case Builtin::BI_InterlockedExchange:
5893 case Builtin::BI_InterlockedExchangePointer:
5896 case Builtin::BI_InterlockedCompareExchangePointer:
5899 case Builtin::BI_InterlockedCompareExchangePointer_nf:
5902 case Builtin::BI_InterlockedCompareExchange8:
5903 case Builtin::BI_InterlockedCompareExchange16:
5904 case Builtin::BI_InterlockedCompareExchange:
5905 case Builtin::BI_InterlockedCompareExchange64:
5907 case Builtin::BI_InterlockedIncrement16:
5908 case Builtin::BI_InterlockedIncrement:
5911 case Builtin::BI_InterlockedDecrement16:
5912 case Builtin::BI_InterlockedDecrement:
5915 case Builtin::BI_InterlockedAnd8:
5916 case Builtin::BI_InterlockedAnd16:
5917 case Builtin::BI_InterlockedAnd:
5919 case Builtin::BI_InterlockedExchangeAdd8:
5920 case Builtin::BI_InterlockedExchangeAdd16:
5921 case Builtin::BI_InterlockedExchangeAdd:
5924 case Builtin::BI_InterlockedExchangeSub8:
5925 case Builtin::BI_InterlockedExchangeSub16:
5926 case Builtin::BI_InterlockedExchangeSub:
5929 case Builtin::BI_InterlockedOr8:
5930 case Builtin::BI_InterlockedOr16:
5931 case Builtin::BI_InterlockedOr:
5933 case Builtin::BI_InterlockedXor8:
5934 case Builtin::BI_InterlockedXor16:
5935 case Builtin::BI_InterlockedXor:
5938 case Builtin::BI_bittest64:
5939 case Builtin::BI_bittest:
5940 case Builtin::BI_bittestandcomplement64:
5941 case Builtin::BI_bittestandcomplement:
5942 case Builtin::BI_bittestandreset64:
5943 case Builtin::BI_bittestandreset:
5944 case Builtin::BI_bittestandset64:
5945 case Builtin::BI_bittestandset:
5946 case Builtin::BI_interlockedbittestandreset:
5947 case Builtin::BI_interlockedbittestandreset64:
5948 case Builtin::BI_interlockedbittestandreset64_acq:
5949 case Builtin::BI_interlockedbittestandreset64_rel:
5950 case Builtin::BI_interlockedbittestandreset64_nf:
5951 case Builtin::BI_interlockedbittestandset64:
5952 case Builtin::BI_interlockedbittestandset64_acq:
5953 case Builtin::BI_interlockedbittestandset64_rel:
5954 case Builtin::BI_interlockedbittestandset64_nf:
5955 case Builtin::BI_interlockedbittestandset:
5956 case Builtin::BI_interlockedbittestandset_acq:
5957 case Builtin::BI_interlockedbittestandset_rel:
5958 case Builtin::BI_interlockedbittestandset_nf:
5959 case Builtin::BI_interlockedbittestandreset_acq:
5960 case Builtin::BI_interlockedbittestandreset_rel:
5961 case Builtin::BI_interlockedbittestandreset_nf:
5966 case Builtin::BI__iso_volatile_load8:
5967 case Builtin::BI__iso_volatile_load16:
5968 case Builtin::BI__iso_volatile_load32:
5969 case Builtin::BI__iso_volatile_load64:
5971 case Builtin::BI__iso_volatile_store8:
5972 case Builtin::BI__iso_volatile_store16:
5973 case Builtin::BI__iso_volatile_store32:
5974 case Builtin::BI__iso_volatile_store64:
5977 case Builtin::BI__builtin_ptrauth_sign_constant:
5980 case Builtin::BI__builtin_ptrauth_auth:
5981 case Builtin::BI__builtin_ptrauth_auth_and_resign:
5982 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
5983 case Builtin::BI__builtin_ptrauth_blend_discriminator:
5984 case Builtin::BI__builtin_ptrauth_sign_generic_data:
5985 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
5986 case Builtin::BI__builtin_ptrauth_strip: {
5993 llvm::Type *OrigValueType = Args[0]->getType();
5994 if (OrigValueType->isPointerTy())
5997 switch (BuiltinID) {
5998 case Builtin::BI__builtin_ptrauth_auth_and_resign:
5999 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6000 if (Args[4]->
getType()->isPointerTy())
6004 case Builtin::BI__builtin_ptrauth_auth:
6005 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6006 if (Args[2]->
getType()->isPointerTy())
6010 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6011 if (Args[1]->
getType()->isPointerTy())
6015 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6016 case Builtin::BI__builtin_ptrauth_strip:
6021 auto IntrinsicID = [&]() ->
unsigned {
6022 switch (BuiltinID) {
6023 case Builtin::BI__builtin_ptrauth_auth:
6024 return Intrinsic::ptrauth_auth;
6025 case Builtin::BI__builtin_ptrauth_auth_and_resign:
6026 return Intrinsic::ptrauth_resign;
6027 case Builtin::BI__builtin_ptrauth_auth_load_relative_and_sign:
6028 return Intrinsic::ptrauth_resign_load_relative;
6029 case Builtin::BI__builtin_ptrauth_blend_discriminator:
6030 return Intrinsic::ptrauth_blend;
6031 case Builtin::BI__builtin_ptrauth_sign_generic_data:
6032 return Intrinsic::ptrauth_sign_generic;
6033 case Builtin::BI__builtin_ptrauth_sign_unauthenticated:
6034 return Intrinsic::ptrauth_sign;
6035 case Builtin::BI__builtin_ptrauth_strip:
6036 return Intrinsic::ptrauth_strip;
6038 llvm_unreachable(
"bad ptrauth intrinsic");
6040 auto Intrinsic =
CGM.getIntrinsic(IntrinsicID);
6043 if (BuiltinID != Builtin::BI__builtin_ptrauth_sign_generic_data &&
6044 BuiltinID != Builtin::BI__builtin_ptrauth_blend_discriminator &&
6045 OrigValueType->isPointerTy()) {
6051 case Builtin::BI__builtin_get_vtable_pointer: {
6057 assert(ThisAddress.isValid());
6058 llvm::Value *VTablePointer =
6063 case Builtin::BI__exception_code:
6064 case Builtin::BI_exception_code:
6066 case Builtin::BI__exception_info:
6067 case Builtin::BI_exception_info:
6069 case Builtin::BI__abnormal_termination:
6070 case Builtin::BI_abnormal_termination:
6072 case Builtin::BI_setjmpex:
6077 case Builtin::BI_setjmp:
6089 case Builtin::BImove:
6090 case Builtin::BImove_if_noexcept:
6091 case Builtin::BIforward:
6092 case Builtin::BIforward_like:
6093 case Builtin::BIas_const:
6095 case Builtin::BI__GetExceptionInfo: {
6096 if (llvm::GlobalVariable *GV =
6102 case Builtin::BI__fastfail:
6105 case Builtin::BI__builtin_coro_id:
6107 case Builtin::BI__builtin_coro_promise:
6109 case Builtin::BI__builtin_coro_resume:
6112 case Builtin::BI__builtin_coro_frame:
6114 case Builtin::BI__builtin_coro_noop:
6116 case Builtin::BI__builtin_coro_free:
6118 case Builtin::BI__builtin_coro_destroy:
6121 case Builtin::BI__builtin_coro_done:
6123 case Builtin::BI__builtin_coro_alloc:
6125 case Builtin::BI__builtin_coro_begin:
6127 case Builtin::BI__builtin_coro_end:
6129 case Builtin::BI__builtin_coro_suspend:
6131 case Builtin::BI__builtin_coro_size:
6133 case Builtin::BI__builtin_coro_align:
6137 case Builtin::BIread_pipe:
6138 case Builtin::BIwrite_pipe: {
6146 unsigned GenericAS =
6148 llvm::Type *I8PTy = llvm::PointerType::get(
getLLVMContext(), GenericAS);
6152 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_2"
6157 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6158 Value *ACast =
Builder.CreateAddrSpaceCast(Arg1, I8PTy);
6161 {Arg0, ACast, PacketSize, PacketAlign}));
6164 "Illegal number of parameters to pipe function");
6165 const char *Name = (BuiltinID == Builtin::BIread_pipe) ?
"__read_pipe_4"
6168 llvm::Type *ArgTys[] = {Arg0->
getType(), Arg1->getType(),
Int32Ty, I8PTy,
6172 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6173 Value *ACast =
Builder.CreateAddrSpaceCast(Arg3, I8PTy);
6180 {Arg0, Arg1, Arg2, ACast, PacketSize, PacketAlign}));
6185 case Builtin::BIreserve_read_pipe:
6186 case Builtin::BIreserve_write_pipe:
6187 case Builtin::BIwork_group_reserve_read_pipe:
6188 case Builtin::BIwork_group_reserve_write_pipe:
6189 case Builtin::BIsub_group_reserve_read_pipe:
6190 case Builtin::BIsub_group_reserve_write_pipe: {
6193 if (BuiltinID == Builtin::BIreserve_read_pipe)
6194 Name =
"__reserve_read_pipe";
6195 else if (BuiltinID == Builtin::BIreserve_write_pipe)
6196 Name =
"__reserve_write_pipe";
6197 else if (BuiltinID == Builtin::BIwork_group_reserve_read_pipe)
6198 Name =
"__work_group_reserve_read_pipe";
6199 else if (BuiltinID == Builtin::BIwork_group_reserve_write_pipe)
6200 Name =
"__work_group_reserve_write_pipe";
6201 else if (BuiltinID == Builtin::BIsub_group_reserve_read_pipe)
6202 Name =
"__sub_group_reserve_read_pipe";
6204 Name =
"__sub_group_reserve_write_pipe";
6215 llvm::FunctionType *FTy =
6216 llvm::FunctionType::get(ReservedIDTy, ArgTys,
false);
6219 if (Arg1->getType() !=
Int32Ty)
6222 {Arg0, Arg1, PacketSize, PacketAlign}));
6226 case Builtin::BIcommit_read_pipe:
6227 case Builtin::BIcommit_write_pipe:
6228 case Builtin::BIwork_group_commit_read_pipe:
6229 case Builtin::BIwork_group_commit_write_pipe:
6230 case Builtin::BIsub_group_commit_read_pipe:
6231 case Builtin::BIsub_group_commit_write_pipe: {
6233 if (BuiltinID == Builtin::BIcommit_read_pipe)
6234 Name =
"__commit_read_pipe";
6235 else if (BuiltinID == Builtin::BIcommit_write_pipe)
6236 Name =
"__commit_write_pipe";
6237 else if (BuiltinID == Builtin::BIwork_group_commit_read_pipe)
6238 Name =
"__work_group_commit_read_pipe";
6239 else if (BuiltinID == Builtin::BIwork_group_commit_write_pipe)
6240 Name =
"__work_group_commit_write_pipe";
6241 else if (BuiltinID == Builtin::BIsub_group_commit_read_pipe)
6242 Name =
"__sub_group_commit_read_pipe";
6244 Name =
"__sub_group_commit_write_pipe";
6254 llvm::FunctionType *FTy = llvm::FunctionType::get(
6258 {Arg0, Arg1, PacketSize, PacketAlign}));
6261 case Builtin::BIget_pipe_num_packets:
6262 case Builtin::BIget_pipe_max_packets: {
6263 const char *BaseName;
6265 if (BuiltinID == Builtin::BIget_pipe_num_packets)
6266 BaseName =
"__get_pipe_num_packets";
6268 BaseName =
"__get_pipe_max_packets";
6269 std::string Name = std::string(BaseName) +
6270 std::string(PipeTy->isReadOnly() ?
"_ro" :
"_wo");
6278 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6281 {Arg0, PacketSize, PacketAlign}));
6285 case Builtin::BIto_global:
6286 case Builtin::BIto_local:
6287 case Builtin::BIto_private: {
6289 auto NewArgT = llvm::PointerType::get(
6292 auto NewRetT = llvm::PointerType::get(
6294 CGM.getContext().getTargetAddressSpace(
6296 auto FTy = llvm::FunctionType::get(NewRetT, {NewArgT},
false);
6297 llvm::Value *NewArg;
6298 if (Arg0->getType()->getPointerAddressSpace() !=
6299 NewArgT->getPointerAddressSpace())
6300 NewArg =
Builder.CreateAddrSpaceCast(Arg0, NewArgT);
6302 NewArg =
Builder.CreateBitOrPointerCast(Arg0, NewArgT);
6318 case Builtin::BIenqueue_kernel: {
6323 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6340 Range = Range->stripPointerCasts();
6342 llvm::Type *RangePtrTy = Range->getType();
6347 Name =
"__enqueue_kernel_basic";
6348 llvm::Type *ArgTys[] = {QueueTy,
Int32Ty, RangePtrTy, GenericVoidPtrTy,
6350 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6353 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6355 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6356 llvm::Value *
Block =
6357 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6360 {Queue, Flags, Range, Kernel, Block});
6363 assert(NumArgs >= 5 &&
"Invalid enqueue_kernel signature");
6367 auto CreateArrayForSizeVar =
6368 [=](
unsigned First) -> std::pair<llvm::Value *, llvm::Value *> {
6369 llvm::APInt ArraySize(32, NumArgs -
First);
6371 getContext().getSizeType(), ArraySize,
nullptr,
6375 llvm::Value *TmpPtr = Tmp.getPointer();
6380 llvm::Value *Alloca = TmpPtr->stripPointerCasts();
6381 llvm::Value *ElemPtr;
6385 auto *
Zero = llvm::ConstantInt::get(
IntTy, 0);
6386 for (
unsigned I =
First; I < NumArgs; ++I) {
6387 auto *Index = llvm::ConstantInt::get(
IntTy, I -
First);
6389 Builder.CreateGEP(Tmp.getElementType(), Alloca, {Zero, Index});
6395 V, GEP,
CGM.getDataLayout().getPrefTypeAlign(
SizeTy));
6399 return {ElemPtr, Alloca};
6405 Name =
"__enqueue_kernel_varargs";
6407 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(3));
6409 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6410 auto *
Block =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6411 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(4);
6415 llvm::Value *
const Args[] = {Queue, Flags,
6419 llvm::Type *
const ArgTys[] = {
6420 QueueTy,
IntTy, RangePtrTy, GenericVoidPtrTy,
6421 GenericVoidPtrTy,
IntTy, ElemPtr->getType()};
6423 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6431 llvm::PointerType *PtrTy = llvm::PointerType::get(
6432 CGM.getLLVMContext(),
6435 llvm::Value *NumEvents =
6441 llvm::Value *EventWaitList =
nullptr;
6444 EventWaitList = llvm::ConstantPointerNull::get(PtrTy);
6451 EventWaitList =
Builder.CreatePointerCast(EventWaitList, PtrTy);
6453 llvm::Value *EventRet =
nullptr;
6456 EventRet = llvm::ConstantPointerNull::get(PtrTy);
6463 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(6));
6465 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6466 llvm::Value *
Block =
6467 Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6469 std::vector<llvm::Type *> ArgTys = {
6471 PtrTy, PtrTy, GenericVoidPtrTy, GenericVoidPtrTy};
6473 std::vector<llvm::Value *> Args = {Queue, Flags, Range,
6474 NumEvents, EventWaitList, EventRet,
6479 Name =
"__enqueue_kernel_basic_events";
6480 llvm::FunctionType *FTy =
6481 llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6487 Args.push_back(ConstantInt::get(
Int32Ty, NumArgs - 7));
6489 Name =
"__enqueue_kernel_events_varargs";
6491 auto [ElemPtr, TmpPtr] = CreateArrayForSizeVar(7);
6492 Args.push_back(ElemPtr);
6493 ArgTys.push_back(ElemPtr->getType());
6495 llvm::FunctionType *FTy = llvm::FunctionType::get(
Int32Ty, ArgTys,
false);
6501 llvm_unreachable(
"Unexpected enqueue_kernel signature");
6505 case Builtin::BIget_kernel_work_group_size: {
6506 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6509 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6511 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6512 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6514 CGM.CreateRuntimeFunction(
6515 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6517 "__get_kernel_work_group_size_impl"),
6520 case Builtin::BIget_kernel_preferred_work_group_size_multiple: {
6521 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6524 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(0));
6526 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6527 Value *Arg =
Builder.CreatePointerCast(Info.BlockArg, GenericVoidPtrTy);
6529 CGM.CreateRuntimeFunction(
6530 llvm::FunctionType::get(
IntTy, {GenericVoidPtrTy, GenericVoidPtrTy},
6532 "__get_kernel_preferred_work_group_size_multiple_impl"),
6535 case Builtin::BIget_kernel_max_sub_group_size_for_ndrange:
6536 case Builtin::BIget_kernel_sub_group_count_for_ndrange: {
6537 llvm::Type *GenericVoidPtrTy =
Builder.getPtrTy(
6542 CGM.getOpenCLRuntime().emitOpenCLEnqueuedBlock(*
this, E->
getArg(1));
6544 Builder.CreatePointerCast(Info.KernelHandle, GenericVoidPtrTy);
6547 BuiltinID == Builtin::BIget_kernel_max_sub_group_size_for_ndrange
6548 ?
"__get_kernel_max_sub_group_size_for_ndrange_impl"
6549 :
"__get_kernel_sub_group_count_for_ndrange_impl";
6551 CGM.CreateRuntimeFunction(
6552 llvm::FunctionType::get(
6553 IntTy, {NDRange->getType(), GenericVoidPtrTy, GenericVoidPtrTy},
6556 {NDRange, Kernel, Block}));
6558 case Builtin::BI__builtin_store_half:
6559 case Builtin::BI__builtin_store_halff: {
6567 case Builtin::BI__builtin_load_half: {
6572 case Builtin::BI__builtin_load_halff: {
6577 case Builtin::BI__builtin_printf:
6578 case Builtin::BIprintf:
6592 case Builtin::BI__builtin_canonicalize:
6593 case Builtin::BI__builtin_canonicalizef:
6594 case Builtin::BI__builtin_canonicalizef16:
6595 case Builtin::BI__builtin_canonicalizel:
6599 case Builtin::BI__builtin_thread_pointer: {
6600 if (!
getContext().getTargetInfo().isTLSSupported())
6601 CGM.ErrorUnsupported(E,
"__builtin_thread_pointer");
6604 {GlobalsInt8PtrTy}, {}));
6606 case Builtin::BI__builtin_os_log_format:
6609 case Builtin::BI__xray_customevent: {
6613 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6617 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6621 Function *F =
CGM.getIntrinsic(Intrinsic::xray_customevent);
6622 auto FTy = F->getFunctionType();
6623 auto Arg0 = E->
getArg(0);
6625 auto Arg0Ty = Arg0->getType();
6626 auto PTy0 = FTy->getParamType(0);
6627 if (PTy0 != Arg0Val->getType()) {
6628 if (Arg0Ty->isArrayType())
6631 Arg0Val =
Builder.CreatePointerCast(Arg0Val, PTy0);
6634 auto PTy1 = FTy->getParamType(1);
6635 if (PTy1 != Arg1->getType())
6636 Arg1 =
Builder.CreateTruncOrBitCast(Arg1, PTy1);
6640 case Builtin::BI__xray_typedevent: {
6647 if (!
CGM.getCodeGenOpts().XRayInstrumentationBundle.has(
6651 if (
const auto *XRayAttr =
CurFuncDecl->getAttr<XRayInstrumentAttr>())
6655 Function *F =
CGM.getIntrinsic(Intrinsic::xray_typedevent);
6656 auto FTy = F->getFunctionType();
6658 auto PTy0 = FTy->getParamType(0);
6659 if (PTy0 != Arg0->getType())
6660 Arg0 =
Builder.CreateTruncOrBitCast(Arg0, PTy0);
6661 auto Arg1 = E->
getArg(1);
6663 auto Arg1Ty = Arg1->getType();
6664 auto PTy1 = FTy->getParamType(1);
6665 if (PTy1 != Arg1Val->getType()) {
6666 if (Arg1Ty->isArrayType())
6669 Arg1Val =
Builder.CreatePointerCast(Arg1Val, PTy1);
6672 auto PTy2 = FTy->getParamType(2);
6673 if (PTy2 != Arg2->getType())
6674 Arg2 =
Builder.CreateTruncOrBitCast(Arg2, PTy2);
6678 case Builtin::BI__builtin_ms_va_start:
6679 case Builtin::BI__builtin_ms_va_end:
6682 BuiltinID == Builtin::BI__builtin_ms_va_start));
6684 case Builtin::BI__builtin_ms_va_copy: {
6701 case Builtin::BI__builtin_get_device_side_mangled_name: {
6702 auto Name =
CGM.getCUDARuntime().getDeviceSideName(
6704 auto Str =
CGM.GetAddrOfConstantCString(Name,
"");
6714 BI.isLibFunction(BuiltinID))
6716 CGM.getBuiltinLibFunction(FD, BuiltinID));
6720 if (BI.isPredefinedLibFunction(BuiltinID))
6730 if (
unsigned VectorWidth =
getContext().BuiltinInfo.getRequiredVectorWidth(BuiltinID))
6731 LargestVectorWidth = std::max(LargestVectorWidth, VectorWidth);
6735 Intrinsic::ID IntrinsicID = Intrinsic::not_intrinsic;
6738 if (!Prefix.empty()) {
6739 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(Prefix.data(), Name);
6740 if (IntrinsicID == Intrinsic::not_intrinsic && Prefix ==
"spv" &&
6742 IntrinsicID = Intrinsic::getIntrinsicForClangBuiltin(
"amdgcn", Name);
6746 if (IntrinsicID == Intrinsic::not_intrinsic)
6747 IntrinsicID = Intrinsic::getIntrinsicForMSBuiltin(Prefix.data(), Name);
6750 if (IntrinsicID != Intrinsic::not_intrinsic) {
6755 unsigned ICEArguments = 0;
6761 llvm::FunctionType *FTy = F->getFunctionType();
6763 for (
unsigned i = 0, e = E->
getNumArgs(); i != e; ++i) {
6767 llvm::Type *PTy = FTy->getParamType(i);
6768 if (PTy != ArgValue->
getType()) {
6770 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(PTy)) {
6771 if (PtrTy->getAddressSpace() !=
6772 ArgValue->
getType()->getPointerAddressSpace()) {
6773 ArgValue =
Builder.CreateAddrSpaceCast(
6775 PtrTy->getAddressSpace()));
6781 if (PTy->isX86_AMXTy())
6782 ArgValue =
Builder.CreateIntrinsic(Intrinsic::x86_cast_vector_to_tile,
6783 {ArgValue->
getType()}, {ArgValue});
6785 ArgValue =
Builder.CreateBitCast(ArgValue, PTy);
6788 Args.push_back(ArgValue);
6794 llvm::Type *RetTy =
VoidTy;
6798 if (RetTy !=
V->getType()) {
6800 if (
auto *PtrTy = dyn_cast<llvm::PointerType>(RetTy)) {
6801 if (PtrTy->getAddressSpace() !=
V->getType()->getPointerAddressSpace()) {
6804 PtrTy->getAddressSpace()));
6810 if (
V->getType()->isX86_AMXTy())
6811 V =
Builder.CreateIntrinsic(Intrinsic::x86_cast_tile_to_vector, {RetTy},
6817 if (RetTy->isVoidTy())
6837 if (
V->getType()->isVoidTy())
6844 llvm_unreachable(
"No current target builtin returns complex");
6846 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");
6853 if (
V->getType()->isVoidTy())
6860 llvm_unreachable(
"No current hlsl builtin returns complex");
6862 llvm_unreachable(
"Bad evaluation kind in EmitBuiltinExpr");