#### Hardware Description Languages

Andre Mitterbacher andre.mitterbacher@fhv.at

Fachhochschule Vorarlberg

v01 - 10.10.2016: Corrected typos.

#### Introduction to HDL

2 / 64

## Complexity in digital designs

- Modern digital circuitry comprises millions of transistors.
- Modern FPGAs include numerous functionalities.
- It is not humanly possible to comprehend such complex systems in their entirety.
- We need to find methods of dealing with the complexity → abstraction.



Figure: Moore's law: Over the history of computing hardware, the number of transistors in a dense integrated circuit doubles approximately every two years.

Source: By Wgsimon via Wikimedia Commons (link)

#### Abstraction layers

- Structural: Description in terms of interconnection of more primitive components. (FPGA: Connection of LE, memories and additional resources)
- Behavioral: Description by input/ output response. (i.e. description of the desired logic).
- Physical: Description by a physical layout. (FPGA: Place and Route)



Figure: Abstraction layers applied to FPGA design. The blue design inputs are mostly done by humans. The rest is machine work.

Source: own work

4 / 64

 Design Entry: Either schematic or HDL description of the intended logic.



- Design Entry: Either schematic or HDL description of the intended logic.
- ▶ Simulation: Verify the correct behavior of the design.



- Design Entry: Either schematic or HDL description of the intended logic.
- ▶ Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTL netlist.



Figure: Digital design flow. Source: Altera Quartus help.

5 / 64

- Design Entry: Either schematic or HDL description of the intended logic.
- ▶ Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTL netlist.
- Synthesis: Map the RTL netlist to the available logic cells (fab design kit, PLD logic elements) → gate level netlist.



- Design Entry: Either schematic or HDL description of the intended logic.
- ▶ Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTL netlist.
- Synthesis: Map the RTL netlist to the available logic cells (fab design kit, PLD logic elements) → gate level netlist.
- ▶ Place and Route: Place the logic cells in the available digital Si area or in the PLD.



- Design Entry: Either schematic or HDL description of the intended logic.
- ▶ Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTL netlist.
- Synthesis: Map the RTL netlist to the available logic cells (fab design kit, PLD logic elements) → gate level netlist.
- Place and Route: Place the logic cells in the available digital Si area or in the PLD.
- Simulation of the gate level netlist together with estimated timing delays.



- ▶ Design Entry: Either schematic or HDL description of the intended logic.
- Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTI netlist.
- ► Synthesis: Map the RTL netlist to the available logic cells (fab design kit, PLD logic elements) → gate level netlist.
- Place and Route: Place the logic cells in the available digital Si area or in the PLD.
- Simulation of the gate level netlist together with estimated timing delays.
- ► Timing analysis use Static Timing Analysis to verify that setup and hold times are ok for all FFs.



Figure: Digital design flow. Source: Altera Quartus help.

- Design Entry: Either schematic or HDL description of the intended logic.
- Simulation: Verify the correct behavior of the design.
- Analysis: Analyze the design entry for errors and convert it to RTL netlist.
- Synthesis: Map the RTL netlist to the available logic cells (fab design kit, PLD logic elements) → gate level netlist.
- Place and Route: Place the logic cells in the available digital Si area or in the PLD.
- Simulation of the gate level netlist together with estimated timing delays.
- ► Timing analysis use Static Timing Analysis to verify that setup and hold times are ok for all FFs.
- Programming of Chip manufacturing
  - IC design → Tape-out GDS2 files are sent to the fab. Mask and IC manufacturing starts.
  - ► PMIDFHY programming files are loaded to the PLD



Figure: Digital design flow. Source: Altera Quartus help.

## Hardware Description Language

#### In order to facilitate

- the usage of abstraction layers
- the description of complex logic
- advanced test and verification methods
- revision control of the design

Hardware Description Languages were developed.

# A model of the digital circuit is described – NOT programmed!

Differences to a programming language:

- Concurrent statements
- ► Time can be explicitly expressed

## History

PLD development lead to the languages for the description of their behavior. (1983: Data I/O introduced ABEL.)
In the late 1980's two HDL emerged: VHDL and Verilog.

#### **VHDL**

- Developed by the U.S Department of Defense to describe the behavior of ASICs
- ▶ 1987 Submitted as IEEE standard 1076.
- Due to the Department of Defense requiring as much of the syntax as possible to be based on Ada.
- Strongly typed.

#### Verilog

- Created by Prabhu Goel and Phil Moorby during the winter of 1983/1984 for Gateway Design Automation.Cadence buys Gateway Design Automation in 1990.
- 1995 Cadence transferred Verilog into the public domain and submitted as IEEE standard 1364.
- 2002 SystemVerilog adds advanced verification → IEEE standard 1800.
- Verilog is based on C.
- Weakly typed.

7 / 64

#### Development

- 1. Description (design entry) of logic for specification and documentation.
- 2. Simulation / Verification of the described logic was so attractive that simulators were developed.
- 3. Synthesis of the logic to a definition of the physical implementation of the circuit.
- 4. Enhanced verification support (e.g. self-checking) was added to account for the growing complexity.



## HDL for Digital Design Entry

HDLs are used to do the design entry on RTL level.

