

# BASIC INPUT/OUTPUT

Lecture - 3

# LOGIC CIRCUIT



# SWITCH AND LED CIRCUIT



# IN THIS EXPERIMENT, WE WILL LEARN

- ❖ How to receive and send data in a logic circuit
- ❖ How to use HLS design flow to describe such a design
- ❖ Use the Xilinx Vivado to generate bitstream for design with input and outputs
- ❖ Program the Zed board and set the input data and check the outputs





- ❖ Peripherals and their connections are on board
- ❖ Design and its connection to I/O pins are inside the FPGA

# ASSIGNMENT Q

Can we describe a circuit design and the connection between its ports and the FPGA I/O pins in HLS C functions?

# HLS PORT

Basic input/output

# INPUT/OUTPUT EXAMPLE

```
#define data_type unsigned char

void basic_input_output(  
    data_type   input  
    data_type *output) {  
  
    *output = input;  
}
```

# TOP-LEVEL FUNCTION

When the top-level function is synthesized, the arguments (or parameters) to the function are synthesized into RTL ports. This process is called **interface synthesis**.



# PORT INTERFACES

```
void basic_input_output(
    data_type *output) {
#pragma HLS INTERFACE ?????? port=o
#pragma HLS INTERFACE ap_ctrl_none port=return
    *output = 0b11110000;
}
```

# PORT INTERFACES

```
void basic_input_output(
    data_type *output) {
#pragma HLS INTERFACE ?????????? port=o
#pragma HLS INTERFACE ap_ctrl_none port=return
    *output = 0b11110000;
}
```

## List of interface mode

- ap\_ack
- ap\_bus
- ap\_fifo
- ap\_hls
- ap\_memory
- ap\_none
- ap\_ovld
- ap\_stable
- ap\_vld
- axis
- m\_axi
- s\_axilite

# PORT INTERFACES

```
void basic_input_output(  
    data_type *output) {  
#pragma HLS INTERFACE ?????????? port=o  
#pragma HLS INTERFACE ap_ctrl_none port=return  
    *output = 0b11110000;  
}
```

List of interface mode

- ap\_ack
- ap\_bus
- ap\_fifo
- ap\_hls
- ap\_memory
- ap\_none
- ap\_ovld
- ap\_stable
- ap\_vld
- axis
- m\_axi
- s\_axilite



# TOP-LEVEL FUNCTION CONTROL SIGNAL



# INPUT/OUTPUT EXAMPLE

```
typedef unsigned char data_type;

void basic_input_output(
    data_type    input,
    data_type *output) {
#pragma HLS INTERFACE ap_none      port=input
#pragma HLS INTERFACE ap_none      port=output
#pragma HLS INTERFACE ap_ctrl_none port=return

    *output = input;
}
```

# USING FUNCTION RETURN

```
typedef unsigned char data_type;

data_type basic_input_output(
    data_type   input
) {
#pragma HLS INTERFACE ap_none      port=input
#pragma HLS INTERFACE ap_ctrl_none port=return

    return input;
}
```

# NOTE

The return value to the top-level function cannot be a pointer.

```
...  
data_type *basic_input_output(  
    data_type input  
){  
  
    return input;  
}
```

# SUMMARY

- ❖ Each HLS hardware description can have only one top-function
- ❖ Only arguments in the top function require an associated interface
- ❖ There is also a block-level interface assigned to the top-function

# ASSIGNMENT Q

Add interfaces pragmas to this top-level function

```
#define data_type unsigned char

void basic_input_output(
    data_type input,
    data_type &output) {

    output = input;
}
```

# HLS LAB

Basic input/output

# SUMMARY

- ❖ Two groups of interfaces should be added to the top-function in an HLS design
  - Argument interfaces
  - And top-function block interfaces
- ❖ If you don't add any of these interfaces, the Vivado-HLS considers the corresponding default interface

# ASSIGNMENT @

Use the following C function as the LED controller that returns the LED values , then generate the corresponding IP using the Vivado-HLS.

