aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite/gna/ticket39/test.vhd
blob: e1df8050149591af801c445eb7cf2ad6fe50f80a (plain)
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
41
42
43
44
entity test is
end entity test;

library ieee;
use ieee.std_logic_1164.all;

architecture test of test is

  type state_t is record
    a : real;
  end record state_t;

  procedure p1 (
    variable state : inout state_t;
    a : in std_ulogic_vector(1 downto 0)) is
  begin
    report "test " & std_ulogic'image(a(1)) & std_ulogic'image(a(0)) severity note;
  end procedure p1;

  procedure p2 (
    variable state : inout state_t;
    n : in natural) is
    variable b : std_ulogic;
  begin
    b := '0';
    for i in 0 to n loop
      p1(state => state, a(0) => b, a(1) => 'X');
      b := not b;
      state.a := state.a + 1.0;
    end loop;
  end procedure p2;

begin

  p_p: process is
    variable state : state_t;
  begin
    state.a := 0.0;
    p2(state, 2);
    p2(state, 2);
    wait;
  end process p_p;

end architecture test;