================
@@ -0,0 +1,27 @@
+// RUN: cir-opt %s -cir-to-llvm -o - | FileCheck %s
+
+// Contract test for CIRToLLVMLLVMIntrinsicCallOpLowering: the op def
+// declares Optional<CIR_AnyType>:$result, so the lowering must accept
+// 0-result (void) calls in addition to the single-result case.
+
+!s32i = !cir.int<s, 32>
+
+module {
+  // 0-result, 0-operand.
+  // CHECK-LABEL: llvm.func @void_no_operands
+  // CHECK:         llvm.call_intrinsic "llvm.donothing"() : () -> ()
+  // CHECK:         llvm.return
+  cir.func @void_no_operands() {
+    cir.call_llvm_intrinsic "donothing" : () -> ()
----------------
andykaylor wrote:

How did you get into this situation? We have existing builtin handlers that 
call LLVM intrinsics with a void return type, and they're implemented using an 
explicit void type. For example:

```
void test_lfence(void) {
  __builtin_ia32_lfence();
}
```
Produces this CIR:
```
  !void = !cir.void
  cir.func @test_lfence() {
    %0 = cir.call_llvm_intrinsic "x86.sse2.lfence"  : () -> !void
    cir.return loc(#loc2)
  }
```
Which lowers to this LLVM IR:
```
define dso_local void @test_lfence() {
  call void @llvm.x86.sse2.lfence()
  ret void
}
```

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

Reply via email to