diff options
Diffstat (limited to 'testsuite/synth/synth109/tb_ram10.vhdl')
-rw-r--r-- | testsuite/synth/synth109/tb_ram10.vhdl | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/testsuite/synth/synth109/tb_ram10.vhdl b/testsuite/synth/synth109/tb_ram10.vhdl new file mode 100644 index 000000000..9d9e3c15c --- /dev/null +++ b/testsuite/synth/synth109/tb_ram10.vhdl @@ -0,0 +1,62 @@ +entity tb_ram10 is +end tb_ram10; + +library ieee; +use ieee.std_logic_1164.all; + +architecture behav of tb_ram10 is + signal clk : std_logic; + signal en : std_logic; + signal we : std_logic; + signal addr : std_logic_vector(5 downto 0); + signal rdat : std_logic_vector(31 downto 0); + signal wdat : std_logic_vector(31 downto 0); +begin + dut: entity work.ram10 + port map (clkB => clk, enB => en, weB => we, addrB => addr, + diB => wdat, doB => rdat); + + process + procedure pulse is + begin + clk <= '0'; + wait for 1 ns; + clk <= '1'; + wait for 1 ns; + end pulse; + begin + en <= '1'; + we <= '1'; + addr <= b"00_0000"; + wdat <= x"11_22_33_f0"; + pulse; + assert rdat = x"11_22_33_f0" severity failure; + + addr <= b"00_0001"; + wdat <= x"11_22_33_f1"; + pulse; + assert rdat = x"11_22_33_f1" severity failure; + + -- Read. + we <= '0'; + addr <= b"00_0000"; + wdat <= x"ff_22_33_f1"; + pulse; + assert rdat = x"11_22_33_f0" severity failure; + + addr <= b"00_0001"; + wdat <= x"ff_22_33_f1"; + pulse; + assert rdat = x"11_22_33_f1" severity failure; + + -- Disable. + en <= '0'; + we <= '1'; + addr <= b"00_0000"; + wdat <= x"11_22_33_f0"; + pulse; + assert rdat = x"11_22_33_f1" severity failure; + + wait; + end process; +end behav; |