PlTbUtils  1.3
PlTbUtils is a collection of functions, procedures and components for easily creating stimuli and checking response in automatic self-checking testbenches.
tb_template1.vhd
Go to the documentation of this file.
1 
16 library ieee;
17 use ieee.std_logic_1164.all;
18 use std.textio.all;
19 use work.txt_util.all;
20 use work.pltbutils_func_pkg.all;
21 use work.pltbutils_comp_pkg.all;
22 -- < Template info: add more libraries here, if needed >
23 
24 entity tb_template1 is
25  generic (
26  G_CLK_PERIOD : time := 10 ns; -- < Template info: change value if needed >
27  G_SKIPTESTS : std_logic_vector := (
28  '0', -- Dummy
29  '0', -- Test 1
30  '0' -- Test 2
31  -- ... etc
32  )
33  -- < Template info: add more generics here if needed >
34  );
35 end entity tb_template1;
36 
37 architecture bhv of tb_template1 is
38 
39  -- Simulation status- and control signals
40  -- for accessing .stop_sim and for viewing in waveform window
41  signal pltbs : pltbs_t := C_PLTBS_INIT;
42 
43  -- DUT stimuli and response signals
44  signal clk : std_logic;
45  signal rst : std_logic;
46  -- < Template info: add more DUT stimuli and response signals here. >
47 
48 begin
49 
50  dut0 : entity work.template
51  -- generic map (
52  -- < Template info: add DUT generics here, if any. >
53  -- )
54  port map (
55  clk_i => clk, -- Template example
56  rst_i => rst -- Template example
57  -- < Template info: add more DUT ports here. >
58  );
59 
60  clkgen0 : pltbutils_clkgen
61  generic map(
62  G_PERIOD => G_CLK_PERIOD
63  )
64  port map(
65  clk_o => clk,
66  stop_sim_i => pltbs.stop_sim
67  );
68 
69  -- Testcase process
70  p_tc1 : process
71  variable pltbv : pltbv_t := C_PLTBV_INIT;
72  begin
73  startsim("tc1", G_SKIPTESTS, pltbv, pltbs);
74  rst <= '1'; -- Template example
75  -- < Template info: initialize other DUT stimuli here. >
76 
77  starttest(1, "Reset test", pltbv, pltbs); -- Template example
78  if is_test_active(pltbv) then
79  waitclks(2, clk, pltbv, pltbs); -- Template example
80  check("template_signal during reset", template_signal, 0, pltbv, pltbs); -- Template example
81  -- < Template info: check other DUT outputs here.
82  rst <= '0'; -- Template example
83  end if; -- is_test_active
84  endtest(pltbv, pltbs);
85 
86  starttest(2, "Template test", pltbv, pltbs);
87  if is_test_active(pltbv) then
88  -- < Template info: set all relevant DUT inputs here. >
89  waitclks(2, clk, pltbv, pltbs); -- Template example
90  -- < Template info: check all relevant DUT outputs here. >
91  end if; -- is_test_active
92  endtest(pltbv, pltbs);
93 
94  -- < Template info: add more tests here. >
95 
96  endsim(pltbv, pltbs, true);
97  wait;
98  end process p_tc1;
99 
100 end architecture bhv;
See pltbutils_comp.vhd for a description of the components.
This package defines fuctions and procedures for controlling stimuli to a DUT and checking response.
pltbutils_clkgen clkgen0clkgen0
pltbs_t := C_PLTBS_INIT pltbs
G_SKIPTESTS std_logic_vector :=( '0', '0', '0')
G_CLK_PERIOD time := 10 ns
Defines useful functions an procedures for text handling text in VHDL.
Definition: txt_util.vhd:31