Author: Jianjian Guan
Date: 2026-03-25T17:27:51+08:00
New Revision: b549b3378f5613f9e136e8d3003603b826906e39

URL: 
https://github.com/llvm/llvm-project/commit/b549b3378f5613f9e136e8d3003603b826906e39
DIFF: 
https://github.com/llvm/llvm-project/commit/b549b3378f5613f9e136e8d3003603b826906e39.diff

LOG: [CIR][RISCV][NFC] Add CIRGenBuiltinRISCV file to support RISCV builtins 
codegen (#186050)

This PR adds CIRGenBuiltinRISCV.cpp file for RISCV specific builtins
codegen support.
List all builtins except vector builtins which need tablegen, and mark
them as "NYI".

Added: 
    clang/lib/CIR/CodeGen/CIRGenBuiltinRISCV.cpp

Modified: 
    clang/lib/CIR/CodeGen/CIRGenBuiltin.cpp
    clang/lib/CIR/CodeGen/CIRGenFunction.h
    clang/lib/CIR/CodeGen/CMakeLists.txt

Removed: 
    


################################################################################
diff  --git a/clang/lib/CIR/CodeGen/CIRGenBuiltin.cpp 
b/clang/lib/CIR/CodeGen/CIRGenBuiltin.cpp
index 1c62543d40bb3..06dfdcb7c8014 100644
--- a/clang/lib/CIR/CodeGen/CIRGenBuiltin.cpp
+++ b/clang/lib/CIR/CodeGen/CIRGenBuiltin.cpp
@@ -2384,11 +2384,12 @@ emitTargetArchBuiltinExpr(CIRGenFunction *cgf, unsigned 
builtinID,
   case llvm::Triple::wasm32:
   case llvm::Triple::wasm64:
   case llvm::Triple::hexagon:
-  case llvm::Triple::riscv32:
-  case llvm::Triple::riscv64:
     // These are actually NYI, but that will be reported by emitBuiltinExpr.
     // At this point, we don't even know that the builtin is target-specific.
     return std::nullopt;
+  case llvm::Triple::riscv32:
+  case llvm::Triple::riscv64:
+    return cgf->emitRISCVBuiltinExpr(builtinID, e);
   default:
     return std::nullopt;
   }

diff  --git a/clang/lib/CIR/CodeGen/CIRGenBuiltinRISCV.cpp 
b/clang/lib/CIR/CodeGen/CIRGenBuiltinRISCV.cpp
new file mode 100644
index 0000000000000..899ba253be7c9
--- /dev/null
+++ b/clang/lib/CIR/CodeGen/CIRGenBuiltinRISCV.cpp
@@ -0,0 +1,112 @@
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM 
Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+//
+// This contains code to emit RISC-V Builtin calls as CIR or a function call
+// to be later resolved.
+//
+//===----------------------------------------------------------------------===//
+
+#include "CIRGenFunction.h"
+#include "clang/Basic/TargetBuiltins.h"
+
+using namespace clang;
+using namespace clang::CIRGen;
+
+std::optional<mlir::Value>
+CIRGenFunction::emitRISCVBuiltinExpr(unsigned builtinID, const CallExpr *e) {
+  if (builtinID == Builtin::BI__builtin_cpu_supports ||
+      builtinID == Builtin::BI__builtin_cpu_init ||
+      builtinID == Builtin::BI__builtin_cpu_is) {
+    cgm.errorNYI(e->getSourceRange(),
+                 std::string("unimplemented RISC-V builtin call: ") +
+                     getContext().BuiltinInfo.getName(builtinID));
+    return mlir::Value{};
+  }
+  switch (builtinID) {
+  default:
+    llvm_unreachable("unexpected builtin ID");
+
+  // Zbb
+  case RISCV::BI__builtin_riscv_orc_b_32:
+  case RISCV::BI__builtin_riscv_orc_b_64:
+  // Zbc
+  case RISCV::BI__builtin_riscv_clmul_32:
+  case RISCV::BI__builtin_riscv_clmul_64:
+  case RISCV::BI__builtin_riscv_clmulh_32:
+  case RISCV::BI__builtin_riscv_clmulh_64:
+  case RISCV::BI__builtin_riscv_clmulr_32:
+  case RISCV::BI__builtin_riscv_clmulr_64:
+  // Zbkx
+  case RISCV::BI__builtin_riscv_xperm4_32:
+  case RISCV::BI__builtin_riscv_xperm4_64:
+  case RISCV::BI__builtin_riscv_xperm8_32:
+  case RISCV::BI__builtin_riscv_xperm8_64:
+  // Zbkb
+  case RISCV::BI__builtin_riscv_brev8_32:
+  case RISCV::BI__builtin_riscv_brev8_64:
+  case RISCV::BI__builtin_riscv_zip_32:
+  case RISCV::BI__builtin_riscv_unzip_32:
+  // Zknh
+  case RISCV::BI__builtin_riscv_sha256sig0:
+  case RISCV::BI__builtin_riscv_sha256sig1:
+  case RISCV::BI__builtin_riscv_sha256sum0:
+  case RISCV::BI__builtin_riscv_sha256sum1:
+  // Zksed
+  case RISCV::BI__builtin_riscv_sm4ks:
+  case RISCV::BI__builtin_riscv_sm4ed:
+  // Zksh
+  case RISCV::BI__builtin_riscv_sm3p0:
+  case RISCV::BI__builtin_riscv_sm3p1:
+  // Zbb
+  case RISCV::BI__builtin_riscv_clz_32:
+  case RISCV::BI__builtin_riscv_clz_64:
+  case RISCV::BI__builtin_riscv_ctz_32:
+  case RISCV::BI__builtin_riscv_ctz_64:
+  // Zihintntl
+  case RISCV::BI__builtin_riscv_ntl_load:
+  case RISCV::BI__builtin_riscv_ntl_store:
+  // Zihintpause
+  case RISCV::BI__builtin_riscv_pause:
+  // XCValu
+  case RISCV::BI__builtin_riscv_cv_alu_addN:
+  case RISCV::BI__builtin_riscv_cv_alu_addRN:
+  case RISCV::BI__builtin_riscv_cv_alu_adduN:
+  case RISCV::BI__builtin_riscv_cv_alu_adduRN:
+  case RISCV::BI__builtin_riscv_cv_alu_clip:
+  case RISCV::BI__builtin_riscv_cv_alu_clipu:
+  case RISCV::BI__builtin_riscv_cv_alu_extbs:
+  case RISCV::BI__builtin_riscv_cv_alu_extbz:
+  case RISCV::BI__builtin_riscv_cv_alu_exths:
+  case RISCV::BI__builtin_riscv_cv_alu_exthz:
+  case RISCV::BI__builtin_riscv_cv_alu_sle:
+  case RISCV::BI__builtin_riscv_cv_alu_sleu:
+  case RISCV::BI__builtin_riscv_cv_alu_subN:
+  case RISCV::BI__builtin_riscv_cv_alu_subRN:
+  case RISCV::BI__builtin_riscv_cv_alu_subuN:
+  case RISCV::BI__builtin_riscv_cv_alu_subuRN:
+  // XAndesPerf
+  case RISCV::BI__builtin_riscv_nds_ffb_32:
+  case RISCV::BI__builtin_riscv_nds_ffb_64:
+  case RISCV::BI__builtin_riscv_nds_ffzmism_32:
+  case RISCV::BI__builtin_riscv_nds_ffzmism_64:
+  case RISCV::BI__builtin_riscv_nds_ffmism_32:
+  case RISCV::BI__builtin_riscv_nds_ffmism_64:
+  case RISCV::BI__builtin_riscv_nds_flmism_32:
+  case RISCV::BI__builtin_riscv_nds_flmism_64:
+  // XAndesBFHCvt
+  case RISCV::BI__builtin_riscv_nds_fcvt_s_bf16:
+  case RISCV::BI__builtin_riscv_nds_fcvt_bf16_s: {
+    cgm.errorNYI(e->getSourceRange(),
+                 std::string("unimplemented RISC-V builtin call: ") +
+                     getContext().BuiltinInfo.getName(builtinID));
+    return mlir::Value{};
+  }
+
+    // TODO: Handle vector builtins in tablegen.
+  }
+}

diff  --git a/clang/lib/CIR/CodeGen/CIRGenFunction.h 
b/clang/lib/CIR/CodeGen/CIRGenFunction.h
index 153bc19ab2f31..d80c2d635a89f 100644
--- a/clang/lib/CIR/CodeGen/CIRGenFunction.h
+++ b/clang/lib/CIR/CodeGen/CIRGenFunction.h
@@ -1939,6 +1939,9 @@ class CIRGenFunction : public CIRGenTypeCache {
 
   mlir::LogicalResult emitWhileStmt(const clang::WhileStmt &s);
 
+  std::optional<mlir::Value> emitRISCVBuiltinExpr(unsigned builtinID,
+                                                  const CallExpr *expr);
+
   std::optional<mlir::Value> emitX86BuiltinExpr(unsigned builtinID,
                                                 const CallExpr *expr);
 

diff  --git a/clang/lib/CIR/CodeGen/CMakeLists.txt 
b/clang/lib/CIR/CodeGen/CMakeLists.txt
index 8548cc8424527..439f77f7933dd 100644
--- a/clang/lib/CIR/CodeGen/CMakeLists.txt
+++ b/clang/lib/CIR/CodeGen/CMakeLists.txt
@@ -15,6 +15,7 @@ add_clang_library(clangCIR
   CIRGenBuiltinAArch64.cpp
   CIRGenBuiltinAMDGPU.cpp
   CIRGenAMDGPU.cpp
+  CIRGenBuiltinRISCV.cpp
   CIRGenBuiltinX86.cpp
   CIRGenCall.cpp
   CIRGenClass.cpp


        
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to