22 if (builtinID == Builtin::BI__builtin_cpu_supports ||
23 builtinID == Builtin::BI__builtin_cpu_init ||
24 builtinID == Builtin::BI__builtin_cpu_is) {
26 std::string(
"unimplemented RISC-V builtin call: ") +
31 StringRef intrinsicName;
32 mlir::Type returnType;
37 unsigned iceArguments = 0;
41 for (
auto [idx, arg] : llvm::enumerate(e->
arguments()))
46 llvm_unreachable(
"unexpected builtin ID");
49 case RISCV::BI__builtin_riscv_orc_b_32:
50 case RISCV::BI__builtin_riscv_orc_b_64:
52 case RISCV::BI__builtin_riscv_clmul_32:
53 case RISCV::BI__builtin_riscv_clmul_64:
54 case RISCV::BI__builtin_riscv_clmulh_32:
55 case RISCV::BI__builtin_riscv_clmulh_64:
56 case RISCV::BI__builtin_riscv_clmulr_32:
57 case RISCV::BI__builtin_riscv_clmulr_64:
59 case RISCV::BI__builtin_riscv_xperm4_32:
60 case RISCV::BI__builtin_riscv_xperm4_64:
61 case RISCV::BI__builtin_riscv_xperm8_32:
62 case RISCV::BI__builtin_riscv_xperm8_64:
64 case RISCV::BI__builtin_riscv_brev8_32:
65 case RISCV::BI__builtin_riscv_brev8_64:
66 case RISCV::BI__builtin_riscv_zip_32:
67 case RISCV::BI__builtin_riscv_unzip_32:
69 case RISCV::BI__builtin_riscv_sha256sig0:
70 case RISCV::BI__builtin_riscv_sha256sig1:
71 case RISCV::BI__builtin_riscv_sha256sum0:
72 case RISCV::BI__builtin_riscv_sha256sum1:
74 case RISCV::BI__builtin_riscv_sm4ks:
75 case RISCV::BI__builtin_riscv_sm4ed:
77 case RISCV::BI__builtin_riscv_sm3p0:
78 case RISCV::BI__builtin_riscv_sm3p1:
80 case RISCV::BI__builtin_riscv_clz_32:
81 case RISCV::BI__builtin_riscv_clz_64:
82 case RISCV::BI__builtin_riscv_ctz_32:
83 case RISCV::BI__builtin_riscv_ctz_64:
85 case RISCV::BI__builtin_riscv_ntl_load:
86 case RISCV::BI__builtin_riscv_ntl_store: {
88 std::string(
"unimplemented RISC-V builtin call: ") +
94 case RISCV::BI__builtin_riscv_pause: {
95 intrinsicName =
"riscv.pause";
96 returnType = builder.getVoidTy();
101 case RISCV::BI__builtin_riscv_cv_alu_addN:
102 case RISCV::BI__builtin_riscv_cv_alu_addRN:
103 case RISCV::BI__builtin_riscv_cv_alu_adduN:
104 case RISCV::BI__builtin_riscv_cv_alu_adduRN:
105 case RISCV::BI__builtin_riscv_cv_alu_clip:
106 case RISCV::BI__builtin_riscv_cv_alu_clipu:
107 case RISCV::BI__builtin_riscv_cv_alu_extbs:
108 case RISCV::BI__builtin_riscv_cv_alu_extbz:
109 case RISCV::BI__builtin_riscv_cv_alu_exths:
110 case RISCV::BI__builtin_riscv_cv_alu_exthz:
111 case RISCV::BI__builtin_riscv_cv_alu_sle:
112 case RISCV::BI__builtin_riscv_cv_alu_sleu:
113 case RISCV::BI__builtin_riscv_cv_alu_subN:
114 case RISCV::BI__builtin_riscv_cv_alu_subRN:
115 case RISCV::BI__builtin_riscv_cv_alu_subuN:
116 case RISCV::BI__builtin_riscv_cv_alu_subuRN:
118 case RISCV::BI__builtin_riscv_nds_ffb_32:
119 case RISCV::BI__builtin_riscv_nds_ffb_64:
120 case RISCV::BI__builtin_riscv_nds_ffzmism_32:
121 case RISCV::BI__builtin_riscv_nds_ffzmism_64:
122 case RISCV::BI__builtin_riscv_nds_ffmism_32:
123 case RISCV::BI__builtin_riscv_nds_ffmism_64:
124 case RISCV::BI__builtin_riscv_nds_flmism_32:
125 case RISCV::BI__builtin_riscv_nds_flmism_64:
127 case RISCV::BI__builtin_riscv_nds_fcvt_s_bf16:
128 case RISCV::BI__builtin_riscv_nds_fcvt_bf16_s: {
130 std::string(
"unimplemented RISC-V builtin call: ") +
132 return mlir::Value{};
139 return builder.emitIntrinsicCallOp(loc, intrinsicName, returnType, ops);
QualType GetBuiltinType(unsigned ID, GetBuiltinTypeError &Error, unsigned *IntegerConstantArgs=nullptr) const
Return the type for the specified builtin.