| // RUN: mlir-translate --export-smtlib %s | FileCheck %s |
| // RUN: mlir-translate --export-smtlib --smtlibexport-inline-single-use-values %s | FileCheck %s --check-prefix=CHECK-INLINED |
| |
| smt.solver () : () -> () { |
| %c0_bv32 = smt.bv.constant #smt.bv<0> : !smt.bv<32> |
| |
| // CHECK: (assert (let (([[V0:.+]] (bvneg #x00000000))) |
| // CHECK: (let (([[V1:.+]] (= [[V0]] #x00000000))) |
| // CHECK: [[V1]]))) |
| |
| // CHECK-INLINED: (assert (= (bvneg #x00000000) #x00000000)) |
| %0 = smt.bv.neg %c0_bv32 : !smt.bv<32> |
| %a0 = smt.eq %0, %c0_bv32 : !smt.bv<32> |
| smt.assert %a0 |
| |
| // CHECK: (assert (let (([[V2:.+]] (bvadd #x00000000 #x00000000))) |
| // CHECK: (let (([[V3:.+]] (= [[V2]] #x00000000))) |
| // CHECK: [[V3]]))) |
| |
| // CHECK-INLINED: (assert (= (bvadd #x00000000 #x00000000) #x00000000)) |
| %1 = smt.bv.add %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a1 = smt.eq %1, %c0_bv32 : !smt.bv<32> |
| smt.assert %a1 |
| |
| // CHECK: (assert (let (([[V4:.+]] (bvmul #x00000000 #x00000000))) |
| // CHECK: (let (([[V5:.+]] (= [[V4]] #x00000000))) |
| // CHECK: [[V5]]))) |
| |
| // CHECK-INLINED: (assert (= (bvmul #x00000000 #x00000000) #x00000000)) |
| %3 = smt.bv.mul %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a3 = smt.eq %3, %c0_bv32 : !smt.bv<32> |
| smt.assert %a3 |
| |
| // CHECK: (assert (let (([[V6:.+]] (bvurem #x00000000 #x00000000))) |
| // CHECK: (let (([[V7:.+]] (= [[V6]] #x00000000))) |
| // CHECK: [[V7]]))) |
| |
| // CHECK-INLINED: (assert (= (bvurem #x00000000 #x00000000) #x00000000)) |
| %4 = smt.bv.urem %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a4 = smt.eq %4, %c0_bv32 : !smt.bv<32> |
| smt.assert %a4 |
| |
| // CHECK: (assert (let (([[V8:.+]] (bvsrem #x00000000 #x00000000))) |
| // CHECK: (let (([[V9:.+]] (= [[V8]] #x00000000))) |
| // CHECK: [[V9]]))) |
| |
| // CHECK-INLINED: (assert (= (bvsrem #x00000000 #x00000000) #x00000000)) |
| %5 = smt.bv.srem %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a5 = smt.eq %5, %c0_bv32 : !smt.bv<32> |
| smt.assert %a5 |
| |
| // CHECK: (assert (let (([[V10:.+]] (bvsmod #x00000000 #x00000000))) |
| // CHECK: (let (([[V11:.+]] (= [[V10]] #x00000000))) |
| // CHECK: [[V11]]))) |
| |
| // CHECK-INLINED: (assert (= (bvsmod #x00000000 #x00000000) #x00000000)) |
| %7 = smt.bv.smod %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a7 = smt.eq %7, %c0_bv32 : !smt.bv<32> |
| smt.assert %a7 |
| |
| // CHECK: (assert (let (([[V12:.+]] (bvshl #x00000000 #x00000000))) |
| // CHECK: (let (([[V13:.+]] (= [[V12]] #x00000000))) |
| // CHECK: [[V13]]))) |
| |
| // CHECK-INLINED: (assert (= (bvshl #x00000000 #x00000000) #x00000000)) |
| %8 = smt.bv.shl %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a8 = smt.eq %8, %c0_bv32 : !smt.bv<32> |
| smt.assert %a8 |
| |
| // CHECK: (assert (let (([[V14:.+]] (bvlshr #x00000000 #x00000000))) |
| // CHECK: (let (([[V15:.+]] (= [[V14]] #x00000000))) |
| // CHECK: [[V15]]))) |
| |
| // CHECK-INLINED: (assert (= (bvlshr #x00000000 #x00000000) #x00000000)) |
| %9 = smt.bv.lshr %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a9 = smt.eq %9, %c0_bv32 : !smt.bv<32> |
| smt.assert %a9 |
| |
| // CHECK: (assert (let (([[V16:.+]] (bvashr #x00000000 #x00000000))) |
| // CHECK: (let (([[V17:.+]] (= [[V16]] #x00000000))) |
| // CHECK: [[V17]]))) |
| |
| // CHECK-INLINED: (assert (= (bvashr #x00000000 #x00000000) #x00000000)) |
| %10 = smt.bv.ashr %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a10 = smt.eq %10, %c0_bv32 : !smt.bv<32> |
| smt.assert %a10 |
| |
| // CHECK: (assert (let (([[V18:.+]] (bvudiv #x00000000 #x00000000))) |
| // CHECK: (let (([[V19:.+]] (= [[V18]] #x00000000))) |
| // CHECK: [[V19]]))) |
| |
| // CHECK-INLINED: (assert (= (bvudiv #x00000000 #x00000000) #x00000000)) |
| %11 = smt.bv.udiv %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a11 = smt.eq %11, %c0_bv32 : !smt.bv<32> |
| smt.assert %a11 |
| |
| // CHECK: (assert (let (([[V20:.+]] (bvsdiv #x00000000 #x00000000))) |
| // CHECK: (let (([[V21:.+]] (= [[V20]] #x00000000))) |
| // CHECK: [[V21]]))) |
| |
| // CHECK-INLINED: (assert (= (bvsdiv #x00000000 #x00000000) #x00000000)) |
| %12 = smt.bv.sdiv %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a12 = smt.eq %12, %c0_bv32 : !smt.bv<32> |
| smt.assert %a12 |
| |
| // CHECK: (assert (let (([[V22:.+]] (bvnot #x00000000))) |
| // CHECK: (let (([[V23:.+]] (= [[V22]] #x00000000))) |
| // CHECK: [[V23]]))) |
| |
| // CHECK-INLINED: (assert (= (bvnot #x00000000) #x00000000)) |
| %13 = smt.bv.not %c0_bv32 : !smt.bv<32> |
| %a13 = smt.eq %13, %c0_bv32 : !smt.bv<32> |
| smt.assert %a13 |
| |
| // CHECK: (assert (let (([[V24:.+]] (bvand #x00000000 #x00000000))) |
| // CHECK: (let (([[V25:.+]] (= [[V24]] #x00000000))) |
| // CHECK: [[V25]]))) |
| |
| // CHECK-INLINED: (assert (= (bvand #x00000000 #x00000000) #x00000000)) |
| %14 = smt.bv.and %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a14 = smt.eq %14, %c0_bv32 : !smt.bv<32> |
| smt.assert %a14 |
| |
| // CHECK: (assert (let (([[V26:.+]] (bvor #x00000000 #x00000000))) |
| // CHECK: (let (([[V27:.+]] (= [[V26]] #x00000000))) |
| // CHECK: [[V27]]))) |
| |
| // CHECK-INLINED: (assert (= (bvor #x00000000 #x00000000) #x00000000)) |
| %15 = smt.bv.or %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a15 = smt.eq %15, %c0_bv32 : !smt.bv<32> |
| smt.assert %a15 |
| |
| // CHECK: (assert (let (([[V28:.+]] (bvxor #x00000000 #x00000000))) |
| // CHECK: (let (([[V29:.+]] (= [[V28]] #x00000000))) |
| // CHECK: [[V29]]))) |
| |
| // CHECK-INLINED: (assert (= (bvxor #x00000000 #x00000000) #x00000000)) |
| %16 = smt.bv.xor %c0_bv32, %c0_bv32 : !smt.bv<32> |
| %a16 = smt.eq %16, %c0_bv32 : !smt.bv<32> |
| smt.assert %a16 |
| |
| // CHECK: (assert (let (([[V30:.+]] (bvslt #x00000000 #x00000000))) |
| // CHECK: [[V30]])) |
| |
| // CHECK-INLINED: (assert (bvslt #x00000000 #x00000000)) |
| %27 = smt.bv.cmp slt %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %27 |
| |
| // CHECK: (assert (let (([[V31:.+]] (bvsle #x00000000 #x00000000))) |
| // CHECK: [[V31]])) |
| |
| // CHECK-INLINED: (assert (bvsle #x00000000 #x00000000)) |
| %28 = smt.bv.cmp sle %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %28 |
| |
| // CHECK: (assert (let (([[V32:.+]] (bvsgt #x00000000 #x00000000))) |
| // CHECK: [[V32]])) |
| |
| // CHECK-INLINED: (assert (bvsgt #x00000000 #x00000000)) |
| %29 = smt.bv.cmp sgt %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %29 |
| |
| // CHECK: (assert (let (([[V33:.+]] (bvsge #x00000000 #x00000000))) |
| // CHECK: [[V33]])) |
| |
| // CHECK-INLINED: (assert (bvsge #x00000000 #x00000000)) |
| %30 = smt.bv.cmp sge %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %30 |
| |
| // CHECK: (assert (let (([[V34:.+]] (bvult #x00000000 #x00000000))) |
| // CHECK: [[V34]])) |
| |
| // CHECK-INLINED: (assert (bvult #x00000000 #x00000000)) |
| %31 = smt.bv.cmp ult %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %31 |
| |
| // CHECK: (assert (let (([[V35:.+]] (bvule #x00000000 #x00000000))) |
| // CHECK: [[V35]])) |
| |
| // CHECK-INLINED: (assert (bvule #x00000000 #x00000000)) |
| %32 = smt.bv.cmp ule %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %32 |
| |
| // CHECK: (assert (let (([[V36:.+]] (bvugt #x00000000 #x00000000))) |
| // CHECK: [[V36]])) |
| |
| // CHECK-INLINED: (assert (bvugt #x00000000 #x00000000)) |
| %33 = smt.bv.cmp ugt %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %33 |
| |
| // CHECK: (assert (let (([[V37:.+]] (bvuge #x00000000 #x00000000))) |
| // CHECK: [[V37]])) |
| |
| // CHECK-INLINED: (assert (bvuge #x00000000 #x00000000)) |
| %34 = smt.bv.cmp uge %c0_bv32, %c0_bv32 : !smt.bv<32> |
| smt.assert %34 |
| |
| // CHECK: (assert (let (([[V38:.+]] (concat #x00000000 #x00000000))) |
| // CHECK: (let (([[V39:.+]] ((_ extract 23 8) [[V38]]))) |
| // CHECK: (let (([[V40:.+]] ((_ repeat 2) [[V39]]))) |
| // CHECK: (let (([[V41:.+]] (= [[V40]] #x00000000))) |
| // CHECK: [[V41]]))))) |
| |
| // CHECK-INLINED: (assert (= ((_ repeat 2) ((_ extract 23 8) (concat #x00000000 #x00000000))) #x00000000)) |
| %35 = smt.bv.concat %c0_bv32, %c0_bv32 : !smt.bv<32>, !smt.bv<32> |
| %36 = smt.bv.extract %35 from 8 : (!smt.bv<64>) -> !smt.bv<16> |
| %37 = smt.bv.repeat 2 times %36 : !smt.bv<16> |
| %a37 = smt.eq %37, %c0_bv32 : !smt.bv<32> |
| smt.assert %a37 |
| |
| // CHECK: (reset) |
| // CHECK-INLINED: (reset) |
| } |