aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2013-12-20 04:48:54 +0100
committerTristan Gingold <tgingold@free.fr>2013-12-20 04:48:54 +0100
commit6c3f709174e8e4d5411f851cedb7d84c38d3b04a (patch)
treebd12c79c71a2ee65899a9ade9919ec2045addef8 /testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd
parentbd4aff0f670351c0652cf24e9b04361dc0e3a01c (diff)
downloadghdl-6c3f709174e8e4d5411f851cedb7d84c38d3b04a.tar.gz
ghdl-6c3f709174e8e4d5411f851cedb7d84c38d3b04a.tar.bz2
ghdl-6c3f709174e8e4d5411f851cedb7d84c38d3b04a.zip
Import vests testsuite
Diffstat (limited to 'testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd')
-rw-r--r--testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd169
1 files changed, 169 insertions, 0 deletions
diff --git a/testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd b/testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd
new file mode 100644
index 000000000..d5abd4a35
--- /dev/null
+++ b/testsuite/vests/vhdl-93/billowitch/compliant/tc2077.vhd
@@ -0,0 +1,169 @@
+
+-- Copyright (C) 2001 Bill Billowitch.
+
+-- Some of the work to develop this test suite was done with Air Force
+-- support. The Air Force and Bill Billowitch assume no
+-- responsibilities for this software.
+
+-- 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
+
+-- ---------------------------------------------------------------------
+--
+-- $Id: tc2077.vhd,v 1.2 2001-10-26 16:29:45 paw Exp $
+-- $Revision: 1.2 $
+--
+-- ---------------------------------------------------------------------
+
+ENTITY c07s02b04x00p01n02i02077ent IS
+END c07s02b04x00p01n02i02077ent;
+
+ARCHITECTURE c07s02b04x00p01n02i02077arch OF c07s02b04x00p01n02i02077ent IS
+
+BEGIN
+ TESTING: PROCESS
+ variable A : bit_vector (1 to 32);
+ constant AA : bit_vector (1 to 32) := x"0000ffff";
+ variable B : bit_vector (32 downto 1);
+ variable C : bit_vector (15 downto 0);
+ variable D, DD : bit_vector (0 to 15);
+ variable E : bit_vector (0 to 47);
+ variable F : bit_vector (47 downto 0);
+ alias FF : bit_vector (47 downto 0) is F;
+ variable Q, R : bit;
+ BEGIN
+
+ A := x"ffffffff";
+ B := x"00000000";
+ C := x"ffff";
+ D := x"0000";
+ E := x"ffffffffffff";
+ FF := x"000000000000";
+ Q := '1';
+ R := '0';
+
+ assert NOT( ( C & Q = b"11111111111111111") and
+ ( C & R = b"11111111111111110") and
+ ( D & Q = b"00000000000000001") and
+ ( D & R = b"00000000000000000") and
+ ( Q & C = b"11111111111111111") and
+ ( R & C = b"01111111111111111") and
+ ( Q & D = b"10000000000000000") and
+ ( R & D = b"00000000000000000") and
+ ( A & Q = Q & A) and
+ ( B & R = R & B) and
+ ( A & R = C & (C & R)) and
+ ( R & A = (R & C) & C) and
+ ( R & R & R & R & C = x"0ffff") and
+ ( C & R & R & R & R = x"ffff0") and
+ ( E & Q = Q & E) and
+ ( F & Q = not (E & R)) and
+ ( A & A = x"ffffffffffffffff") and
+ ( A & B = x"ffffffff00000000") and
+ ( A & C = x"ffffffffffff") and
+ ( A & D = x"ffffffff0000") and
+ ( A & E = x"ffffffffffffffffffff") and
+ ( A & F = x"ffffffff000000000000") and
+ ( B & A = x"00000000ffffffff") and
+ ( B & B = x"0000000000000000") and
+ ( B & C = x"00000000ffff") and
+ ( B & D = x"000000000000") and
+ ( B & E = x"00000000ffffffffffff") and
+ ( B & F = x"00000000000000000000") and
+ ( C & A = x"ffffffffffff") and
+ ( C & B = x"ffff00000000") and
+ ( C & C = x"ffffffff") and
+ ( C & D = x"ffff0000") and
+ ( C & E = x"ffffffffffffffff") and
+ ( C & F = x"ffff000000000000") and
+ ( D & A = x"0000ffffffff") and
+ ( D & B = x"000000000000") and
+ ( D & C = x"0000ffff") and
+ ( D & D = x"00000000") and
+ ( D & E = x"0000ffffffffffff") and
+ ( D & F = x"0000000000000000") and
+ ( E & A = x"ffffffffffffffffffff") and
+ ( E & B = x"ffffffffffff00000000") and
+ ( E & C = x"ffffffffffffffff") and
+ ( E & D = x"ffffffffffff0000") and
+ ( E & E = x"ffffffffffffffffffffffff") and
+ ( E & F = x"ffffffffffff000000000000") and
+ ( F & A = x"000000000000ffffffff") and
+ ( F & B = x"00000000000000000000") and
+ ( F & C = x"000000000000ffff") and
+ ( F & D = x"0000000000000000") and
+ ( F & E = x"000000000000ffffffffffff") and
+ ( F & F = x"000000000000000000000000") )
+ report "***PASSED TEST: c07s02b04x00p01n02i02077"
+ severity NOTE;
+ assert ( ( C & Q = b"11111111111111111") and
+ ( C & R = b"11111111111111110") and
+ ( D & Q = b"00000000000000001") and
+ ( D & R = b"00000000000000000") and
+ ( Q & C = b"11111111111111111") and
+ ( R & C = b"01111111111111111") and
+ ( Q & D = b"10000000000000000") and
+ ( R & D = b"00000000000000000") and
+ ( A & Q = Q & A) and
+ ( B & R = R & B) and
+ ( A & R = C & (C & R)) and
+ ( R & A = (R & C) & C) and
+ ( R & R & R & R & C = x"0ffff") and
+ ( C & R & R & R & R = x"ffff0") and
+ ( E & Q = Q & E) and
+ ( F & Q = not (E & R)) and
+ ( A & A = x"ffffffffffffffff") and
+ ( A & B = x"ffffffff00000000") and
+ ( A & C = x"ffffffffffff") and
+ ( A & D = x"ffffffff0000") and
+ ( A & E = x"ffffffffffffffffffff") and
+ ( A & F = x"ffffffff000000000000") and
+ ( B & A = x"00000000ffffffff") and
+ ( B & B = x"0000000000000000") and
+ ( B & C = x"00000000ffff") and
+ ( B & D = x"000000000000") and
+ ( B & E = x"00000000ffffffffffff") and
+ ( B & F = x"00000000000000000000") and
+ ( C & A = x"ffffffffffff") and
+ ( C & B = x"ffff00000000") and
+ ( C & C = x"ffffffff") and
+ ( C & D = x"ffff0000") and
+ ( C & E = x"ffffffffffffffff") and
+ ( C & F = x"ffff000000000000") and
+ ( D & A = x"0000ffffffff") and
+ ( D & B = x"000000000000") and
+ ( D & C = x"0000ffff") and
+ ( D & D = x"00000000") and
+ ( D & E = x"0000ffffffffffff") and
+ ( D & F = x"0000000000000000") and
+ ( E & A = x"ffffffffffffffffffff") and
+ ( E & B = x"ffffffffffff00000000") and
+ ( E & C = x"ffffffffffffffff") and
+ ( E & D = x"ffffffffffff0000") and
+ ( E & E = x"ffffffffffffffffffffffff") and
+ ( E & F = x"ffffffffffff000000000000") and
+ ( F & A = x"000000000000ffffffff") and
+ ( F & B = x"00000000000000000000") and
+ ( F & C = x"000000000000ffff") and
+ ( F & D = x"0000000000000000") and
+ ( F & E = x"000000000000ffffffffffff") and
+ ( F & F = x"000000000000000000000000") )
+ report "***FAILED TEST: c07s02b04x00p01n02i02077 - The operation of operator & test failed."
+ severity ERROR;
+ wait;
+ END PROCESS TESTING;
+
+END c07s02b04x00p01n02i02077arch;