VHDL你能在同一个文件中声明一个包和一个实体吗?

时间:2013-11-06 14:45:54

标签: entity package vhdl

我试图将包和实体放在同一个文件中,但它没有编译它给我一个错误说:未知标识符std_logic,

我有什么办法把它们放在同一个文件中吗?

2 个答案:

答案 0 :(得分:6)

您在文件顶部提供的库声明适用于下一个设计单元(可能是您的包)。

启动实体时,它是一个新的设计单元,以空库空间开头,因此您必须再次放入库声明。如果在给定文件中放置多个实体,则会发生同样的情况 - 您必须为每个实体放置库子句。

VHDL编译器根本不关心任何文件是什么,它只对其中的单元进行操作。因此,您可以在一个文件中包含entitylibrary个声明,而architecture在另一个文件中。这些库然后需要在架构文件中重做,它们与实体一起进入。如果您只有 所需的库,那么它们可以包含在架构语句之前(无论您是在一个文件还是两个文件中):

library ieee; 
use ieee.std_logic_1164.all;
entity foo
port ( 
   bar: std_logic; 
   etc...);
end entity;

-- could start a new file here, or not.
use ieee.numeric_std.all; -- not needed for the entity as it doesn't use unsigned types
architecture a of foo is
    signal counter : unsigned (10 downto 0);
begin
...
end architecture;

答案 1 :(得分:4)

是的,你可以,但你必须记住,任何使用声明的库只适用于下一个实体或包,而不是整个文件!

实际上,您需要编写两个可以独立编译的文件,然后将一个文件的全部内容复制到另一个文件的末尾。