```
unsigned char led_ctrl(char sw_input) {  
    return sw_input;  
}
```

# VIVADO LAB

Basic input/output

# ASSIGNMENT Q

A simple hardware circuit connects five lower LEDs (i.e., LD0 to LD4) on the Basys3 board to the five lower slide switches.

- a- Describe the hardware in Vivado-HLS and generate the RTL-IP.
- b- Import the design into the Xilinx Vivado suite and generate the FPAG bitstream.
- c- Program the Basys3 board and check the output.

# COMBINATIONAL CIRCUIT

Lecture 3

# LOGIC CIRCUIT



- ❖ arithmetic or logical functions,
- ❖ a data transmission
- ❖ a coding conversion
- ❖ or a complex task such as AI training or inference process

# COMBINATIONAL LOGIC CIRCUITS



# DEFINITION

Combinational circuit

# DEFINITION

A circuit whose outputs depends only on the state of its inputs.

A combinational circuit does not use any types of memories or storage devices.



Combinational Circuit

## EXAMPLES



## Logical and bitwise expressions:



## Simple arithmetic expressions:



## Simple programming structures:





# ASSIGNMENT Q

**Which circuit can be combinational:**

1. Traffic light controller
2. 4-bit integer multiplier
3. Binary counter
4. A three-layer perceptron neural network
5. A recurrent neural network

# PROPAGATION DELAY

Combinational circuit

# GATE PROPAGATION DELAY



# GATE PROPAGATION DELAY



P1( $a$  or  $b$   $\rightarrow g1 \rightarrow g2 \rightarrow f$ ) ..... 4ns

P2( $c$   $\rightarrow g2 \rightarrow f$ ) ..... 2ns

P3( $a$   $\rightarrow g4 \rightarrow h$ ) ..... 3ns

P4( $c$  or  $d$   $\rightarrow g3 \rightarrow g4 \rightarrow h$ ) ..... 5ns

# PROPAGATION DELAY



$$\delta = t_o - t_i$$

**Critical Path**  
defines this delay

# ASSIGNMENT Q

Let's assume the following circuit in which all gates have the same propagation delay denoted by  $t_d$ .

Find the output signal diagram for these input values.



# ASSIGNMENT Q

Let's assume the full-adder circuit in which all gates have the same propagation delay denoted by  $t_d$ .

*Find the propagation delay of this circuit.*



# BINARY ADDER DELAY

Combinational circuit

# FULL ADDER DELAY

Full Adder



# FULL ADDER DELAY

Full Adder



|                              |       |     |
|------------------------------|-------|-----|
| $a \rightarrow s$            | ..... | 4ns |
| $b \rightarrow s$            | ..... | 4ns |
| $c_{in} \rightarrow s$       | ..... | 2ns |
| $a \rightarrow c_{out}$      | ..... | 2ns |
| $b \rightarrow c_{out}$      | ..... | 2ns |
| $c_{in} \rightarrow c_{out}$ | ..... | 2ns |

# N-BIT BINARY ADDER

$$\begin{array}{r} c_{N-1} \ c_{N-2} \ c_1 \ c_0 \ 0 \\ a_{N-1} \dots a_1 a_0 \\ + b_{N-1} \dots b_1 b_0 \\ \hline s_{N-1} \dots s_1 \ s_0 \end{array}$$



# N-BIT BINARY ADDER PATHS



# N-BIT ADDER PROPAGATION DELAY



# N-BIT ADDER PROPAGATION DELAY



# N-BIT ADDER PROPAGATION DELAY



# SUMMARY

**Serially connected modules in hardware  
increase the corresponding propagation delay.**

# ASSIGNMENT Q

I have slightly changed the structure of the full-adder in this quiz. Now, what is the propagation delay of the n-bit adder utilises this full-adder?



# HLS

Combinational circuit

# A SIMPLE COMBINATIONAL CIRCUIT



$$d = ab + \bar{c}$$

$$d = (a \text{ AND } b) \text{ OR } (\text{NOT } c)$$

