[llvm] [CodeGen] Add preliminary plumbing for `samesign` flag (PR #112354)

Antonio Frighetto via llvm-commits llvm-commits at lists.llvm.org
Wed Oct 30 07:04:36 PDT 2024


================
@@ -0,0 +1,38 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5
+# RUN: llc -march=x86-64 -run-pass none -verify-machineinstrs -o - %s | FileCheck %s
+
+--- |
+
+  define i1 @icmp_samesign(i32 %a, i32 %b) {
+  entry:
+    %res = icmp samesign ult i32 %a, %b
+    ret i1 %res
+  }
+
+...
+---
+name:            icmp_samesign
+tracksRegLiveness: true
+registers:
+  - { id: 0, class: gr32 }
+  - { id: 1, class: gr32 }
+liveins:
+  - { reg: '$edi', virtual-reg: '%0' }
+  - { reg: '$esi', virtual-reg: '%1' }
+body: |
+  bb.0.entry:
+    liveins: $edi, $esi
+    ; CHECK-LABEL: name: icmp_samesign
+    ; CHECK: liveins: $edi, $esi
+    ; CHECK-NEXT: {{  $}}
+    ; CHECK-NEXT: [[COPY:%[0-9]+]]:gr32 = COPY $esi
+    ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gr32 = COPY $edi
+    ; CHECK-NEXT: samesign CMP32rr killed [[COPY1]], killed [[COPY]], implicit-def $eflags
+    ; CHECK-NEXT: $al = SETCCr 2, implicit killed $eflags
+    ; CHECK-NEXT: RET 0, $al
+    %1 = COPY $esi
+    %0 = COPY $edi
+    samesign CMP32rr killed %0, killed %1, implicit-def $eflags
+    $al = SETCCr 2, implicit killed $eflags
----------------
antoniofrighetto wrote:

Changed the test to use generic MIR. The gMIR comes from GISel, stopping before legalization. Also rebased to main for the recent enum change.

https://github.com/llvm/llvm-project/pull/112354


More information about the llvm-commits mailing list