| // RUN: mlir-translate --export-smtlib %s | FileCheck %s |
| |
| smt.solver () : () -> () { |
| %0 = smt.int.constant 5 |
| %1 = smt.int.constant 10 |
| |
| // CHECK: (assert (let (([[V0:.+]] (+ 5 5 5))) |
| // CHECK: (let (([[V1:.+]] (= [[V0]] 10))) |
| // CHECK: [[V1]]))) |
| |
| // CHECK-INLINED: (assert (= (+ 5 5 5) 10)) |
| %2 = smt.int.add %0, %0, %0 |
| %a2 = smt.eq %2, %1 : !smt.int |
| smt.assert %a2 |
| |
| // CHECK: (assert (let (([[V2:.+]] (* 5 5 5))) |
| // CHECK: (let (([[V3:.+]] (= [[V2]] 10))) |
| // CHECK: [[V3]]))) |
| |
| // CHECK-INLINED: (assert (= (* 5 5 5) 10)) |
| %3 = smt.int.mul %0, %0, %0 |
| %a3 = smt.eq %3, %1 : !smt.int |
| smt.assert %a3 |
| |
| // CHECK: (assert (let (([[V4:.+]] (- 5 5))) |
| // CHECK: (let (([[V5:.+]] (= [[V4]] 10))) |
| // CHECK: [[V5]]))) |
| |
| // CHECK-INLINED: (assert (= (- 5 5) 10)) |
| %4 = smt.int.sub %0, %0 |
| %a4 = smt.eq %4, %1 : !smt.int |
| smt.assert %a4 |
| |
| // CHECK: (assert (let (([[V6:.+]] (div 5 5))) |
| // CHECK: (let (([[V7:.+]] (= [[V6]] 10))) |
| // CHECK: [[V7]]))) |
| |
| // CHECK-INLINED: (assert (= (div 5 5) 10)) |
| %5 = smt.int.div %0, %0 |
| %a5 = smt.eq %5, %1 : !smt.int |
| smt.assert %a5 |
| |
| // CHECK: (assert (let (([[V8:.+]] (mod 5 5))) |
| // CHECK: (let (([[V9:.+]] (= [[V8]] 10))) |
| // CHECK: [[V9]]))) |
| |
| // CHECK-INLINED: (assert (= (mod 5 5) 10)) |
| %6 = smt.int.mod %0, %0 |
| %a6 = smt.eq %6, %1 : !smt.int |
| smt.assert %a6 |
| |
| // CHECK: (assert (let (([[V10:.+]] (<= 5 5))) |
| // CHECK: [[V10]])) |
| |
| // CHECK-INLINED: (assert (<= 5 5)) |
| %9 = smt.int.cmp le %0, %0 |
| smt.assert %9 |
| |
| // CHECK: (assert (let (([[V11:.+]] (< 5 5))) |
| // CHECK: [[V11]])) |
| |
| // CHECK-INLINED: (assert (< 5 5)) |
| %10 = smt.int.cmp lt %0, %0 |
| smt.assert %10 |
| |
| // CHECK: (assert (let (([[V12:.+]] (>= 5 5))) |
| // CHECK: [[V12]])) |
| |
| // CHECK-INLINED: (assert (>= 5 5)) |
| %11 = smt.int.cmp ge %0, %0 |
| smt.assert %11 |
| |
| // CHECK: (assert (let (([[V13:.+]] (> 5 5))) |
| // CHECK: [[V13]])) |
| |
| // CHECK-INLINED: (assert (> 5 5)) |
| %12 = smt.int.cmp gt %0, %0 |
| smt.assert %12 |
| |
| // CHECK: (reset) |
| // CHECK-INLINED: (reset) |
| } |