# Design with Hardware Description Languages (HDL) (DHDL-94952) Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful mehranzadeh@iaud.ac.ir Mehran.students@gmail.com # Data Types Amin Mehranzadeh, Ph.D. - VHDL contains a series of pre-defined data types, specified through the IEEE 1076 and IEEE 1164 standards. More specifically, such data type definitions can be found in the following packages / libraries: - Package standard of library std: Defines BIT, BOOLEAN, INTEGER, and REAL data types. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### Pre-Defined Data Types: - Package std\_logic\_1164 of library ieee: Defines STD\_LOGIC and STD\_ULOGIC data types. - Package std\_logic\_arith of library ieee: Defines SIGNED and UNSIGNED data types, plus several data conversion functions, like: conv\_integer(p) conv\_unsigned(p, b), conv\_signed(p, b), and conv\_std\_logic\_vector(p, b). Amin Mehranzadeh, Ph.D. Packages std\_logic\_signed and std\_logic\_unsigned of library ieee: Contain functions that allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED or UNSIGNED, respectively. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ### Pre-Defined Data Types: • BIT (and BIT\_VECTOR): 2-level logic ('0', '1'): Examples: SIGNAL x: BIT; Note: x is declared as a one-digit signal of type BIT. SIGNAL y: BIT\_VECTOR (3 DOWNTO 0); Note: y is a 4-bit vector, with the leftmost bit being the MSB. SIGNAL w: BIT\_VECTOR (0 TO 7); Note: w is an 8-bit vector, with the rightmost bit being the MSB. Amin Mehranzadeh, Ph.D. Based on the signals above, the following assignments would be legal (to assign a value to a signal, the "<=" operator must be used):</li> ``` X <= '1'; ``` Note: single quotes (' ') are used for a single bit. ``` y <= "0111"; ``` Note: double quotes (" ") are used for vectors (MSB='0'). w <= "01110001"; Note: w is an 8-bit signal, whose value is "01110001" (MSB='1'). Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ### Pre-Defined Data Types: - STD\_LOGIC (and STD\_LOGIC\_VECTOR): 8-valued logic system introduced in the IEEE 1164 standard. - 'X' Forcing Unknown (synthesizable unknown) - '0' Forcing Low (synthesizable logic '1') - '1' Forcing High (synthesizable logic '0') - 'Z' High impedance (synthesizable tri-state buffer) - 'W' Weak unknown - 'L' Weak low - 'H' Weak high - '-' Don't care Amin Mehranzadeh, Ph.D. #### **Examples:** SIGNAL x: STD\_LOGIC; Note: x is declared as a one-digit (scalar) signal of type STD\_LOGIC. SIGNAL y: STD\_LOGIC\_VECTOR (3 DOWNTO 0) := "0001"; Note1: y is declared as a 4-bit vector, with the leftmost bit being the MSB. Note2: The initial value (optional) of y is "0001". Note3: the ":=" operator is used to establish the initial value. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ### Pre-Defined Data Types: Most of the std\_logic levels are intended for simulation only. However, '0', '1', and 'Z' are synthesizable with no restrictions. With respect to the "weak" values, they are resolved in favor of the "forcing" values in multiply-driven nodes (see table 3.1). Indeed, if any two std\_logic signals are connected to the same node, then conflicting logic levels are automatically resolved according to table 3.1. Amin Mehranzadeh, Ph.D. Table 3.1 Resolved logic system (STD\_LOGIC). | | Х | 0 | 1 | Z | W | L | Н | - | |---|---|---|---|--------------|---|---|---|---| | Х | х | Х | Х | Х | Х | Х | Х | Х | | 0 | Х | 0 | X | 0 | 0 | 0 | 0 | Х | | 1 | Х | X | 1 | 1 | 1 | 1 | 1 | Х | | z | Х | 0 | 1 | $\mathbf{z}$ | W | L | H | Х | | W | Х | 0 | 1 | W | W | W | W | Х | | L | Х | 0 | 1 | L | W | L | W | Х | | Н | Х | 0 | 1 | Н | W | W | H | Х | | - | Х | Х | X | Х | X | X | Х | Х | | | | | | | | | | | Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### Pre-Defined Data Types: - STD\_ULOGIC (STD\_ULOGIC\_VECTOR): - 9-level logic system introduced in the IEEE 1164 standard ('U', 'X', '0', '1', 'Z', 'W', 'L', 'H', '-'). - The STD\_LOGIC system described above is a subtype of STD\_ULOGIC. - The STD\_ULOGIC includes an extra logic value, 'U', which stands for unresolved. - Contrary to STD\_LOGIC, conflicting logic levels are not automatically resolved here, so output wires should never be connected together directly. Amin Mehranzadeh, Ph.D. - BOOLEAN: True, False. - INTEGER: 32-bit integers (from -2,147,483,647 to +2,147,483,647). - NATURAL: Non-negative integers (fro 0 to +2,147,483,647). - REAL: Real numbers ranging from -1.0E38 to +1.0E38 (Not synthesizable). - Physical literals: Used to inform physical quantities, like time, voltage, etc. (Useful in simulations, Not synthesizable). - Character literals: Single ASCII character or a string of such characters (Not synthesizable). Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ### Pre-Defined Data Types: - SIGNED and UNSIGNED: - data types defined in the std\_logic\_arith package of the ieee library. - They have the appearance of STD\_LOGIC\_VECTOR, but accept arithmetic operations, which are typical of INTEGER data types. Amin Mehranzadeh, Ph.D. ``` Examples: x0 <= '0'; -- bit, std_logic, or std_ulogic value '0' x1 <= "00011111"; -- bit_vector, std_logic_vector, -- std_ulogic_vector, signed, or unsigned x2 <= "0001_1111"; -- underscore allowed to ease visualization x3 <= "101111" -- binary representation of decimal 47 x4 <= B"101111" -- binary representation of decimal 47 x5 <= 0"57" -- octal representation of decimal 47 -- hexadecimal representation of decimal 47 x6 \le X"2F" n \le 1200; -- integer m \le 1 200; -- integer, underscore allowed IF ready THEN... -- Boolean, executed if ready=TRUE y \le 1.2E-5; -- real, not synthesizable ``` -- physical, not synthesizable Amin Mehranzadeh, Ph.D. q <= d after 10 ns; CE Department of Islamic Azad University of Dezful # Pre-Defined Data Types: Example: Legal and illegal operations between data of different types. ``` SIGNAL a: BIT; SIGNAL b: BIT VECTOR(7 DOWNTO 0); SIGNAL c: STD LOGIC; SIGNAL d: STD_LOGIC_VECTOR(7 DOWNTO 0); SIGNAL e: INTEGER RANGE 0 TO 255; a <= b(5); -- legal (same scalar type: BIT) b(0) <= a; -- legal (same scalar type: BIT) c <= d(5); -- legal (same scalar type: STD LOGIC)</pre> d(0) <= c; -- legal (same scalar type: STD_LOGIC)</pre> a <= c; -- illegal (type mismatch: BIT x STD_LOGIC) -- illegal (type mismatch: BIT_VECTOR x b <= d; -- STD_LOGIC_VECTOR) e <= b; -- illegal (type mismatch: INTEGER x BIT VECTOR) e <= d; -- illegal (type mismatch: INTEGER x -- STD_LOGIC_VECTOR) Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ``` # **User-Defined Data Types:** VHDL also allows the user to define his/her own data types. Two categories of user defined data types are shown below: integer and enumerated. ``` • User-defined integer types: TYPE integer IS RANGE -2147483647 TO +2147483647; -- This is indeed the pre-defined type INTEGER. TYPE natural IS RANGE 0 TO +2147483647; -- This is indeed the pre-defined type NATURAL. TYPE my_integer IS RANGE -32 TO 32; -- A user-defined subset of integers. TYPE student_grade IS RANGE 0 TO 100; -- A user-defined subset of integers or naturals. ``` Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### **User-Defined Data Types:** ``` · User-defined enumerated types: TYPE bit IS ('0', '1'); -- This is indeed the pre-defined type BIT TYPE my logic IS ('0', '1', 'Z'); -- A user-defined subset of std_logic. TYPE bit_vector IS ARRAY (NATURAL RANGE <>) OF BIT; -- This is indeed the pre-defined type BIT_VECTOR. -- RANGE <> is used to indicate that the range is unconstrained. -- NATURAL RANGE <>, on the other hand, indicates that the only -- restriction is that the range must fall within the NATURAL TYPE state IS (idle, forward, backward, stop); -- An enumerated data type, typical of finite state machines. TYPE color IS (red, green, blue, white); -- Another enumerated data type. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ``` # Subtypes: A SUBTYPE is a TYPE with a constraint. The main reason for using a subtype rather than specifying a new type is that, though operations between data of different types are not allowed, they are allowed between a subtype and its corresponding base type. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful # Subtypes: Examples: The subtypes below were derived from the types presented in the previous examples. ``` SUBTYPE natural IS INTEGER RANGE 0 TO INTEGER'HIGH; -- As expected, NATURAL is a subtype (subset) of INTEGER. SUBTYPE my_logic IS STD_LOGIC RANGE '0' TO 'Z'; -- Recall that STD_LOGIC=('X','0','1','Z','W','L','H','-'). -- Therefore, my_logic=('0','1','Z'). SUBTYPE my_color IS color RANGE red TO blue; -- Since color=(red, green, blue, white), then -- my_color=(red, green, blue). SUBTYPE small_integer IS INTEGER RANGE -32 TO 32; -- A subtype of INTEGER. ``` Amin Mehranzadeh, Ph.D. # Subtypes: Example: Legal and illegal operations between types and subtypes. SUBTYPE my\_logic IS STD\_LOGIC RANGE '0' TO '1'; SIGNAL a: BIT; SIGNAL b: STD\_LOGIC; SIGNAL c: my\_logic; ... b <= a; -- illegal (type mismatch: BIT versus STD\_LOGIC) b <= c; -- legal (same "base" type: STD\_LOGIC) Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### Arrays: Arrays are collections of objects of the same type. They can be one-dimensional (1D), two-dimensional (2D), or one-dimensional-by-one-dimensional (1Dx1D). They can also be of higher dimensions, but then they are generally not synthesizable. Amin Mehranzadeh, Ph.D. | Array | S: | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------------|-------------------------|--|--|--|--| | Figure 3.1 illustrates the construction of data arrays. A single value (scalar) is shown in (a), a vector (1D array) in (b), an array of vectors (1Dx1D array) in (c), and an array of scalars (2D array) in (d). | | | | | | | | | 0 | 0 1 0 0 0 | 0 1 0 0 0 1 0 0 1 0 1 1 0 0 1 | 0 1 0 0 0 1 0 1 1 0 0 1 | | | | | | (a) | (b) | (c) | (d) | | | | | | Figure 3.1 Illustration of (a) scalar, (b) 1D, (c) 1Dx1D, and (d) 2D data arrays. | | | | | | | | | Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful | | | | | | | | The pre-defined VHDL data types include only the scalar (single bit) and vector (one-dimensional array of bits) categories. The predefined synthesizable types in each of these categories are the following: - -Scalars: BIT, STD\_LOGIC, STD\_ULOGIC, and BOOLEAN. - -Vectors: BIT\_VECTOR, STD\_LOGIC\_VECTOR, STD\_ULOGIC\_VECTOR, INTEGER, SIGNED, and UNSIGNED. Amin Mehranzadeh, Ph.D. As can be seen, there are no pre-defined 2D or 1Dx1D arrays, which, when necessary, must be specified by the user. To do so, the new TYPE must first be defined, then the new SIGNAL, VARIABLE, or CONSTANT can be declared using that data type. The syntax below should be used. To specify a new array type: TYPE type\_name IS ARRAY (specification) OF data\_type; Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### Arrays: To make use of the new array type: ``` SIGNAL signal_name: type_name [:= initial_value]; ``` Example: 1Dx1D array: ``` TYPE row IS ARRAY (7 DOWNTO 0) OF STD_LOGIC; -- 1D array TYPE matrix IS ARRAY (0 TO 3) OF row; -- 1DxlD array SIGNAL x: matrix; -- 1DxlD signal ``` Another way of constructing the 1Dx1D array above would be the following: TYPE matrix IS ARRAY (0 TO 3) OF STD\_LOGIC\_VECTOR(7 DOWNTO 0); Amin Mehranzadeh, Ph.D. #### Example: 2D array. ``` TYPE matrix2D IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD LOGIC; ``` Example: Array initialization. ``` ... :="0001"; -- for 1D array ... :=('0','0','0','1') -- for 1D array ... :=(('0','1','1','1'), ('1','1','1','0')); -- for 1Dx1D or -- 2D array ``` Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful CE Department of Islamic Azad University of Dezful # Arrays: Amin Mehranzadeh, Ph.D. Example: Legal and illegal array assignments. The assignments in this example are based on the following type definitions and signal declarations: ``` TYPE row IS ARRAY (7 DOWNTO 0) OF STD_LOGIC; -- 1D array TYPE array1 IS ARRAY (0 TO 3) OF row; -- 1Dx1D array TYPE array2 IS ARRAY (0 TO 3) OF STD_LOGIC_VECTOR(7 DOWNTO 0); -- 1Dx1D TYPE array3 IS ARRAY (0 TO 3, 7 DOWNTO 0) OF STD_LOGIC; -- 2D array SIGNAL x: row; SIGNAL y: array1; SIGNAL v: array2; SIGNAL w: array3; ``` ``` ----- Legal scalar assignments: ----- -- The scalar (single bit) assignments below are all legal, -- because the "base" (scalar) type is STD_LOGIC for all signals -- (x,y,v,w). -- notice two pairs of parenthesis x(0) \le y(1)(2); -- (y is 1Dx1D) x(1) \le v(2)(3); -- two pairs of parenthesis (v is 1Dx1D) -- a single pair of parenthesis (w is 2D) x(2) \le w(2,1); y(1)(1) \le x(6); y(2)(0) \le v(0)(0); y(0)(0) \le w(3,3); w(1,1) \le x(7); w(3,0) \le v(0)(3); Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ``` #### Arrays: ``` ----- Vector assignments: ----- x \ll y(0); -- legal (same data types: ROW) x \le v(1); -- illegal (type mismatch: ROW x -- STD_LOGIC_VECTOR) x \le w(2); -- illegal (w must have 2D index) x \le w(2, 2 DOWNTO 0); -- illegal (type mismatch: ROW x -- STD_LOGIC) v(0) <= w(2, 2 DOWNTO 0); -- illegal (mismatch: STD_LOGIC_VECTOR -- x STD_LOGIC) v(0) \le w(2); -- illegal (w must have 2D index) y(1) \le v(3); -- illegal (type mismatch: ROW x -- STD_LOGIC_VECTOR) y(1)(7 DOWNTO 3) \le x(4 DOWNTO 0); -- legal (same type, -- same size) v(1)(7 \text{ DOWNTO } 3) \le v(2)(4 \text{ DOWNTO } 0); -- \text{ legal (same type,} -- same size) w(1, 5 DOWNTO 1) \le v(2)(4 DOWNTO 0); -- illegal (type mismatch) CE Department of Islamic Azad University of Dezful Amin Mehranzadeh, Ph.D. ``` ### Port Array: In the specification of the input or output pins (PORTS) of a circuit (which is made in the ENTITY), we might need to specify the ports as arrays of vectors. Since TYPE declarations are not allowed in an ENTITY, the solution is to declare user-defined data types in a PACKAGE, which will then be visible to the whole design (thus including the ENTITY). Amin Mehranzadeh, Ph.D. ``` Port Array: ----- Package: ---- An example: USE ieee.std_logic_1164.all; PACKAGE my_data_types IS TYPE vector array IS ARRAY (NATURAL RANGE <>) OF STD LOGIC VECTOR(7 DOWNTO 0); END my data types; ----- Main code: ----- LIBRARY ieee; USE ieee.std logic 1164.all; ENTITY mux IS PORT (inp: IN VECTOR_ARRAY (0 TO 3); ...); END mux; ... ; Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ``` # Port Array: - NATURAL RANGE <> signifies that the range is not fixed, with the only restriction that it must fall within the NATURAL range, which goes from 0 to +2,147,483,647). - -The data type was saved in a PACKAGE called my\_data\_types, and later used in an ENTITY to specify a PORT called inp. - -Notice in the main code the inclusion of an additional USE clause to make the user-defined package my\_data\_types visible to the design. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### Port Array: Another option for the PACKAGE would be that shown below, where a CONSTANT declaration is included: ``` LIBRARY ieee; USE ieee.std_logic_1164.all; ------- PACKAGE my_data_types IS CONSTANT b: INTEGER := 7; TYPE vector_array IS ARRAY (NATURAL RANGE <>) OF STD_LOGIC_VECTOR(b DOWNTO 0); END my_data_types; ``` Amin Mehranzadeh, Ph.D. #### Records: Records are similar to arrays, with the only difference that they contain objects of different types. ``` Example: TYPE birthday IS RECORD day: INTEGER RANGE 1 TO 31; month: month_name; END RECORD; ``` Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful # Signed and Unsigned Data Types: As mentioned earlier, these types are defined in the std\_logic\_arith package of the ieee library. Their syntax is illustrated in the examples below. ``` Examples: SIGNAL x: SIGNED (7 DOWNTO 0); SIGNAL y: UNSIGNED (0 TO 3); ``` Notice that their syntax is similar to that of STD\_LOGIC\_VECTOR, not like that of an INTEGER, as one might have expected. Amin Mehranzadeh, Ph.D. ### Signed and Unsigned Data Types: -An UNSIGNED value is a number never lower than zero. For example, "0101" represents the decimal 5, while "1101" signifies 13. If type SIGNED is used instead, the value can be positive or negative (in two's complement format). Therefore, "0101" would represent the decimal 5, while "1101" would mean -3. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful # Signed and Unsigned Data Types: -To use SIGNED or UNSIGNED data types, the std\_logic\_arith package, of the ieee library, must be declared. Despite their syntax, SIGNED and UNSIGNED data types are intended mainly for arithmetic operations, that is, contrary to STD\_LOGIC\_VECTOR, they accept arithmetic operations. On the other hand, logical operations are not allowed. With respect to relational (comparison) operations, there are no restrictions. Amin Mehranzadeh, Ph.D. # Signed and Unsigned Data Types: ``` Example: Legal and illegal operations with signed/unsigned data types. LIBRARY ieee; USE ieee.std_logic_1164.all; USE ieee.std_logic_arith.all; -- extra package necessary ... SIGNAL a: IN SIGNED (7 DOWNTO 0); SIGNAL b: IN SIGNED (7 DOWNTO 0); SIGNAL x: OUT SIGNED (7 DOWNTO 0); ... v <= a + b; -- legal (arithmetic operation OK) w <= a AND b; -- illegal (logical operation not OK) Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful ``` # Signed and Unsigned Data Types: ``` Example: Legal and illegal operations with std_logic_vector. LIBRARY ieee; USE ieee.std_logic_1164.all; -- no extra package required ... SIGNAL a: IN STD_LOGIC_VECTOR (7 DOWNTO 0); SIGNAL b: IN STD_LOGIC_VECTOR (7 DOWNTO 0); SIGNAL x: OUT STD_LOGIC_VECTOR (7 DOWNTO 0); ... v <= a + b; -- illegal (arithmetic operation not OK) w <= a AND b; -- legal (logical operation OK) ``` Amin Mehranzadeh, Ph.D. # Signed and Unsigned Data Types: There is a simple way of allowing data of type STD\_LOGIC\_VECTOR to participate directly in arithmetic operations. For that, the ieee library provides two packages, std\_logic\_signed and std\_logic\_unsigned, which allow operations with STD\_LOGIC\_VECTOR data to be performed as if the data were of type SIGNED or UNSIGNED, respectively. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful # Signed and Unsigned Data Types: Example: Arithmetic operations with std\_logic\_vector. ``` LIBRARY ieee; USE ieee.std_logic_1164.all; USE ieee.std_logic_unsigned.all; -- extra package included ... SIGNAL a: IN STD_LOGIC_VECTOR (7 DOWNTO 0); SIGNAL b: IN STD_LOGIC_VECTOR (7 DOWNTO 0); SIGNAL x: OUT STD_LOGIC_VECTOR (7 DOWNTO 0); ... v <= a + b; -- legal (arithmetic operation OK), unsigned w <= a AND b; -- legal (logical operation OK) ``` Amin Mehranzadeh, Ph.D. #### **Data Conversion:** VHDL does not allow direct operations (arithmetic, logical, etc.) between data of different types. Therefore, it is often necessary to convert data from one type to another. This can be done in basically two ways: or we write a piece of VHDL code for that, or we invoke a FUNCTION from a pre-defined PACKAGE which is capable of doing it for us. If the data are closely related (that is, both operands have the same base type, despite being declared as belonging to two different type classes), then the std\_logic\_1164 of the ieee library provides straightforward conversion functions. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### **Data Conversion:** #### An example is shown below: Amin Mehranzadeh, Ph.D. #### **Data Conversion:** Several data conversion functions can be found in the std\_logic\_arith package of the ieee library. They are: - conv\_integer(p): Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an INTEGER value. Notice that STD\_LOGIC\_VECTOR is not included. - conv\_unsigned(p, b): Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to an UNSIGNED value with size b bits. Amin Mehranzadeh, Ph.D. CE Department of Islamic Azad University of Dezful #### **Data Conversion:** - conv\_signed(p, b): Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_ULOGIC to a SIGNED value with size b bits. - conv\_std\_logic\_vector(p, b): Converts a parameter p of type INTEGER, UNSIGNED, SIGNED, or STD\_LOGIC to a STD\_LOGIC\_VECTOR value with size b bits. Amin Mehranzadeh, Ph.D. #### **Data Conversion:** ``` Example: Data conversion. LIBRARY ieee; USE ieee.std_logic_1164.all; USE ieee.std_logic_arith.all; ... SIGNAL a: IN UNSIGNED (7 DOWNTO 0); SIGNAL b: IN UNSIGNED (7 DOWNTO 0); SIGNAL y: OUT STD_LOGIC_VECTOR (7 DOWNTO 0); ... y <= CONV_STD_LOGIC_VECTOR ((a+b), 8); -- Legal operation: a+b is converted from UNSIGNED to an -- 8-bit STD_LOGIC_VECTOR value, then assigned to y. ``` # Synthesizable data types: Amin Mehranzadeh, Ph.D. Synthesizable data types. Data types Synthesizable values '0', '1' 'X', '0', '1', 'Z' (resolved) 'X', '0', '1', 'Z' (unresolved) BIT, BIT\_VECTOR STD\_LOGIC, STD\_LOGIC\_VECTOR STD\_ULOGIC, STD\_ULOGIC\_VECTOR BOOLEAN True, False NATURAL From 0 to +2, 147, 483, 647 INTEGER From -2,147,483,647 to +2,147,483,647 SIGNED From -2,147,483,647 to +2,147,483,647 UNSIGNED From 0 to +2,147,483,647 User-defined integer type Subset of INTEGER Collection enumerated by user User-defined enumerated type SUBTYPE Subset of any type (pre- or user-defined) ARRAY Single-type collection of any type above RECORD Multiple-type collection of any types above | Problems: | | | |-------------------------|---------------------------------------------|--------| | Please read Additio | nal Examples | | | (From page 3 | | | | | | | | Amin Mehranzadeh, Ph.D. | CE Department of Islamic Azad University of | Dezful |