-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathfull_adder_testbench.vhd
40 lines (37 loc) · 1.39 KB
/
full_adder_testbench.vhd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
library ieee;
use ieee.std_logic_1164.all;
entity full_adder_testbench is
end full_adder_testbench;
architecture behavior of full_adder_testbench is
component full_adder is
port (
a : in std_logic;
b : in std_logic;
ci : in std_logic;
s : out std_logic;
co : out std_logic);
end component;
signal input : std_logic_vector(2 downto 0);
signal output : std_logic_vector(1 downto 0);
begin
uut: full_adder port map (
a => input(0),
b => input(1),
ci => input(2),
s => output(0),
co => output(1)
);
stim_proc: process
begin
input <= "000"; wait for 10 ns; assert output = "00" report "0+0+0 failed";
input <= "001"; wait for 10 ns; assert output = "01" report "0+0+1 failed";
input <= "010"; wait for 10 ns; assert output = "01" report "0+1+0 failed";
input <= "100"; wait for 10 ns; assert output = "01" report "1+0+0 failed";
input <= "011"; wait for 10 ns; assert output = "10" report "0+1+1 failed";
input <= "110"; wait for 10 ns; assert output = "10" report "1+1+0 failed";
input <= "101"; wait for 10 ns; assert output = "10" report "1+0+1 failed";
input <= "111"; wait for 10 ns; assert output = "11" report "1+1+1 failed";
report "Full adder testbench finished";
wait;
end process;
end;