- ightharpoonup RTL 
  ightharpoonup Register Transfer Level (i.e. it is described how register are linked to other registers and IOs with combinatorial logic)
- ► Therefore a HDL needs to offer possibilities to describe:
  - Inputs and Outputs of a module (ports)
  - Hierarchy of modules (connection of submodules)
  - Connection of signals (similar to a wire or a PCB track)
  - Combinatorial logic (gates but also behavioral)
  - ▶ Sequential logic → FFs (FlipFlops)

## **HDL** for Digital Verification

It is essential to have the possibility to simulate the behavior of a digital design!

- $\triangleright$  Full custom IC design have huge NRE (non-recurring engineering) cost ( $\approx$ Mio USD).  $\rightarrow$  Tape-out is only signed off when verification coverage is close to 100%.
- FPGA designs offer only limited debug possibilities.
- → Before a design is implemented (FPGA or IC) it needs to be verified thoroughly!

## **HDL** for Digital Verification

It is essential to have the possibility to simulate the behavior of a digital design!

- $\triangleright$  Full custom IC design have huge NRE (non-recurring engineering) cost ( $\approx$ Mio USD).  $\rightarrow$  Tape-out is only signed off when verification coverage is close to 100%.
- ▶ FPGA designs offer only limited debug possibilities.
- → Before a design is implemented (FPGA or IC) it needs to be verified thoroughly!

Therefore a HDL needs to offer the possibility to

- Drive signals
- Check signals (e.g. compare against expected values)
- Output and log signals
- Advance the time

The code that is generated to verify a digital design is typically called a test bench.

▶ In test benches code elements can be used that are not synthesizable.



#### Verification vs. Validation

- ▶ Validation: The assurance that a product, service, or system meets the needs of the customer and other identified stakeholders. It often involves acceptance and suitability with external customers. Contrast with verification."
- ▶ Verification: The evaluation of whether or not a product, service, or system complies with a regulation, requirement, specification, or imposed condition. It is often an internal process. Contrast with validation."

Source: IEEE. "IEEE Guide-Adoption of the Project Management Institute (PMI) Standard A Guide to the Project Management Body of Knowledge (PMBOK Guide)-Fourth Edition", p. 452. doi:10.1109/IEEESTD.2011.6086685, Retrieved 7 December 2012.

#### HDL for Digital Synthesis

Synthesis means "conversion of the higher level abstract description of the design to the actual components on the gate and flip-flop level" [RJ08].

- ► This is done by the synthesis tool.
- Only the synthesizable part of HDL expressions can be processed (\$fprintf("Hello World") is perfectly fine Verilog code but cannot be synthesized).
- ► To ensure that the algorithm understands the described logic, design templates shall be used (There is exactly one way how a FF needs to be coded).

#### **HDL** for Digital Synthesis

Synthesis means "conversion of the higher level abstract description of the design to the actual components on the gate and flip-flop level" [RJ08].

- This is done by the synthesis tool.
- Only the synthesizable part of HDL expressions can be processed (\$fprintf("Hello World") is perfectly fine Verilog code but cannot be synthesized).
- ➤ To ensure that the algorithm understands the described logic, design templates shall be used (There is exactly one way how a FF needs to be coded).

There are different synthesis tools for FPGAs, IC design.

- ► FPGAs for IC prototyping.
- ▶ Sim and synthesis tools need to behave the same!



Figure: RTL code is used by more than one tool.

AnMi (FHV) HDL v01 – 10.10.2016: Corrected typos. 12 / 64

- 1. Start (w/o HDL) to structure the problem
  - ► Toplevel / Division into modules / Interfaces between modules
  - ► Block diagram
  - ► State charts

AnMi (FHV)

- 1. Start (w/o HDL) to structure the problem
  - Toplevel / Division into modules / Interfaces between modules
  - Block diagram
  - State charts
