-- code from book: entity and3 is port ( a, b, c : in bit := '1'; z, not_z : out bit); end entity and3; -- end of code from book ---------------------------------------------------------------- architecture functional of and3 is begin non_inverting: z <= a and b and c; inverting: not_z <= not (a and b and c); end architecture functional; ---------------------------------------------------------------- entity inline_24 is end entity inline_24; ---------------------------------------------------------------- library util; use util.stimulus_generators.all; architecture test of inline_24 is signal s1, s2, ctrl1_a, ctrl1_b : bit; signal test_input : bit_vector(1 to 2); begin block_4_a : block is port ( ctrl1 : out bit ); port map ( ctrl1 => ctrl1_a ); begin -- code from book: g1 : entity work.and3 port map ( a => s1, b => s2, not_z => ctrl1 ); -- end of code from book end block block_4_a; ---------------- block_4_b : block is port ( ctrl1 : out bit ); port map ( ctrl1 => ctrl1_b ); begin -- code from book: g1 : entity work.and3 port map ( a => s1, b => s2, not_z => ctrl1, c => open, z => open ); -- end of code from book end block block_4_b; ---------------- stimulus : all_possible_values( bv => test_input, delay_between_values => 10 ns ); (s1, s2) <= test_input; verifier : assert ctrl1_a = ctrl1_b report "versions differ"; end architecture test;