3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-04 13:54:07 +00:00

fix lookup of mangled path names

This commit is contained in:
N. Engelhardt 2024-10-16 13:55:50 +02:00
parent 117fb26c68
commit 0f13fc6bc7
2 changed files with 98 additions and 2 deletions

View file

@ -146,12 +146,12 @@ class SbyModule:
path_iter = iter(path)
mod = next(path_iter).translate(trans)
if self.name != mod:
if self.name.translate(trans) != mod:
raise ValueError(f"{self.name} is not the first module in hierarchical path {pretty_path(path)}.")
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!")

View file

@ -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;