- 2. Design entry for modules
  - ▶ It's not programming → Think in digital logic!
  - Choose your favorite editor.
  - ► Use Version Control (e.g. SVN https://tortoisesvn.net/index.de.html).

- 1. Start (w/o HDL) to structure the problem
  - Toplevel / Division into modules / Interfaces between modules
  - Block diagram
  - State charts
- 2. Design entry for modules
  - It's not programming → Think in digital logic!
  - Choose your favorite editor.
  - Use Version Control (e.g. SVN https://tortoisesvn.net/index.de.html).
- 3. Verification
  - ► Verify that the design of your submodule/module fulfills the specification.
  - ▶ When designing think also about how to verify the module.

- 1. Start (w/o HDL) to structure the problem
  - Toplevel / Division into modules / Interfaces between modules
  - Block diagram
  - State charts
- 2. Design entry for modules
  - It's not programming → Think in digital logic!
  - Choose your favorite editor.
  - Use Version Control (e.g. SVN https://tortoisesvn.net/index.de.html).
- 3. Verification
  - ▶ Verify that the design of your submodule/module fulfills the specification.
  - When designing think also about how to verify the module.
- 4. Synthesis
  - After verification the design can be deployed onto the target hardware with the Synthesis Tool.
  - A post-simulation simulation can be done to proof that the synthesized netlist complies with the spec.
  - ► Check the design on the target hardware.

Programmable logic devices (PLD)

## Programmable logic devices (PLD)

## Programmable logic devices (PLD)

A brief review from BuS2 – let's use the decoder for a seven segment display here:

| S | bcd[3] | bcd[2] | bcd[1] | bcd[0] | а | b | С | d | е | f | g |
|---|--------|--------|--------|--------|---|---|---|---|---|---|---|
| 0 | 0      | 0      | 0      | 0      | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 1 | 0      | 0      | 0      | 1      | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 2 | 0      | 0      | 1      | 0      | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 3 | 0      | 0      | 1      | 1      | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 4 | 0      | 1      | 0      | 0      | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 5 | 0      | 1      | 0      | 1      | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 6 | 0      | 1      | 1      | 0      | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
| 7 | 0      | 1      | 1      | 1      | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| 8 | 1      | 0      | 0      | 0      | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 9 | 1      | 0      | 0      | 1      | 1 | 1 | 1 | 1 | 0 | 1 | 1 |



Figure: Seven segment display.

How can this functionality be implemented?

#### **ASIC**

An ASIC is an Application Specific Integrated Circuit.

- ▶ It is custom designed and manufactured for a specific use.
- ► Examples: Audio processor for a hearing aid, a control IC that controls the power electronics in your smartphone charger, . . .
- ▶ Pro: Best performance, exclusive use, IP protection
- ▶ Con: Highest NRE¹ cost, highest risk

#### **ASSP**

An ASSP is an Application Specific Standard Product.

- ► ICs that are dedicated to a specific application market and sold to more than one user (and hence, standard) in contrast to ASICs.
- Examples: 74xx family ICs, power electronic control ICs, 555, Micro-controllers . . .
- ▶ Pro: Cheap off the shelf solution. Specifically designed for a certain application. Risk depends on the IC.
- Con: Easy to copy. Constrained to the functionality of the IC. Small room for differentiation.

#### **PLD**

#### A PLD is a Programmable Logic Device.

- ICs that contain logic building blocks which are connected after wafer fabrication to offer the desired function.
- Examples: FPGA, CPLD, PAL, PLA
- ▶ Pro: Short development cycle, Low NRE cost, bug fixes at lower cost.
- Con: Power consumption, higher per unit cost, usually no analog peripherals on board

#### **PLD**

#### A PLD is a Programmable Logic Device.

- ICs that contain logic building blocks which are connected after wafer fabrication to offer the desired function.
- Examples: FPGA, CPLD, PAL, PLA
- ▶ Pro: Short development cycle, Low NRE cost, bug fixes at lower cost.
- Con: Power consumption, higher per unit cost, usually no analog peripherals on board
- ▶ PLD types and building blocks were already covered in BuS2.
- ▶ We will review all that when working with the devices.

## Verilog – SystemVerilog

19 / 64

#### Basic elements

A brief introduction into SystemVerilog showing the main building blocks of a design. Refer to the example design for more information.

- Comments:
  - ▶ // starts a line comment
  - ▶ /\* start a block comment
  - \*/ ends a block comment
- Case sensitive
- ▶ White spaces and tabs are not critical.

#### Listing 1: SV comments and names

```
/* This is a block comment */

// A line comment

small != SmaLL;

y = x + 1;
y = x + 1;
```

#### **Numbers**

- ▶ Integers: The notation contains value, width und number format.
- ▶ Floating point: Decimal numbers with floating point . and e for powers of ten.

#### Listing 2: SV numbers

```
1 // integers
                  // decimal 123, unknown bit width
2 123
3 8'ha5
                  // hexadecimal a5, 8 bits wide
4 '0125
                  // octal 125, unknown bit width
5 -4'd6
                  // two's complement of 6, 4bits wide, thus 4'b1010
6 8'b0000_1010
                  // binary grouped using '_'
8 //floating point
9 1.2
                  // decimal 1.2
10 3.4e2
                  // 340
11 3.4E3
                  // also 340
```

21 / 64

## Strings

- Strings are mainly used in simulation.
- Data type string

#### Listing 3: SV strings

## Data types

#### Data types can be split into

- Synthesizable boolean and integer types used to describe RTL logic of digital systems (logic, integer)
- Support data types for test benches (float, double, string, time)

## Digital signals can have four different values:

- ▶ 0 (logic low)
- ▶ 1 (logic high)
- ► Z (high-ohmic, not driven)
- X (unknown)

Note: The high-ohmic 'Z' value cannot be used inside an FPGA. Output pins can use tristate drivers to act like 'Z' towards other ICs. There are also two-valued (0,1) signals available for test benches to improve simulation time.

- ➤ Signals can be grouped to vectors (buses).
- ► Integers and logic signals can be assigned to each other w/o problems (SV is weakly typed).
- Signals can be concatenated using a,b notation.

23 / 64

# Assignments

The description of signal routings can be done using assignments.

- Connection of submodules.
- Connection of other signals.
- Concatenation of signals.
- 'Simple' logic operations.

## Listing 4: Assignments

# Logic / Integer / Assignments

#### Listing 5: Logic and integer data types

```
1 // Create an 'adder' of two 8bit signals
2 logic [7:0] x1;
                                      // 8bit vector
3 logic [7:0] x2;
                                      // 8bit vector
4 logic [7:0] y,z;
                                      // Two 8bit vectors
5 logic co;
                                      // 1bit carry out
6 integer result;
                                      // integer data type is 32bit wide
8 assign \{co,y\} = x1 + x2;
                                      // Add two 8bit numbers and
                                      // assign the result to the 8bit
10 assign result = {co,v};
                                      // Assign the logic vector to an
                                      // integer data type --> no problem!
12 // overflow
13 assign z = x1+x2;
                                      // Syntactically ok
                                      // but overflow is possible :-(
```

Note: Logic vectors of different sizes can be assigned to each other (weakly typed).

- ightharpoonup Left hand side is smaller than the right hand side  $\rightarrow$  data is truncated.
- Left hand side is wider than the right hand side  $\rightarrow$  MSBs are filled with zeros (unsigned) or the MSB of the left hand side (signed).

Here the designer needs to be extremely careful to avoid overflows!

# Design units

- Encapsulate parts of the code.
- ► Form larger parts
- ► The Toplevel unit interfaces to the outside world.
- ► IOs are defined using input and output.
- Interconnects are done using logic data types.



26 / 64

## Listing 6: SV module declaration

1 // Toplevel module ultra\_dsp

```
2 module ultra_dsp(
     input
                              clk,
3
     input
                              rst_n,
     input [7:0]
5
                              х,
     input [7:0]
                               a,
7
     input [7:0]
                               ъ.
     output logic [15:0]
8
                              dsp_out
9);
10
11 logic [8:0] add_out; //create internal signal add_out, 9bit wide
13 add_1 u_add_1(
                              //create a instance of add_1 called u_add_1
14
          .in1
                   (a)
                                  //connect input in1 to a
15
          .in2
                   (b)
                                 //connect input in2 to b
                   (add_out)
                                 //connect output res to add_out
16
          .res
17 );
18
19 mult_a u_mult_a(
                            //create an instance of mult_a called u_mult_a
                   (clk).
          . с
                                 //
                   (rst_n),
                                 11
          .r
          .х,
                                 //if the name is the same automatic connection can
                   (add_out),
                                 //
          . у
                   (dsp_out)
                                 11
          .out
25);
27 endmodule;
```

# Arithmetic operators

Table: Arithmetic operators

| Operator | Description                      |
|----------|----------------------------------|
| +        | Addition                         |
| _        | Subtraction                      |
| *        | Multiplication                   |
| /        | Division                         |
| %        | Remainder of an integer division |

## Synthesis of arithmetic operators

- ▶ The addition and subtraction are synthesizable.
- ► The multiplication is synthesizable for FPGAs and will be mapped to on-board multipliers.
- ▶ The division is not in general not synthesizable.



# Comparison

#### Table: Comparison

| Operator | Description                                 |
|----------|---------------------------------------------|
| a < b    | a smaller than b                            |
| a > b    | a larger than b                             |
| a <= b   | a smaller or equal b                        |
| a >= b   | a larger or equal b                         |
| a == b   | a has the same value as b                   |
| a! = b   | a has a different value to b                |
| a === b  | a has the same value as b including X, Z    |
| a! == b  | a has a different value to b including X, Z |
|          |                                             |

# Logic vs. case equality

- ► The logic equalities (==,!=) is
  - ▶ 0 if the comparison is false
  - ▶ 1 if the comparison is true
  - X if at least 1 bit of the operands a,b is X or Z.

AnMi (FHV) HDL v01 – 10.10.2016: Corrected typos. 29 /

# Logic operators

Table: Logic operators

| Operator | Description |
|----------|-------------|
| &&       | logic and   |
|          | logic or    |
| !        | Negation    |

Table: Bitwise logic operators

| Operator | Description       |
|----------|-------------------|
| &        | Bitwise and       |
|          | Bitwise or        |
| $\sim$   | Bitwise inversion |
| ^        | Bitwise xor       |
| ^ ~      | Bitwise xnor      |

# Reduction operators

Table: Reduction operators

| Operator        | Description                       |
|-----------------|-----------------------------------|
| &x              | and operation an all bits in x    |
| x               | or operation on all bits in x     |
| $\wedge x$      | xor operation on all bits in x    |
| ~ &x            | and all bits in $x$ , then negate |
| $\sim  x $      | or all bits in $x$ , then negate  |
| $\sim \wedge x$ | xor all bits in $x$ , then negate |

#### Listing 7: Reduction operators

```
1 logic [7:0] data;
2 logic all_one;
3 logic all_zero;
5 assign all_one = &data;
6 assign all_zero = ~|data;
```

# Shift, Concatenate

#### Table: Shift and concatenation

| Operator | Description                                                                            |
|----------|----------------------------------------------------------------------------------------|
| a << b   | shift a by b bits to the left                                                          |
| a >> b   | shift a by b bits to the right, shift in zeros $\rightarrow$ only correct for unsigned |
| a <<< b  | shift a by b bits to the left                                                          |
| a >>> b  | shift a by b bits to the right, shift in the MSB for a correct sign                    |
|          |                                                                                        |
| a, b, c  | Concatenate vectors a, b and c                                                         |

# Higher abstraction levels

- ▶ The operators shown so far allow the description of low level logic.
- ➤ To describe logic on a higher level of abstraction and to create test benches to check the correct behavior of a design more complex statements are required

# Higher abstraction levels

- ▶ The operators shown so far allow the description of low level logic.
- ➤ To describe logic on a higher level of abstraction and to create test benches to check the correct behavior of a design more complex statements are required

#### initial

- All initial processes are started in parallel when simulation starts.
- All statements inside the initial are executed one after each other.
- # statements are used to wait for a specified time.
- Simulation only not synthesizable.



# Higher abstraction levels

- ▶ The operators shown so far allow the description of low level logic.
- ► To describe logic on a higher level of abstraction and to create test benches to check the correct behavior of a design more complex statements are required

## initial

- All initial processes are started in parallel when simulation starts.
- All statements inside the initial are executed one after each other.
- # statements are used to wait for a specified time.
- Simulation only not synthesizable.

## always

- always statements are executed if one of the signals in the sensitivity list changes.
- Used to describe sequential or combinatorial logic:
  - ▶ always\_comb → combinatorial logic (e.g. decoders, muxers)
  - always\_ff → sequential logic (e.g. flipflop)



# Combinatorial logic – always\_comb

- ▶ Use the always\_comb process to describe complex combinatorial logic.
- Control structures like if, case, for or while can be used.
- Output signals need to be defined for all conditions!

## Listing 8: Combinatorial logic – always\_comb

```
always_comb begin : majority_voter
      v = 0;
                                // default value
      if (x == 3'b011) begin // override default for 011
          v = 1:
      end
5
      else if (x == 3'b101) begin // override default for 101
6
          y = 1;
      end
8
      else if (x == 3'b110) begin // override default for 110
          v = 1:
10
      end
11
      else if (x == 3'b111) begin // override default for 111
          v = 1;
13
14
      end
15 end : majority_voter
```

# Sequential logic – always\_ff

- Use the always\_ff process to describe sequential logic (FFs, counters)
- ► For good synthesis results defined templates shall be used.
- Clock and reset conditions are specified with @
- Only changes of the output signal needs to specified (else it stays at the stored value).

## Listing 9: D-FF

35 / 64

## 4bit counter - always\_ff

## Example: 4 bit up counter with enable and synchronous data load

- Async active low reset to all zeros.
- Counts up on the rising edge of the clock if enabled.
- data\_in can be loaded using the load signal.

## Listing 10: 4 bit up counter

```
1 always_ff @ (negedge rst_n or posedge clk10m) begin : 4bit_up_cnt
     cnt <= '0: // '0 is all zeros
     end
     else if (load) begin
5
        cnt <= data in:
6
     end
7
     else if (en) begin
8
        cnt <= cnt + 4'd1:
10
     end
     // no else is required here -- in this case the cnt stays where it is
11
12 end : 4bit up cnt
```

## Test pattern – initial

- ▶ In a test bench stimuli are sent the DUT.
- ▶ The timing of the test stimuli can be controlled using an initial process.
- 'timescale defines the fundamental time step of the simulator
- # wait for the specified number of time steps or a time unit.
- Q waits for an event

Listing 11: Test stimuli for the 4bit counter

```
1 initial begin : test_stim
      rst_n = 1'b0;
                                     // assert rst_n
                                     // initial condition of en
      en = 1'b0:
3
      load = 1'b0;
                                     // initial condition of load
4
      data = 4'b0000;
                                     // initial condition of data
5
      # 100ns;
                                     // wait for 100ns
      rst_n = 1'b1;
                                     // --- release rst_n
8
      @ (negedge clk10m)
                                     // wait for 2 negative edges of clk10m
      @ (negedge clk10m)
10
      en = 1'b1:
                                     // --- enable the counter
11
      @ (negedge clk10m)
                                     // wait for 2 negative edges of clk10m
      @ (negedge clk10m)
13
      data = 4'b1111:
14
                                     // set data to all ones
15
      #1us;
      @ (negedge clk10m)
                                     // wait for a negative edges of clk10m
16
      load = 1'b1:
                                     // --- assert load
17
                                     // wait for a negative edges of clk10m
      @ (negedge clk10m)
                                     // -- HD@lear load --- v01 - 10.10.2016: Corrected typos.
                                                                                    37 / 64
      load An Mi 1 FH 0 :
```

# Signal assignments

Without explanation three different ways of signal assignments were used so far:

- **continuous assignment**: assign y = x;
- ▶ blocking assignment: y = x;
- ▶ non-blocking assignment: y <= x;</p>

assign 
$$y = x$$
;

- Models a permanent connection (wire).
- ► To be used outside processes.
- Signal routing and simple logic.

#### v = x:

- ► For comb logic.
- Inside always\_comb or initial processes.
- Executed one line after another (like software).

#### $y \le x$ ;

- For sequential logic.
- Inside always\_ff processes.
- All <= in a process are executed at the same time.

## If statement

- C-style
- Curly brackets ({}) are replaced by begin end statements.
- Introduces a priority!

## Listing 12: if statement

```
always_comb begin : if_example
      if (sel == 2'b00) begin
                                     // prio 1
          v = x1;
      end
      else if (sel == 2'b01) begin // prio 2
5
          y = x2;
6
      end
      else if (sel == 2'b10) begin // prio 3
8
          y = x3;
      end
10
      else begin
                                       // prio 4
11
          y = x4;
13
      end
      : if_example
```

39 / 64

# If statement - synthesized



Figure: Synthesized if statement from listing 12

Source: own work created with Altera Quartus II.

## Case statement

- Similiar to if, else but without priority.
- casez and casex can also use wildcards.

## Listing 13: case statement

```
always_comb begin : case_example
       case (sel)
           2'b00 : begin
3
4
                y = x1;
5
           end
           2'b01 : begin
6
                v = x2;
           end
8
           2'b10 : begin
                y = x3;
           end
11
           default : begin
12
13
                y = x4;
           end
14
       endcase
16 end : case_example
```

41 / 64

# Case statement – synthesized



Figure: Synthesized if statement from listing 13

Source: own work created with Altera Quartus II.

# For loop

- C-style
- Used primarily in test benches to generate stimuli
- ▶ In special applications also for synthesis.
- Special derivatives: repeat(n), forever

#### Listing 14: for loop to test the muxer

# While loop

- C-style
- Used primarily in test benches to generate stimuli

## Listing 15: while loop

```
1 initial begin : while_example
      sel = 2'b00:
                                     // initial value for sel.
      #100ns;
                                     // wait for 100ns
3
      integer i = 0;
      while (i<4) begin
5
           sel = i;
                                    // assign i to sel
6
                                     // increment i
          i++:
           #500ns;
                                     // wait for 500ns;
8
      end
10 end : while_example
```

# VHDL – Very High Speed Integrated Circuit Hardware Description Language

## Basic elements

A brief introduction into VHDL showing the main building blocks of a design. Refer to the example design for more information.

- Comments:
  - starts a line comment, end at the EOL
  - No block comment available
- Case insensitive
- Names need to start with a letter
- White spaces and tabs are not critical.

#### Listing 16: VHDL comment and names

```
This is a VHDL comment
     small = SmaLL; -- case insensitive -> but do not exploit that feature
3
           <= x
```

# Data Types

- ▶ VHDL is a strongly typed language.
- ▶ There is no implicit type conversion like in C or SystemVerilog!

## The following basic data types are available:

- boolean: (true, false)
- ▶ bit: (0,1)
- integer: range  $-(2^{31}-1):+(2^{31}-1)$
- real: single precision floating point
- character: any character. enclosed with ".
- time: integer with unit (fs, ps, ns, us, ms, sec, min of hr)

#### Listing 17: VHDL basic data types

```
signal XO, X1, X2, X3: bit; -- four signals XO to X3 of type bit signal on_off, res: boolean; -- two boolean signal
```

# VHDL assignements

Once signals are declared a value can be assigned to them.

- ightharpoonup Concurrent assignment  $\rightarrow$  it's rather a wire than a variable!
- Similar to connecting a PCB track to a source!
- ▶ The <= operator is used to assign a value to a signal.

## Listing 18: VHDL assignments

```
XO <= '0':
                           -- drive the signal XO low
on_off <= true;
                           -- on_off is true
X1 <= (X0 or X2) and X3; -- logic gates
res <= (X1=X2); -- compare X1 to X2 and assign the result to res
```

# VHDL basic operators

- Logic operators
  - ▶ not → Negation
  - ► and. or
  - nand, nor
  - xor, xnor
- Arithmetic and comparison
  - $\rightarrow$  +,  $-\rightarrow$  Addition and subtraction are synthesizable
  - lacktriangleright \*,  $/\to$  Multiplication supported by most FPGA synthesis tools, Division not supported.
  - $\triangleright$  =,  $/ = \rightarrow$  equal and unequal (synthesizable)
  - $ightharpoonup <, <= \rightarrow$  less than and less or equal (synthesizable)
  - >, >= → greater and greater or equal (synthesizable)

## Vectors

#### Signals of the same type can be bundled into vectors.

- ► Allows easier handling of multiple signals.
- ► Index is an integer.

#### Listing 19: VHDL vectors

```
1 signal x: bit_vector(0 to 7); -- eight signals of type bit: x(0), x(1), x(2)
2 signal y: bit_vector(0 to 7);
3 signal z: bit_vector(0 to 7);
4
5 signal r: bit_vector(3 downto 0); -- four signals of type bit: r(0), r(1), r(2);
6 signal s: bit_vector(3 downto 0);
7 signal t: bit_vector(3 downto 0);
```

## Listing 20: VHDL vectors assignment

## VHDL libraries

VHDL libraries are used to extend the functionality by defining types, functions and overloaded operators.

Two important libraries that are often used are

- ► IEEE.std\_logic\_1164
- ▶ IEEE.numeric\_std

#### Listing 21: VHDL libraries

```
1 library ieee;
2 use ieee.std_logic_1164.all; -- standard unresolved logic UX01ZWLH-
3 use ieee.numeric_std.all; -- for the signed, unsigned types and arithmetic
```

# Std\_logic, std\_logic\_vector, numeric arithmetic

The IEEE 1164 standard describes a 9-valued logic system that can be used to model typical CMOS logic designs and allows for easier simulation.

Std\_logic and std\_logic\_vector shall be used to describe digital logic.

Table: Possible values of std\_logic.

| Character | Value                                |
|-----------|--------------------------------------|
| U         | uninitialized, unknown logic value   |
| X         | strong drive, conflict 0 vs. 1       |
| 0         | strong drive, logic zero             |
| 1         | strong drive, logic one              |
| Z         | high impedance                       |
| W         | weak drive, conflict L vs. H         |
| L         | weak drive (open source), logic zero |
| Н         | weak drive (open drain), logic one   |
| _         | don't care                           |

# STD LOGIC data types

For logic description the following possible values of std\_logic are important:

- O: Active drive to low.
- ▶ 1: Active drive to high.
- ▶ Z: high ohmic. Can be used to describe tristate buffers (if the target hardware supports it).
- -: don't care: Allows for logic optimization.

AnMi (FHV) HDI

## Numeric std

The package numeric\_std is used to perform integer arithmetic using vectors.

- ► Two numeric types are defined: unsigned (represents UNSIGNED numbers in vector form) and signed (represents a SIGNED number in vector form).
- ▶ The base element type is type STD\_LOGIC.
- ▶ Vectors can be casted from std\_logic\_vector to unsigned/signed and vice versa.

The types defined in numeric\_std shall be used to describe synthesizable integer arithmetic.

For an example see listing 22.

54 / 64

AnMi (FHV)

#### Listing 22: VHDL integer arithmetic

```
1 entity test_data_types is
          port(
                  x1, x2:
                                           in std_logic_vector(7 downto 0);
3
                  s11m1:
                                           out std_logic_vector(8 downto 0)
          ):
5
6 end test_data_types;
 architecture behavioral of test_data_types is
          signal x1_u, x2_u :
                                           unsigned (7 downto 0);
          signal sum1_u : unsigned (8 downto 0);
10
          begin
          -- Adding std_logic_vectors does not work!
14
          -- sum1 <= x1 + x2:
15
         -- So we need to convert x1 and x2 into unsigned
17
          x1_u <= unsigned(x1); -- type cast</pre>
18
          x2_u <= unsigned(x2);</pre>
          sum1_u \le (0, \% x1_u) + (0, \% x2_u); -- numeric vectors need to be sai
          sum1 <= std_logic_vector(sum1_u);</pre>
24 end behavioral:
```

## Modul declaration

Entities are VHDL blocks with a defined interface and internal logic. The logic is defined by at least one architecture.

- ▶ The module that connects to the pins of the IC is the toplevel.
- Modules can be instantiated as submodules. Thereby a hierarchical description of the whole IC is possible.



Figure: Toplevel containing two submodules(counter and decode7seg).

AnMi (FHV)

# Entity with sub-entities

Listing 23: VHDL entities and sub-entities

```
1 entity toplevel is
           port (
2
                     rst_n
                                                 std_logic;
3
                                       in
                     clk10m
                                                 std_logic;
                                       in
5
                     load
                                       in
                                                 std_logic;
                     cnt
                                                          std_logic;
                                                 in
6
                                                 std_logic_vector (6 downto 0)
                     seg7
                                       out
                              :
           );
8
  end toplevel;
10
  architecture hierarchical of toplevel is
           -- declare internal signals
13
           signal bcd
                                       std_logic_vector (3 downto 0);
14
  begin
15
           -- instantiate sub-entities
                                       entity counter(behavorial)
           u1_counter
           port map (
                        sub name
                                                 toplevel name
                                       =>
                     rst_n
                                       =>
                                                 rst_n,
                     clk
                                                          clk10m,
                                                 =>
                     1 d
                                                 =>
                                                          load,
                     count
                                       =>
                                                 cnt,
                     data
                                                 bcd
                                       =>
           );
           u1 decode7seg
                                       entity decode7seg(behavorial)
                                                                 v01 - 10.10.2016: Corrected typos.
           AnMi +(FHV) n (
```

# VHDL Sequential environments

All VHDL signal assignments so far were concurrent.

To allow for a behavioral (more abstract) description there exists the process environment.

## In a process:

- All statements are treated sequentially.
- ▶ The sensitivity list needs to contain all signals that can trigger a process.
- ▶ When the last line of a process is reached it immediately starts at the beginning.
- ▶ Inside a process if/else, case, for,... structures can be used to describe the behavior of the logic.

58 / 64

AnMi (FHV) HDL

# VHDL Sequential environments

All VHDL signal assignments so far were concurrent.

To allow for a behavioral (more abstract) description there exists the process environment.

## In a process:

- All statements are treated sequentially.
- ▶ The sensitivity list needs to contain all signals that can trigger a process.
- ▶ When the last line of a process is reached it immediately starts at the beginning.
- Inside a process if/else, case, for,... structures can be used to describe the behavior of the logic.

Processes can be used to describe combinatorial and sequential logic.

If the logic shall be combinatorial → make sure that the output signal is assigned for all cases (e.g. all branches of an IF/ELSIF/ELSE statement).

AnMi (FHV)

# VHDL Sequential environments

All VHDL signal assignments so far were concurrent.

To allow for a behavioral (more abstract) description there exists the process environment.

## In a process:

- All statements are treated sequentially.
- ▶ The sensitivity list needs to contain all signals that can trigger a process.
- ▶ When the last line of a process is reached it immediately starts at the beginning.
- Inside a process if/else, case, for,... structures can be used to describe the behavior of the logic.

Processes can be used to describe combinatorial and sequential logic.

If the logic shall be combinatorial → make sure that the output signal is assigned for all cases (e.g. all branches of an IF/ELSIF/ELSE statement).

Processes are furthermore used to drive the test stimuli in a test bench in a certain sequence.

# VHDL process – update of signals

To understand sequential logic it is important when signals are updated:

▶ In a process all signals are updated at the next clock cycle.

For example a 4-bit shift register:



Figure: 4bit shift register block diagram.

#### Listing 24: VHDL 4 bit shift register

```
process (clk10m)

pegin

from (clk10m = '1') and clk10m'event then

from q1 <= d;
 q2 <= q1;
 q3 <= q2;
 q4 <= q3;
 end if;

end process;</pre>
```

▶ q1 is upplated to the value of d just before the clock event corrected types. 59

# VHDL process – update of variables

To allow for values that are immediately updates variables can be used.

▶ In a process all variables are updated immediately.

#### For example a muxer:



Figure: 2 bit multiplexer.

## Listing 25: VHDL 2 bit muxer

```
process (s)
          variable y_1 : std_logic; -- declaration of y as local variable
     begin
3
                                      -- default assignement (makes sure that the
            (s = '1') then
                                      -- override the previous assignment
              v 1 := b:
          end if;
```

end AnModels :

v <= v 1:

8

# Concurrent assignments

#### VHDL offers behavorial descriptions also in concurrent statements:

- ▶ with / select
- ▶ when / else

#### Listing 26: VHDL 2 bit muxer concurrent

```
-- no need for a process (it's concurrent)

signal y,z: std_logic

with s select -- use s as selector
y <= a when '0', -- assign a if s = '0'
y <= b when '1', -- assign b if s = '1'
y <= 'x' when others; -- default assignment (s could be L, H, Z,...)

z <= a when (s='0') else b; -- alternative description of a muxer
```

# Sequential assignments in a process

In a process many constructs known from software can be used to describe logic:

- if/elsif/else
- case/is
- loops (for, while)

The same multiplexer as above now in a process environment:

#### Listing 27: VHDL 2 bit muxer sequential

```
-- concurrent with process and if/else
    process (s,a,b)
    begin
             if (s='0') then
                     v3 <= a;
             else
                     y3 <= b;
             end if:
    end process;
    --concurrent with process and case/is
    process (s,a,b)
    begin
             case (s) is
                      when '0'
                                   => y4 <= a;
                                       => y4 <= b;
                      when '1'
                      when others => v4 <= 'U': -- is it needed?
             end case;
                                                       v01 - 10.10.2016: Corrected typos.
                                                                             62 / 64
    enMa (5HV) cess:
                                    HDI
```

## VHDL Test benches

Test benches are used to stimulate a DUT (device under test) and to check that the outputs behave correctly (verification).

- ▶ Stimuli are driven concurrently (e.g. clock) or from processes (e.g. sequential test patterns).
- ▶ The wait statement is used to advance the the simulation time.
  - wait until condition; → wait until clk = '1'; waits for rising edge
  - ▶ wait for time; → wait for 100 ns;
  - ▶ wait; → suspends a process indefinitely

AnMi (FHV) HDL v01 – 10.10.2016: Corrected typos. 63 / 64

# VHDL Test benches (2)

#### Listing 28: VHDL TB with time control

```
Clock generator can be done in a concurrent statement with delay
           clk50m <= not clk50m after 10 ns when (run_sim /= '0') else '0';</pre>
2
3
           -- test pattern to stimulate the inputs
          test_stimuli : process is
5
           begin
6
                   action <= "Init
                   rst_n <= '0':
8
                   load <= '0':
9
                   preload <= x"00":
10
                   wait for 99 ns;
11
13
                   action <= "POR
                   rst_n <= '1':
15
                   -- Let the counter count
                   wait for 10 us:
                   -- Load with OxFF
                   action <= "load FF
                   preload <= x"FF";
                   wait until clk50m 'event and clk50m = '1';
                   load <= '1':
                   wait until clk50m 'event and clk50m = '1';
                   load
                            <= '0':
                   wait for 10 us:
          AnMi (FHV)
                                                             v01 - 10.10.2016: Corrected typos.
                                           HDI
                                                                                    64 / 64
```



ROTH, Charles H.; JOHN, Lizy K.:

Digital systems design using VHDL.

2. ed.

Toronto (u.a.): Thomson, 2008. – ISBN 978-0-534-38462-3

◆□▶ ◆□▶ ◆豆▶ ◆豆▶ 亳|= 釣魚@

AnMi (FHV) HDL v01 – 10.10.2016: Corrected typos. 64 / 64