diff --git a/Changes b/Changes index de058e7a7..cd6d50ee7 100644 --- a/Changes +++ b/Changes @@ -5,6 +5,8 @@ The contributors that suggested a given feature are shown in []. Thanks! * Verilator 4.009 devel +**** For --xml, add additional var information, bug1372. [Jonathan Kimmitt] + * Verilator 4.008 2018-12-01 diff --git a/src/V3AstNodes.cpp b/src/V3AstNodes.cpp index d5899664a..d12a643df 100644 --- a/src/V3AstNodes.cpp +++ b/src/V3AstNodes.cpp @@ -200,6 +200,8 @@ string AstVar::verilogKwd() const { return "wire"; } else if (varType()==AstVarType::WREAL) { return "wreal"; + } else if (varType()==AstVarType::IFACEREF) { + return "ifaceref"; } else { return dtypep()->name(); } diff --git a/src/V3EmitXml.cpp b/src/V3EmitXml.cpp index 863ee8e06..15eaa88d0 100644 --- a/src/V3EmitXml.cpp +++ b/src/V3EmitXml.cpp @@ -115,7 +115,17 @@ class EmitXmlFileVisitor : public AstNVisitor { outputChildrenEnd(nodep, ""); } virtual void visit(AstVar* nodep) { - outputTag(nodep, ""); + AstVarType typ = nodep->varType(); + string kw = nodep->verilogKwd(); + string vt = nodep->dtypep()->name(); + outputTag(nodep, ""); + if (nodep->isIO()) { + puts(" dir="); putsQuoted(kw); + puts(" vartype="); putsQuoted(!vt.empty() + ? vt : typ == AstVarType::PORT ? "port" : "unknown"); + } else { + puts(" vartype="); putsQuoted(!vt.empty() ? vt : kw); + } puts(" origName="); putsQuoted(nodep->origName()); outputChildrenEnd(nodep, ""); } diff --git a/test_regress/t/t_xml_first.out b/test_regress/t/t_xml_first.out index 1f4b543ae..e6743605d 100644 --- a/test_regress/t/t_xml_first.out +++ b/test_regress/t/t_xml_first.out @@ -20,10 +20,10 @@ - - - - + + + + @@ -48,9 +48,9 @@ - - - + + + @@ -64,9 +64,9 @@ - - - + + + diff --git a/test_regress/t/t_xml_tag.out b/test_regress/t/t_xml_tag.out index aed866106..43ace0dbb 100644 --- a/test_regress/t/t_xml_tag.out +++ b/test_regress/t/t_xml_tag.out @@ -17,11 +17,11 @@ - - - + + + - +