lustrec-tests / vhdl_json / vhdl_files / 2-exportOK / ghdl / ghdl / testsuite / vests / vhdl-93 / billowitch / compliant / tc2126.vhd @ 3fd18385
History | View | Annotate | Download (2.65 KB)
1 |
|
---|---|
2 |
-- Copyright (C) 2001 Bill Billowitch. |
3 |
|
4 |
-- Some of the work to develop this test suite was done with Air Force |
5 |
-- support. The Air Force and Bill Billowitch assume no |
6 |
-- responsibilities for this software. |
7 |
|
8 |
-- This file is part of VESTs (Vhdl tESTs). |
9 |
|
10 |
-- VESTs is free software; you can redistribute it and/or modify it |
11 |
-- under the terms of the GNU General Public License as published by the |
12 |
-- Free Software Foundation; either version 2 of the License, or (at |
13 |
-- your option) any later version. |
14 |
|
15 |
-- VESTs is distributed in the hope that it will be useful, but WITHOUT |
16 |
-- ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
17 |
-- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
18 |
-- for more details. |
19 |
|
20 |
-- You should have received a copy of the GNU General Public License |
21 |
-- along with VESTs; if not, write to the Free Software Foundation, |
22 |
-- Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
23 |
|
24 |
-- --------------------------------------------------------------------- |
25 |
-- |
26 |
-- $Id: tc2126.vhd,v 1.2 2001-10-26 16:29:45 paw Exp $ |
27 |
-- $Revision: 1.2 $ |
28 |
-- |
29 |
-- --------------------------------------------------------------------- |
30 |
|
31 |
ENTITY c07s02b04x00p20n01i02126ent IS |
32 |
END c07s02b04x00p20n01i02126ent; |
33 |
|
34 |
ARCHITECTURE c07s02b04x00p20n01i02126arch OF c07s02b04x00p20n01i02126ent IS |
35 |
|
36 |
TYPE integer_v is array (integer range <>) of integer; |
37 |
SUBTYPE integer_4 is integer_v (1 to 4); |
38 |
SUBTYPE integer_8 is integer_v (1 to 8); |
39 |
SUBTYPE integer_8_dwn is integer_v (8 downto 1); |
40 |
|
41 |
BEGIN |
42 |
TESTING: PROCESS |
43 |
variable r_operand : integer_4 := ( 5,6,7,8 ); |
44 |
variable l_operand1: integer := 1; |
45 |
variable l_operand2: integer := 2; |
46 |
variable l_operand3: integer := 3; |
47 |
variable l_operand4: integer := 4; |
48 |
variable result : integer_8; |
49 |
variable result_dwn: integer_8_dwn; |
50 |
BEGIN |
51 |
result_dwn := l_operand1 & |
52 |
l_operand2 & |
53 |
l_operand3 & |
54 |
l_operand4 & |
55 |
l_operand2 & |
56 |
l_operand3 & |
57 |
l_operand2 & |
58 |
l_operand3; |
59 |
|
60 |
assert (result_dwn = (1,2,3,4,2,3,2,3)) |
61 |
report "integer implicit array concatenation failed" |
62 |
severity FAILURE; |
63 |
|
64 |
assert NOT(result_dwn = (1,2,3,4,2,3,2,3)) |
65 |
report "***PASSED TEST: c07s02b04x00p20n01i02126" |
66 |
severity NOTE; |
67 |
assert (result_dwn = (1,2,3,4,2,3,2,3)) |
68 |
report "***FAILED TEST: c07s02b04x00p20n01i02126 - The left bound of this implicit array is the left bound of the index subtype of the array and its direction is ascending if the index subtype is ascending." |
69 |
severity ERROR; |
70 |
wait; |
71 |
END PROCESS TESTING; |
72 |
|
73 |
END c07s02b04x00p20n01i02126arch; |