-- Copyright (C) 2002 Morgan Kaufmann Publishers, Inc -- This file is part of VESTs (Vhdl tESTs). -- VESTs is free software; you can redistribute it and/or modify it -- under the terms of the GNU General Public License as published by the -- Free Software Foundation; either version 2 of the License, or (at -- your option) any later version. -- VESTs is distributed in the hope that it will be useful, but WITHOUT -- ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -- for more details. -- You should have received a copy of the GNU General Public License -- along with VESTs; if not, write to the Free Software Foundation, -- Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -- code from book: entity and_gate is port ( i : in bit_vector; y : out bit ); end entity and_gate; -- end of code from book ---------------------------------------------------------------- architecture behavioral of and_gate is begin reducer : process (i) is constant Tpd : delay_length := 2 ns; variable result : bit; begin result := '1'; for index in i'range loop result := result and i(index); end loop; y <= result after Tpd; end process reducer; end architecture behavioral; ---------------------------------------------------------------- entity inline_21 is end entity inline_21; ---------------------------------------------------------------- library util; use util.stimulus_generators.all; architecture test of inline_21 is -- code from book: signal serial_select, write_en, bus_clk, serial_wr : bit; -- end of code from book signal test_input : bit_vector(2 downto 0); begin -- code from book: serial_write_gate : entity work.and_gate port map ( i(1) => serial_select, i(2) => write_en, i(3) => bus_clk, y => serial_wr ); -- end of code from book ---------------- stimulus : all_possible_values( bv => test_input, delay_between_values => 10 ns ); (serial_select, write_en, bus_clk) <= test_input; end architecture test;