

# INTERFACE SYNTHESIS

Lecture-15

# HARDWARE MODULE COMMUNICATION



# HARDWARE MODULE COMMUNICATION



# HLS AND HARDWARE MODULE



# PERIPHERAL COMMUNICATION



# COMMUNICATIONS

- ❖ **Communication among modules**



- ❖ **Communication with peripherals**

## PORt TYPES

Vitis HLS adds three types of ports to HLS design after synthesis:

- ❖ Clock and Reset ports
- ❖ Block-Level ports
- ❖ Argument-Level ports

## CLOCK AND RESET PORTS

```
#include <ap_int.h>

ap_int<100> interface_synthesis_example(
    int a,
    long long int b,
    float *o) {

    ap_int<100> r;

    r = a * b;
    *o = *o / a;

    return r;
}
```



# RESET SETTING



|                     |                                     |                                  |
|---------------------|-------------------------------------|----------------------------------|
| config_op           |                                     |                                  |
| config_rtl          |                                     |                                  |
| header              |                                     |                                  |
| kernel_profile      | <input type="checkbox"/>            | 0                                |
| module_auto_prefix  | <input checked="" type="checkbox"/> | 1                                |
| module_prefix       |                                     |                                  |
| mult_keep_attribute | <input type="checkbox"/>            | 0                                |
| register_all_io     | <input type="checkbox"/>            | 0                                |
| register_reset_num  | 0                                   | 0(vivado)                        |
| reset               | control                             | <input type="button" value="▼"/> |
| reset_async         | <input type="checkbox"/>            | 0                                |
| reset_level         | high                                | <input type="button" value="▼"/> |
| config_schedule     |                                     |                                  |

# RESET SETTING



|                     |                                     |           |         |
|---------------------|-------------------------------------|-----------|---------|
| ► config_op         |                                     |           |         |
| ► config_rtl        |                                     |           |         |
| header              |                                     |           |         |
| kernel_profile      | <input type="checkbox"/>            | 0         |         |
| module_auto_prefix  | <input checked="" type="checkbox"/> | 1         |         |
| module_prefix       |                                     |           |         |
| mult_keep_attribute | <input type="checkbox"/>            | 0         |         |
| register_all_io     | <input type="checkbox"/>            | 0         |         |
| register_reset_num  | 0                                   | 0(vivado) |         |
| reset               | control                             | control   | control |
| reset_async         | <input type="checkbox"/>            | 0         |         |
| reset_level         | high                                | high      | high    |
| ► config_schedule   |                                     |           |         |

- ❖ none
- ❖ control
- ❖ state
- ❖ all

# RESET CONFIGURATION

```
#include <ap_int.h>

ap_int<100> interface_synthesis_example(
    int a,
    long long int b,
    float *o) {
    #pragma HLS reset variable=r off
    ap_int<100> r;

    r = a * b;
    *o = *o / a;

    return r;
}
```

#pragma HLS reset variable=<a> off



# CLOCK ENABLE PORT



| Name                      | Value     | Default   |
|---------------------------|-----------|-----------|
| config_interface          |           |           |
| clock_enable              | ✓         | 0         |
| default_slave_interface   | s_axilite | s_axilite |
| m_axi_address             | ✓         | 1         |
| m_axi_alignment_byte_size | 0         | 0(vivado) |



# BLOCK-LEVEL PORT

```
#include <ap_int.h>

ap_int<100>
interface_synthesis_example(
    int a,
    long long int b,
    float *o) {

    ap_int<100> r;

    r = a * b;
    *o = *o / a;

    return r;
}
```



## EXAMPLE (PORTS)

```
#include <ap_int.h>

ap_int<100> interface_synthesis_example(
    int a,
    long long int b,
    float *o) {
    ap_int<100> r;
    r = a * b;
    *o = *o / a;
    return r;
}
```



## TAKEAWAY

- ❖ The reset signal behaviour can be controlled through solution settings and adding the corresponding pragma in code
- ❖ The HLS tool considers a default interface for block and arguments if you don't define them.

# BLOCK-LEVEL INTERFACE PROTOCOLS



# BLOCK-LEVEL I/O PROTOCOLS

## Block-level interface types:

- ❖ `ap_ctrl_none`
- ❖ `ap_ctrl_hs`
- ❖ `ap_ctrl_chain`
- ❖ `s_axilite`

## Block-level handshake signals specify the following:

- ❖ When the design can start to perform the operation
- ❖ When the operation ends
- ❖ When the design is idle and ready for new inputs

# BLOCK-LEVEL I/O PROTOCOLS

```
#include <ap_int.h>

ap_int<100> interface_synthesis_example(
    int a,
    long long int b,
    float *o) {
#pragma HLS INTERFACE ap_ctrl_hs port=return
    ap_int<100> r;

    r = a * b;
    *o = *o / a;

    return r;
}
```



# BLOK-LEVEL AP\_CTRL\_HS INTERFACE



# BLOK-LEVEL AP\_CTRL\_HS SIGNALLING



## PORT LEVEL (AP\_VLD)

```
void ap_vld_example(float x, float &z) {  
#pragma HLS INTERFACE ap_ctrl_hs port=return  
  
#pragma HLS INTERFACE ap_vld port=x  
#pragma HLS INTERFACE ap_vld port=z  
  
    z = x + 4;  
}
```

ap\_vld {  
 Data port  
 Valid signal



# POR T LEVEL (AP\_VLD) TIMING



## PORT LEVEL (AP\_ACK)

```
void ap_vld_example(float x, float &z) {  
#pragma HLS INTERFACE ap_ctrl_hs port=return  
  
#pragma HLS INTERFACE ap_ack port=x  
#pragma HLS INTERFACE ap_ack port=z  
  
    z = x + 4;  
}
```

ap\_vld {  
 Data port  
 acknowledge signal



# PORT LEVEL (AP\_ACK) TIMING



## PORT LEVEL (AP\_ACK)

**For input arguments, the design generates an output acknowledge that is active-High in the cycle the input is read.**

**For output arguments, Vivado HLS implements an input acknowledge port to confirm the output was read.**

## PORt LEVEL (AP\_HS)



# INPUT PORT LEVEL (AP\_HS) TIMING



# OUTPUT PORT LEVEL (AP\_HS) TIMING



## TAKEAWAY

- ❖ Interface mode ap\_hs includes a two-way handshake signal with the data port. The handshake is an industry-standard valid and acknowledges handshake.
- ❖ The ap\_hs port-level I/O protocol provides the following signals:
  - Data port
  - Acknowledge signal to indicate when data is consumed.
  - Valid signal to indicate when data is read.

Any Question... □

Thank you