URL
https://opencores.org/ocsvn/potato/potato/trunk
Subversion Repositories potato
[/] [potato/] [trunk/] [testbenches/] [tb_soc_timer.vhd] - Rev 12
Go to most recent revision | Compare with Previous | Blame | View Log
-- The Potato Processor - A simple processor for FPGAs -- (c) Kristian Klomsten Skordal 2014 - 2015 <kristian.skordal@wafflemail.net> -- Report bugs and issues on <https://github.com/skordal/potato/issues> library ieee; use ieee.std_logic_1164.all; entity tb_soc_timer is end entity tb_soc_timer; architecture behaviour of tb_soc_timer is -- Clock signal: signal clk : std_logic := '0'; constant clk_period : time := 10 ns; -- Reset signal: signal reset : std_logic := '1'; -- IRQ signal: signal irq : std_logic; -- Wishbone interface: signal wb_adr_in : std_logic_vector(1 downto 0) := (others => '0'); signal wb_dat_in : std_logic_vector(31 downto 0) := (others => '0'); signal wb_dat_out : std_logic_vector(31 downto 0); signal wb_cyc_in : std_logic := '0'; signal wb_stb_in : std_logic := '0'; signal wb_we_in : std_logic := '0'; signal wb_ack_out : std_logic; begin uut: entity work.pp_soc_timer port map( clk => clk, reset => reset, irq => irq, wb_adr_in => wb_adr_in, wb_dat_in => wb_dat_in, wb_dat_out => wb_dat_out, wb_cyc_in => wb_cyc_in, wb_stb_in => wb_stb_in, wb_we_in => wb_we_in, wb_ack_out => wb_ack_out ); clock: process begin clk <= '1'; wait for clk_period / 2; clk <= '0'; wait for clk_period / 2; end process clock; stimulus: process begin wait for clk_period * 2; reset <= '0'; wait for clk_period; -- Set the compare register to 50: wb_cyc_in <= '1'; wb_stb_in <= '1'; wb_adr_in <= b"01"; wb_dat_in <= x"00000032"; wb_we_in <= '1'; wait until wb_ack_out = '1'; wait for clk_period; wb_stb_in <= '0'; wait for clk_period; -- Start the timer: wb_stb_in <= '1'; wb_adr_in <= b"00"; wb_dat_in <= x"00000003"; wait until wb_ack_out = '1'; wait for clk_period; wb_stb_in <= '0'; wb_cyc_in <= '0'; wb_we_in <= '0'; wait for clk_period; -- Wait for the interrupt: wait until irq = '1'; wait for clk_period; -- Reset the interrupt: wb_cyc_in <= '1'; wb_stb_in <= '1'; wb_we_in <= '1'; wb_adr_in <= b"00"; wb_dat_in <= x"00000003"; wait until wb_ack_out = '1'; wait for clk_period; wb_stb_in <= '0'; wb_cyc_in <= '0'; wb_we_in <= '0'; wait for clk_period; wait; end process stimulus; end architecture behaviour;
Go to most recent revision | Compare with Previous | Blame | View Log