clang 23.0.0git
CIRGenBuiltinRISCV.cpp
Go to the documentation of this file.
1//===----------------------------------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This contains code to emit RISC-V Builtin calls as CIR or a function call
10// to be later resolved.
11//
12//===----------------------------------------------------------------------===//
13
14#include "CIRGenFunction.h"
16
17using namespace clang;
18using namespace clang::CIRGen;
19
20std::optional<mlir::Value>
21CIRGenFunction::emitRISCVBuiltinExpr(unsigned builtinID, const CallExpr *e) {
22 if (builtinID == Builtin::BI__builtin_cpu_supports ||
23 builtinID == Builtin::BI__builtin_cpu_init ||
24 builtinID == Builtin::BI__builtin_cpu_is) {
25 cgm.errorNYI(e->getSourceRange(),
26 std::string("unimplemented RISC-V builtin call: ") +
27 getContext().BuiltinInfo.getName(builtinID));
28 return mlir::Value{};
29 }
30
31 StringRef intrinsicName;
32 mlir::Type returnType = convertType(e->getType());
34
35 // `iceArguments` is a bitmap indicating whether the argument at the i-th bit
36 // is required to be a constant integer expression.
37 unsigned iceArguments = 0;
39 getContext().GetBuiltinType(builtinID, error, &iceArguments);
40 assert(error == ASTContext::GE_None && "Should not codegen an error");
41 for (auto [idx, arg] : llvm::enumerate(e->arguments()))
42 ops.push_back(emitScalarOrConstFoldImmArg(iceArguments, idx, arg));
43
44 switch (builtinID) {
45 default:
46 llvm_unreachable("unexpected builtin ID");
47
48 // Zbb
49 case RISCV::BI__builtin_riscv_orc_b_32:
50 case RISCV::BI__builtin_riscv_orc_b_64: {
51 intrinsicName = "riscv.orc.b";
52 break;
53 }
54
55 // Zbc
56 case RISCV::BI__builtin_riscv_clmul_32:
57 case RISCV::BI__builtin_riscv_clmul_64: {
58 intrinsicName = "clmul";
59 break;
60 }
61 case RISCV::BI__builtin_riscv_clmulh_32:
62 case RISCV::BI__builtin_riscv_clmulh_64: {
63 intrinsicName = "riscv.clmulh";
64 break;
65 }
66 case RISCV::BI__builtin_riscv_clmulr_32:
67 case RISCV::BI__builtin_riscv_clmulr_64: {
68 intrinsicName = "riscv.clmulr";
69 break;
70 }
71
72 // Zbkx
73 case RISCV::BI__builtin_riscv_xperm4_32:
74 case RISCV::BI__builtin_riscv_xperm4_64: {
75 intrinsicName = "riscv.xperm4";
76 break;
77 }
78 case RISCV::BI__builtin_riscv_xperm8_32:
79 case RISCV::BI__builtin_riscv_xperm8_64: {
80 intrinsicName = "riscv.xperm8";
81 break;
82 }
83 // Zbkb
84 case RISCV::BI__builtin_riscv_brev8_32:
85 case RISCV::BI__builtin_riscv_brev8_64: {
86 intrinsicName = "riscv.brev8";
87 break;
88 }
89 case RISCV::BI__builtin_riscv_zip_32: {
90 intrinsicName = "riscv.zip";
91 break;
92 }
93 case RISCV::BI__builtin_riscv_unzip_32: {
94 intrinsicName = "riscv.unzip";
95 break;
96 }
97 // Zknh
98 case RISCV::BI__builtin_riscv_sha256sig0:
99 case RISCV::BI__builtin_riscv_sha256sig1:
100 case RISCV::BI__builtin_riscv_sha256sum0:
101 case RISCV::BI__builtin_riscv_sha256sum1:
102 // Zksed
103 case RISCV::BI__builtin_riscv_sm4ks:
104 case RISCV::BI__builtin_riscv_sm4ed:
105 // Zksh
106 case RISCV::BI__builtin_riscv_sm3p0:
107 case RISCV::BI__builtin_riscv_sm3p1:
108 // Zbb
109 case RISCV::BI__builtin_riscv_clz_32:
110 case RISCV::BI__builtin_riscv_clz_64:
111 case RISCV::BI__builtin_riscv_ctz_32:
112 case RISCV::BI__builtin_riscv_ctz_64:
113 // Zihintntl
114 case RISCV::BI__builtin_riscv_ntl_load:
115 case RISCV::BI__builtin_riscv_ntl_store: {
116 cgm.errorNYI(e->getSourceRange(),
117 std::string("unimplemented RISC-V builtin call: ") +
118 getContext().BuiltinInfo.getName(builtinID));
119 return mlir::Value{};
120 }
121
122 // Zihintpause
123 case RISCV::BI__builtin_riscv_pause: {
124 intrinsicName = "riscv.pause";
125 returnType = builder.getVoidTy();
126 break;
127 }
128
129 // XCValu
130 case RISCV::BI__builtin_riscv_cv_alu_addN:
131 case RISCV::BI__builtin_riscv_cv_alu_addRN:
132 case RISCV::BI__builtin_riscv_cv_alu_adduN:
133 case RISCV::BI__builtin_riscv_cv_alu_adduRN:
134 case RISCV::BI__builtin_riscv_cv_alu_clip:
135 case RISCV::BI__builtin_riscv_cv_alu_clipu:
136 case RISCV::BI__builtin_riscv_cv_alu_extbs:
137 case RISCV::BI__builtin_riscv_cv_alu_extbz:
138 case RISCV::BI__builtin_riscv_cv_alu_exths:
139 case RISCV::BI__builtin_riscv_cv_alu_exthz:
140 case RISCV::BI__builtin_riscv_cv_alu_sle:
141 case RISCV::BI__builtin_riscv_cv_alu_sleu:
142 case RISCV::BI__builtin_riscv_cv_alu_subN:
143 case RISCV::BI__builtin_riscv_cv_alu_subRN:
144 case RISCV::BI__builtin_riscv_cv_alu_subuN:
145 case RISCV::BI__builtin_riscv_cv_alu_subuRN:
146 // XAndesPerf
147 case RISCV::BI__builtin_riscv_nds_ffb_32:
148 case RISCV::BI__builtin_riscv_nds_ffb_64:
149 case RISCV::BI__builtin_riscv_nds_ffzmism_32:
150 case RISCV::BI__builtin_riscv_nds_ffzmism_64:
151 case RISCV::BI__builtin_riscv_nds_ffmism_32:
152 case RISCV::BI__builtin_riscv_nds_ffmism_64:
153 case RISCV::BI__builtin_riscv_nds_flmism_32:
154 case RISCV::BI__builtin_riscv_nds_flmism_64:
155 // XAndesBFHCvt
156 case RISCV::BI__builtin_riscv_nds_fcvt_s_bf16:
157 case RISCV::BI__builtin_riscv_nds_fcvt_bf16_s: {
158 cgm.errorNYI(e->getSourceRange(),
159 std::string("unimplemented RISC-V builtin call: ") +
160 getContext().BuiltinInfo.getName(builtinID));
161 return mlir::Value{};
162 }
163
164 // TODO: Handle vector builtins in tablegen.
165 }
166
167 mlir::Location loc = getLoc(e->getSourceRange());
168 return builder.emitIntrinsicCallOp(loc, intrinsicName, returnType, ops);
169}
Enumerates target-specific builtins in their own namespaces within namespace clang.
QualType GetBuiltinType(unsigned ID, GetBuiltinTypeError &Error, unsigned *IntegerConstantArgs=nullptr) const
Return the type for the specified builtin.
@ GE_None
No error.
mlir::Type convertType(clang::QualType t)
mlir::Location getLoc(clang::SourceLocation srcLoc)
Helpers to convert Clang's SourceLocation to a MLIR Location.
std::optional< mlir::Value > emitRISCVBuiltinExpr(unsigned builtinID, const CallExpr *expr)
clang::ASTContext & getContext() const
mlir::Value emitScalarOrConstFoldImmArg(unsigned iceArguments, unsigned idx, const Expr *argExpr)
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
Definition Expr.h:2946
arg_range arguments()
Definition Expr.h:3198
QualType getType() const
Definition Expr.h:144
SourceRange getSourceRange() const LLVM_READONLY
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpre...
Definition Stmt.cpp:343
The JSON file list parser is used to communicate input to InstallAPI.