aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2018-11-04 10:08:33 +0100
committerGitHub <noreply@github.com>2018-11-04 10:08:33 +0100
commit68304c6d176e396e068cbe3ac2800ac75091143c (patch)
treea92f295d2f5ee780eb6e8f042817f1a633125e54
parent18a4c1cdacc948ef669678f9e3ac1052aadba1a2 (diff)
parent04cd17969657dc7402d79e054ea390f98e159083 (diff)
downloadyosys-68304c6d176e396e068cbe3ac2800ac75091143c.tar.gz
yosys-68304c6d176e396e068cbe3ac2800ac75091143c.tar.bz2
yosys-68304c6d176e396e068cbe3ac2800ac75091143c.zip
Merge pull request #687 from trcwm/master
Liberty file: error when it contains pin references to non-existing pins
-rw-r--r--passes/techmap/dfflibmap.cc3
-rw-r--r--passes/techmap/libparse.cc11
2 files changed, 10 insertions, 4 deletions
diff --git a/passes/techmap/dfflibmap.cc b/passes/techmap/dfflibmap.cc
index 416ed2bd5..421073485 100644
--- a/passes/techmap/dfflibmap.cc
+++ b/passes/techmap/dfflibmap.cc
@@ -100,6 +100,9 @@ static bool parse_pin(LibertyAst *cell, LibertyAst *attr, std::string &pin_name,
for (auto child : cell->children)
if (child->id == "pin" && child->args.size() == 1 && child->args[0] == pin_name)
return true;
+
+ log_error("Malformed liberty file - cannot find pin '%s' in cell '%s'.\n", pin_name.c_str(), cell->args[0].c_str());
+
return false;
}
diff --git a/passes/techmap/libparse.cc b/passes/techmap/libparse.cc
index d3b1ff02f..bb09117e2 100644
--- a/passes/techmap/libparse.cc
+++ b/passes/techmap/libparse.cc
@@ -159,7 +159,7 @@ int LibertyParser::lexer(std::string &str)
if (c == '\n') {
line++;
- return ';';
+ return 'n';
}
// if (c >= 32 && c < 255)
@@ -175,7 +175,7 @@ LibertyAst *LibertyParser::parse()
int tok = lexer(str);
- while (tok == ';')
+ while (tok == 'n')
tok = lexer(str);
if (tok == '}' || tok < 0)
@@ -194,6 +194,9 @@ LibertyAst *LibertyParser::parse()
if (tok == ';')
break;
+ if (tok == 'n')
+ continue;
+
if (tok == ':' && ast->value.empty()) {
tok = lexer(ast->value);
if (tok != 'v')
@@ -249,14 +252,14 @@ LibertyAst *LibertyParser::parse()
void LibertyParser::error()
{
- log_error("Syntax error in line %d.\n", line);
+ log_error("Syntax error in liberty file on line %d.\n", line);
}
#else
void LibertyParser::error()
{
- fprintf(stderr, "Syntax error in line %d.\n", line);
+ fprintf(stderr, "Syntax error in liberty file on line %d.\n", line);
exit(1);
}