From 109aa3c61748398ad355b4b608deed5840c2f3c3 Mon Sep 17 00:00:00 2001 From: Will Dietz Date: Mon, 23 Jan 2023 09:00:14 -0600 Subject: [PATCH] [patch] Clarify cover string argument as comment not message. (#64) This is different than the explanatory message argument on assert and assume statements. --- revision-history.yaml | 2 ++ spec.md | 12 +++++++----- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/revision-history.yaml b/revision-history.yaml index e1a594bb..65aa28ff 100644 --- a/revision-history.yaml +++ b/revision-history.yaml @@ -16,6 +16,8 @@ revisionHistory: Compiler implementations - Fix spelling/grammar issues - Allow out-of-bounds errors to be caught at compile time. + - Clarify the string argument for cover is a comment, not a message + as it is for assert and assume. # Information about the old versions. This should be static. oldVersions: - version: 1.1.0 diff --git a/spec.md b/spec.md index 72797c76..43ca6b76 100644 --- a/spec.md +++ b/spec.md @@ -1632,11 +1632,12 @@ Format strings support the following escape characters: To facilitate simulation, model checking and formal methods, there are three non-synthesizable verification statements available: assert, assume and cover. Each type of verification statement requires a clock signal, a predicate -signal, an enable signal and an explanatory message string literal. The -predicate and enable signals must have single bit unsigned integer type. When an -assert is violated the explanatory message may be issued as guidance. The -explanatory message may be phrased as if prefixed by the words "Verifies -that\...". +signal, an enable signal and a string literal. The predicate and enable +signals must have single bit unsigned integer type. Assert and assume use the +string as an explanatory message. For cover statements the string indicates a +suggested comment. When an assert or assume is violated the explanatory +message may be issued as guidance. The explanatory message may be phrased as +if prefixed by the words "Verifies that\...". Backends are free to generate the corresponding model checking constructs in the target language, but this is not required by the FIRRTL specification. Backends @@ -1691,6 +1692,7 @@ The cover statement verifies that the predicate is true on the rising edge of some clock cycle when the enable is true. In other words, it directs the model checker to find some way to make both enable and predicate true at some time step. +The string argument may be emitted as a comment with the cover. ``` firrtl wire clk: Clock