VHDL - DE0 - QUARTUS II PLL 在 modsim 中不显示输出
VHDL - DE0 - QUARTUS II PLL not showing output in modsim
您好,我正在尝试使用锁相环来为 VGA 控制器生成时钟。我运气不好,决定制作自己的时钟,然后工作正常。我让 VGA 控制器工作。回到 PLL,尽管我仍然无法选择 PLL 来给我输出。我做了一个小测试model来模拟它。
LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
ENTITY PLL4 IS
PORT (
clk : IN std_logic;
a : IN std_logic;
rst : IN std_logic:='0';
x : OUT std_logic
);
END ENTITY PLL4;
ARCHITECTURE A1 OF PLL4 IS
COMPONENT PLL_4 IS
PORT(
clk_in_clk : in std_logic; -- clk
rst_reset : in std_logic; -- reset
clk_out_clk : out std_logic -- clk
);
END COMPONENT PLL_4;
SIGNAL clk25 : std_logic;
BEGIN
CLK_25 : PLL_4 PORT MAP (clk,rst,clk25);
x <= a and clk25;
END ARCHITECTURE A1;
当我用 mod sim 模拟这个时,我得到以下结果
我从未见过 PLL 时钟输出。谁能给我一些建议。
--更新--
添加来自 CLK_25 的信号后:PLL 我现在在 Modsim 上得到以下信息。第一个连接到实例化很好,也连接到 clk_in_clk,但值 clk_out_clk 永远改变。见下文:
这让我觉得我遇到的问题是 PLL model 创建的 Qsys.The model 包含在 Qsys 生成的 .vhd 中:
-- PLL_4.vhd
-- Generated using ACDS version 13.0sp1 232 at 2016.02.09.16:46:16
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
entity PLL_4 is
port (
clk_in_clk : in std_logic := '0'; -- clk_in.clk
rst_reset : in std_logic := '0'; -- rst.reset
clk_out_clk : out std_logic -- clk_out.clk
);
end entity PLL_4;
architecture rtl of PLL_4 is
component PLL_4_altpll_0 is
port (
clk : in std_logic := 'X'; -- clk
reset : in std_logic := 'X'; -- reset
read : in std_logic := 'X'; -- read
write : in std_logic := 'X'; -- write
address : in std_logic_vector(1 downto 0) := (others => 'X'); -- address
readdata : out std_logic_vector(31 downto 0); -- readdata
writedata : in std_logic_vector(31 downto 0) := (others => 'X'); -- writedata
c0 : out std_logic; -- clk
areset : in std_logic := 'X'; -- export
locked : out std_logic; -- export
phasedone : out std_logic -- export
);
end component PLL_4_altpll_0;
begin
altpll_0 : component PLL_4_altpll_0
port map (
clk => clk_in_clk, -- inclk_interface.clk
reset => rst_reset, -- inclk_interface_reset.reset
read => open, -- pll_slave.read
write => open, -- .write
address => open, -- .address
readdata => open, -- .readdata
writedata => open, -- .writedata
c0 => clk_out_clk, -- c0.clk
areset => open, -- areset_conduit.export
locked => open, -- locked_conduit.export
phasedone => open -- phasedone_conduit.export
);
end architecture rtl; -- of PLL_4
我无法直接模拟你的VHDL代码,因为你没有贴出PLL_4_altpll_0
的代码。因此,我使用 Quartus-II 的 MegaWizard 插件管理器创建了一个合适的 PLL。无论如何,如果我直接在 ModelSim 中模拟 PLL4
实体并将时钟应用于信号 clk
以及 1
信号 a
,我得到与您相同的输出: clk25
未定义。
但如果我使用单独的 testbench,它会按预期工作。您必须在 Quartus II 中设置测试台,菜单 Assignements -> Settings -> Simulation -> Compile test bench -> Test Benches -> New。这是我的测试平台代码。应用重置是可选的,所以我保留了它 0
。
library ieee;
use ieee.std_logic_1164.all;
entity PLL4_tb is
end entity PLL4_tb;
architecture sim of PLL4_tb is
-- component ports
signal clk : std_logic := '1';
signal a : std_logic;
signal rst : std_logic;
signal x : std_logic;
begin -- architecture sim
-- component instantiation
DUT: entity work.PLL4
port map (
clk => clk,
a => a,
rst => rst,
x => x);
-- clock generation
clk <= not clk after 10 ns;
-- waveform generation
WaveGen_Proc: process
begin
rst <= '0'; -- no reset required
a <= '1';
wait;
end process WaveGen_Proc;
end architecture sim;
这是模拟输出:
您好,我正在尝试使用锁相环来为 VGA 控制器生成时钟。我运气不好,决定制作自己的时钟,然后工作正常。我让 VGA 控制器工作。回到 PLL,尽管我仍然无法选择 PLL 来给我输出。我做了一个小测试model来模拟它。
LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
ENTITY PLL4 IS
PORT (
clk : IN std_logic;
a : IN std_logic;
rst : IN std_logic:='0';
x : OUT std_logic
);
END ENTITY PLL4;
ARCHITECTURE A1 OF PLL4 IS
COMPONENT PLL_4 IS
PORT(
clk_in_clk : in std_logic; -- clk
rst_reset : in std_logic; -- reset
clk_out_clk : out std_logic -- clk
);
END COMPONENT PLL_4;
SIGNAL clk25 : std_logic;
BEGIN
CLK_25 : PLL_4 PORT MAP (clk,rst,clk25);
x <= a and clk25;
END ARCHITECTURE A1;
当我用 mod sim 模拟这个时,我得到以下结果
我从未见过 PLL 时钟输出。谁能给我一些建议。
--更新-- 添加来自 CLK_25 的信号后:PLL 我现在在 Modsim 上得到以下信息。第一个连接到实例化很好,也连接到 clk_in_clk,但值 clk_out_clk 永远改变。见下文:
这让我觉得我遇到的问题是 PLL model 创建的 Qsys.The model 包含在 Qsys 生成的 .vhd 中:
-- PLL_4.vhd
-- Generated using ACDS version 13.0sp1 232 at 2016.02.09.16:46:16
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
entity PLL_4 is
port (
clk_in_clk : in std_logic := '0'; -- clk_in.clk
rst_reset : in std_logic := '0'; -- rst.reset
clk_out_clk : out std_logic -- clk_out.clk
);
end entity PLL_4;
architecture rtl of PLL_4 is
component PLL_4_altpll_0 is
port (
clk : in std_logic := 'X'; -- clk
reset : in std_logic := 'X'; -- reset
read : in std_logic := 'X'; -- read
write : in std_logic := 'X'; -- write
address : in std_logic_vector(1 downto 0) := (others => 'X'); -- address
readdata : out std_logic_vector(31 downto 0); -- readdata
writedata : in std_logic_vector(31 downto 0) := (others => 'X'); -- writedata
c0 : out std_logic; -- clk
areset : in std_logic := 'X'; -- export
locked : out std_logic; -- export
phasedone : out std_logic -- export
);
end component PLL_4_altpll_0;
begin
altpll_0 : component PLL_4_altpll_0
port map (
clk => clk_in_clk, -- inclk_interface.clk
reset => rst_reset, -- inclk_interface_reset.reset
read => open, -- pll_slave.read
write => open, -- .write
address => open, -- .address
readdata => open, -- .readdata
writedata => open, -- .writedata
c0 => clk_out_clk, -- c0.clk
areset => open, -- areset_conduit.export
locked => open, -- locked_conduit.export
phasedone => open -- phasedone_conduit.export
);
end architecture rtl; -- of PLL_4
我无法直接模拟你的VHDL代码,因为你没有贴出PLL_4_altpll_0
的代码。因此,我使用 Quartus-II 的 MegaWizard 插件管理器创建了一个合适的 PLL。无论如何,如果我直接在 ModelSim 中模拟 PLL4
实体并将时钟应用于信号 clk
以及 1
信号 a
,我得到与您相同的输出: clk25
未定义。
但如果我使用单独的 testbench,它会按预期工作。您必须在 Quartus II 中设置测试台,菜单 Assignements -> Settings -> Simulation -> Compile test bench -> Test Benches -> New。这是我的测试平台代码。应用重置是可选的,所以我保留了它 0
。
library ieee;
use ieee.std_logic_1164.all;
entity PLL4_tb is
end entity PLL4_tb;
architecture sim of PLL4_tb is
-- component ports
signal clk : std_logic := '1';
signal a : std_logic;
signal rst : std_logic;
signal x : std_logic;
begin -- architecture sim
-- component instantiation
DUT: entity work.PLL4
port map (
clk => clk,
a => a,
rst => rst,
x => x);
-- clock generation
clk <= not clk after 10 ns;
-- waveform generation
WaveGen_Proc: process
begin
rst <= '0'; -- no reset required
a <= '1';
wait;
end process WaveGen_Proc;
end architecture sim;
这是模拟输出: