Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 1 | // Copyright lowRISC contributors. |
| 2 | // Licensed under the Apache License, Version 2.0, see LICENSE for details. |
| 3 | // SPDX-License-Identifier: Apache-2.0 |
| 4 | // |
| 5 | // Assertions for ${dut.name}. |
| 6 | // Intended to be used with a formal tool. |
| 7 | |
Greg Chadwick | cf42308 | 2020-02-05 16:52:23 +0000 | [diff] [blame] | 8 | `include "prim_assert.sv" |
| 9 | |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 10 | % if len(dut.pkgs) > 0: |
Michael Schaffner | 8446204 | 2019-12-04 18:46:19 -0800 | [diff] [blame] | 11 | module ${dut.name}_assert_fpv |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 12 | % for pkg in dut.pkgs: |
| 13 | import ${pkg}; |
| 14 | % endfor |
| 15 | % if dut.params: |
| 16 | #( |
| 17 | % else: |
| 18 | ( |
| 19 | % endif |
| 20 | % else: |
| 21 | % if dut.params: |
| 22 | module ${dut.name}_assert_fpv #( |
| 23 | % else: |
| 24 | module ${dut.name}_assert_fpv ( |
| 25 | % endif |
| 26 | % endif |
| 27 | % if dut.params: |
| 28 | % for k, param in enumerate(dut.params): |
| 29 | <% comma = "" if (k == len(dut.params)-1) else "," %> ${param.style} ${param.datatype} ${param.name} =${param.value}${comma} |
| 30 | % endfor |
| 31 | ) ( |
| 32 | % endif |
| 33 | % for k, port in enumerate(dut.ports): |
| 34 | <% comma = "" if (k == len(dut.ports)-1) else "," %> input ${port.datatype} ${port.name}${comma} |
| 35 | % endfor |
| 36 | ); |
| 37 | |
| 38 | /////////////////////////////// |
| 39 | // Declarations & Parameters // |
| 40 | /////////////////////////////// |
| 41 | |
Michael Schaffner | 8a4c043 | 2019-12-06 15:02:45 -0800 | [diff] [blame] | 42 | ///////////////// |
| 43 | // Assumptions // |
| 44 | ///////////////// |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 45 | |
Greg Chadwick | 46ede4b | 2020-01-14 12:46:39 +0000 | [diff] [blame] | 46 | // `ASSUME(MyAssumption_M, ...) |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 47 | |
Michael Schaffner | 8a4c043 | 2019-12-06 15:02:45 -0800 | [diff] [blame] | 48 | //////////////////////// |
| 49 | // Forward Assertions // |
| 50 | //////////////////////// |
| 51 | |
Greg Chadwick | 46ede4b | 2020-01-14 12:46:39 +0000 | [diff] [blame] | 52 | // `ASSERT(MyFwdAssertion_A, ...) |
Michael Schaffner | 8a4c043 | 2019-12-06 15:02:45 -0800 | [diff] [blame] | 53 | |
Michael Schaffner | ccef827 | 2019-12-06 08:54:55 -0800 | [diff] [blame] | 54 | ///////////////////////// |
| 55 | // Backward Assertions // |
| 56 | ///////////////////////// |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 57 | |
Greg Chadwick | 46ede4b | 2020-01-14 12:46:39 +0000 | [diff] [blame] | 58 | // `ASSERT(MyBkwdAssertion_A, ...) |
Michael Schaffner | b5a88f2 | 2019-11-26 19:43:37 -0800 | [diff] [blame] | 59 | |
| 60 | endmodule : ${dut.name}_assert_fpv |