aboutsummaryrefslogtreecommitdiffstats
path: root/libraries
diff options
context:
space:
mode:
Diffstat (limited to 'libraries')
-rw-r--r--libraries/ieee/std_logic_1164-body.vhdl1634
-rw-r--r--libraries/ieee/std_logic_1164.vhdl320
2 files changed, 1008 insertions, 946 deletions
diff --git a/libraries/ieee/std_logic_1164-body.vhdl b/libraries/ieee/std_logic_1164-body.vhdl
index 88a87482c..2714f6525 100644
--- a/libraries/ieee/std_logic_1164-body.vhdl
+++ b/libraries/ieee/std_logic_1164-body.vhdl
@@ -1,10 +1,30 @@
--- --------------------------------------------------------------------
+-- -----------------------------------------------------------------
+--
+-- Copyright 2019 IEEE P1076 WG Authors
+--
+-- See the LICENSE file distributed with this work for copyright and
+-- licensing information and the AUTHORS file.
+--
+-- This file to you under the Apache License, Version 2.0 (the "License").
+-- You may obtain a copy of the License at
+--
+-- http://www.apache.org/licenses/LICENSE-2.0
--
--- Title : std_logic_1164 multi-value logic system
+-- Unless required by applicable law or agreed to in writing, software
+-- distributed under the License is distributed on an "AS IS" BASIS,
+-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+-- implied. See the License for the specific language governing
+-- permissions and limitations under the License.
+--
+-- Title : Standard multivalue logic package
+-- : (STD_LOGIC_1164 package body)
+-- :
-- Library : This package shall be compiled into a library
-- : symbolically named IEEE.
-- :
--- Developers: IEEE model standards group (par 1164)
+-- Developers: IEEE model standards group (PAR 1164),
+-- : Accellera VHDL-TC, and IEEE P1076 Working Group
+-- :
-- Purpose : This packages defines a standard for designers
-- : to use in describing the interconnection data types
-- : used in vhdl modeling.
@@ -17,814 +37,844 @@
-- : issues as it relates to this package and are therefore
-- : beyond the scope of this effort.
-- :
--- Note : No declarations or definitions shall be included in,
--- : or excluded from this package. The "package declaration"
--- : defines the types, subtypes and declarations of
--- : std_logic_1164. The std_logic_1164 package body shall be
--- : considered the formal definition of the semantics of
--- : this package. Tool developers may choose to implement
--- : the package body in the most efficient manner available
--- : to them.
+-- Note : This package may be modified to include additional data
+-- : required by tools, but it must in no way change the
+-- : external interfaces or simulation behavior of the
+-- : description. It is permissible to add comments and/or
+-- : attributes to the package declarations, but not to change
+-- : or delete any original lines of the package declaration.
+-- : The package body may be changed only in accordance with
+-- : the terms of Clause 16 of this standard.
-- :
-- --------------------------------------------------------------------
--- modification history :
--- --------------------------------------------------------------------
--- version | mod. date:|
--- v4.200 | 01/02/91 |
+-- $Revision: 1220 $
+-- $Date: 2008-04-10 17:16:09 +0930 (Thu, 10 Apr 2008) $
-- --------------------------------------------------------------------
-PACKAGE BODY std_logic_1164 IS
- -------------------------------------------------------------------
- -- local types
- -------------------------------------------------------------------
- TYPE stdlogic_1d IS ARRAY (std_ulogic) OF std_ulogic;
- TYPE stdlogic_table IS ARRAY(std_ulogic, std_ulogic) OF std_ulogic;
-
- -------------------------------------------------------------------
- -- resolution function
- -------------------------------------------------------------------
- CONSTANT resolution_table : stdlogic_table := (
+package body std_logic_1164 is
+ -------------------------------------------------------------------
+ -- local types
+ -------------------------------------------------------------------
+ type stdlogic_1d is array (STD_ULOGIC) of STD_ULOGIC;
+ type stdlogic_table is array(STD_ULOGIC, STD_ULOGIC) of STD_ULOGIC;
+
+ -------------------------------------------------------------------
+ -- resolution function
+ -------------------------------------------------------------------
+ constant resolution_table : stdlogic_table := (
-- ---------------------------------------------------------
-- | U X 0 1 Z W L H - | |
-- ---------------------------------------------------------
- ( 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U' ), -- | U |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ), -- | X |
- ( 'U', 'X', '0', 'X', '0', '0', '0', '0', 'X' ), -- | 0 |
- ( 'U', 'X', 'X', '1', '1', '1', '1', '1', 'X' ), -- | 1 |
- ( 'U', 'X', '0', '1', 'Z', 'W', 'L', 'H', 'X' ), -- | Z |
- ( 'U', 'X', '0', '1', 'W', 'W', 'W', 'W', 'X' ), -- | W |
- ( 'U', 'X', '0', '1', 'L', 'W', 'L', 'W', 'X' ), -- | L |
- ( 'U', 'X', '0', '1', 'H', 'W', 'W', 'H', 'X' ), -- | H |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ) -- | - |
- );
-
- FUNCTION resolved ( s : std_ulogic_vector ) RETURN std_ulogic IS
- VARIABLE result : std_ulogic := 'Z'; -- weakest state default
- BEGIN
- -- the test for a single driver is essential otherwise the
- -- loop would return 'X' for a single driver of '-' and that
- -- would conflict with the value of a single driver unresolved
- -- signal.
- IF (s'LENGTH = 1) THEN RETURN s(s'LOW);
- ELSE
- FOR i IN s'RANGE LOOP
- result := resolution_table(result, s(i));
- END LOOP;
- END IF;
- RETURN result;
- END resolved;
-
- -------------------------------------------------------------------
- -- tables for logical operations
- -------------------------------------------------------------------
-
- -- truth table for "and" function
- CONSTANT and_table : stdlogic_table := (
+ ('U', 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U'), -- | U |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X'), -- | X |
+ ('U', 'X', '0', 'X', '0', '0', '0', '0', 'X'), -- | 0 |
+ ('U', 'X', 'X', '1', '1', '1', '1', '1', 'X'), -- | 1 |
+ ('U', 'X', '0', '1', 'Z', 'W', 'L', 'H', 'X'), -- | Z |
+ ('U', 'X', '0', '1', 'W', 'W', 'W', 'W', 'X'), -- | W |
+ ('U', 'X', '0', '1', 'L', 'W', 'L', 'W', 'X'), -- | L |
+ ('U', 'X', '0', '1', 'H', 'W', 'W', 'H', 'X'), -- | H |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X') -- | - |
+ );
+
+ function resolved (s : STD_ULOGIC_VECTOR) return STD_ULOGIC is
+ variable result : STD_ULOGIC := 'Z'; -- weakest state default
+ begin
+ -- the test for a single driver is essential otherwise the
+ -- loop would return 'X' for a single driver of '-' and that
+ -- would conflict with the value of a single driver unresolved
+ -- signal.
+ if (s'length = 1) then return s(s'low);
+ else
+ for i in s'range loop
+ result := resolution_table(result, s(i));
+ end loop;
+ end if;
+ return result;
+ end resolved;
+
+ -------------------------------------------------------------------
+ -- tables for logical operations
+ -------------------------------------------------------------------
+
+ -- truth table for "and" function
+ constant and_table : stdlogic_table := (
-- ----------------------------------------------------
-- | U X 0 1 Z W L H - | |
-- ----------------------------------------------------
- ( 'U', 'U', '0', 'U', 'U', 'U', '0', 'U', 'U' ), -- | U |
- ( 'U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X' ), -- | X |
- ( '0', '0', '0', '0', '0', '0', '0', '0', '0' ), -- | 0 |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | 1 |
- ( 'U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X' ), -- | Z |
- ( 'U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X' ), -- | W |
- ( '0', '0', '0', '0', '0', '0', '0', '0', '0' ), -- | L |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | H |
- ( 'U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X' ) -- | - |
- );
+ ('U', 'U', '0', 'U', 'U', 'U', '0', 'U', 'U'), -- | U |
+ ('U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X'), -- | X |
+ ('0', '0', '0', '0', '0', '0', '0', '0', '0'), -- | 0 |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | 1 |
+ ('U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X'), -- | Z |
+ ('U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X'), -- | W |
+ ('0', '0', '0', '0', '0', '0', '0', '0', '0'), -- | L |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | H |
+ ('U', 'X', '0', 'X', 'X', 'X', '0', 'X', 'X') -- | - |
+ );
- -- truth table for "or" function
- CONSTANT or_table : stdlogic_table := (
+ -- truth table for "or" function
+ constant or_table : stdlogic_table := (
-- ----------------------------------------------------
-- | U X 0 1 Z W L H - | |
-- ----------------------------------------------------
- ( 'U', 'U', 'U', '1', 'U', 'U', 'U', '1', 'U' ), -- | U |
- ( 'U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X' ), -- | X |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | 0 |
- ( '1', '1', '1', '1', '1', '1', '1', '1', '1' ), -- | 1 |
- ( 'U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X' ), -- | Z |
- ( 'U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X' ), -- | W |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | L |
- ( '1', '1', '1', '1', '1', '1', '1', '1', '1' ), -- | H |
- ( 'U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X' ) -- | - |
- );
+ ('U', 'U', 'U', '1', 'U', 'U', 'U', '1', 'U'), -- | U |
+ ('U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X'), -- | X |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | 0 |
+ ('1', '1', '1', '1', '1', '1', '1', '1', '1'), -- | 1 |
+ ('U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X'), -- | Z |
+ ('U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X'), -- | W |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | L |
+ ('1', '1', '1', '1', '1', '1', '1', '1', '1'), -- | H |
+ ('U', 'X', 'X', '1', 'X', 'X', 'X', '1', 'X') -- | - |
+ );
- -- truth table for "xor" function
- CONSTANT xor_table : stdlogic_table := (
+ -- truth table for "xor" function
+ constant xor_table : stdlogic_table := (
-- ----------------------------------------------------
-- | U X 0 1 Z W L H - | |
-- ----------------------------------------------------
- ( 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U' ), -- | U |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ), -- | X |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | 0 |
- ( 'U', 'X', '1', '0', 'X', 'X', '1', '0', 'X' ), -- | 1 |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ), -- | Z |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ), -- | W |
- ( 'U', 'X', '0', '1', 'X', 'X', '0', '1', 'X' ), -- | L |
- ( 'U', 'X', '1', '0', 'X', 'X', '1', '0', 'X' ), -- | H |
- ( 'U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X' ) -- | - |
- );
+ ('U', 'U', 'U', 'U', 'U', 'U', 'U', 'U', 'U'), -- | U |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X'), -- | X |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | 0 |
+ ('U', 'X', '1', '0', 'X', 'X', '1', '0', 'X'), -- | 1 |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X'), -- | Z |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X'), -- | W |
+ ('U', 'X', '0', '1', 'X', 'X', '0', '1', 'X'), -- | L |
+ ('U', 'X', '1', '0', 'X', 'X', '1', '0', 'X'), -- | H |
+ ('U', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X') -- | - |
+ );
- -- truth table for "not" function
- CONSTANT not_table: stdlogic_1d :=
+ -- truth table for "not" function
+ constant not_table : stdlogic_1d :=
-- -------------------------------------------------
-- | U X 0 1 Z W L H - |
-- -------------------------------------------------
- ( 'U', 'X', '1', '0', 'X', 'X', '1', '0', 'X' );
-
- -------------------------------------------------------------------
- -- overloaded logical operators ( with optimizing hints )
- -------------------------------------------------------------------
-
- FUNCTION "and" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (and_table(l, r));
- END "and";
-
- FUNCTION "nand" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (not_table ( and_table(l, r)));
- END "nand";
-
- FUNCTION "or" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (or_table(l, r));
- END "or";
-
- FUNCTION "nor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (not_table ( or_table( l, r )));
- END "nor";
-
- FUNCTION "xor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (xor_table(l, r));
- END "xor";
-
---START-!V87
- FUNCTION "xnor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN not_table(xor_table(l, r));
- END "xnor";
---END-!V87
-
- FUNCTION "not" ( l : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (not_table(l));
- END "not";
-
- -------------------------------------------------------------------
- -- and
- -------------------------------------------------------------------
- FUNCTION "and" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'and' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := and_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "and";
- ---------------------------------------------------------------------
- FUNCTION "and" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'and' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := and_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "and";
- -------------------------------------------------------------------
- -- nand
- -------------------------------------------------------------------
- FUNCTION "nand" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'nand' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(and_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "nand";
- ---------------------------------------------------------------------
- FUNCTION "nand" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'nand' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(and_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "nand";
- -------------------------------------------------------------------
- -- or
- -------------------------------------------------------------------
- FUNCTION "or" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'or' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := or_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "or";
- ---------------------------------------------------------------------
- FUNCTION "or" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'or' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := or_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "or";
- -------------------------------------------------------------------
- -- nor
- -------------------------------------------------------------------
- FUNCTION "nor" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'nor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(or_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "nor";
- ---------------------------------------------------------------------
- FUNCTION "nor" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'nor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(or_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "nor";
- ---------------------------------------------------------------------
- -- xor
- -------------------------------------------------------------------
- FUNCTION "xor" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'xor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := xor_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "xor";
- ---------------------------------------------------------------------
- FUNCTION "xor" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'xor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := xor_table (lv(i), rv(i));
- END LOOP;
- END IF;
- RETURN result;
- END "xor";
--- -------------------------------------------------------------------
--- -- xnor
--- -------------------------------------------------------------------
--- -----------------------------------------------------------------------
--- Note : The declaration and implementation of the "xnor" function is
--- specifically commented until at which time the VHDL language has been
--- officially adopted as containing such a function. At such a point,
--- the following comments may be removed along with this notice without
--- further "official" ballotting of this std_logic_1164 package. It is
--- the intent of this effort to provide such a function once it becomes
--- available in the VHDL standard.
--- -----------------------------------------------------------------------
---START-!V87
- FUNCTION "xnor" ( l,r : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_logic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'xnor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(xor_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "xnor";
- ---------------------------------------------------------------------
- FUNCTION "xnor" ( l,r : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- ALIAS rv : std_ulogic_vector ( 1 TO r'LENGTH ) IS r;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH );
- BEGIN
- IF ( l'LENGTH /= r'LENGTH ) THEN
- ASSERT FALSE
- REPORT "arguments of overloaded 'xnor' operator are not of the same length"
- SEVERITY FAILURE;
- ELSE
- FOR i IN result'RANGE LOOP
- result(i) := not_table(xor_table (lv(i), rv(i)));
- END LOOP;
- END IF;
- RETURN result;
- END "xnor";
---END-!V87
- -------------------------------------------------------------------
- -- not
- -------------------------------------------------------------------
- FUNCTION "not" ( l : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS lv : std_logic_vector ( 1 TO l'LENGTH ) IS l;
- VARIABLE result : std_logic_vector ( 1 TO l'LENGTH ) := (OTHERS => 'X');
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := not_table( lv(i) );
- END LOOP;
- RETURN result;
- END;
- ---------------------------------------------------------------------
- FUNCTION "not" ( l : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS lv : std_ulogic_vector ( 1 TO l'LENGTH ) IS l;
- VARIABLE result : std_ulogic_vector ( 1 TO l'LENGTH ) := (OTHERS => 'X');
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := not_table( lv(i) );
- END LOOP;
- RETURN result;
- END;
- -------------------------------------------------------------------
- -- conversion tables
- -------------------------------------------------------------------
- TYPE logic_x01_table IS ARRAY (std_ulogic'LOW TO std_ulogic'HIGH) OF X01;
- TYPE logic_x01z_table IS ARRAY (std_ulogic'LOW TO std_ulogic'HIGH) OF X01Z;
- TYPE logic_ux01_table IS ARRAY (std_ulogic'LOW TO std_ulogic'HIGH) OF UX01;
- ----------------------------------------------------------
- -- table name : cvt_to_x01
- --
- -- parameters :
- -- in : std_ulogic -- some logic value
- -- returns : x01 -- state value of logic value
- -- purpose : to convert state-strength to state only
- --
- -- example : if (cvt_to_x01 (input_signal) = '1' ) then ...
- --
- ----------------------------------------------------------
- CONSTANT cvt_to_x01 : logic_x01_table := (
- 'X', -- 'U'
- 'X', -- 'X'
- '0', -- '0'
- '1', -- '1'
- 'X', -- 'Z'
- 'X', -- 'W'
- '0', -- 'L'
- '1', -- 'H'
- 'X' -- '-'
- );
-
- ----------------------------------------------------------
- -- table name : cvt_to_x01z
- --
- -- parameters :
- -- in : std_ulogic -- some logic value
- -- returns : x01z -- state value of logic value
- -- purpose : to convert state-strength to state only
- --
- -- example : if (cvt_to_x01z (input_signal) = '1' ) then ...
- --
- ----------------------------------------------------------
- CONSTANT cvt_to_x01z : logic_x01z_table := (
- 'X', -- 'U'
- 'X', -- 'X'
- '0', -- '0'
- '1', -- '1'
- 'Z', -- 'Z'
- 'X', -- 'W'
- '0', -- 'L'
- '1', -- 'H'
- 'X' -- '-'
- );
-
- ----------------------------------------------------------
- -- table name : cvt_to_ux01
- --
- -- parameters :
- -- in : std_ulogic -- some logic value
- -- returns : ux01 -- state value of logic value
- -- purpose : to convert state-strength to state only
- --
- -- example : if (cvt_to_ux01 (input_signal) = '1' ) then ...
- --
- ----------------------------------------------------------
- CONSTANT cvt_to_ux01 : logic_ux01_table := (
- 'U', -- 'U'
- 'X', -- 'X'
- '0', -- '0'
- '1', -- '1'
- 'X', -- 'Z'
- 'X', -- 'W'
- '0', -- 'L'
- '1', -- 'H'
- 'X' -- '-'
- );
-
- -------------------------------------------------------------------
- -- conversion functions
- -------------------------------------------------------------------
- FUNCTION To_bit ( s : std_ulogic; xmap : BIT := '0') RETURN BIT IS
- BEGIN
- CASE s IS
- WHEN '0' | 'L' => RETURN ('0');
- WHEN '1' | 'H' => RETURN ('1');
- WHEN OTHERS => RETURN xmap;
- END CASE;
- END;
- --------------------------------------------------------------------
- FUNCTION To_bitvector ( s : std_logic_vector ; xmap : BIT := '0') RETURN BIT_VECTOR IS
- ALIAS sv : std_logic_vector ( s'LENGTH-1 DOWNTO 0 ) IS s;
- VARIABLE result : BIT_VECTOR ( s'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE sv(i) IS
- WHEN '0' | 'L' => result(i) := '0';
- WHEN '1' | 'H' => result(i) := '1';
- WHEN OTHERS => result(i) := xmap;
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_bitvector ( s : std_ulogic_vector; xmap : BIT := '0') RETURN BIT_VECTOR IS
- ALIAS sv : std_ulogic_vector ( s'LENGTH-1 DOWNTO 0 ) IS s;
- VARIABLE result : BIT_VECTOR ( s'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE sv(i) IS
- WHEN '0' | 'L' => result(i) := '0';
- WHEN '1' | 'H' => result(i) := '1';
- WHEN OTHERS => result(i) := xmap;
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_StdULogic ( b : BIT ) RETURN std_ulogic IS
- BEGIN
- CASE b IS
- WHEN '0' => RETURN '0';
- WHEN '1' => RETURN '1';
- END CASE;
- END;
- --------------------------------------------------------------------
- FUNCTION To_StdLogicVector ( b : BIT_VECTOR ) RETURN std_logic_vector IS
- ALIAS bv : BIT_VECTOR ( b'LENGTH-1 DOWNTO 0 ) IS b;
- VARIABLE result : std_logic_vector ( b'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_StdLogicVector ( s : std_ulogic_vector ) RETURN std_logic_vector IS
- ALIAS sv : std_ulogic_vector ( s'LENGTH-1 DOWNTO 0 ) IS s;
- VARIABLE result : std_logic_vector ( s'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := sv(i);
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_StdULogicVector ( b : BIT_VECTOR ) RETURN std_ulogic_vector IS
- ALIAS bv : BIT_VECTOR ( b'LENGTH-1 DOWNTO 0 ) IS b;
- VARIABLE result : std_ulogic_vector ( b'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_StdULogicVector ( s : std_logic_vector ) RETURN std_ulogic_vector IS
- ALIAS sv : std_logic_vector ( s'LENGTH-1 DOWNTO 0 ) IS s;
- VARIABLE result : std_ulogic_vector ( s'LENGTH-1 DOWNTO 0 );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := sv(i);
- END LOOP;
- RETURN result;
- END;
-
- -------------------------------------------------------------------
- -- strength strippers and type convertors
- -------------------------------------------------------------------
- -- to_x01
- -------------------------------------------------------------------
- FUNCTION To_X01 ( s : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS sv : std_logic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_logic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_x01 (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01 ( s : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS sv : std_ulogic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_ulogic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_x01 (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01 ( s : std_ulogic ) RETURN X01 IS
- BEGIN
- RETURN (cvt_to_x01(s));
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01 ( b : BIT_VECTOR ) RETURN std_logic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_logic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01 ( b : BIT_VECTOR ) RETURN std_ulogic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_ulogic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01 ( b : BIT ) RETURN X01 IS
- BEGIN
- CASE b IS
- WHEN '0' => RETURN('0');
- WHEN '1' => RETURN('1');
- END CASE;
- END;
- --------------------------------------------------------------------
- -- to_x01z
- -------------------------------------------------------------------
- FUNCTION To_X01Z ( s : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS sv : std_logic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_logic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_x01z (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01Z ( s : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS sv : std_ulogic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_ulogic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_x01z (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01Z ( s : std_ulogic ) RETURN X01Z IS
- BEGIN
- RETURN (cvt_to_x01z(s));
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01Z ( b : BIT_VECTOR ) RETURN std_logic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_logic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01Z ( b : BIT_VECTOR ) RETURN std_ulogic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_ulogic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_X01Z ( b : BIT ) RETURN X01Z IS
- BEGIN
- CASE b IS
- WHEN '0' => RETURN('0');
- WHEN '1' => RETURN('1');
- END CASE;
- END;
- --------------------------------------------------------------------
- -- to_ux01
- -------------------------------------------------------------------
- FUNCTION To_UX01 ( s : std_logic_vector ) RETURN std_logic_vector IS
- ALIAS sv : std_logic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_logic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_ux01 (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_UX01 ( s : std_ulogic_vector ) RETURN std_ulogic_vector IS
- ALIAS sv : std_ulogic_vector ( 1 TO s'LENGTH ) IS s;
- VARIABLE result : std_ulogic_vector ( 1 TO s'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- result(i) := cvt_to_ux01 (sv(i));
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_UX01 ( s : std_ulogic ) RETURN UX01 IS
- BEGIN
- RETURN (cvt_to_ux01(s));
- END;
- --------------------------------------------------------------------
- FUNCTION To_UX01 ( b : BIT_VECTOR ) RETURN std_logic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_logic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_UX01 ( b : BIT_VECTOR ) RETURN std_ulogic_vector IS
- ALIAS bv : BIT_VECTOR ( 1 TO b'LENGTH ) IS b;
- VARIABLE result : std_ulogic_vector ( 1 TO b'LENGTH );
- BEGIN
- FOR i IN result'RANGE LOOP
- CASE bv(i) IS
- WHEN '0' => result(i) := '0';
- WHEN '1' => result(i) := '1';
- END CASE;
- END LOOP;
- RETURN result;
- END;
- --------------------------------------------------------------------
- FUNCTION To_UX01 ( b : BIT ) RETURN UX01 IS
- BEGIN
- CASE b IS
- WHEN '0' => RETURN('0');
- WHEN '1' => RETURN('1');
- END CASE;
- END;
-
- -------------------------------------------------------------------
- -- edge detection
- -------------------------------------------------------------------
- FUNCTION rising_edge (SIGNAL s : std_ulogic) RETURN BOOLEAN IS
- BEGIN
- RETURN (s'EVENT AND (To_X01(s) = '1') AND
- (To_X01(s'LAST_VALUE) = '0'));
- END;
-
- FUNCTION falling_edge (SIGNAL s : std_ulogic) RETURN BOOLEAN IS
- BEGIN
- RETURN (s'EVENT AND (To_X01(s) = '0') AND
- (To_X01(s'LAST_VALUE) = '1'));
- END;
-
- -------------------------------------------------------------------
- -- object contains an unknown
- -------------------------------------------------------------------
- FUNCTION Is_X ( s : std_ulogic_vector ) RETURN BOOLEAN IS
- BEGIN
- FOR i IN s'RANGE LOOP
- CASE s(i) IS
- WHEN 'U' | 'X' | 'Z' | 'W' | '-' => RETURN TRUE;
- WHEN OTHERS => NULL;
- END CASE;
- END LOOP;
- RETURN FALSE;
- END;
- --------------------------------------------------------------------
- FUNCTION Is_X ( s : std_logic_vector ) RETURN BOOLEAN IS
- BEGIN
- FOR i IN s'RANGE LOOP
- CASE s(i) IS
- WHEN 'U' | 'X' | 'Z' | 'W' | '-' => RETURN TRUE;
- WHEN OTHERS => NULL;
- END CASE;
- END LOOP;
- RETURN FALSE;
- END;
- --------------------------------------------------------------------
- FUNCTION Is_X ( s : std_ulogic ) RETURN BOOLEAN IS
- BEGIN
- CASE s IS
- WHEN 'U' | 'X' | 'Z' | 'W' | '-' => RETURN TRUE;
- WHEN OTHERS => NULL;
- END CASE;
- RETURN FALSE;
- END;
-
-END std_logic_1164;
+ ('U', 'X', '1', '0', 'X', 'X', '1', '0', 'X');
+
+ -------------------------------------------------------------------
+ -- overloaded logical operators ( with optimizing hints )
+ -------------------------------------------------------------------
+
+ function "and" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return (and_table(l, r));
+ end "and";
+
+ function "nand" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return (not_table (and_table(l, r)));
+ end "nand";
+
+ function "or" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return (or_table(l, r));
+ end "or";
+
+ function "nor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return (not_table (or_table(l, r)));
+ end "nor";
+
+ function "xor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return (xor_table(l, r));
+ end "xor";
+
+ --START-!V87
+
+ function "xnor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01 is
+ begin
+ return not_table(xor_table(l, r));
+ end "xnor";
+
+ --END-!V87
+
+ function "not" (l : STD_ULOGIC) return UX01 is
+ begin
+ return (not_table(l));
+ end "not";
+
+ -------------------------------------------------------------------
+ -- and
+ -------------------------------------------------------------------
+ function "and" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""and"": "
+ & "arguments of overloaded 'and' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := and_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "and";
+
+ function "and" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""and"": "
+ & "arguments of overloaded 'and' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := and_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "and";
+
+ -------------------------------------------------------------------
+ -- nand
+ -------------------------------------------------------------------
+ function "nand" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""nand"": "
+ & "arguments of overloaded 'nand' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(and_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "nand";
+
+ function "nand" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""nand"": "
+ & "arguments of overloaded 'nand' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(and_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "nand";
+
+ -------------------------------------------------------------------
+ -- or
+ -------------------------------------------------------------------
+ function "or" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""or"": "
+ & "arguments of overloaded 'or' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := or_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "or";
+
+ function "or" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""or"": "
+ & "arguments of overloaded 'or' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := or_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "or";
+
+ -------------------------------------------------------------------
+ -- nor
+ -------------------------------------------------------------------
+ function "nor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""nor"": "
+ & "arguments of overloaded 'nor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(or_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "nor";
+
+ function "nor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""nor"": "
+ & "arguments of overloaded 'nor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(or_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "nor";
+
+ ---------------------------------------------------------------------
+ -- xor
+ -------------------------------------------------------------------
+ function "xor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""xor"": "
+ & "arguments of overloaded 'xor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := xor_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "xor";
+
+ function "xor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""xor"": "
+ & "arguments of overloaded 'xor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := xor_table (lv(i), rv(i));
+ end loop;
+ end if;
+ return result;
+ end "xor";
+
+ -------------------------------------------------------------------
+ -- xnor
+ -------------------------------------------------------------------
+ --START-!V87
+ function "xnor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_LOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_LOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""xnor"": "
+ & "arguments of overloaded 'xnor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(xor_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "xnor";
+
+ function "xnor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ alias rv : STD_ULOGIC_VECTOR (1 to r'length) is r;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length);
+ begin
+ if (l'length /= r'length) then
+ assert false
+ report "STD_LOGIC_1164.""xnor"": "
+ & "arguments of overloaded 'xnor' operator are not of the same length"
+ severity failure;
+ else
+ for i in result'range loop
+ result(i) := not_table(xor_table (lv(i), rv(i)));
+ end loop;
+ end if;
+ return result;
+ end "xnor";
+ --END-!V87
+
+ -------------------------------------------------------------------
+ -- not
+ -------------------------------------------------------------------
+ function "not" (l : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias lv : STD_LOGIC_VECTOR (1 to l'length) is l;
+ variable result : STD_LOGIC_VECTOR (1 to l'length) := (others => 'X');
+ begin
+ for i in result'range loop
+ result(i) := not_table(lv(i));
+ end loop;
+ return result;
+ end "not";
+
+ function "not" (l : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias lv : STD_ULOGIC_VECTOR (1 to l'length) is l;
+ variable result : STD_ULOGIC_VECTOR (1 to l'length) := (others => 'X');
+ begin
+ for i in result'range loop
+ result(i) := not_table(lv(i));
+ end loop;
+ return result;
+ end "not";
+
+ -------------------------------------------------------------------
+ -- conversion tables
+ -------------------------------------------------------------------
+ type logic_x01_table is array (STD_ULOGIC'low to STD_ULOGIC'high) of X01;
+ type logic_x01z_table is array (STD_ULOGIC'low to STD_ULOGIC'high) of X01Z;
+ type logic_ux01_table is array (STD_ULOGIC'low to STD_ULOGIC'high) of UX01;
+ ----------------------------------------------------------
+ -- table name : cvt_to_x01
+ --
+ -- parameters :
+ -- in : std_ulogic -- some logic value
+ -- returns : x01 -- state value of logic value
+ -- purpose : to convert state-strength to state only
+ --
+ -- example : if (cvt_to_x01 (input_signal) = '1' ) then ...
+ --
+ ----------------------------------------------------------
+ constant cvt_to_x01 : logic_x01_table := (
+ 'X', -- 'U'
+ 'X', -- 'X'
+ '0', -- '0'
+ '1', -- '1'
+ 'X', -- 'Z'
+ 'X', -- 'W'
+ '0', -- 'L'
+ '1', -- 'H'
+ 'X' -- '-'
+ );
+
+ ----------------------------------------------------------
+ -- table name : cvt_to_x01z
+ --
+ -- parameters :
+ -- in : std_ulogic -- some logic value
+ -- returns : x01z -- state value of logic value
+ -- purpose : to convert state-strength to state only
+ --
+ -- example : if (cvt_to_x01z (input_signal) = '1' ) then ...
+ --
+ ----------------------------------------------------------
+ constant cvt_to_x01z : logic_x01z_table := (
+ 'X', -- 'U'
+ 'X', -- 'X'
+ '0', -- '0'
+ '1', -- '1'
+ 'Z', -- 'Z'
+ 'X', -- 'W'
+ '0', -- 'L'
+ '1', -- 'H'
+ 'X' -- '-'
+ );
+
+ ----------------------------------------------------------
+ -- table name : cvt_to_ux01
+ --
+ -- parameters :
+ -- in : std_ulogic -- some logic value
+ -- returns : ux01 -- state value of logic value
+ -- purpose : to convert state-strength to state only
+ --
+ -- example : if (cvt_to_ux01 (input_signal) = '1' ) then ...
+ --
+ ----------------------------------------------------------
+ constant cvt_to_ux01 : logic_ux01_table := (
+ 'U', -- 'U'
+ 'X', -- 'X'
+ '0', -- '0'
+ '1', -- '1'
+ 'X', -- 'Z'
+ 'X', -- 'W'
+ '0', -- 'L'
+ '1', -- 'H'
+ 'X' -- '-'
+ );
+
+ -------------------------------------------------------------------
+ -- conversion functions
+ -------------------------------------------------------------------
+ function To_bit (s : STD_ULOGIC; xmap : BIT := '0') return BIT is
+ begin
+ case s is
+ when '0' | 'L' => return ('0');
+ when '1' | 'H' => return ('1');
+ when others => return xmap;
+ end case;
+ end To_bit;
+ --------------------------------------------------------------------
+ function To_bitvector (s : STD_LOGIC_VECTOR; xmap : BIT := '0')
+ return BIT_VECTOR
+ is
+ alias sv : STD_LOGIC_VECTOR (s'length-1 downto 0) is s;
+ variable result : BIT_VECTOR (s'length-1 downto 0);
+ begin
+ for i in result'range loop
+ case sv(i) is
+ when '0' | 'L' => result(i) := '0';
+ when '1' | 'H' => result(i) := '1';
+ when others => result(i) := xmap;
+ end case;
+ end loop;
+ return result;
+ end To_bitvector;
+
+ function To_bitvector (s : STD_ULOGIC_VECTOR; xmap : BIT := '0')
+ return BIT_VECTOR
+ is
+ alias sv : STD_ULOGIC_VECTOR (s'length-1 downto 0) is s;
+ variable result : BIT_VECTOR (s'length-1 downto 0);
+ begin
+ for i in result'range loop
+ case sv(i) is
+ when '0' | 'L' => result(i) := '0';
+ when '1' | 'H' => result(i) := '1';
+ when others => result(i) := xmap;
+ end case;
+ end loop;
+ return result;
+ end To_bitvector;
+
+ --------------------------------------------------------------------
+ function To_StdULogic (b : BIT) return STD_ULOGIC is
+ begin
+ case b is
+ when '0' => return '0';
+ when '1' => return '1';
+ end case;
+ end To_StdULogic;
+ --------------------------------------------------------------------
+ function To_StdLogicVector (b : BIT_VECTOR)
+ return STD_LOGIC_VECTOR
+ is
+ alias bv : BIT_VECTOR (b'length-1 downto 0) is b;
+ variable result : STD_LOGIC_VECTOR (b'length-1 downto 0);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_StdLogicVector;
+ --------------------------------------------------------------------
+ function To_StdLogicVector (s : STD_ULOGIC_VECTOR)
+ return STD_LOGIC_VECTOR
+ is
+ alias sv : STD_ULOGIC_VECTOR (s'length-1 downto 0) is s;
+ variable result : STD_LOGIC_VECTOR (s'length-1 downto 0);
+ begin
+ for i in result'range loop
+ result(i) := sv(i);
+ end loop;
+ return result;
+ end To_StdLogicVector;
+ --------------------------------------------------------------------
+ function To_StdULogicVector (b : BIT_VECTOR)
+ return STD_ULOGIC_VECTOR
+ is
+ alias bv : BIT_VECTOR (b'length-1 downto 0) is b;
+ variable result : STD_ULOGIC_VECTOR (b'length-1 downto 0);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_StdULogicVector;
+ --------------------------------------------------------------------
+ function To_StdULogicVector (s : STD_LOGIC_VECTOR)
+ return STD_ULOGIC_VECTOR
+ is
+ alias sv : STD_LOGIC_VECTOR (s'length-1 downto 0) is s;
+ variable result : STD_ULOGIC_VECTOR (s'length-1 downto 0);
+ begin
+ for i in result'range loop
+ result(i) := sv(i);
+ end loop;
+ return result;
+ end To_StdULogicVector;
+
+ -------------------------------------------------------------------
+ -- strength strippers and type convertors
+ -------------------------------------------------------------------
+ -------------------------------------------------------------------
+ -- to_x01
+ -------------------------------------------------------------------
+ function To_X01 (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias sv : STD_LOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_LOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_x01 (sv(i));
+ end loop;
+ return result;
+ end To_X01;
+
+ function To_X01 (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias sv : STD_ULOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_ULOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_x01 (sv(i));
+ end loop;
+ return result;
+ end To_X01;
+ --------------------------------------------------------------------
+ function To_X01 (s : STD_ULOGIC) return X01 is
+ begin
+ return (cvt_to_x01(s));
+ end To_X01;
+ --------------------------------------------------------------------
+ function To_X01 (b : BIT_VECTOR) return STD_LOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_LOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_X01;
+
+ function To_X01 (b : BIT_VECTOR) return STD_ULOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_ULOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_X01;
+
+ --------------------------------------------------------------------
+ function To_X01 (b : BIT) return X01 is
+ begin
+ case b is
+ when '0' => return('0');
+ when '1' => return('1');
+ end case;
+ end To_X01;
+ --------------------------------------------------------------------
+ -- to_x01z
+ -------------------------------------------------------------------
+ function To_X01Z (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias sv : STD_LOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_LOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_x01z (sv(i));
+ end loop;
+ return result;
+ end To_X01Z;
+
+ function To_X01Z (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias sv : STD_ULOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_ULOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_x01z (sv(i));
+ end loop;
+ return result;
+ end To_X01Z;
+
+ --------------------------------------------------------------------
+ function To_X01Z (s : STD_ULOGIC) return X01Z is
+ begin
+ return (cvt_to_x01z(s));
+ end To_X01Z;
+ --------------------------------------------------------------------
+ function To_X01Z (b : BIT_VECTOR) return STD_LOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_LOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_X01Z;
+
+ function To_X01Z (b : BIT_VECTOR) return STD_ULOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_ULOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_X01Z;
+
+ --------------------------------------------------------------------
+ function To_X01Z (b : BIT) return X01Z is
+ begin
+ case b is
+ when '0' => return('0');
+ when '1' => return('1');
+ end case;
+ end To_X01Z;
+ --------------------------------------------------------------------
+ -- to_ux01
+ -------------------------------------------------------------------
+ function To_UX01 (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR is
+ alias sv : STD_LOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_LOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_ux01 (sv(i));
+ end loop;
+ return result;
+ end To_UX01;
+
+ function To_UX01 (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR is
+ alias sv : STD_ULOGIC_VECTOR (1 to s'length) is s;
+ variable result : STD_ULOGIC_VECTOR (1 to s'length);
+ begin
+ for i in result'range loop
+ result(i) := cvt_to_ux01 (sv(i));
+ end loop;
+ return result;
+ end To_UX01;
+
+ --------------------------------------------------------------------
+ function To_UX01 (s : STD_ULOGIC) return UX01 is
+ begin
+ return (cvt_to_ux01(s));
+ end To_UX01;
+ --------------------------------------------------------------------
+ function To_UX01 (b : BIT_VECTOR) return STD_LOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_LOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_UX01;
+
+ function To_UX01 (b : BIT_VECTOR) return STD_ULOGIC_VECTOR is
+ alias bv : BIT_VECTOR (1 to b'length) is b;
+ variable result : STD_ULOGIC_VECTOR (1 to b'length);
+ begin
+ for i in result'range loop
+ case bv(i) is
+ when '0' => result(i) := '0';
+ when '1' => result(i) := '1';
+ end case;
+ end loop;
+ return result;
+ end To_UX01;
+
+ --------------------------------------------------------------------
+ function To_UX01 (b : BIT) return UX01 is
+ begin
+ case b is
+ when '0' => return('0');
+ when '1' => return('1');
+ end case;
+ end To_UX01;
+
+ -------------------------------------------------------------------
+ -- edge detection
+ -------------------------------------------------------------------
+ function rising_edge (signal s : STD_ULOGIC) return BOOLEAN is
+ begin
+ return (s'event and (To_X01(s) = '1') and
+ (To_X01(s'last_value) = '0'));
+ end rising_edge;
+
+ function falling_edge (signal s : STD_ULOGIC) return BOOLEAN is
+ begin
+ return (s'event and (To_X01(s) = '0') and
+ (To_X01(s'last_value) = '1'));
+ end falling_edge;
+
+ -------------------------------------------------------------------
+ -- object contains an unknown
+ -------------------------------------------------------------------
+ function Is_X (s : STD_LOGIC_VECTOR) return BOOLEAN is
+ begin
+ for i in s'range loop
+ case s(i) is
+ when 'U' | 'X' | 'Z' | 'W' | '-' => return true;
+ when others => null;
+ end case;
+ end loop;
+ return false;
+ end Is_X;
+
+ function Is_X (s : STD_ULOGIC_VECTOR) return BOOLEAN is
+ begin
+ for i in s'range loop
+ case s(i) is
+ when 'U' | 'X' | 'Z' | 'W' | '-' => return true;
+ when others => null;
+ end case;
+ end loop;
+ return false;
+ end Is_X;
+
+ --------------------------------------------------------------------
+ function Is_X (s : STD_ULOGIC) return BOOLEAN is
+ begin
+ case s is
+ when 'U' | 'X' | 'Z' | 'W' | '-' => return true;
+ when others => null;
+ end case;
+ return false;
+ end Is_X;
+
+end std_logic_1164;
diff --git a/libraries/ieee/std_logic_1164.vhdl b/libraries/ieee/std_logic_1164.vhdl
index c1c964817..749f4c842 100644
--- a/libraries/ieee/std_logic_1164.vhdl
+++ b/libraries/ieee/std_logic_1164.vhdl
@@ -1,10 +1,30 @@
--- --------------------------------------------------------------------
+-- -----------------------------------------------------------------
+--
+-- Copyright 2019 IEEE P1076 WG Authors
+--
+-- See the LICENSE file distributed with this work for copyright and
+-- licensing information and the AUTHORS file.
+--
+-- This file to you under the Apache License, Version 2.0 (the "License").
+-- You may obtain a copy of the License at
+--
+-- http://www.apache.org/licenses/LICENSE-2.0
--
--- Title : std_logic_1164 multi-value logic system
+-- Unless required by applicable law or agreed to in writing, software
+-- distributed under the License is distributed on an "AS IS" BASIS,
+-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+-- implied. See the License for the specific language governing
+-- permissions and limitations under the License.
+--
+-- Title : Standard multivalue logic package
+-- : (STD_LOGIC_1164 package declaration)
+-- :
-- Library : This package shall be compiled into a library
-- : symbolically named IEEE.
-- :
--- Developers: IEEE model standards group (par 1164)
+-- Developers: IEEE model standards group (PAR 1164),
+-- : Accellera VHDL-TC, and IEEE P1076 Working Group
+-- :
-- Purpose : This packages defines a standard for designers
-- : to use in describing the interconnection data types
-- : used in vhdl modeling.
@@ -17,159 +37,151 @@
-- : issues as it relates to this package and are therefore
-- : beyond the scope of this effort.
-- :
--- Note : No declarations or definitions shall be included in,
--- : or excluded from this package. The "package declaration"
--- : defines the types, subtypes and declarations of
--- : std_logic_1164. The std_logic_1164 package body shall be
--- : considered the formal definition of the semantics of
--- : this package. Tool developers may choose to implement
--- : the package body in the most efficient manner available
--- : to them.
+-- Note : This package may be modified to include additional data
+-- : required by tools, but it must in no way change the
+-- : external interfaces or simulation behavior of the
+-- : description. It is permissible to add comments and/or
+-- : attributes to the package declarations, but not to change
+-- : or delete any original lines of the package declaration.
+-- : The package body may be changed only in accordance with
+-- : the terms of Clause 16 of this standard.
-- :
-- --------------------------------------------------------------------
--- modification history :
--- --------------------------------------------------------------------
--- version | mod. date:|
--- v4.200 | 01/02/92 |
+-- $Revision: 1228 $
+-- $Date: 2008-04-30 10:04:53 +0930 (Wed, 30 Apr 2008) $
-- --------------------------------------------------------------------
-PACKAGE std_logic_1164 IS
-
- -------------------------------------------------------------------
- -- logic state system (unresolved)
- -------------------------------------------------------------------
- TYPE std_ulogic IS ( 'U', -- Uninitialized
- 'X', -- Forcing Unknown
- '0', -- Forcing 0
- '1', -- Forcing 1
- 'Z', -- High Impedance
- 'W', -- Weak Unknown
- 'L', -- Weak 0
- 'H', -- Weak 1
- '-' -- Don't care
+package std_logic_1164 is
+
+ -------------------------------------------------------------------
+ -- logic state system (unresolved)
+ -------------------------------------------------------------------
+ type STD_ULOGIC is ( 'U', -- Uninitialized
+ 'X', -- Forcing Unknown
+ '0', -- Forcing 0
+ '1', -- Forcing 1
+ 'Z', -- High Impedance
+ 'W', -- Weak Unknown
+ 'L', -- Weak 0
+ 'H', -- Weak 1
+ '-' -- Don't care
);
- -------------------------------------------------------------------
- -- unconstrained array of std_ulogic for use with the resolution function
- -------------------------------------------------------------------
- TYPE std_ulogic_vector IS ARRAY ( NATURAL RANGE <> ) OF std_ulogic;
-
- -------------------------------------------------------------------
- -- resolution function
- -------------------------------------------------------------------
- FUNCTION resolved ( s : std_ulogic_vector ) RETURN std_ulogic;
-
- -------------------------------------------------------------------
- -- *** industry standard logic type ***
- -------------------------------------------------------------------
- SUBTYPE std_logic IS resolved std_ulogic;
-
- -------------------------------------------------------------------
- -- unconstrained array of std_logic for use in declaring signal arrays
- -------------------------------------------------------------------
- TYPE std_logic_vector IS ARRAY ( NATURAL RANGE <>) OF std_logic;
-
- -------------------------------------------------------------------
- -- common subtypes
- -------------------------------------------------------------------
- SUBTYPE X01 IS resolved std_ulogic RANGE 'X' TO '1'; -- ('X','0','1')
- SUBTYPE X01Z IS resolved std_ulogic RANGE 'X' TO 'Z'; -- ('X','0','1','Z')
- SUBTYPE UX01 IS resolved std_ulogic RANGE 'U' TO '1'; -- ('U','X','0','1')
- SUBTYPE UX01Z IS resolved std_ulogic RANGE 'U' TO 'Z'; -- ('U','X','0','1','Z')
-
- -------------------------------------------------------------------
- -- overloaded logical operators
- -------------------------------------------------------------------
-
- FUNCTION "and" ( l : std_ulogic; r : std_ulogic ) RETURN UX01;
- FUNCTION "nand" ( l : std_ulogic; r : std_ulogic ) RETURN UX01;
- FUNCTION "or" ( l : std_ulogic; r : std_ulogic ) RETURN UX01;
- FUNCTION "nor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01;
- FUNCTION "xor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01;
- FUNCTION "xnor" ( l : std_ulogic; r : std_ulogic ) RETURN UX01; --!V87
- FUNCTION "not" ( l : std_ulogic ) RETURN UX01;
-
- -------------------------------------------------------------------
- -- vectorized overloaded logical operators
- -------------------------------------------------------------------
- FUNCTION "and" ( l, r : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "and" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;
-
- FUNCTION "nand" ( l, r : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "nand" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;
-
- FUNCTION "or" ( l, r : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "or" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;
-
- FUNCTION "nor" ( l, r : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "nor" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;
-
- FUNCTION "xor" ( l, r : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "xor" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;
-
--- -----------------------------------------------------------------------
--- Note : The declaration and implementation of the "xnor" function is
--- specifically commented until at which time the VHDL language has been
--- officially adopted as containing such a function. At such a point,
--- the following comments may be removed along with this notice without
--- further "official" ballotting of this std_logic_1164 package. It is
--- the intent of this effort to provide such a function once it becomes
--- available in the VHDL standard.
--- -----------------------------------------------------------------------
- FUNCTION "xnor" ( l, r : std_logic_vector ) RETURN std_logic_vector; --!V87
- FUNCTION "xnor" ( l, r : std_ulogic_vector ) RETURN std_ulogic_vector;--!V87
-
- FUNCTION "not" ( l : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION "not" ( l : std_ulogic_vector ) RETURN std_ulogic_vector;
-
- -------------------------------------------------------------------
- -- conversion functions
- -------------------------------------------------------------------
- FUNCTION To_bit ( s : std_ulogic; xmap : BIT := '0') RETURN BIT;
- FUNCTION To_bitvector ( s : std_logic_vector ; xmap : BIT := '0') RETURN BIT_VECTOR;
- FUNCTION To_bitvector ( s : std_ulogic_vector; xmap : BIT := '0') RETURN BIT_VECTOR;
-
- FUNCTION To_StdULogic ( b : BIT ) RETURN std_ulogic;
- FUNCTION To_StdLogicVector ( b : BIT_VECTOR ) RETURN std_logic_vector;
- FUNCTION To_StdLogicVector ( s : std_ulogic_vector ) RETURN std_logic_vector;
- FUNCTION To_StdULogicVector ( b : BIT_VECTOR ) RETURN std_ulogic_vector;
- FUNCTION To_StdULogicVector ( s : std_logic_vector ) RETURN std_ulogic_vector;
-
- -------------------------------------------------------------------
- -- strength strippers and type convertors
- -------------------------------------------------------------------
-
- FUNCTION To_X01 ( s : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION To_X01 ( s : std_ulogic_vector ) RETURN std_ulogic_vector;
- FUNCTION To_X01 ( s : std_ulogic ) RETURN X01;
- FUNCTION To_X01 ( b : BIT_VECTOR ) RETURN std_logic_vector;
- FUNCTION To_X01 ( b : BIT_VECTOR ) RETURN std_ulogic_vector;
- FUNCTION To_X01 ( b : BIT ) RETURN X01;
-
- FUNCTION To_X01Z ( s : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION To_X01Z ( s : std_ulogic_vector ) RETURN std_ulogic_vector;
- FUNCTION To_X01Z ( s : std_ulogic ) RETURN X01Z;
- FUNCTION To_X01Z ( b : BIT_VECTOR ) RETURN std_logic_vector;
- FUNCTION To_X01Z ( b : BIT_VECTOR ) RETURN std_ulogic_vector;
- FUNCTION To_X01Z ( b : BIT ) RETURN X01Z;
-
- FUNCTION To_UX01 ( s : std_logic_vector ) RETURN std_logic_vector;
- FUNCTION To_UX01 ( s : std_ulogic_vector ) RETURN std_ulogic_vector;
- FUNCTION To_UX01 ( s : std_ulogic ) RETURN UX01;
- FUNCTION To_UX01 ( b : BIT_VECTOR ) RETURN std_logic_vector;
- FUNCTION To_UX01 ( b : BIT_VECTOR ) RETURN std_ulogic_vector;
- FUNCTION To_UX01 ( b : BIT ) RETURN UX01;
-
- -------------------------------------------------------------------
- -- edge detection
- -------------------------------------------------------------------
- FUNCTION rising_edge (SIGNAL s : std_ulogic) RETURN BOOLEAN;
- FUNCTION falling_edge (SIGNAL s : std_ulogic) RETURN BOOLEAN;
-
- -------------------------------------------------------------------
- -- object contains an unknown
- -------------------------------------------------------------------
- FUNCTION Is_X ( s : std_ulogic_vector ) RETURN BOOLEAN;
- FUNCTION Is_X ( s : std_logic_vector ) RETURN BOOLEAN;
- FUNCTION Is_X ( s : std_ulogic ) RETURN BOOLEAN;
-
-END std_logic_1164;
+ -------------------------------------------------------------------
+ -- unconstrained array of std_ulogic for use with the resolution function
+ -- and for use in declaring signal arrays of unresolved elements
+ -------------------------------------------------------------------
+ type STD_ULOGIC_VECTOR is array (NATURAL range <>) of STD_ULOGIC;
+
+ -------------------------------------------------------------------
+ -- resolution function
+ -------------------------------------------------------------------
+ function resolved (s : STD_ULOGIC_VECTOR) return STD_ULOGIC;
+
+
+ -------------------------------------------------------------------
+ -- logic state system (resolved)
+ -------------------------------------------------------------------
+ subtype STD_LOGIC is resolved STD_ULOGIC;
+
+ -------------------------------------------------------------------
+ -- unconstrained array of resolved std_ulogic for use in declaring
+ -- signal arrays of resolved elements
+ -------------------------------------------------------------------
+ type STD_LOGIC_VECTOR is array (NATURAL range <>) of STD_LOGIC;
+
+ -------------------------------------------------------------------
+ -- common subtypes
+ -------------------------------------------------------------------
+ subtype X01 is resolved STD_ULOGIC range 'X' to '1'; -- ('X','0','1')
+ subtype X01Z is resolved STD_ULOGIC range 'X' to 'Z'; -- ('X','0','1','Z')
+ subtype UX01 is resolved STD_ULOGIC range 'U' to '1'; -- ('U','X','0','1')
+ subtype UX01Z is resolved STD_ULOGIC range 'U' to 'Z'; -- ('U','X','0','1','Z')
+
+ -------------------------------------------------------------------
+ -- overloaded logical operators
+ -------------------------------------------------------------------
+
+ function "and" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01;
+ function "nand" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01;
+ function "or" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01;
+ function "nor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01;
+ function "xor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01;
+ function "xnor" (l : STD_ULOGIC; r : STD_ULOGIC) return UX01; --!V87
+ function "not" (l : STD_ULOGIC) return UX01;
+
+ -------------------------------------------------------------------
+ -- vectorized overloaded logical operators
+ -------------------------------------------------------------------
+ function "and" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "and" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ function "nand" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "nand" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ function "or" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "or" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ function "nor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "nor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ function "xor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "xor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ function "xnor" (l, r : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR; --!V87
+ function "xnor" (l, r : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR; --!V87
+
+ function "not" (l : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function "not" (l : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ -------------------------------------------------------------------
+ -- conversion functions
+ -------------------------------------------------------------------
+ function To_bit (s : STD_ULOGIC; xmap : BIT := '0') return BIT;
+ function To_bitvector (s : STD_LOGIC_VECTOR; xmap : BIT := '0') return BIT_VECTOR;
+ function To_bitvector (s : STD_ULOGIC_VECTOR; xmap : BIT := '0') return BIT_VECTOR;
+
+ function To_StdULogic (b : BIT) return STD_ULOGIC;
+ function To_StdLogicVector (b : BIT_VECTOR) return STD_LOGIC_VECTOR;
+ function To_StdLogicVector (s : STD_ULOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function To_StdULogicVector (b : BIT_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_StdULogicVector (s : STD_LOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+
+ -------------------------------------------------------------------
+ -- strength strippers and type convertors
+ -------------------------------------------------------------------
+
+ function To_X01 (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function To_X01 (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_X01 (s : STD_ULOGIC) return X01;
+ function To_X01 (b : BIT_VECTOR) return STD_LOGIC_VECTOR;
+ function To_X01 (b : BIT_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_X01 (b : BIT) return X01;
+
+ function To_X01Z (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function To_X01Z (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_X01Z (s : STD_ULOGIC) return X01Z;
+ function To_X01Z (b : BIT_VECTOR) return STD_LOGIC_VECTOR;
+ function To_X01Z (b : BIT_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_X01Z (b : BIT) return X01Z;
+
+ function To_UX01 (s : STD_LOGIC_VECTOR) return STD_LOGIC_VECTOR;
+ function To_UX01 (s : STD_ULOGIC_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_UX01 (s : STD_ULOGIC) return UX01;
+ function To_UX01 (b : BIT_VECTOR) return STD_LOGIC_VECTOR;
+ function To_UX01 (b : BIT_VECTOR) return STD_ULOGIC_VECTOR;
+ function To_UX01 (b : BIT) return UX01;
+
+ -------------------------------------------------------------------
+ -- edge detection
+ -------------------------------------------------------------------
+ function rising_edge (signal s : STD_ULOGIC) return BOOLEAN;
+ function falling_edge (signal s : STD_ULOGIC) return BOOLEAN;
+
+ -------------------------------------------------------------------
+ -- object contains an unknown
+ -------------------------------------------------------------------
+ function Is_X (s : STD_ULOGIC_VECTOR) return BOOLEAN;
+ function Is_X (s : STD_LOGIC_VECTOR) return BOOLEAN;
+ function Is_X (s : STD_ULOGIC) return BOOLEAN;
+
+end std_logic_1164;