Вы находитесь на странице: 1из 7

Kevin Fells Assignment #1

Problem Statement 1. Extend the 4-bit parity generator that discussed during the demonstration to 8-bit parity generator. 2. Perform the behavioral and timing simulation for your code that you entered using Xilinx ISE design tools. Solution (1) VHDL Source Code ----------------------------------------------------------------------------------- Course: ECE 5752 - Reconfigurable Computing -- Engineer: Kevin Fells

-- Design Name: 8 Bit Parity Generator -- Project Name: Assignment #1 ---------------------------------------------------------------------------------library IEEE; use IEEE.STD_LOGIC_1164.ALL; --8-bit parity generator --2-bit parity generator, then use a 2-bit component --to generate 8-bit entity parity_2bits is port (d0, d1:in std_logic; e0:out std_logic); end parity_2bits; architecture parity_2bits_arch of parity_2bits is begin e0 <= d0 xor d1; end parity_2bits_arch; --8-bit parity generator library IEEE; use IEEE.STD_LOGIC_1164.ALL; entity parity_8bits is port(d0, d1, d2, d3, d4, d5, d6, d7: in std_logic; z: out std_logic); end parity_8bits; architecture parity_8bits_arch of parity_8bits is component parity_2bits port (d0, d1:in std_logic; e0:out std_logic);

end component; signal s1, s2, s3, s4, s5, s6: std_logic; begin p1: parity_2bits port map (d0, d1, s1); p2: parity_2bits port map (d2, d3, s2); p3: parity_2bits port map (d4, d5, s3); p4: parity_2bits port map (d6, d7, s4); q1: parity_2bits port map (s1, s2, s5); q2: parity_2bits port map (s3, s4, s6); top: parity_2bits port map (s5, s6, z); end parity_8bits_arch;

Solution (2) VHDL Test Bench Source Code LIBRARY ieee; USE ieee.std_logic_1164.ALL; -- Uncomment the following library declaration if using -- arithmetic functions with Signed or Unsigned values --USE ieee.numeric_std.ALL; ENTITY parity_tb IS END parity_tb; ARCHITECTURE behavior OF parity_tb IS -- Component Declaration for the Unit Under Test (UUT) COMPONENT parity_8bits PORT( d0 : IN std_logic; d1 : IN std_logic; d2 : IN std_logic; d3 : IN std_logic; d4 : IN std_logic; d5 : IN std_logic; d6 : IN std_logic; d7 : IN std_logic; z : OUT std_logic ); END COMPONENT;

--Inputs signal d0 : std_logic := '0'; signal d1 : std_logic := '0'; signal d2 : std_logic := '0'; signal d3 : std_logic := '0'; signal d4 : std_logic := '0'; signal d5 : std_logic := '0'; signal d6 : std_logic := '0'; signal d7 : std_logic := '0'; --Outputs signal z : std_logic; -- No clocks detected in port list. Replace <clock> below with -- appropriate port name -- constant <clock>_period : time := 10 ns;

BEGIN -- Instantiate the Unit Under Test (UUT) uut: parity_8bits PORT MAP ( d0 => d0, d1 => d1, d2 => d2, d3 => d3, d4 => d4, d5 => d5, d6 => d6, d7 => d7, z => z ); -- Clock process definitions -- <clock>_process :process --begin -<clock> <= '0'; -wait for <clock>_period/2; -<clock> <= '1'; -wait for <clock>_period/2; --end process;

-- Stimulus process stim_proc: process begin -- hold reset state for 100 ns. wait for 100 ns; -- wait for <clock>_period*10; -- insert stimulus here d0 <= '0'; d1 <= '1'; d2 <= '1'; d3 <= '0'; d4 <= '1'; d5 <= '1'; d6 <= '0'; d7 <= '0'; wait for 100 ns; d0 <= '1'; d1 <= '1'; d2 <= '0'; d3 <= '1'; d4 <= '0'; d5 <= '1'; d6 <= '0';

d7 <= '1'; -- wait; end process; END;

Behavioral Model Simulation

Timing Simulation

Вам также может понравиться