-
Notifications
You must be signed in to change notification settings - Fork 604
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[smt] treat stop with non-zero ret like an assertion (#2338)
We treat it as an assertion that the stop will never be enabled. stop(0) will still be ignored (but now demoted to a info from a warning).
- Loading branch information
Showing
2 changed files
with
78 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
63 changes: 63 additions & 0 deletions
63
src/test/scala/firrtl/backends/experimental/smt/end2end/AssertAssumeStopSpec.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package firrtl.backends.experimental.smt.end2end | ||
|
||
class AssertAssumeStopSpec extends EndToEndSMTBaseSpec { | ||
behavior.of("the SMT backend") | ||
|
||
private def prefix(ii: Int): String = | ||
s"""circuit AssertAssumStop$ii: | ||
| module AssertAssumStop$ii: | ||
| input clock: Clock | ||
| input a: UInt<8> | ||
| output b: UInt<8> | ||
| | ||
| b <= add(a, UInt(16)) | ||
| | ||
|""".stripMargin | ||
|
||
it should "support assertions" in { | ||
val src = prefix(0) + | ||
""" assert(clock, gt(b, a), lt(a, UInt(240)), "") : b_gt_a | ||
|""".stripMargin | ||
test(src, MCSuccess, kmax = 2) | ||
} | ||
|
||
it should "support assumptions" in { | ||
val src = prefix(1) + | ||
""" assert(clock, gt(b, a), UInt(1), "") : b_gt_a | ||
|""".stripMargin | ||
val srcWithAssume = prefix(2) + | ||
""" assert(clock, gt(b, a), UInt(1), "") : b_gt_a | ||
| assume(clock, lt(a, UInt(240)), UInt(1), "") : a_lt_240 | ||
|""".stripMargin | ||
// the assertion alone fails because of potential overflow | ||
test(src, MCFail(0), kmax = 2) | ||
// with the assumption that a is not too big, it works! | ||
test(srcWithAssume, MCSuccess, kmax = 2) | ||
} | ||
|
||
it should "treat stop with ret =/= 0 as assertion" in { | ||
val src = prefix(3) + | ||
""" stop(clock, not(gt(b, a)), 1) : b_gt_a | ||
|""".stripMargin | ||
val srcWithAssume = prefix(4) + | ||
""" stop(clock, not(gt(b, a)), 1) : b_gt_a | ||
| assume(clock, lt(a, UInt(240)), UInt(1), "") : a_lt_240 | ||
|""".stripMargin | ||
// the assertion alone fails because of potential overflow | ||
test(src, MCFail(0), kmax = 2) | ||
// with the assumption that a is not too big, it works! | ||
test(srcWithAssume, MCSuccess, kmax = 2) | ||
} | ||
|
||
it should "ignore stop with ret === 0" in { | ||
val src = prefix(5) + | ||
""" stop(clock, not(gt(b, a)), 1) : b_gt_a | ||
| assume(clock, lt(a, UInt(240)), UInt(1), "") : a_lt_240 | ||
| stop(clock, UInt(1), 0) : always_stop | ||
|""".stripMargin | ||
test(src, MCSuccess, kmax = 2) | ||
} | ||
|
||
} |