From 845590aa8e3a7994b7082b5f0b4ab39c377163ba Mon Sep 17 00:00:00 2001 From: Clifford Wolf Date: Wed, 16 Oct 2013 06:32:35 +0200 Subject: [PATCH] Fixed parsing or liberty file statements such as 'clocked_on : "(!CLK)";' Patch by Tim Edwards --- passes/dfflibmap/dfflibmap.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/passes/dfflibmap/dfflibmap.cc b/passes/dfflibmap/dfflibmap.cc index dd873cadd..5e3219d55 100644 --- a/passes/dfflibmap/dfflibmap.cc +++ b/passes/dfflibmap/dfflibmap.cc @@ -69,12 +69,15 @@ static bool parse_pin(LibertyAst *cell, LibertyAst *attr, std::string &pin_name, std::string value = attr->value; - for (size_t pos = value.find_first_of("\" \t"); pos != std::string::npos; pos = value.find_first_of("\" \t")) + for (size_t pos = value.find_first_of("\" \t()"); pos != std::string::npos; pos = value.find_first_of("\" \t()")) value.erase(pos, 1); if (value[value.size()-1] == '\'') { pin_name = value.substr(0, value.size()-1); pin_pol = false; + } else if (value[0] == '!') { + pin_name = value.substr(1, value.size()-1); + pin_pol = false; } else { pin_name = value; pin_pol = true; -- 2.30.2