577 llvm::StringMap<bool> FunctionFeatureMap;
578 Context.getFunctionFeatureMap(FunctionFeatureMap, FD);
581 StringRef FeaturesStr = A->getFeaturesStr();
583 FeaturesStr.split(RequiredFeatures,
',');
584 for (
auto RF : RequiredFeatures)
585 if (!TI.
hasFeature(RF) && !FunctionFeatureMap.lookup(RF))
587 diag::err_riscv_builtin_requires_extension)
596 case RISCVVector::BI__builtin_rvv_vmulhsu_vv:
597 case RISCVVector::BI__builtin_rvv_vmulhsu_vx:
598 case RISCVVector::BI__builtin_rvv_vmulhsu_vv_tu:
599 case RISCVVector::BI__builtin_rvv_vmulhsu_vx_tu:
600 case RISCVVector::BI__builtin_rvv_vmulhsu_vv_m:
601 case RISCVVector::BI__builtin_rvv_vmulhsu_vx_m:
602 case RISCVVector::BI__builtin_rvv_vmulhsu_vv_mu:
603 case RISCVVector::BI__builtin_rvv_vmulhsu_vx_mu:
604 case RISCVVector::BI__builtin_rvv_vmulhsu_vv_tum:
605 case RISCVVector::BI__builtin_rvv_vmulhsu_vx_tum:
606 case RISCVVector::BI__builtin_rvv_vmulhsu_vv_tumu:
607 case RISCVVector::BI__builtin_rvv_vmulhsu_vx_tumu:
608 case RISCVVector::BI__builtin_rvv_vmulhu_vv:
609 case RISCVVector::BI__builtin_rvv_vmulhu_vx:
610 case RISCVVector::BI__builtin_rvv_vmulhu_vv_tu:
611 case RISCVVector::BI__builtin_rvv_vmulhu_vx_tu:
612 case RISCVVector::BI__builtin_rvv_vmulhu_vv_m:
613 case RISCVVector::BI__builtin_rvv_vmulhu_vx_m:
614 case RISCVVector::BI__builtin_rvv_vmulhu_vv_mu:
615 case RISCVVector::BI__builtin_rvv_vmulhu_vx_mu:
616 case RISCVVector::BI__builtin_rvv_vmulhu_vv_tum:
617 case RISCVVector::BI__builtin_rvv_vmulhu_vx_tum:
618 case RISCVVector::BI__builtin_rvv_vmulhu_vv_tumu:
619 case RISCVVector::BI__builtin_rvv_vmulhu_vx_tumu:
620 case RISCVVector::BI__builtin_rvv_vmulh_vv:
621 case RISCVVector::BI__builtin_rvv_vmulh_vx:
622 case RISCVVector::BI__builtin_rvv_vmulh_vv_tu:
623 case RISCVVector::BI__builtin_rvv_vmulh_vx_tu:
624 case RISCVVector::BI__builtin_rvv_vmulh_vv_m:
625 case RISCVVector::BI__builtin_rvv_vmulh_vx_m:
626 case RISCVVector::BI__builtin_rvv_vmulh_vv_mu:
627 case RISCVVector::BI__builtin_rvv_vmulh_vx_mu:
628 case RISCVVector::BI__builtin_rvv_vmulh_vv_tum:
629 case RISCVVector::BI__builtin_rvv_vmulh_vx_tum:
630 case RISCVVector::BI__builtin_rvv_vmulh_vv_tumu:
631 case RISCVVector::BI__builtin_rvv_vmulh_vx_tumu:
632 case RISCVVector::BI__builtin_rvv_vsmul_vv:
633 case RISCVVector::BI__builtin_rvv_vsmul_vx:
634 case RISCVVector::BI__builtin_rvv_vsmul_vv_tu:
635 case RISCVVector::BI__builtin_rvv_vsmul_vx_tu:
636 case RISCVVector::BI__builtin_rvv_vsmul_vv_m:
637 case RISCVVector::BI__builtin_rvv_vsmul_vx_m:
638 case RISCVVector::BI__builtin_rvv_vsmul_vv_mu:
639 case RISCVVector::BI__builtin_rvv_vsmul_vx_mu:
640 case RISCVVector::BI__builtin_rvv_vsmul_vv_tum:
641 case RISCVVector::BI__builtin_rvv_vsmul_vx_tum:
642 case RISCVVector::BI__builtin_rvv_vsmul_vv_tumu:
643 case RISCVVector::BI__builtin_rvv_vsmul_vx_tumu: {
648 !FunctionFeatureMap.lookup(
"v"))
650 diag::err_riscv_builtin_requires_extension)
657 auto CheckVSetVL = [&](
unsigned SEWOffset,
unsigned LMULOffset) ->
bool {
659 llvm::StringMap<bool> FunctionFeatureMap;
660 Context.getFunctionFeatureMap(FunctionFeatureMap, FD);
661 llvm::APSInt SEWResult;
662 llvm::APSInt LMULResult;
663 if (
SemaRef.BuiltinConstantArg(TheCall, SEWOffset, SEWResult) ||
664 SemaRef.BuiltinConstantArg(TheCall, LMULOffset, LMULResult))
666 int SEWValue = SEWResult.getSExtValue();
667 int LMULValue = LMULResult.getSExtValue();
668 if (((SEWValue == 0 && LMULValue == 5) ||
669 (SEWValue == 1 && LMULValue == 6) ||
670 (SEWValue == 2 && LMULValue == 7) ||
673 !FunctionFeatureMap.lookup(
"zve64x"))
675 diag::err_riscv_builtin_requires_extension)
677 return SemaRef.BuiltinConstantArgRange(TheCall, SEWOffset, 0, 3) ||
681 case RISCVVector::BI__builtin_rvv_vsetvli:
682 return CheckVSetVL(1, 2);
683 case RISCVVector::BI__builtin_rvv_vsetvlimax:
684 return CheckVSetVL(0, 1);
685 case RISCVVector::BI__builtin_rvv_sf_vsettnt:
686 case RISCVVector::BI__builtin_rvv_sf_vsettm:
687 case RISCVVector::BI__builtin_rvv_sf_vsettn:
688 case RISCVVector::BI__builtin_rvv_sf_vsettk:
689 return SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 3) ||
690 SemaRef.BuiltinConstantArgRange(TheCall, 2, 1, 3);
691 case RISCVVector::BI__builtin_rvv_sf_mm_f_f_w1:
692 case RISCVVector::BI__builtin_rvv_sf_mm_f_f_w2:
693 case RISCVVector::BI__builtin_rvv_sf_mm_e5m2_e4m3_w4:
694 case RISCVVector::BI__builtin_rvv_sf_mm_e5m2_e5m2_w4:
695 case RISCVVector::BI__builtin_rvv_sf_mm_e4m3_e4m3_w4:
696 case RISCVVector::BI__builtin_rvv_sf_mm_e4m3_e5m2_w4:
697 case RISCVVector::BI__builtin_rvv_sf_mm_u_u_w4:
698 case RISCVVector::BI__builtin_rvv_sf_mm_u_s_w4:
699 case RISCVVector::BI__builtin_rvv_sf_mm_s_u_w4:
700 case RISCVVector::BI__builtin_rvv_sf_mm_s_s_w4: {
703 SemaRef.Context.getBuiltinVectorTypeInfo(
720 if ((BuiltinID == RISCVVector::BI__builtin_rvv_sf_mm_f_f_w1 &&
722 (BuiltinID == RISCVVector::BI__builtin_rvv_sf_mm_f_f_w2 &&
724 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 15) ||
725 SemaRef.BuiltinConstantArgMultiple(TheCall, 0, 2);
726 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 15) ||
727 SemaRef.BuiltinConstantArgMultiple(TheCall, 0, 4);
729 case RISCVVector::BI__builtin_rvv_sf_vtzero_t: {
730 llvm::APSInt Log2SEWResult;
731 llvm::APSInt TWidenResult;
732 if (
SemaRef.BuiltinConstantArg(TheCall, 3, Log2SEWResult) ||
733 SemaRef.BuiltinConstantArg(TheCall, 4, TWidenResult))
736 int Log2SEW = Log2SEWResult.getSExtValue();
737 int TWiden = TWidenResult.getSExtValue();
740 if (
SemaRef.BuiltinConstantArgRange(TheCall, 3, 3, 6))
744 if (TWiden != 1 && TWiden != 2 && TWiden != 4)
746 diag::err_riscv_builtin_invalid_twiden);
748 int TEW = (1 << Log2SEW) * TWiden;
753 if (
SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 15))
755 if (TEW == 16 || TEW == 64)
756 return SemaRef.BuiltinConstantArgMultiple(TheCall, 0, 2);
757 return SemaRef.BuiltinConstantArgMultiple(TheCall, 0, 4);
759 case RISCVVector::BI__builtin_rvv_vget_v: {
770 MaxIndex = (VecInfo.
EC.getKnownMinValue() * VecInfo.
NumVectors) /
771 (ResVecInfo.
EC.getKnownMinValue() * ResVecInfo.
NumVectors);
772 return SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, MaxIndex - 1);
774 case RISCVVector::BI__builtin_rvv_vset_v: {
785 MaxIndex = (ResVecInfo.
EC.getKnownMinValue() * ResVecInfo.
NumVectors) /
787 return SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, MaxIndex - 1);
790 case RISCVVector::BI__builtin_rvv_vaeskf1_vi_tu:
791 case RISCVVector::BI__builtin_rvv_vaeskf2_vi_tu:
792 case RISCVVector::BI__builtin_rvv_vaeskf2_vi:
793 case RISCVVector::BI__builtin_rvv_vsm4k_vi_tu: {
800 SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 31);
802 case RISCVVector::BI__builtin_rvv_vsm3c_vi_tu:
803 case RISCVVector::BI__builtin_rvv_vsm3c_vi: {
807 SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 31);
809 case RISCVVector::BI__builtin_rvv_vaeskf1_vi:
810 case RISCVVector::BI__builtin_rvv_vsm4k_vi: {
814 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31);
816 case RISCVVector::BI__builtin_rvv_vaesdf_vv:
817 case RISCVVector::BI__builtin_rvv_vaesdf_vs:
818 case RISCVVector::BI__builtin_rvv_vaesdm_vv:
819 case RISCVVector::BI__builtin_rvv_vaesdm_vs:
820 case RISCVVector::BI__builtin_rvv_vaesef_vv:
821 case RISCVVector::BI__builtin_rvv_vaesef_vs:
822 case RISCVVector::BI__builtin_rvv_vaesem_vv:
823 case RISCVVector::BI__builtin_rvv_vaesem_vs:
824 case RISCVVector::BI__builtin_rvv_vaesz_vs:
825 case RISCVVector::BI__builtin_rvv_vsm4r_vv:
826 case RISCVVector::BI__builtin_rvv_vsm4r_vs:
827 case RISCVVector::BI__builtin_rvv_vaesdf_vv_tu:
828 case RISCVVector::BI__builtin_rvv_vaesdf_vs_tu:
829 case RISCVVector::BI__builtin_rvv_vaesdm_vv_tu:
830 case RISCVVector::BI__builtin_rvv_vaesdm_vs_tu:
831 case RISCVVector::BI__builtin_rvv_vaesef_vv_tu:
832 case RISCVVector::BI__builtin_rvv_vaesef_vs_tu:
833 case RISCVVector::BI__builtin_rvv_vaesem_vv_tu:
834 case RISCVVector::BI__builtin_rvv_vaesem_vs_tu:
835 case RISCVVector::BI__builtin_rvv_vaesz_vs_tu:
836 case RISCVVector::BI__builtin_rvv_vsm4r_vv_tu:
837 case RISCVVector::BI__builtin_rvv_vsm4r_vs_tu: {
845 case RISCVVector::BI__builtin_rvv_vsha2ch_vv:
846 case RISCVVector::BI__builtin_rvv_vsha2cl_vv:
847 case RISCVVector::BI__builtin_rvv_vsha2ms_vv:
848 case RISCVVector::BI__builtin_rvv_vsha2ch_vv_tu:
849 case RISCVVector::BI__builtin_rvv_vsha2cl_vv_tu:
850 case RISCVVector::BI__builtin_rvv_vsha2ms_vv_tu: {
856 uint64_t ElemSize = Context.getTypeSize(Info.
ElementType);
859 Arg0Type, ElemSize * 4) ||
861 Arg1Type, ElemSize * 4) ||
863 Arg2Type, ElemSize * 4);
866 case RISCVVector::BI__builtin_rvv_sf_vc_i_se:
868 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
869 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31) ||
870 SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 31) ||
871 SemaRef.BuiltinConstantArgRange(TheCall, 3, -16, 15) ||
873 case RISCVVector::BI__builtin_rvv_sf_vc_iv_se:
875 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
876 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31) ||
877 SemaRef.BuiltinConstantArgRange(TheCall, 3, -16, 15);
878 case RISCVVector::BI__builtin_rvv_sf_vc_v_i:
879 case RISCVVector::BI__builtin_rvv_sf_vc_v_i_se:
881 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
882 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31) ||
883 SemaRef.BuiltinConstantArgRange(TheCall, 2, -16, 15);
884 case RISCVVector::BI__builtin_rvv_sf_vc_v_iv:
885 case RISCVVector::BI__builtin_rvv_sf_vc_v_iv_se:
887 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
888 SemaRef.BuiltinConstantArgRange(TheCall, 2, -16, 15);
889 case RISCVVector::BI__builtin_rvv_sf_vc_ivv_se:
890 case RISCVVector::BI__builtin_rvv_sf_vc_ivw_se:
891 case RISCVVector::BI__builtin_rvv_sf_vc_v_ivv:
892 case RISCVVector::BI__builtin_rvv_sf_vc_v_ivw:
893 case RISCVVector::BI__builtin_rvv_sf_vc_v_ivv_se:
894 case RISCVVector::BI__builtin_rvv_sf_vc_v_ivw_se:
896 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
897 SemaRef.BuiltinConstantArgRange(TheCall, 3, -16, 15);
898 case RISCVVector::BI__builtin_rvv_sf_vc_x_se:
900 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
901 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31) ||
902 SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 31) ||
904 case RISCVVector::BI__builtin_rvv_sf_vc_xv_se:
905 case RISCVVector::BI__builtin_rvv_sf_vc_vv_se:
907 case RISCVVector::BI__builtin_rvv_sf_vc_v_x:
908 case RISCVVector::BI__builtin_rvv_sf_vc_v_x_se:
910 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3) ||
911 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31);
912 case RISCVVector::BI__builtin_rvv_sf_vc_vvv_se:
913 case RISCVVector::BI__builtin_rvv_sf_vc_xvv_se:
914 case RISCVVector::BI__builtin_rvv_sf_vc_vvw_se:
915 case RISCVVector::BI__builtin_rvv_sf_vc_xvw_se:
917 case RISCVVector::BI__builtin_rvv_sf_vc_v_xv:
918 case RISCVVector::BI__builtin_rvv_sf_vc_v_vv:
919 case RISCVVector::BI__builtin_rvv_sf_vc_v_xv_se:
920 case RISCVVector::BI__builtin_rvv_sf_vc_v_vv_se:
922 case RISCVVector::BI__builtin_rvv_sf_vc_v_xvv:
923 case RISCVVector::BI__builtin_rvv_sf_vc_v_vvv:
924 case RISCVVector::BI__builtin_rvv_sf_vc_v_xvw:
925 case RISCVVector::BI__builtin_rvv_sf_vc_v_vvw:
926 case RISCVVector::BI__builtin_rvv_sf_vc_v_xvv_se:
927 case RISCVVector::BI__builtin_rvv_sf_vc_v_vvv_se:
928 case RISCVVector::BI__builtin_rvv_sf_vc_v_xvw_se:
929 case RISCVVector::BI__builtin_rvv_sf_vc_v_vvw_se:
931 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 3);
932 case RISCVVector::BI__builtin_rvv_sf_vc_fv_se:
934 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 1) ||
935 SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 31);
936 case RISCVVector::BI__builtin_rvv_sf_vc_fvv_se:
937 case RISCVVector::BI__builtin_rvv_sf_vc_fvw_se:
938 case RISCVVector::BI__builtin_rvv_sf_vc_v_fvv:
939 case RISCVVector::BI__builtin_rvv_sf_vc_v_fvw:
940 case RISCVVector::BI__builtin_rvv_sf_vc_v_fvv_se:
941 case RISCVVector::BI__builtin_rvv_sf_vc_v_fvw_se:
943 case RISCVVector::BI__builtin_rvv_sf_vc_v_fv:
944 case RISCVVector::BI__builtin_rvv_sf_vc_v_fv_se:
946 return SemaRef.BuiltinConstantArgRange(TheCall, 0, 0, 1);
948 case RISCV::BI__builtin_riscv_aes32dsi:
949 case RISCV::BI__builtin_riscv_aes32dsmi:
950 case RISCV::BI__builtin_riscv_aes32esi:
951 case RISCV::BI__builtin_riscv_aes32esmi:
952 case RISCV::BI__builtin_riscv_sm4ks:
953 case RISCV::BI__builtin_riscv_sm4ed:
954 return SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 3);
956 case RISCV::BI__builtin_riscv_aes64ks1i:
957 return SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 10);
959 case RISCVVector::BI__builtin_rvv_vaaddu_vv:
960 case RISCVVector::BI__builtin_rvv_vaaddu_vx:
961 case RISCVVector::BI__builtin_rvv_vaadd_vv:
962 case RISCVVector::BI__builtin_rvv_vaadd_vx:
963 case RISCVVector::BI__builtin_rvv_vasubu_vv:
964 case RISCVVector::BI__builtin_rvv_vasubu_vx:
965 case RISCVVector::BI__builtin_rvv_vasub_vv:
966 case RISCVVector::BI__builtin_rvv_vasub_vx:
967 case RISCVVector::BI__builtin_rvv_vsmul_vv:
968 case RISCVVector::BI__builtin_rvv_vsmul_vx:
969 case RISCVVector::BI__builtin_rvv_vssra_vv:
970 case RISCVVector::BI__builtin_rvv_vssra_vx:
971 case RISCVVector::BI__builtin_rvv_vssrl_vv:
972 case RISCVVector::BI__builtin_rvv_vssrl_vx:
973 case RISCVVector::BI__builtin_rvv_vnclip_wv:
974 case RISCVVector::BI__builtin_rvv_vnclip_wx:
975 case RISCVVector::BI__builtin_rvv_vnclipu_wv:
976 case RISCVVector::BI__builtin_rvv_vnclipu_wx:
977 return SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 3);
978 case RISCVVector::BI__builtin_rvv_vaaddu_vv_tu:
979 case RISCVVector::BI__builtin_rvv_vaaddu_vx_tu:
980 case RISCVVector::BI__builtin_rvv_vaadd_vv_tu:
981 case RISCVVector::BI__builtin_rvv_vaadd_vx_tu:
982 case RISCVVector::BI__builtin_rvv_vasubu_vv_tu:
983 case RISCVVector::BI__builtin_rvv_vasubu_vx_tu:
984 case RISCVVector::BI__builtin_rvv_vasub_vv_tu:
985 case RISCVVector::BI__builtin_rvv_vasub_vx_tu:
986 case RISCVVector::BI__builtin_rvv_vsmul_vv_tu:
987 case RISCVVector::BI__builtin_rvv_vsmul_vx_tu:
988 case RISCVVector::BI__builtin_rvv_vssra_vv_tu:
989 case RISCVVector::BI__builtin_rvv_vssra_vx_tu:
990 case RISCVVector::BI__builtin_rvv_vssrl_vv_tu:
991 case RISCVVector::BI__builtin_rvv_vssrl_vx_tu:
992 case RISCVVector::BI__builtin_rvv_vnclip_wv_tu:
993 case RISCVVector::BI__builtin_rvv_vnclip_wx_tu:
994 case RISCVVector::BI__builtin_rvv_vnclipu_wv_tu:
995 case RISCVVector::BI__builtin_rvv_vnclipu_wx_tu:
996 case RISCVVector::BI__builtin_rvv_vaaddu_vv_m:
997 case RISCVVector::BI__builtin_rvv_vaaddu_vx_m:
998 case RISCVVector::BI__builtin_rvv_vaadd_vv_m:
999 case RISCVVector::BI__builtin_rvv_vaadd_vx_m:
1000 case RISCVVector::BI__builtin_rvv_vasubu_vv_m:
1001 case RISCVVector::BI__builtin_rvv_vasubu_vx_m:
1002 case RISCVVector::BI__builtin_rvv_vasub_vv_m:
1003 case RISCVVector::BI__builtin_rvv_vasub_vx_m:
1004 case RISCVVector::BI__builtin_rvv_vsmul_vv_m:
1005 case RISCVVector::BI__builtin_rvv_vsmul_vx_m:
1006 case RISCVVector::BI__builtin_rvv_vssra_vv_m:
1007 case RISCVVector::BI__builtin_rvv_vssra_vx_m:
1008 case RISCVVector::BI__builtin_rvv_vssrl_vv_m:
1009 case RISCVVector::BI__builtin_rvv_vssrl_vx_m:
1010 case RISCVVector::BI__builtin_rvv_vnclip_wv_m:
1011 case RISCVVector::BI__builtin_rvv_vnclip_wx_m:
1012 case RISCVVector::BI__builtin_rvv_vnclipu_wv_m:
1013 case RISCVVector::BI__builtin_rvv_vnclipu_wx_m:
1014 return SemaRef.BuiltinConstantArgRange(TheCall, 3, 0, 3);
1015 case RISCVVector::BI__builtin_rvv_vaaddu_vv_tum:
1016 case RISCVVector::BI__builtin_rvv_vaaddu_vv_tumu:
1017 case RISCVVector::BI__builtin_rvv_vaaddu_vv_mu:
1018 case RISCVVector::BI__builtin_rvv_vaaddu_vx_tum:
1019 case RISCVVector::BI__builtin_rvv_vaaddu_vx_tumu:
1020 case RISCVVector::BI__builtin_rvv_vaaddu_vx_mu:
1021 case RISCVVector::BI__builtin_rvv_vaadd_vv_tum:
1022 case RISCVVector::BI__builtin_rvv_vaadd_vv_tumu:
1023 case RISCVVector::BI__builtin_rvv_vaadd_vv_mu:
1024 case RISCVVector::BI__builtin_rvv_vaadd_vx_tum:
1025 case RISCVVector::BI__builtin_rvv_vaadd_vx_tumu:
1026 case RISCVVector::BI__builtin_rvv_vaadd_vx_mu:
1027 case RISCVVector::BI__builtin_rvv_vasubu_vv_tum:
1028 case RISCVVector::BI__builtin_rvv_vasubu_vv_tumu:
1029 case RISCVVector::BI__builtin_rvv_vasubu_vv_mu:
1030 case RISCVVector::BI__builtin_rvv_vasubu_vx_tum:
1031 case RISCVVector::BI__builtin_rvv_vasubu_vx_tumu:
1032 case RISCVVector::BI__builtin_rvv_vasubu_vx_mu:
1033 case RISCVVector::BI__builtin_rvv_vasub_vv_tum:
1034 case RISCVVector::BI__builtin_rvv_vasub_vv_tumu:
1035 case RISCVVector::BI__builtin_rvv_vasub_vv_mu:
1036 case RISCVVector::BI__builtin_rvv_vasub_vx_tum:
1037 case RISCVVector::BI__builtin_rvv_vasub_vx_tumu:
1038 case RISCVVector::BI__builtin_rvv_vasub_vx_mu:
1039 case RISCVVector::BI__builtin_rvv_vsmul_vv_mu:
1040 case RISCVVector::BI__builtin_rvv_vsmul_vx_mu:
1041 case RISCVVector::BI__builtin_rvv_vssra_vv_mu:
1042 case RISCVVector::BI__builtin_rvv_vssra_vx_mu:
1043 case RISCVVector::BI__builtin_rvv_vssrl_vv_mu:
1044 case RISCVVector::BI__builtin_rvv_vssrl_vx_mu:
1045 case RISCVVector::BI__builtin_rvv_vnclip_wv_mu:
1046 case RISCVVector::BI__builtin_rvv_vnclip_wx_mu:
1047 case RISCVVector::BI__builtin_rvv_vnclipu_wv_mu:
1048 case RISCVVector::BI__builtin_rvv_vnclipu_wx_mu:
1049 case RISCVVector::BI__builtin_rvv_vsmul_vv_tum:
1050 case RISCVVector::BI__builtin_rvv_vsmul_vx_tum:
1051 case RISCVVector::BI__builtin_rvv_vssra_vv_tum:
1052 case RISCVVector::BI__builtin_rvv_vssra_vx_tum:
1053 case RISCVVector::BI__builtin_rvv_vssrl_vv_tum:
1054 case RISCVVector::BI__builtin_rvv_vssrl_vx_tum:
1055 case RISCVVector::BI__builtin_rvv_vnclip_wv_tum:
1056 case RISCVVector::BI__builtin_rvv_vnclip_wx_tum:
1057 case RISCVVector::BI__builtin_rvv_vnclipu_wv_tum:
1058 case RISCVVector::BI__builtin_rvv_vnclipu_wx_tum:
1059 case RISCVVector::BI__builtin_rvv_vsmul_vv_tumu:
1060 case RISCVVector::BI__builtin_rvv_vsmul_vx_tumu:
1061 case RISCVVector::BI__builtin_rvv_vssra_vv_tumu:
1062 case RISCVVector::BI__builtin_rvv_vssra_vx_tumu:
1063 case RISCVVector::BI__builtin_rvv_vssrl_vv_tumu:
1064 case RISCVVector::BI__builtin_rvv_vssrl_vx_tumu:
1065 case RISCVVector::BI__builtin_rvv_vnclip_wv_tumu:
1066 case RISCVVector::BI__builtin_rvv_vnclip_wx_tumu:
1067 case RISCVVector::BI__builtin_rvv_vnclipu_wv_tumu:
1068 case RISCVVector::BI__builtin_rvv_vnclipu_wx_tumu:
1069 return SemaRef.BuiltinConstantArgRange(TheCall, 4, 0, 3);
1070 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm:
1071 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm:
1072 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm:
1073 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm:
1074 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm:
1075 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm:
1076 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm:
1077 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm:
1078 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm:
1079 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm:
1080 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm:
1081 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm:
1082 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm:
1083 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm:
1084 return SemaRef.BuiltinConstantArgRange(TheCall, 1, 0, 4);
1085 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm:
1086 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm:
1087 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm:
1088 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm:
1089 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm:
1090 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm:
1091 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm:
1092 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm:
1093 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm:
1094 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm:
1095 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm:
1096 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm:
1097 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm:
1098 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm:
1099 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm:
1100 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm:
1101 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm:
1102 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm:
1103 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm:
1104 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm:
1105 case RISCVVector::BI__builtin_rvv_vfredosum_vs_rm:
1106 case RISCVVector::BI__builtin_rvv_vfredusum_vs_rm:
1107 case RISCVVector::BI__builtin_rvv_vfwredosum_vs_rm:
1108 case RISCVVector::BI__builtin_rvv_vfwredusum_vs_rm:
1109 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_x_f_qf_rm:
1110 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_xu_f_qf_rm:
1111 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm_tu:
1112 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm_tu:
1113 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm_tu:
1114 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm_tu:
1115 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm_tu:
1116 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm_tu:
1117 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm_tu:
1118 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm_tu:
1119 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm_tu:
1120 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm_tu:
1121 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm_tu:
1122 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm_tu:
1123 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm_tu:
1124 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm_tu:
1125 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm_m:
1126 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm_m:
1127 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm_m:
1128 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm_m:
1129 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm_m:
1130 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm_m:
1131 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm_m:
1132 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm_m:
1133 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm_m:
1134 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm_m:
1135 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm_m:
1136 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm_m:
1137 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm_m:
1138 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm_m:
1139 return SemaRef.BuiltinConstantArgRange(TheCall, 2, 0, 4);
1140 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm_tu:
1141 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm_tu:
1142 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm_tu:
1143 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm_tu:
1144 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm_tu:
1145 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm_tu:
1146 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm_tu:
1147 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm_tu:
1148 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm_tu:
1149 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm_tu:
1150 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm_tu:
1151 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm_tu:
1152 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm_tu:
1153 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm_tu:
1154 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm_tu:
1155 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm_tu:
1156 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm_tu:
1157 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm_tu:
1158 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm_tu:
1159 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm_tu:
1160 case RISCVVector::BI__builtin_rvv_vfredosum_vs_rm_tu:
1161 case RISCVVector::BI__builtin_rvv_vfredusum_vs_rm_tu:
1162 case RISCVVector::BI__builtin_rvv_vfwredosum_vs_rm_tu:
1163 case RISCVVector::BI__builtin_rvv_vfwredusum_vs_rm_tu:
1164 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm:
1165 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm:
1166 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm:
1167 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm:
1168 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm:
1169 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm:
1170 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm:
1171 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm:
1172 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm:
1173 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm:
1174 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm:
1175 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm:
1176 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm:
1177 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm:
1178 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm:
1179 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm:
1180 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm:
1181 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm:
1182 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm:
1183 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm:
1184 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm:
1185 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm:
1186 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm:
1187 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm:
1188 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm:
1189 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm:
1190 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm_tu:
1191 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm_tu:
1192 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm_tu:
1193 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm_tu:
1194 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm_tu:
1195 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm_tu:
1196 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm_tu:
1197 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm_tu:
1198 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm_tu:
1199 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm_tu:
1200 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm_tu:
1201 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm_tu:
1202 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm_tu:
1203 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm_tu:
1204 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm_tu:
1205 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm_tu:
1206 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm_tu:
1207 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm_tu:
1208 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm_tu:
1209 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm_tu:
1210 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm_tu:
1211 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm_tu:
1212 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm_tu:
1213 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm_tu:
1214 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm_tu:
1215 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm_tu:
1216 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_x_f_qf_rm_tu:
1217 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_xu_f_qf_rm_tu:
1218 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm_m:
1219 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm_m:
1220 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm_m:
1221 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm_m:
1222 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm_m:
1223 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm_m:
1224 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm_m:
1225 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm_m:
1226 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm_m:
1227 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm_m:
1228 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm_m:
1229 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm_m:
1230 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm_m:
1231 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm_m:
1232 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm_m:
1233 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm_m:
1234 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm_m:
1235 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm_m:
1236 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm_m:
1237 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm_m:
1238 case RISCVVector::BI__builtin_rvv_vfredosum_vs_rm_m:
1239 case RISCVVector::BI__builtin_rvv_vfredusum_vs_rm_m:
1240 case RISCVVector::BI__builtin_rvv_vfwredosum_vs_rm_m:
1241 case RISCVVector::BI__builtin_rvv_vfwredusum_vs_rm_m:
1242 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm_tum:
1243 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm_tum:
1244 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm_tum:
1245 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm_tum:
1246 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm_tum:
1247 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm_tum:
1248 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm_tum:
1249 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm_tum:
1250 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm_tum:
1251 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm_tum:
1252 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm_tum:
1253 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm_tum:
1254 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm_tum:
1255 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm_tum:
1256 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm_tumu:
1257 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm_tumu:
1258 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm_tumu:
1259 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm_tumu:
1260 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm_tumu:
1261 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm_tumu:
1262 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm_tumu:
1263 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm_tumu:
1264 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm_tumu:
1265 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm_tumu:
1266 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm_tumu:
1267 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm_tumu:
1268 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm_tumu:
1269 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm_tumu:
1270 case RISCVVector::BI__builtin_rvv_vfsqrt_v_rm_mu:
1271 case RISCVVector::BI__builtin_rvv_vfrec7_v_rm_mu:
1272 case RISCVVector::BI__builtin_rvv_vfcvt_x_f_v_rm_mu:
1273 case RISCVVector::BI__builtin_rvv_vfcvt_xu_f_v_rm_mu:
1274 case RISCVVector::BI__builtin_rvv_vfcvt_f_x_v_rm_mu:
1275 case RISCVVector::BI__builtin_rvv_vfcvt_f_xu_v_rm_mu:
1276 case RISCVVector::BI__builtin_rvv_vfwcvt_x_f_v_rm_mu:
1277 case RISCVVector::BI__builtin_rvv_vfwcvt_xu_f_v_rm_mu:
1278 case RISCVVector::BI__builtin_rvv_vfncvt_x_f_w_rm_mu:
1279 case RISCVVector::BI__builtin_rvv_vfncvt_xu_f_w_rm_mu:
1280 case RISCVVector::BI__builtin_rvv_vfncvt_f_x_w_rm_mu:
1281 case RISCVVector::BI__builtin_rvv_vfncvt_f_xu_w_rm_mu:
1282 case RISCVVector::BI__builtin_rvv_vfncvt_f_f_w_rm_mu:
1283 case RISCVVector::BI__builtin_rvv_vfncvtbf16_f_f_w_rm_mu:
1284 return SemaRef.BuiltinConstantArgRange(TheCall, 3, 0, 4);
1285 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm_m:
1286 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm_m:
1287 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm_m:
1288 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm_m:
1289 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm_m:
1290 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm_m:
1291 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm_m:
1292 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm_m:
1293 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm_m:
1294 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm_m:
1295 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm_m:
1296 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm_m:
1297 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm_m:
1298 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm_m:
1299 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm_m:
1300 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm_m:
1301 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm_m:
1302 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm_m:
1303 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm_m:
1304 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm_m:
1305 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm_m:
1306 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm_m:
1307 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm_m:
1308 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm_m:
1309 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm_m:
1310 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm_m:
1311 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm_tum:
1312 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm_tum:
1313 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm_tum:
1314 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm_tum:
1315 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm_tum:
1316 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm_tum:
1317 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm_tum:
1318 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm_tum:
1319 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm_tum:
1320 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm_tum:
1321 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm_tum:
1322 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm_tum:
1323 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm_tum:
1324 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm_tum:
1325 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm_tum:
1326 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm_tum:
1327 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm_tum:
1328 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm_tum:
1329 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm_tum:
1330 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm_tum:
1331 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm_tum:
1332 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm_tum:
1333 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm_tum:
1334 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm_tum:
1335 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm_tum:
1336 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm_tum:
1337 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm_tum:
1338 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm_tum:
1339 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm_tum:
1340 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm_tum:
1341 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm_tum:
1342 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm_tum:
1343 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm_tum:
1344 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm_tum:
1345 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm_tum:
1346 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm_tum:
1347 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm_tum:
1348 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm_tum:
1349 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm_tum:
1350 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm_tum:
1351 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm_tum:
1352 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm_tum:
1353 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm_tum:
1354 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm_tum:
1355 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm_tum:
1356 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm_tum:
1357 case RISCVVector::BI__builtin_rvv_vfredosum_vs_rm_tum:
1358 case RISCVVector::BI__builtin_rvv_vfredusum_vs_rm_tum:
1359 case RISCVVector::BI__builtin_rvv_vfwredosum_vs_rm_tum:
1360 case RISCVVector::BI__builtin_rvv_vfwredusum_vs_rm_tum:
1361 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_x_f_qf_rm_tum:
1362 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_xu_f_qf_rm_tum:
1363 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm_tumu:
1364 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm_tumu:
1365 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm_tumu:
1366 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm_tumu:
1367 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm_tumu:
1368 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm_tumu:
1369 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm_tumu:
1370 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm_tumu:
1371 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm_tumu:
1372 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm_tumu:
1373 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm_tumu:
1374 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm_tumu:
1375 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm_tumu:
1376 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm_tumu:
1377 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm_tumu:
1378 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm_tumu:
1379 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm_tumu:
1380 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm_tumu:
1381 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm_tumu:
1382 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm_tumu:
1383 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm_tumu:
1384 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm_tumu:
1385 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm_tumu:
1386 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm_tumu:
1387 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm_tumu:
1388 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm_tumu:
1389 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm_tumu:
1390 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm_tumu:
1391 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm_tumu:
1392 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm_tumu:
1393 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm_tumu:
1394 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm_tumu:
1395 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm_tumu:
1396 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm_tumu:
1397 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm_tumu:
1398 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm_tumu:
1399 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm_tumu:
1400 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm_tumu:
1401 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm_tumu:
1402 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm_tumu:
1403 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm_tumu:
1404 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm_tumu:
1405 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm_tumu:
1406 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm_tumu:
1407 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm_tumu:
1408 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm_tumu:
1409 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_x_f_qf_rm_tumu:
1410 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_xu_f_qf_rm_tumu:
1411 case RISCVVector::BI__builtin_rvv_vfadd_vv_rm_mu:
1412 case RISCVVector::BI__builtin_rvv_vfadd_vf_rm_mu:
1413 case RISCVVector::BI__builtin_rvv_vfsub_vv_rm_mu:
1414 case RISCVVector::BI__builtin_rvv_vfsub_vf_rm_mu:
1415 case RISCVVector::BI__builtin_rvv_vfrsub_vf_rm_mu:
1416 case RISCVVector::BI__builtin_rvv_vfwadd_vv_rm_mu:
1417 case RISCVVector::BI__builtin_rvv_vfwadd_vf_rm_mu:
1418 case RISCVVector::BI__builtin_rvv_vfwsub_vv_rm_mu:
1419 case RISCVVector::BI__builtin_rvv_vfwsub_vf_rm_mu:
1420 case RISCVVector::BI__builtin_rvv_vfwadd_wv_rm_mu:
1421 case RISCVVector::BI__builtin_rvv_vfwadd_wf_rm_mu:
1422 case RISCVVector::BI__builtin_rvv_vfwsub_wv_rm_mu:
1423 case RISCVVector::BI__builtin_rvv_vfwsub_wf_rm_mu:
1424 case RISCVVector::BI__builtin_rvv_vfmul_vv_rm_mu:
1425 case RISCVVector::BI__builtin_rvv_vfmul_vf_rm_mu:
1426 case RISCVVector::BI__builtin_rvv_vfdiv_vv_rm_mu:
1427 case RISCVVector::BI__builtin_rvv_vfdiv_vf_rm_mu:
1428 case RISCVVector::BI__builtin_rvv_vfrdiv_vf_rm_mu:
1429 case RISCVVector::BI__builtin_rvv_vfwmul_vv_rm_mu:
1430 case RISCVVector::BI__builtin_rvv_vfwmul_vf_rm_mu:
1431 case RISCVVector::BI__builtin_rvv_vfmacc_vv_rm_mu:
1432 case RISCVVector::BI__builtin_rvv_vfmacc_vf_rm_mu:
1433 case RISCVVector::BI__builtin_rvv_vfnmacc_vv_rm_mu:
1434 case RISCVVector::BI__builtin_rvv_vfnmacc_vf_rm_mu:
1435 case RISCVVector::BI__builtin_rvv_vfmsac_vv_rm_mu:
1436 case RISCVVector::BI__builtin_rvv_vfmsac_vf_rm_mu:
1437 case RISCVVector::BI__builtin_rvv_vfnmsac_vv_rm_mu:
1438 case RISCVVector::BI__builtin_rvv_vfnmsac_vf_rm_mu:
1439 case RISCVVector::BI__builtin_rvv_vfmadd_vv_rm_mu:
1440 case RISCVVector::BI__builtin_rvv_vfmadd_vf_rm_mu:
1441 case RISCVVector::BI__builtin_rvv_vfnmadd_vv_rm_mu:
1442 case RISCVVector::BI__builtin_rvv_vfnmadd_vf_rm_mu:
1443 case RISCVVector::BI__builtin_rvv_vfmsub_vv_rm_mu:
1444 case RISCVVector::BI__builtin_rvv_vfmsub_vf_rm_mu:
1445 case RISCVVector::BI__builtin_rvv_vfnmsub_vv_rm_mu:
1446 case RISCVVector::BI__builtin_rvv_vfnmsub_vf_rm_mu:
1447 case RISCVVector::BI__builtin_rvv_vfwmacc_vv_rm_mu:
1448 case RISCVVector::BI__builtin_rvv_vfwmacc_vf_rm_mu:
1449 case RISCVVector::BI__builtin_rvv_vfwnmacc_vv_rm_mu:
1450 case RISCVVector::BI__builtin_rvv_vfwnmacc_vf_rm_mu:
1451 case RISCVVector::BI__builtin_rvv_vfwmsac_vv_rm_mu:
1452 case RISCVVector::BI__builtin_rvv_vfwmsac_vf_rm_mu:
1453 case RISCVVector::BI__builtin_rvv_vfwnmsac_vv_rm_mu:
1454 case RISCVVector::BI__builtin_rvv_vfwnmsac_vf_rm_mu:
1455 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vv_rm_mu:
1456 case RISCVVector::BI__builtin_rvv_vfwmaccbf16_vf_rm_mu:
1457 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_x_f_qf_rm_mu:
1458 case RISCVVector::BI__builtin_rvv_sf_vfnrclip_xu_f_qf_rm_mu:
1459 return SemaRef.BuiltinConstantArgRange(TheCall, 4, 0, 4);
1460 case RISCV::BI__builtin_riscv_ntl_load:
1461 case RISCV::BI__builtin_riscv_ntl_store:
1464 assert((BuiltinID == RISCV::BI__builtin_riscv_ntl_store ||
1465 BuiltinID == RISCV::BI__builtin_riscv_ntl_load) &&
1466 "Unexpected RISC-V nontemporal load/store builtin!");
1467 bool IsStore = BuiltinID == RISCV::BI__builtin_riscv_ntl_store;
1468 unsigned NumArgs = IsStore ? 3 : 2;
1470 if (
SemaRef.checkArgCountAtLeast(TheCall, NumArgs - 1))
1473 if (
SemaRef.checkArgCountAtMost(TheCall, NumArgs))
1479 SemaRef.BuiltinConstantArgRange(TheCall, NumArgs - 1, 2, 5))
1484 SemaRef.DefaultFunctionArrayLvalueConversion(PointerArg);
1488 PointerArg = PointerArgResult.
get();
1492 Diag(DRE->
getBeginLoc(), diag::err_nontemporal_builtin_must_be_pointer)
1503 diag::err_nontemporal_builtin_must_be_pointer_intfltptr_or_vector)
1515 Context, ValType,
false);
1522 TheCall->
setType(Context.VoidTy);