parent
5676443139
commit
6c6f03cf7c
|
|
@ -1970,8 +1970,10 @@ private:
|
||||||
newp = new AstNToI{nodep->fileline(), nodep->fromp()->unlinkFrBack(), toDtp};
|
newp = new AstNToI{nodep->fileline(), nodep->fromp()->unlinkFrBack(), toDtp};
|
||||||
} else if (!basicp->isDouble() && !fromDtp->isDouble()) {
|
} else if (!basicp->isDouble() && !fromDtp->isDouble()) {
|
||||||
AstNodeDType* const origDTypep = nodep->dtypep();
|
AstNodeDType* const origDTypep = nodep->dtypep();
|
||||||
const int width = toDtp->width();
|
if (!VN_IS(fromDtp, StreamDType)) {
|
||||||
castSized(nodep, nodep->fromp(), width);
|
const int width = toDtp->width();
|
||||||
|
castSized(nodep, nodep->fromp(), width);
|
||||||
|
}
|
||||||
nodep->dtypeFrom(origDTypep); // If was enum, need dtype to preserve as enum
|
nodep->dtypeFrom(origDTypep); // If was enum, need dtype to preserve as enum
|
||||||
// Note castSized might modify nodep->fromp()
|
// Note castSized might modify nodep->fromp()
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -7362,9 +7364,9 @@ private:
|
||||||
// UNSUP unpacked struct/unions (treated like BasicDType)
|
// UNSUP unpacked struct/unions (treated like BasicDType)
|
||||||
const AstNodeDType* fromBaseDtp = computeCastableBase(fromDtp);
|
const AstNodeDType* fromBaseDtp = computeCastableBase(fromDtp);
|
||||||
|
|
||||||
const bool fromNumericable = VN_IS(fromBaseDtp, BasicDType)
|
const bool fromNumericable
|
||||||
|| VN_IS(fromBaseDtp, EnumDType)
|
= VN_IS(fromBaseDtp, BasicDType) || VN_IS(fromBaseDtp, EnumDType)
|
||||||
|| VN_IS(fromBaseDtp, NodeUOrStructDType);
|
|| VN_IS(fromBaseDtp, StreamDType) || VN_IS(fromBaseDtp, NodeUOrStructDType);
|
||||||
|
|
||||||
const AstNodeDType* toBaseDtp = computeCastableBase(toDtp);
|
const AstNodeDType* toBaseDtp = computeCastableBase(toDtp);
|
||||||
const bool toNumericable
|
const bool toNumericable
|
||||||
|
|
|
||||||
|
|
@ -8,15 +8,20 @@
|
||||||
`define checkh(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='h%x exp='h%x\n", `__FILE__,`__LINE__, (gotv), (expv)); $stop; end while(0);
|
`define checkh(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='h%x exp='h%x\n", `__FILE__,`__LINE__, (gotv), (expv)); $stop; end while(0);
|
||||||
`define checks(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='%s' exp='%s'\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
|
`define checks(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='%s' exp='%s'\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
|
||||||
|
|
||||||
|
typedef enum bit [5:0] {
|
||||||
|
A = 6'b111000,
|
||||||
|
B = 6,b111111
|
||||||
|
} enum_t;
|
||||||
|
|
||||||
module t (/*AUTOARG*/);
|
module t (/*AUTOARG*/);
|
||||||
initial begin
|
initial begin
|
||||||
bit arr[];
|
bit arr[];
|
||||||
bit [1:0] arr2[$];
|
bit [1:0] arr2[$];
|
||||||
bit [4:0] arr5[];
|
|
||||||
bit [5:0] arr6[$];
|
bit [5:0] arr6[$];
|
||||||
string v;
|
string v;
|
||||||
bit [5:0] bit6 = 6'b111000;
|
bit [5:0] bit6 = 6'b111000;
|
||||||
bit [5:0] ans;
|
bit [5:0] ans;
|
||||||
|
enum_t ans_enum;
|
||||||
|
|
||||||
{ >> bit {arr}} = bit6;
|
{ >> bit {arr}} = bit6;
|
||||||
v = $sformatf("%p", arr); `checks(v, "'{'h0, 'h0, 'h0, 'h1, 'h1, 'h1} ");
|
v = $sformatf("%p", arr); `checks(v, "'{'h0, 'h0, 'h0, 'h1, 'h1, 'h1} ");
|
||||||
|
|
@ -24,36 +29,54 @@ module t (/*AUTOARG*/);
|
||||||
ans = { >> bit {arr} };
|
ans = { >> bit {arr} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ >> bit {arr} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
{ << bit {arr}} = bit6;
|
{ << bit {arr}} = bit6;
|
||||||
v = $sformatf("%p", arr); `checks(v, "'{'h1, 'h1, 'h1, 'h0, 'h0, 'h0} ");
|
v = $sformatf("%p", arr); `checks(v, "'{'h1, 'h1, 'h1, 'h0, 'h0, 'h0} ");
|
||||||
|
|
||||||
ans = { << bit {arr} };
|
ans = { << bit {arr} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ << bit {arr} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
{ >> bit[1:0] {arr2}} = bit6;
|
{ >> bit[1:0] {arr2}} = bit6;
|
||||||
v = $sformatf("%p", arr2); `checks(v, "'{'h0, 'h2, 'h3} ");
|
v = $sformatf("%p", arr2); `checks(v, "'{'h0, 'h2, 'h3} ");
|
||||||
|
|
||||||
ans = { >> bit[1:0] {arr2} };
|
ans = { >> bit[1:0] {arr2} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ >> bit[1:0] {arr2} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
{ << bit[1:0] {arr2}} = bit6;
|
{ << bit[1:0] {arr2}} = bit6;
|
||||||
v = $sformatf("%p", arr2); `checks(v, "'{'h3, 'h2, 'h0} ");
|
v = $sformatf("%p", arr2); `checks(v, "'{'h3, 'h2, 'h0} ");
|
||||||
|
|
||||||
ans = { << bit[1:0] {arr2} };
|
ans = { << bit[1:0] {arr2} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ << bit[1:0] {arr2} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
{ >> bit [5:0] {arr6} } = bit6;
|
{ >> bit [5:0] {arr6} } = bit6;
|
||||||
v = $sformatf("%p", arr6); `checks(v, "'{'h38} ");
|
v = $sformatf("%p", arr6); `checks(v, "'{'h38} ");
|
||||||
|
|
||||||
ans = { >> bit[5:0] {arr6} };
|
ans = { >> bit[5:0] {arr6} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ >> bit[5:0] {arr6} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
{ << bit [5:0] {arr6} } = bit6;
|
{ << bit [5:0] {arr6} } = bit6;
|
||||||
v = $sformatf("%p", arr6); `checks(v, "'{'h38} ");
|
v = $sformatf("%p", arr6); `checks(v, "'{'h38} ");
|
||||||
|
|
||||||
ans = { << bit[5:0] {arr6} };
|
ans = { << bit[5:0] {arr6} };
|
||||||
`checkh(ans, bit6);
|
`checkh(ans, bit6);
|
||||||
|
|
||||||
|
ans_enum = enum_t'({ << bit[5:0] {arr6} });
|
||||||
|
`checkh(ans_enum, bit6);
|
||||||
|
|
||||||
$write("*-* All Finished *-*\n");
|
$write("*-* All Finished *-*\n");
|
||||||
$finish;
|
$finish;
|
||||||
end
|
end
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue