# Basic Language Constructs of cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 Ί ## **Outline** - 1. Basic VHDL program - 2. Lexical elements and program format - 3. Objects cuu duong than cong . com - 4. Data type and operators cuu duong than cong . com RTL Hardware Design by P. Chu ## 1. Basic VHDL program cuu duong than cong . com cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## Design unit - Building blocks in a VHDL program - Each design unit is analyzed and stored independently - Types of design unit: - entity declaration - architecture body - package declaration - package body - configuration RTL Hardware Design by P. Chu Chapter 3 # Entity declaration Simplified syntax ``` entity entity_name is port( port_names: mode data_type; port_names: mode data_type; ... port_names: mode data_type ); end entity_name; ``` RTL Hardware Design by P. Chu Chapter 3 #### mode: - in: flow into the circuit - out: flow out of the circuit - inout: bi-directional #### • E.g. ``` entity even_detector is port( a: in std_logic_vector(2 downto 0); even: out std_logic); end even_detector; ``` RTL Hardware Design by P. Chu Chapter 3 #### A common mistake with mode ``` library ieee; use ieee.std_logic_1164.all; entity mode_demowisuong than cong. com port( a, b: in std_logic; x, y: out std_logic); end mode_demo; architecture wrong_arch of mode_demo is begin x <= a and b; y <= not x; end wrong_arch;</pre> ``` RTL Hardware Design by P. Chu Chapter 3 #### Fix: use an internal signal ``` architecture ok_arch of mode_demo is signal ab: std_logic; begin ab <= a and b; x <= ab; y <= not ab; end ok_arch;</pre> ``` cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 # Architecture body Simplified syntax ``` architecture arch_name of entity_name is declarations; begin concurrent statement; ``` An entity declaration can be associated with multiple architecture bodies RTL Hardware Design by P. Chu Chapter 3 #### E.g. ``` architecture sop_arch of even_detector is signal p1, p2, p3, p4 : std_logic; begin even <= (p1 or p2) or (p3 or p4); p1 <= (not a(0)) and (not a(1)) and (not a(2)); p2 <= (not a(0)) and a(1) and a(2); p3 <= a(0) and (not a(1)) and a(2); p4 <= a(0) and a(1) and (not a(2)); end sop_arch;</pre> ``` cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 # Other design units - Package declaration/body: - collection of commonly used items, such as data types, subprograms and components - Configuration: - specify which architecture body is to be bound with the entity declaration RTL Hardware Design by P. Chu CuuDuongThanCong.com ## VHDL Library - A place to store the analyzed design units - Normally mapped to a directory in host computer - Software define the mapping between the symbolic library and physical location - Default library: "work" - Library "ieee" is used for many ieee packages RTL Hardware Design by P. Chu Chapter 3 • E.g. ``` library ieee; use ieee.std_logic_1164.all; ``` - Line 1: invoke a library named ieee - Line 2: makes std\_logic\_1164 package visible to the subsequent design units - The package is normally needed for the std\_logic/std\_logic\_vector data type RTL Hardware Design by P. Chu # Processing of VHDL code #### Analysis - Performed on "design unit" basis - Check the syntax and translate the unit into an intermediate form - Store it in a library #### Elaboration - Bind architecture body with entity - Substitute the instantiated components with architecture description - Create a "flattened" description #### Execution Simulation or synthesis RTL Hardware Design by P. Chu Chapter 3 # Lexical elements and program format cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## Lexical elements - Lexical element: - Basic syntactical units in a VHDL program - Types of Lexical elements: - Comments - Identifiers - Reserved words - Numbers - Characters u duong than cong . com - Strings RTL Hardware Design by P. Chu Chapter 3 ## Comments - Starts with - - Just for clarity - e.g., RTL Hardware Design by P. Chu CuuDuongThanCong.com https://fb.com/tailieudientucntt 17 ## Identifier - Identifier is the name of an object - Basic rules: - Can only contain alphabetic letters, decimal digits and underscore - The first character must be a letter - The last character cannot be an underscore - Two successive underscores are not allowed RTL Hardware Design by P. Chu - Valid examples: - A10, next\_state, NextState, mem\_addr\_enable - Invalid examples: - sig#3, \_X10, 7segment, X10\_, hi\_ \_there - VHDL is case insensitive: - Following identifiers are the same: nextstate, NextState, NEXTSTATE, nEXTsTATE RTL Hardware Design by P. Chu ### Reserved words abs access after alias all and architecture array assert attribute begin block body buffer bus case component configuration constant disconnect downto else elsif end entity exit file for function generate generic guarded if impure in inertial inout is label library linkage literal loop map mod nand new next nor not null of on open or others out package port postponed procedure process pure range record register reject rem report return rol ror select severity signal shared sla sll sra srl subtype then to transport type unaffected units until use variable wait when while with xnor xor RTL Hardware Design by P. Chu Chapter 3 ## Numbers, characters and strings #### Number: - Integer: 0, 1234, 98E7 - Real: 0.0, 1.23456 or 9.87E6 - Base 2: 2#101101# #### Character: - 'A', 'Z', '1' #### Strings - "Hello", "101101" #### Note - 0 and '0' are different - 2#101101# and "101101" are different RTL Hardware Design by P. Chu Chapter 3 ## Program format - VHDL is "free-format": blank space, tab, new-line can be freely inserted - e.g., the following are the same ``` library ieee; use ieee.std_logic_1164.all; entity even_detector is port(a: in std_logic_vector(2 downto 0); even: out std_logic); end even_detector; architecture eg_arch of even_detector is signal p1, p2, p3, p4: std_logic; begin even <= (p1 or p2) or (p3 or p4); p1 <= (not a(0)) and (not a(1)) and (not a(2)); p2 <= (not a(0)) and a(1) and a(2); p3 <= a(0) and (not a(1)) and a(2); p4 <= a(0) and a(1) and a(1) and a(2); p4 <= a(0) and a(1) and a(2); end eg_arch; ``` RTL Hardware Design by P. Chu Chapter 3 ``` library ieee; use ieee.std_logic_1164.all; entity even_detector is port ( a: in std_logic_vector(2 downto 0); even: out std_logic); end even_detector; architecture eg_arch of even_detector is signal p1, p2, p3, p4 : std_logic; begin even \leftarrow (p1 or p2) or (p3 or p4); p1 \le (not \ a(0)) \ and \ (not \ a(1)) \ and \ (not \ a(2)); p2 \le (not a(0)) and a(1) and a(2); p3 \le a(0) and (not a(1)) and a(2); p4 \le a(0) and a(1) and (not a(2)); end eg_arch ; ``` RTL Hardware Design by P. Chu Chapter 3 #### A good "header" ``` -- Author: p chu -- File: even_det.vhd -- Design units: entity even_detector function: check even # of 1s from input input: a output: even architecture sop_arch: truth-table based sum-of-products implementation — Library/package: ieee.std_logic_1164: to use std_logic -- Synthesis and verification: Synthesis software: . . . Options/script: . . . Target technology: . . . Test bench: even_detector_tb -- Revision history -- Version 1.0: Cong . com Date: 9/2005 Comments: Original ``` RTL Hardware Design by P. Chu Chapter 3 3. Objects cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## **Objects** - A named item that hold a value of specific data type - Four kinds of objects - Signal - Variable - Constant - File (cannot be synthesized) - Related construct - Alias RTL Hardware Design by P. Chu Chapter 3 ## Signal - Declared in the architecture body's declaration section - Signal declaration: signal signal\_name, signal\_name, ...: data\_type - Signal assignment: signal\_name <= projected\_waveform;</li> CuuDuongThanCong.com - Ports in entity declaration are considered as signals - Can be interpreted as wires or "wires with memory" (i.e., FFs, latches etc.) RTL Hardware Design by P. Chu ### Variable - Declared and used inside a process - Variable declaration: variable variable\_name, ...: data\_type - Variable assignment: variable\_name := value\_expression; - Contains no "timing info" (immediate assignment) - Used as in traditional PL: a "symbolic memory location" where a value can be stored and modified - No direct hardware counterpart RTL Hardware Design by P. Chu ## Constant - Value cannot be changed - Constant declaration: constant const\_name, ...: data\_type := value\_expression - Used to enhance readability ``` - E.g., constant BUS_WIDTH: integer := 32; constant BUS_BYTES: integer := BUS_WIDTH / 8; ``` RTL Hardware Design by P. Chu Chapter 3 #### It is a good idea to avoid "hard literals" ``` architecture beh1_arch of even_detector is signal odd: std_logic; begin tmp := '0'; for i in 2 downto 0 loop tmp := tmp xor a(i); end\ loop ; cuu duong than cong . com architecture beh1_arch of even_detector is signal odd: std_logic; constant BUS_WIDTH: integer := 3; begin tmp := '0';uu duong than cong . com for i in (BUS_WIDTH-1) downto 0 loop tmp := tmp xor a(i); end loop; ``` RTL Hardware Design by P. Chu Chapter 3 ## Alias - Not a object - Alternative name for an object - Used to enhance readability ``` – E.g., ``` ``` signal: word: std_logic_vector(15 downto 0); alias op: std_logic_vector(6 downto 0) is word(15 downto 9); alias reg1: std_logic_vector(2 downto 0) is word(8 downto 6); alias reg2: std_logic_vector(2 downto 0) is word(5 downto 3); alias reg3: std_logic_vector(2 downto 0) is word(2 downto 0); ``` RTL Hardware Design by P. Chu Chapter 3 ## 4. Data type and operators - Standard VHDL - IEEE1164\_std\_logic package - IEEE numeric\_std package cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## Data type - Definition of data type - A set of values that an object can assume. - A set of operations that can be performed on objects of this data type. - VHDL is a <u>strongly-typed</u> language - an object can only be assigned with a value of its type - only the operations defined with the data type can be performed on the object RTL Hardware Design by P. Chu Chapter 3 ## Data types in standard VHDL - integer: - Minimal range: -(2^31-1) to 2^31-1 - Two subtypes: natural, positive - boolean: (false, true) - bit: ('0', '1') - Not capable enough - bit\_vector: a one-dimensional array of bit RTL Hardware Design by P. Chu Chapter 3 # Operators in standard VHDL | operator | description | data type<br>of operand a | data type<br>of operand b | data type<br>of result | |--------------------------------------|---------------------------------------------------|-----------------------------------------------------|--------------------------------------|--------------------------------------------------| | a ** b<br>abs a<br>not a | exponentiation<br>absolute value<br>negation | <pre>integer integer boolean, bit, bit_vector</pre> | integer | integer<br>integer<br>boolean, bit<br>bit_vector | | a * b<br>a / b<br>a mod b<br>a rem b | multiplication<br>division<br>modulo<br>remainder | integer | integer | integer | | + a<br>- a | identity<br>negation | integer | | integer | | a + b<br>a - b | addition cuu duon subtraction | integer cong | integer | integer | | a & b | concatenation | 1-D array,<br>element | <ul><li>1-D array, element</li></ul> | 1-D array | RTL Hardware Design by P. Chu Chapter 3 | a sll b a srl b a sla b a srl b a rol b a ror b | shift left logical<br>shift right logical<br>shift left arithmetic<br>shift right arithmetic<br>rotate left<br>rotate right | bit_vector | integer | bit_vector | |-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------|---------------| | a = b | equal to | any<br>ng than cong . | same as a | boolean | | a /= b | <b>1</b> | | | | | a < b | less than | scalar or 1-D array | same as a | boolean | | a <= b | less than or equal to | | | | | a > b | greater than | | | | | a >= b | greater than or equal to | | | | | a and b | and | boolean, bit, | same as a | boolean, bit, | | a or b | or | bit_vector | | $bit\_vector$ | | a <b>xor</b> b | xor | | | | | a nand b | nand | | | | | a <b>nor</b> b | nor | | | | | a xnor b | xnor | | | | | | | | | | CuuDuongThanCong.com https://fb.com/tailieudientucntt Chapter 3 RTL Hardware Design by P. Chu ## IEEE std\_logic\_1164 package - What's wrong with bit? - New data type: std\_logic, std\_logic\_vector - std\_logic: - 9 values: ('U', 'X', '0', '1', 'Z', 'W', 'L', 'H', '-') - '0', '1': forcing logic 0' and forcing logic 1 - 'Z': high-impedance, as in a tri-state buffer. - 'L', 'H': weak logic 0 and weak logic 1, as in wiredlogic - 'X', 'W': "unknown" and "weak unknown" - 'U': for uninitialized - '-': don't-care. RTL Hardware Design by P. Chu Chapter 3 - std\_logic\_vector - an array of elements with std\_logic data type - Imply a bus - E.g., signal a: std\_logic\_vector(7 downto 0); - Another form (less desired) signal a: std\_logic\_vector(0 to 7); - Need to invoke package to use the data type: library ieee; use ieee.std\_logic\_1164.all; RTL Hardware Design by P. Chu Chapter 3 # Overloaded operator IEEE std\_logic\_1164 package - Which standard VHDL operators can be applied to std\_logic and std\_logic\_vector? - Overloading: same operator of different data types - Overloaded operators in std\_logic\_1164 package | overloaded<br>operator | data type<br>of operand a | data type<br>of operand b | data type<br>of result | |--------------------------------------------------|-------------------------------|---------------------------|------------------------| | not a | std_logic_vector<br>std_logic | | same as a | | a and b a or b a xor b a nand b a nor b a xnor b | std_logic_vector<br>std_logic | same as a | same as a | RTL Hardware Design by P. Chu Chapter 3 39 CuuDuongThanCong.com https://fb.com/tailieudientucntt #### Type conversion function in std\_logic\_1164 package: | function cuu du | data type cong . coof operand a | data type<br>of result | |----------------------|---------------------------------|------------------------| | to_bit(a) | std_logic | bit | | to_stdulogic(a) | bit | ${\tt std\_logic}$ | | to_bit_vector(a) | std_logic_vector | bit_vector | | to_stdlogicvector(a) | bit_vector | std_logic_vector | RTL Hardware Design by P. Chu Chapter 3 #### • E.g., ``` signal s1, s2, s3: std_logic_vector(7 downto 0); signal b1, b2: bit_vector(7 downto 0); ``` The following statements are wrong because of data (?) pe mismatch: We can use the conversion functions to correct these problems: ``` s1 <= to_stdlogicvector(b1); b2 <= to_bitvector(s1 and s2); s3 <= to_stdlogicvector(b1) or s2;</pre> ``` The last statement can also be written as: ``` s3 <= to_stdlogicvector(b1 or to_bitvector(s2)); ``` RTL Hardware Design by P. Chu Chapter 3 ### Operators over an array data type - Relational operators for array - operands must have the same element type but their lengths may differ - Two arrays are compared element by element, form the left most element - All following returns true CuuDuongThanCong.com • "011"="011", "011">"010", "011">"00010", "0110">"011">"00010", "0110">"011" RTL Hardware Design by P. Chu Chapter 3 - Concatenation operator (&) - e.g., ``` y <= "00" & a(7 downto 2); y <= a(7) & a(7) & a(7 downto 2); y <= a(1 downto 0) & a(7 downto 2); ``` cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## Array aggregate Aggregate is a VHDL construct to assign a value to an array-typed object ``` E.g., a <= "101000000";</li> a <= (7=>'1', 6=>'0', 0=>'0', 1=>'0', 5=>'1', 4=>'0', 3=>'0', 2=>'1'); a <= (7|5=>'1', 6|4|3|2|1|0=>'0'); a <= (7|5=>'1', others=>'0'); E.g., a <= "000000000"</li> a <= (others=>'0'); ``` RTL Hardware Design by P. Chu Chapter 3 # IEEE numeric\_std package - How to infer arithmetic operators? - In standard VHDL: ``` signal a, b, sum: integer; ... sum <= a + b;</pre> ``` What's wrong with integer data type? cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 - IEEE numeric\_std package: define integer as a an array of elements of std\_logic - Two new data types: unsigned, signed - The array interpreted as an unsigned or signed binary number - E.g.,signal x, y: signed(15 downto 0); - Need invoke package to use the data type library ieee; use ieee.std\_logic\_1164.all; use ieee.numeric\_std.all; RTL Hardware Design by P. Chu Chapter 3 # Overloaded operators in IEEE numeric\_std package | overloaded<br>operator | description | data type<br>of operand a | data type<br>of operand b | data type<br>of result | |-------------------------------------------------------|----------------------------|----------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------| | abs a - a | absolute value negation | signed | | signed | | a * b a / b a mod b a rem b a + b a - b | arithmetic<br>operation | unsigned<br>unsigned, natural<br>unsigned, signed<br>signed, integer | unsigned, natural<br>unsigned<br>signed, integer<br>signed | unsigned<br>unsigned<br>signed<br>signed | | a = b<br>a /= b<br>a < b<br>a <= b<br>a > b<br>a >= b | relational UU<br>operation | unsigned<br>unsigned, natural<br>signed<br>signed, integer | unsigned, natural<br>unsigned<br>signed, integer<br>signed | boolean<br>boolean<br>boolean<br>boolean | | RTL Hardware I | Design | Chapter 3 | | 47 | CuuDuongThanCong.com https://fb.com/tailieudientucntt #### • E.g., ``` signal a, b, c, d: unsigned(7 downto 0); . . . . cuu duong than cong . com a <= b + c; d <= b + 1; e <= (5 + a + b) - c;</pre> ``` cuu duong than cong . com RTL Hardware Design Chapter 3 by P. Chu 48 CuuDuongThanCong.com https://fb.com/tailieudientucntt # New functions in IEEE numeric\_std package | function | description | data type of<br>operand a | data type of<br>operand b | data type of<br>result | |--------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------|---------------------------|-------------------------------| | <pre>shift_left(a,b) shift_right(a,b) rotate_left(a,b) rotate_right(a,b)</pre> | shift left<br>shift right<br>rotate left<br>rotate right | unsigned, signed | natural | same as a | | resize(a,b) std_match(a,b) | resize array<br>compare '-' | unsigned, signed<br>unsigned, signed<br>std_logic_vector,<br>std_logic | natural<br>same as a | same as a<br>boolean | | to_integer(a) to_unsigned(a,b) to_signed(a,b) | data type conversion | unsigned, signed<br>natural<br>integer | natural<br>natural | integer<br>unsigned<br>signed | | RTL Hardware Design | | Chapter 3 | | 49 | CuuDuongThanCong.com https://fb.com/tailieudientucntt by P. Chu ### Type conversion - Std\_logic\_vector, unsigned, signed are defined as an array of element of std\_logic - They considered as three different data types in VHDL - Type conversion between data types: - type conversion function CuuDuongThanCong.com Type casting (for "closely related" data types) RTL Hardware Design by P. Chu Chapter 3 # Type conversion between numberrelated data types | data type of a | to data type | conversion function / type casting | |--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | unsigned, signed unsigned, std_logic_vector unsigned, signed unsigned, signed unsigned, signed natural | std_logic_vector<br>unsigned<br>std_logic_vector<br>integer<br>unsigned | <pre>std_logic_vector(a) unsigned(a) std_logic_vector(a) to_integer(a) to_unsigned(a, size)</pre> | | integer | signed | to_signed(a, size) | cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 # E.g. library ieee; use ieee.std\_logic\_1164.all; use ieee.numeric\_std.all; ... signal s1, s2, s3, s4, s5, s6: std\_logic\_vector(3 downto 0); signal sg: signed(3 downto 0); ``` cuu duong than cong . com ``` signal u1, u2, u3, u4, u6, u7: unsigned(3 downto 0); RTL Hardware Design by P. Chu Chapter 3 # • E.g. library ieee; use ieee.std\_logic\_1164.all; use ieee.numeric\_std.all; ``` signal s1, s2, s3, s4, s5, s6: std_logic_vector(3 downto 0); signal u1, u2, u3, u4, u6, u7: unsigned(3 downto 0); signal sg: signed(3 downto 0); ``` cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 #### -Ok u3 <= u2 + u1; --- ok, both operands unsigned u4 <= u2 + 1; --- ok, operands unsigned and natural #### Wrong u5 <= sg; -- type mismatch cong . com u6 <= 5; -- type mismatch – Fix u5 <= unsigned(sg); -- type casting u6 <= to\_unsigned(5,4); -- conversion function RTL Hardware Design by P. Chu Chapter 3 #### Wrong u7 <= sg + u1; -- + undefined over the types – Fix u7 <= unsigned(sg) + u1; -- ok, but be careful - Wrong cuu duong than cong . cor s3 <= u3; -- type mismatch s4 <= 5; -- type mismatch – Fix s3 <= std\_logic\_vector(u3); -- type casting s4 <= std\_logic\_vector(to\_unsigned(5,4)); RTL Hardware Design by P. Chu Chapter 3 #### Wrong s5 <= s2 + s1; + undefined over std\_logic\_vector $$s6 \le s2 + 1$$ ; + undefined – Fix cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3 ## Non-IEEE package - Packagea by Synopsys - std\_logic\_arith: - Similar to numeric\_std - New data types: unsigned, signed - Details are different - std\_logic\_unsigned/ std\_logic\_signed - Treat std\_logic\_vector as unsigned and signed numbers - i.e., overload std\_logic\_vector with arith operations RTL Hardware Design by P. Chu Chapter 3 - Software vendors frequently store them in ieee library: - E.g., ``` library ieee; use ieee.std_logic_1164.all; use ieee.std_arith_unsigned.all; ... signal s1, s2, s3, s4, s5, s6: std_logic_vector(3 downto 0); ... s5 <= s2 + s1; -- ok, + overloaded with std_logic_vector s6 <= s2 + 1; -- ok, + overloaded with std_logic_vector ``` RTL Hardware Design by P. Chu CuuDuongThanCong.com Chapter 3 - Only one of the std\_logic\_unsigned and std\_logic\_signed packages can be used - The std\_logic\_unsigned/std\_logic\_signed packages beat the motivation behind a strongly-typed language - Numeric\_std is preferred cuu duong than cong . com RTL Hardware Design by P. Chu Chapter 3