[Mlir-commits] [mlir] [mlir][arith] adding addition regression tests (PR #96973)
Andrzej WarzyĆski
llvmlistbot at llvm.org
Sun Jun 30 08:54:14 PDT 2024
================
@@ -0,0 +1,57 @@
+// Tests arith operations on i1 type.
+// These tests are intended to be target agnostic: they should yield the same results
+// regardless of the target platform.
+
+// RUN: mlir-opt %s --convert-scf-to-cf --convert-cf-to-llvm --convert-vector-to-llvm \
+// RUN: --convert-func-to-llvm --convert-arith-to-llvm | \
+// RUN: mlir-cpu-runner -e entry -entry-point-result=void \
+// RUN: --shared-libs=%mlir_c_runner_utils | \
+// RUN: FileCheck %s --match-full-lines
+
+func.func @zero_plus_one_on_i1() {
+ // addi on i1
+ // addi(0, 1) : i1 = 1 : i1; addi(0, -1) : i1 = 1
+ // CHECK: 1
+ // CHECK-NEXT: 1
+ // CHECK-NEXT: 1
+ %false = arith.constant 0 : i1
+ %true = arith.constant 1 : i1
+ %true_0 = arith.constant -1 : i1
+ vector.print %true_0 : i1
+ %0 = arith.addi %false, %true : i1
+ vector.print %0 : i1
+ %1 = arith.addi %false, %true_0 : i1
+ vector.print %1 : i1
+ return
+}
+
+func.func @addui_extended_i1() {
+ // addui_extended on i1
+ // addui_extended 1 1 : i1 = 0, 1
+ // CHECK-NEXT: 0
+ // CHECK-NEXT: 1
+ %true = arith.constant 1 : i1
+ %sum, %overflow = arith.addui_extended %true, %true : i1, i1
+ vector.print %sum : i1
+ vector.print %overflow : i1
+ return
+}
+
+func.func @addui_extended_overflow_bit_is_n1() {
+ // addui_extended overflow bit is treated as -1
+ // addui_extended -1633386 -1643386 = ... 1 (overflow because negative numbers are large positive numbers)
+ // CHECK-NEXT: 0
+ %c-16433886_i64 = arith.constant -16433886 : i64
+ %sum, %overflow = arith.addui_extended %c-16433886_i64, %c-16433886_i64 : i64, i1
+ %false = arith.constant false
+ %0 = arith.cmpi sge, %overflow, %false : i1
----------------
banach-space wrote:
OK, now I understand what's being tested here. From what I can tell, that's unrelated to `arith.addui_extended`.
This is basically verifying the behaviour of `arith.cmpi` when doing "signed" comparison. `%overflow` is `true`, so that's a binary "1". When interpreting binary "1" as a signed value (that's what happens when using `sge`), it becomes "-1". The origin of `%overflow` doesn't matter though and you can test this behaviour without using `arith.addui_extended`.
I suggest changing this test and moving to a dedicated file (e.g. "comparison.mlir"). I would write something like this (feel free to re-use):
```mlir
func.func @cmpi_sge_i1(%lhs : i1, %rhs :i1) {
%res = arith.cmpi uge, %lhs, %rhs : i1
vector.print %res : i1
return
}
func.func @cmpi_uge_i1(%lhs : i1, %rhs :i1) {
%res = arith.cmpi uge, %lhs, %rhs : i1
vector.print %res : i1
return
}
func.func @entry() {
%false = arith.constant false
%true = arith.constant false
// CHECK:
func.call @cmpi_sge_i1(%false, %true) : () -> ()
// CHECK:
func.call @cmpi_sge_i1(%true, %false) : () -> ()
// CHECK:
func.call @cmpi_uge_i1(%false, %true) : () -> ()
// CHECK:
func.call @cmpi_uge_i1(%true, %false) : () -> ()
// TODO: sgt, ugt, eq, ne ...
return
}
```
[nit] Try using descriptive variables names (instead of e.g. `%0`). Also, I would avoid defining `%0` once `%1` has already been defined. If you want to use integers to name vars, please name them in "order" (i.e. `%0` followed by `%1`, then `%2` etc).
https://github.com/llvm/llvm-project/pull/96973
More information about the Mlir-commits
mailing list