forked from github/verilator
Fix size-changing cast on packed struct, bug993.
Signed-off-by: Wilson Snyder <wsnyder@wsnyder.org>
This commit is contained in:
parent
7850f49963
commit
0081ce4a75
2
Changes
2
Changes
@ -7,6 +7,8 @@ indicates the contributor was also the author of the fix; Thanks!
|
|||||||
|
|
||||||
**** Fix real parameters causing bad module names, bug992. [Johan Bjork]
|
**** Fix real parameters causing bad module names, bug992. [Johan Bjork]
|
||||||
|
|
||||||
|
**** Fix size-changing cast on packed struct, bug993. [Johan Bjork]
|
||||||
|
|
||||||
|
|
||||||
* Verilator 3.878 2015-11-01
|
* Verilator 3.878 2015-11-01
|
||||||
|
|
||||||
|
@ -1017,6 +1017,9 @@ private:
|
|||||||
if (width < 1) { nodep->v3error("Size-changing cast to zero or negative size"); width=1; }
|
if (width < 1) { nodep->v3error("Size-changing cast to zero or negative size"); width=1; }
|
||||||
nodep->lhsp()->iterateAndNext(*this,WidthVP(SELF,PRELIM).p());
|
nodep->lhsp()->iterateAndNext(*this,WidthVP(SELF,PRELIM).p());
|
||||||
AstBasicDType* underDtp = nodep->lhsp()->dtypep()->castBasicDType();
|
AstBasicDType* underDtp = nodep->lhsp()->dtypep()->castBasicDType();
|
||||||
|
if (!underDtp) {
|
||||||
|
underDtp = nodep->lhsp()->dtypep()->basicp();
|
||||||
|
}
|
||||||
if (!underDtp) {
|
if (!underDtp) {
|
||||||
nodep->v3error("Unsupported: Size-changing cast on non-basic data type");
|
nodep->v3error("Unsupported: Size-changing cast on non-basic data type");
|
||||||
underDtp = nodep->findLogicBoolDType()->castBasicDType();
|
underDtp = nodep->findLogicBoolDType()->castBasicDType();
|
||||||
|
@ -8,6 +8,15 @@ module t;
|
|||||||
typedef logic [3:0] mc_t;
|
typedef logic [3:0] mc_t;
|
||||||
typedef mc_t tocast_t;
|
typedef mc_t tocast_t;
|
||||||
|
|
||||||
|
typedef struct packed {
|
||||||
|
logic [15:0] data;
|
||||||
|
} packed_t;
|
||||||
|
|
||||||
|
packed_t pdata;
|
||||||
|
assign pdata.data = 16'h1234;
|
||||||
|
logic [7:0] logic8bit;
|
||||||
|
assign logic8bit = $bits(logic8bit)'(pdata >> 8);
|
||||||
|
|
||||||
mc_t o;
|
mc_t o;
|
||||||
|
|
||||||
logic [15:0] allones = 16'hffff;
|
logic [15:0] allones = 16'hffff;
|
||||||
@ -31,6 +40,7 @@ module t;
|
|||||||
(27'(coeff2 * samp2) >>> 11)); // 15' size casting to avoid synthesis/simulator warnings
|
(27'(coeff2 * samp2) >>> 11)); // 15' size casting to avoid synthesis/simulator warnings
|
||||||
|
|
||||||
initial begin
|
initial begin
|
||||||
|
if (logic8bit != 8'h12) $stop;
|
||||||
if (4'shf > 4'sh0) $stop;
|
if (4'shf > 4'sh0) $stop;
|
||||||
if (signed'(4'hf) > 4'sh0) $stop;
|
if (signed'(4'hf) > 4'sh0) $stop;
|
||||||
if (4'hf < 4'h0) $stop;
|
if (4'hf < 4'h0) $stop;
|
||||||
|
Loading…
Reference in New Issue
Block a user