diff options
author | dmcmahill <dmcmahill@pkgsrc.org> | 2003-02-04 02:42:21 +0000 |
---|---|---|
committer | dmcmahill <dmcmahill@pkgsrc.org> | 2003-02-04 02:42:21 +0000 |
commit | 1e92cff3aeda643be76b7ac7b15b2238a1617b64 (patch) | |
tree | 1569d7994f41267e9b3e40f7defd7a0b6457b864 /cad/covered-current/patches | |
parent | 773f30646f5b53cc20648d400a2069636333e0c0 (diff) | |
download | pkgsrc-1e92cff3aeda643be76b7ac7b15b2238a1617b64.tar.gz |
update to covered-current-20021214 as part of fixing compile problems noted
in recent bulk builds.
Release covered-20021214 made. This release is a bug fix release. See list below
for details. Bugs that lead to infinite looping in the score command and segmentation
faults should now be cleared up. Please let me know if there are any other bugs that
need to be addressed before first stable release. Development documentation updated
to match changes in files. Regression suite has been updated quite a bit from last
time. There are now over 125 diagnostics in the regression suite (my goal was to
write about 100 before first stable release).
- Segmentation fault fixes in report command
- Parser can now handle all net types (not just wire). Diagnostics added to regression
suite to verify their proper handling.
- Parser updated to handle net declaration assignments (e.g., wire a = b & c;).
Diagnostics added to verify proper handling.
- Added human-understandable error messages in parser to help identify file and
line number along with a quasi-helpful error message description.
- When parser error is found, Covered exits after parsing phase without continuing
to write CDD file.
- Fixed bug where a multi-bit select expression existed in a module that was
instantiated more than once. Assertion error fired in this case.
- Updated regression suite for VCS testing.
- Fixed bug where parameters were used in modules that were instantiated more than
once.
- Fixed bug that dealt with parameters (see param6.1.v for test case).
- Fixed bug where a delay statement was the last statement in a statement block used
by Covered. Added diagnostics to verify correct behavior.
- Fixed infinite loop problem with db_add_statement function.
- Fixed infinite loop problem with statement_set_stop function.
- Fixed bug with parsing order. When an instance is found for a module that has
already been parsed, the instance was incorrectly being handled. Bug replicated
with instance6.v diagnostic.
- Fixed output of edge-triggered events to add @(...) around the expression (they
were easily confused with other code that could exist on the same line).
- Fixed bug in parser to not allow module to be parsed more than once.
- Fixed bug that lead to an assertion error (see instance6.1.v for test case).
- Fixing bug with calculating list and concatenation lengths when MBIT_SEL
expressions were included.
- Changed Covered's handling of -y directories. Before, all files in these directories
were fed into the parser to look for missing modules. Now, when a module is needed,
the module name is used to find the matching filename in the -y list (basically,
the -y option works like the -y option in Icarus Verilog and VCS). This fix really
streamlined the parsing phase and fixed several bugs.
- Memory declarations are now properly ignored (produced segmentation fault previously).
- Fixed report command to display all lines and expressions in order according to
their line number (the problem is REALLY fixed now).
- Removed hierarchical references from being scored.
All in all, you should notice a huge improvement in the parsing speed, syntax errors are
reported better, more Verilog syntax should be handled properly, the score command will
run a bit faster than before, and the reports should be a bit easier to read. Segmentation
faults and assertion errors should become lesser in number (if not gone altogether?).
I am feeling pretty confident that we are getting close to a stable release as I have
been able to generate a CDD file for a chip that is millions of gates in size (CDD file
was created in the range of 30 - 45 seconds!) Keep the bug reports coming. I have some
things to work on for next release already.
Diffstat (limited to 'cad/covered-current/patches')
-rw-r--r-- | cad/covered-current/patches/patch-aa | 14 | ||||
-rw-r--r-- | cad/covered-current/patches/patch-ab | 15 | ||||
-rw-r--r-- | cad/covered-current/patches/patch-ac | 21 |
3 files changed, 50 insertions, 0 deletions
diff --git a/cad/covered-current/patches/patch-aa b/cad/covered-current/patches/patch-aa new file mode 100644 index 00000000000..2320478ceb4 --- /dev/null +++ b/cad/covered-current/patches/patch-aa @@ -0,0 +1,14 @@ +$NetBSD: patch-aa,v 1.1 2003/02/04 02:42:21 dmcmahill Exp $ + +--- src/parser_misc.h.orig Mon Nov 4 19:20:08 2002 ++++ src/parser_misc.h Mon Feb 3 21:19:22 2003 +@@ -23,4 +23,9 @@ + + #define YYLTYPE struct vlltype ++ ++/* This for compatibility with new and older bison versions. */ ++#ifndef yylloc ++# define yylloc VLlloc ++#endif + extern YYLTYPE yylloc; + diff --git a/cad/covered-current/patches/patch-ab b/cad/covered-current/patches/patch-ab new file mode 100644 index 00000000000..043d604f55c --- /dev/null +++ b/cad/covered-current/patches/patch-ab @@ -0,0 +1,15 @@ +$NetBSD: patch-ab,v 1.1 2003/02/04 02:42:21 dmcmahill Exp $ + +--- src/lexer.l.orig Thu Dec 5 21:18:59 2002 ++++ src/lexer.l Mon Feb 3 21:28:36 2003 +@@ -15,9 +15,9 @@ + #include "defines.h" + #include "signal.h" ++#include "parser_misc.h" + #include "parser.h" + #include "util.h" + #include "link.h" + #include "vector.h" +-#include "parser_misc.h" + #include "keywords.h" + diff --git a/cad/covered-current/patches/patch-ac b/cad/covered-current/patches/patch-ac new file mode 100644 index 00000000000..a114933c4e0 --- /dev/null +++ b/cad/covered-current/patches/patch-ac @@ -0,0 +1,21 @@ +$NetBSD: patch-ac,v 1.1 2003/02/04 02:42:22 dmcmahill Exp $ + +--- src/parser.y.orig Fri Dec 13 11:49:50 2002 ++++ src/parser.y Mon Feb 3 21:26:01 2003 +@@ -46,4 +46,16 @@ + int yydebug = 1; + */ ++ ++/* Recent version of bison expect that the user supply a ++ YYLLOC_DEFAULT macro that makes up a yylloc value from existing ++ values. I need to supply an explicit version to account for the ++ text field, that otherwise won't be copied. */ ++# define YYLLOC_DEFAULT(Current, Rhs, N) \ ++ Current.first_line = Rhs[1].first_line; \ ++ Current.first_column = Rhs[1].first_column; \ ++ Current.last_line = Rhs[N].last_line; \ ++ Current.last_column = Rhs[N].last_column; \ ++ Current.text = Rhs[1].text; ++ + %} + |