forked from github/verilator
parent
31079ca8b5
commit
62387a0e32
2
Changes
2
Changes
@ -24,7 +24,7 @@ Verilator 4.215 devel
|
|||||||
* Fix nested generate if genblk naming (#3189). [yanx21]
|
* Fix nested generate if genblk naming (#3189). [yanx21]
|
||||||
* Fix hang on recursive definition error (#3199). [Jonathan Kimmitt]
|
* Fix hang on recursive definition error (#3199). [Jonathan Kimmitt]
|
||||||
* Fix display of signed without format (#3204). [Julie Schwartz]
|
* Fix display of signed without format (#3204). [Julie Schwartz]
|
||||||
* Fix display of empty string constant (#3207). [Julie Schwartz]
|
* Fix display of empty string constant (#3207) (#3215). [Julie Schwartz]
|
||||||
* Fix incorrect width after and-or optimization (#3208). [Julie Schwartz]
|
* Fix incorrect width after and-or optimization (#3208). [Julie Schwartz]
|
||||||
* Fix $fopen etc on integer arrays (#3214). [adrienlemasle]
|
* Fix $fopen etc on integer arrays (#3214). [adrienlemasle]
|
||||||
* Fix $size on dynamic strings (#3216).
|
* Fix $size on dynamic strings (#3216).
|
||||||
|
@ -1939,7 +1939,15 @@ private:
|
|||||||
} else {
|
} else {
|
||||||
issigned = bdtypep->isSigned();
|
issigned = bdtypep->isSigned();
|
||||||
}
|
}
|
||||||
if (nodep->valuep()->dtypep()->widthSized()) {
|
if (valueBdtypep->isString()) {
|
||||||
|
// parameter X = "str", per IEEE is a number, not a string
|
||||||
|
if (const auto* const constp = VN_CAST(nodep->valuep(), Const)) {
|
||||||
|
if (constp->num().isString()) {
|
||||||
|
width = constp->num().toString().length() * 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (width < 8) width = 8;
|
||||||
|
} else if (nodep->valuep()->dtypep()->widthSized()) {
|
||||||
width = nodep->valuep()->width();
|
width = nodep->valuep()->width();
|
||||||
} else {
|
} else {
|
||||||
if (nodep->valuep()->width() > 32) {
|
if (nodep->valuep()->width() > 32) {
|
||||||
|
@ -10,6 +10,11 @@ module t;
|
|||||||
parameter string OS = "O";
|
parameter string OS = "O";
|
||||||
parameter OI = "O"; // B is an integer of width 8
|
parameter OI = "O"; // B is an integer of width 8
|
||||||
|
|
||||||
|
parameter bit [31:0] NEST = "NEST";
|
||||||
|
parameter bit [31:0] TEST = "TEST";
|
||||||
|
bit [31:0] rest;
|
||||||
|
string s;
|
||||||
|
|
||||||
initial begin
|
initial begin
|
||||||
$display(">< == >%s<", "");
|
$display(">< == >%s<", "");
|
||||||
$display(">< == >%s<", ES);
|
$display(">< == >%s<", ES);
|
||||||
@ -18,9 +23,23 @@ module t;
|
|||||||
if ($bits("") != 0) $stop;
|
if ($bits("") != 0) $stop;
|
||||||
if ($bits("A") != 8) $stop;
|
if ($bits("A") != 8) $stop;
|
||||||
if ($bits(ES) != 0) $stop;
|
if ($bits(ES) != 0) $stop;
|
||||||
|
if ($bits(EI) != 8) $stop;
|
||||||
if ($bits(OS) != 8) $stop;
|
if ($bits(OS) != 8) $stop;
|
||||||
if ($bits(OI) != 8) $stop;
|
if ($bits(OI) != 8) $stop;
|
||||||
|
|
||||||
|
if (ES == "TEST") $stop; // Illegal in some simulators as not both strings
|
||||||
|
if (EI == "TEST") $stop;
|
||||||
|
if (OS == "TEST") $stop; // Illegal in some simulators as not both strings
|
||||||
|
// verilator lint_off WIDTH
|
||||||
|
if (OI == "TEST") $stop;
|
||||||
|
if (rest == "TEST") $stop;
|
||||||
|
|
||||||
|
if (ES == TEST) $stop;
|
||||||
|
if (EI == TEST) $stop;
|
||||||
|
if (OS == TEST) $stop;
|
||||||
|
if (OI == TEST) $stop;
|
||||||
|
if (rest == TEST) $stop;
|
||||||
|
|
||||||
$write("*-* All Finished *-*\n");
|
$write("*-* All Finished *-*\n");
|
||||||
$finish;
|
$finish;
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user