Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unreachable code panic when instantiating a component with a generic type #348

Open
maltaisn opened this issue Oct 21, 2024 · 4 comments
Open

Comments

@maltaisn
Copy link

The following file:

library ieee;
use ieee.std_logic_1164.all;

entity Foo is
   port (
      clk : in std_logic);
end entity;

architecture Behavioral of Foo is

component Bar
   generic (
      type DATA_TYPE);
   port (
      clk : in std_logic);
end component;

begin

Inst_Bar : Bar
   generic map (
      DATA_TYPE => std_logic)
   port map (
      clk => clk);

end architecture;

Causes a panic:

thread '<unnamed>' panicked at vhdl_lang\src\named_entity\formal_region.rs:101:17:
internal error: entered unreachable code

I'm using v0.83.0.

@jobtijhuis
Copy link

I was just about to report this problem, as I ran into it as well.

@maltaisn
Copy link
Author

I looked at the code and using subprograms or types in generic associations is simply not implemented. In fact generic associations are treated exactly like port associations at the moment.

On my side I just patched it by adding this line:

        AnyEntKind::Type(_) => TypeEnt::from_any(self.ent).unwrap(),

right after:

AnyEntKind::InterfaceFile(file_type) => *file_type,

Which is definitely wrong but at least there's no panic.

@Schottkyc137
Copy link
Contributor

I just want to say that I'm on it, but I have decided against a quick fix because there currently is a lot of duplicate logic when analyzing interface lists (for example, the capabilities missing for entities is implemented for generic packages and generic subprograms) so I want to simplify the code a bit before rolling out the fix.

@rpatel3001
Copy link

rpatel3001 commented Dec 11, 2024

Just want to +1 for a slightly different but related issue. I'm getting the same panic with a package as generic:

package GenPkg is
generic (...);
end package GenPkg;

entity Foo is
end entity;

architecture Behavioral of Foo is

package GenPkgInst is new work.GenPkg generic map (...);

begin

Inst_Bar : entity work.Bar
   generic map (myGenPkg => GenPkgInst);
   port map (...);

and the suggested workaround here did not work.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants