From 7fb58f4c669adf010a87a8b6e5839f52a89befb5 Mon Sep 17 00:00:00 2001 From: "N. Engelhardt" Date: Wed, 16 Oct 2024 13:55:50 +0200 Subject: [PATCH] fix lookup of mangled path names --- sbysrc/sby_design.py | 6 +- tests/regression/vhdl_hier_path.sby | 96 +++++++++++++++++++++++++++++ 2 files changed, 99 insertions(+), 3 deletions(-) create mode 100644 tests/regression/vhdl_hier_path.sby diff --git a/sbysrc/sby_design.py b/sbysrc/sby_design.py index 185ed449..0a0e0499 100644 --- a/sbysrc/sby_design.py +++ b/sbysrc/sby_design.py @@ -146,12 +146,12 @@ def find_property(self, path, cell_name, trans_dict=dict()): path_iter = iter(path) mod = next(path_iter).translate(trans) - if self.name != mod: - raise ValueError(f"{self.name} is not the first module in hierarchical path {pretty_path(path)}.") + if self.name.translate(trans) != mod: + raise ValueError(f"{self.name} is not the first module in hierarchical path {pretty_path(path)}. ({mod})") mod_hier = self for mod in path_iter: - mod_hier = next((v for k, v in mod_hier.submodules.items() if mod == k.translate(trans)), None) + mod_hier = next((v for k, v in mod_hier.submodules.items() if mod.translate(trans) == k.translate(trans)), None) if not mod_hier: raise KeyError(f"Could not find {pretty_path(path)} in design hierarchy!") diff --git a/tests/regression/vhdl_hier_path.sby b/tests/regression/vhdl_hier_path.sby new file mode 100644 index 00000000..cbc78908 --- /dev/null +++ b/tests/regression/vhdl_hier_path.sby @@ -0,0 +1,96 @@ +[options] +mode bmc +depth 1 +expect fail + +[engines] +smtbmc + +[script] +verific -vhdl subsub.vhd +verific -vhdl sub.vhd +verific -vhdl top.vhd +hierarchy -top top +hierarchy -top \\sub(p=41)\(rtl) + +[file top.vhd] +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity top is + port ( + a : in integer + ); +end entity; + +architecture rtl of top is +component sub is + generic ( + p : integer + ); + port ( + a : in integer + ); +end component; +begin + sub_i: sub + generic map ( + p => 41 + ) + port map ( + a => a + ); +end architecture; + +[file sub.vhd] +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity sub is + generic ( + p : integer := 99 + ); + port ( + a : in integer + ); +end entity; + +architecture rtl of sub is +component subsub is + generic ( + p : integer + ); + port ( + a : in integer + ); +end component; +begin + subsub_i: subsub + generic map ( + p => p + 1 + ) + port map ( + a => a + ); +end architecture; + +[file subsub.vhd] +library ieee; +use ieee.std_logic_1164.all; +use ieee.numeric_std.all; + +entity subsub is + generic ( + p : integer := 99 + ); + port ( + a : in integer + ); +end entity; + +architecture rtl of subsub is +begin + assert (p > a); +end architecture;