| Logic | C/C++ Logical Operators | C/C++ Bitwise Operators |
|-------|-------------------------|-------------------------|
| AND   | &&                      | &                       |
| OR    |                         |                         |
| NOT   | !                       | ~                       |

In C/C++:  $d = (a \&\& b) || !c;$   
or  $d = (a \& b) | \sim c;$

# A SIMPLE COMBINATIONAL CIRCUIT

```
void simple_combinational_circuit (
    bool  a, bool  b, bool  c,
    bool *d ) {

    *d = (a && b) || !c;
}
```

# A SIMPLE COMBINATIONAL CIRCUIT

```
void simple_combinational_circuit (
    bool  a, bool  b, bool  c,
    bool *d ) {
#pragma HLS INTERFACE ap_none      port=a
#pragma HLS INTERFACE ap_none      port=b
#pragma HLS INTERFACE ap_none      port=c
#pragma HLS INTERFACE ap_none      port=d
#pragma HLS INTERFACE ap_ctrl_none port=return

    *d = (a && b) | | !c;
}
```

## Propagation delay estimation

The screenshot shows a "Timing" section with a table:

| Clock  | Target | Estimated | Uncertainty |
|--------|--------|-----------|-------------|
| ap_clk | 10.00  | 0.978 ns  | 1.25 ns     |

A red arrow points from the text "Propagation delay estimation" to the "Estimated" column.

```
void simple_combinational_circuit (
    bool a, bool b, bool c,
    bool *d) {
    #pragma HLS INTERFACE ap_none      port=a
    #pragma HLS INTERFACE ap_none      port=b
    #pragma HLS INTERFACE ap_none      port=c
    #pragma HLS INTERFACE ap_none      port=d
    #pragma HLS INTERFACE ap_ctrl_none port=return
    *d = (a && b) || !c;
}
```

## Resource utilization

The screenshot shows a "Utilization Estimates" section with a table:

| Name            | BRAM_18K | DSP48E | FF    | LUT   | URAM |
|-----------------|----------|--------|-------|-------|------|
| DSP             | -        | -      | -     | -     | -    |
| Expression      | -        | -      | -     | 6     | -    |
| FIFO            | -        | -      | -     | -     | -    |
| Instance        | -        | -      | -     | -     | -    |
| Memory          | -        | -      | -     | -     | -    |
| Muxplexer       | -        | -      | -     | -     | -    |
| Register        | -        | -      | -     | -     | -    |
| Total           | 0        | 0      | 0     | 6     | 0    |
| Available       | 100      | 90     | 41600 | 20800 | 0    |
| Utilization (%) | 0        | 0      | 0     | <0    | 0    |

A red arrow points from the text "Resource utilization" to the "LUT" column.

The screenshot shows an "Interface" section with a table:

| RTL Ports | Dir | Bits | Protocol | Source Object | C Type  |
|-----------|-----|------|----------|---------------|---------|
| a         | in  | 1    | ap_none  | a             | scalar  |
| b         | in  | 1    | ap_none  | b             | scalar  |
| c         | in  | 1    | ap_none  | c             | scalar  |
| d         | out | 1    | ap_none  | d             | pointer |

Below the table are links: "Export the report(.html) using the Export Wizard.", "Open Analysis Perspective", and "Analysis Perspective".

# TAKEAWAY MESSAGE

- ❖ The HLS report of combinational circuit synthesised by vivado-HLS
  - ❑ Should not utilise any memory elements
  - ❑ Should not have any clock port in the interface part

# ASSIGNMENT Q

Complete this code by defining the port interfaces using HLS pragmas.

```
bool simple_combinational_circuit (bool a, bool b, bool c) {  
    return (a && b) || !c;  
}
```

# HLS LAB

Combinational circuit

# ASSIGNMENT Q

Generate the RTL-IP corresponding to this simple combinational circuit.

```
bool simple_combinational_circuit (bool a, bool b, bool c) {  
    return (a && b) || !c;  
}
```

Any Question... □

Thank you