# AXIS\_UART



May 21, 2025

Jay Convertino

# **Contents**

| 1 | Usage         1.1 Introduction          1.2 Dependencies          1.2.1 fusesoc_info Depenecies          1.3 In a Project                                                                                                   |                                        |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| 2 | Architecture                                                                                                                                                                                                                | 3                                      |
| 3 | Building 3.1 fusesoc 3.2 Source Files 3.2.1 fusesoc_info File List 3.3 Targets 3.3.1 fusesoc_info Targets 3.4 Directory Guide 3.5 Directory Guide 3.6 Directory Guide                                                       | 3<br>3<br>3<br>4<br>4<br>5             |
| 4 | Simulation         4.1 iverilog                                                                                                                                                                                             |                                        |
| 5 | Module Documentation 5.1 axis_uart_rx 5.2 axis_uart_tx 5.3 axis_uart 5.4 tb_cocotb_full python 5.5 tb_cocotb_full verilog 5.6 tb_cocotb_rx python 5.7 tb_cocotb_rx verilog 5.8 tb_cocotb_tx python 5.9 tb_cocotb_tx verilog | 10<br>12<br>16<br>19<br>22<br>25<br>28 |

# 1 Usage

## 1.1 Introduction

Simple UART core for TTL rs232 software mode data communications. No hardware handshake. This contains its own internal baud rate generator that creates an enable to allow data output or sampling. Baud clock and aclk can be the same clock.

RTS/CTS is not implemented, it simply asserts it as if its always ready, and ignores CTS.

# 1.2 Dependencies

The following are the dependencies of the cores.

- · fusesoc 2.X
- iverilog (simulation)
- cocotb (simulation)

# 1.2.1 fusesoc\_info Depenecies

- dep
  - AFRL:clock:mod\_clock\_ena\_gen:1.1.1
  - AFRL:utility:helper:1.0.0
  - AFRL:simple:piso:1.0.0
  - AFRL:simple:sipo:1.0.0
- · dep tb
  - AFRL:simulation:axis\_stimulator
  - AFRL:utility:sim helper

# 1.3 In a Project

This core connects a UART to the AXIS bus. Meaning this is a streaming device only. Connect the RX/TX to the UART in question and connect the AXIS to its intended endpoints.

# 2 Architecture

This core is made up of other cores that are documented in detail in there source. The cores this is made up of are the,

- axis\_uart\_tx Interface with UART TX and present the data over AXIS interface (see core for documentation).
- axis\_uart\_rx Interface with UART RX and present the data over AXIS interface (see core for documentation).

# 3 Building

The AXIS UART is written in Verilog 2001. It should synthesize in any modern FPGA software. The core comes as a fusesoc packaged core and can be included in any other core. Be sure to make sure you have meet the dependencies listed in the previous section. Linting is performed by verible using the lint target.

### 3.1 fusesoc

Fusesoc is a system for building FPGA software without relying on the internal project management of the tool. Avoiding vendor lock in to Vivado or Quartus. These cores, when included in a project, can be easily integrated and targets created based upon the end developer needs. The core by itself is not a part of a system and should be integrated into a fusesoc based system. Simulations are setup to use fusesoc and are a part of its targets.

## 3.2 Source Files

# 3.2.1 fusesoc\_info File List

- src
  - src/axis\_uart.v
  - src/axis uart rx.v
  - src/axis uart tx.v
- tb
  - tb/tb uart rx.v
  - tb/tb\_uart\_tx.v
- · tb cocotb full

- 'tb/tb\_cocotb\_full.py': 'file\_type': 'user', 'copyto': '.'
- 'tb/tb\_cocotb\_full.v': 'file\_type': 'verilogSource'
- tb\_cocotb\_rx
  - 'tb/tb\_cocotb\_rx.py': 'file\_type': 'user', 'copyto': '.'
  - 'tb/tb\_cocotb\_rx.v': 'file\_type': 'verilogSource'
- · tb cocotb tx
  - 'tb/tb\_cocotb\_tx.py': 'file\_type': 'user', 'copyto': '.'
  - 'tb/tb\_cocotb\_tx.v': 'file\_type': 'verilogSource'

# 3.3 Targets

# 3.3.1 fusesoc\_info Targets

- default
  - Info: Default for IP intergration.
- lint
- Info: Lint with Verible
- sim rx
  - Info: Simulate only the rx block.
- sim tx
  - Info: Simulate only the tx block.
- sim\_cocotb\_full
  - Info: Cocotb unit tests
- sim\_cocotb\_rx
  - Info: Cocotb unit tests
- sim\_cocotb\_tx
  - Info: Cocotb unit tests

# 3.4 Directory Guide

Below highlights important folders from the root of the directory.

- 1. **docs** Contains all documentation related to this project.
  - **manual** Contains user manual and github page that are generated from the latex sources.
- 2. **src** Contains source files for the core
- 3. **tb** Contains test bench files for iverilog and cocotb
  - cocotb testbench files

# 4 Simulation

There are a few different simulations that can be run for this core.

# 4.1 iverilog

iverilog is used for simple test benches for quick verification, visually, of the core.

- sim Standard simulation of TX/RX looped.
- sim\_rx Simulation of receive only.
- sim\_tx Simulation of transmit only.

### 4.2 cocotb

To use the cocotb tests you must install the following python libraries.

```
$ pip install cocotb
$ pip install cocotbext-axi
```

Each module has a cocotb based simulation. These use the cocotb extensions made by Alex. The two extensions used are cocotbext-axi and cocotbext-uart. These provide outside verification of the implimentation. These tests consist of 3 different fusesoc targets.

- sim\_cocotb\_full Standard simulation of TX/RX passing data to and from cocotbexts.
- **sim cocotb rx** Simulation of data receive using cocotbext.
- **sim\_cocotb\_tx** Simulation of data transmit using cocotbext.

Then you must use the cocotb sim target. The targets above can be run with various bus and fifo parameters.

\$ fusesoc run —target AFRL:device converter:axis uart:1.0.0

# **5 Module Documentation**

- axis\_uart\_tx Interfaces AXIS to the UART transmit line.
- axis\_uart\_rx Interfaces AXIS to the UART receive line.
- axis\_uart Wrapper for all of the above modules to create a singular device to interface with.

# axis uart rx.v

### **AUTHORS**

### JAY CONVERTINO

### **DATES**

### 2021/06/24

# **INFORMATION**

### **Brief**

UART RX to AXIS bus.

### **License MIT**

Copyright 2021 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

### axis\_uart\_rx

```
module axis_uart_rx #(
parameter
PARITY_ENA
=
0,
parameter
PARITY_TYPE
=
0,
parameter
STOP_BITS
=
1,
parameter
```

```
DATA_BITS

=
8,
parameter
DELAY

=
0,
parameter
BUS_WIDTH

=
1
) ( input aclk, input arstn, output parity_err, output frame_err, output [BL
```

AXIS UART, simple UART with AXI Streaming interface.

#### **Parameters**

PARITY\_ENA Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**DELAY** Delay in rx data input.

parameter

**BUS\_WIDTH** BUS\_WIDTH for axis bus in bytes.

parameter

# **Ports**

aclk Clock for AXIS

arstn Negative reset for AXIS

parity\_err Indicates error with parity check (active high)
frame\_err Indicates error with frame (active high)

 $m\_axis\_tdata \qquad \text{Output data from UART RX}$ 

 $\begin{tabular}{ll} \textbf{m\_axis\_tvalid} & \textbf{When active high the output data is valid} \\ \end{tabular}$ 

 $\label{eq:m_axis_tready} \textbf{ When set active high the output device is ready for data.}$ 

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

uart\_ena Enable UART data processing from RX.

uart\_hold Output to hold back clock in reset state till uart is in receive state.

rxd receive for UART (input from TX)

# axis uart tx.v

### **AUTHORS**

### JAY CONVERTINO

### **DATES**

### 2021/06/24

# **INFORMATION**

### **Brief**

UART TX from AXIS bus.

### **License MIT**

Copyright 2021 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

### axis\_uart\_tx

```
module axis_uart_tx #(
parameter
PARITY_ENA

=
0,
parameter
PARITY_TYPE
=
1,
parameter
STOP_BITS
=
1,
parameter
```

```
DATA_BITS

=
8,
parameter
DELAY

=
0,
parameter
BUS_WIDTH
=
1
) ( input aclk, input arstn, input [BUS_WIDTH*8-1:0] s_axis_tdata, input s_a
```

AXIS UART TX, simple UART TX from AXI Streaming interface.

#### **Parameters**

PARITY\_ENA Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**DELAY** Delay in tx data output. Delays the time to output of the data.

parameter

**BUS\_WIDTH** BUS\_WIDTH for axis bus in bytes.

parameter

# **Ports**

aclk Clock for AXIS

arstnNegative reset for AXISs\_axis\_tdataInput data for UART TX.

**s\_axis\_tvalid** When set active high the input data is valid

**s\_axis\_tready** When active high the device is ready for input data.

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

uart\_ena When active high enable UART transmit state.

uart\_hold Output to hold back clock in reset state till uart is in transmit state.

txd transmit for UART (output to RX)

# axis uart.v

### **AUTHORS**

### **JAY CONVERTINO**

# **DATES**

### 2021/06/24

# **INFORMATION**

### **Brief**

Core for interfacing with simple UART communications. Output is always the size of DATA\_BITS.

#### License MIT

Copyright 2021 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

### axis\_uart

```
module axis_uart #(
parameter
BAUD_CLOCK_SPEED
=
2000000,
parameter
BAUD_RATE
=
2000000,
parameter
PARITY_ENA
=
0,
parameter
```

```
PARITY_TYPE
 parameter
 STOP_BITS
parameter
 DATA_BITS
parameter
 RX_DELAY
parameter
RX_BAUD_DELAY
parameter
 TX_DELAY
Θ.
parameter
TX_BAUD_DELAY
 parameter
 BUS_WIDTH
) ( input aclk, input arstn, output parity_err, output frame_err, input [BU$
```

AXIS UART, simple UART with AXI Streaming interface.

#### **Parameters**

BAUD\_CLOCK\_SPEED This is the aclk frequency in Hz

parameter

**BAUD\_RATE** Serial Baud, this can be any value including non-standard.

parameter

**PARITY\_ENA** Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**RX\_DELAY** Delay in rx data input.

parameter

**RX\_BAUD\_DELAY** Delay in rx baud enable. This will delay when we sample a bit (default is

parameter midpoint when rx delay is 0).

**TX\_DELAY** Delay in tx data output. Delays the time to output of the data.

parameter

**TX\_BAUD\_DELAY** Delay in tx baud enable. This will delay the time the bit output starts.

parameter

BUS\_WIDTH AXIS data bus width in bytes.

parameter

#### **Ports**

aclk Clock for AXIS

arstn Negative reset for AXIS

parity\_err Indicates error with parity check (active high)
frame\_err Indicates error with frame (active high)

s\_axis\_tdata Input data for UART TX.

s\_axis\_tvalid When set active high the input data is valids\_axis\_tready When active high the device is ready for input data.

m\_axis\_tdata Output data from UART RX

m\_axis\_tvalid When active high the output data is valid

m\_axis\_tready When set active high the output device is ready for data.

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

tx transmit for UART (output to RX)

rx receive for UART (input from TX)

rts request to send is a loop with CTS

cts clear to send is a loop with RTS

### **INSTANTIATED MODULES**

# uart\_baud\_gen\_tx

```
mod_clock_ena_gen #(

CLOCK_SPEED(BAUD_CLOCK_SPEED),

DELAY(TX_BAUD_DELAY)
) uart_baud_gen_tx ( .clk(uart_clk), .rstn(uart_rstn), .start0(1'b1), .clr(uart_rstn))
```

Generates TX BAUD rate for UART modules using modulo divide method.

# uart\_baud\_gen\_rx

Generates RX BAUD rate for UART modules using modulo divide method.

## uart\_tx

```
axis_uart_tx #(
    .
PARITY_ENA(PARITY_ENA),
```

```
PARITY_TYPE(PARITY_TYPE),

STOP_BITS(STOP_BITS),

DATA_BITS(DATA_BITS),

DELAY(TX_DELAY)
) uart_tx ( .aclk(aclk), .arstn(arstn), .s_axis_tdata(s_axis_tdata), .s_axis_
```

Produces transmit data for tx UART from AXIS.

# uart\_rx

```
axis_uart_rx #(

PARITY_ENA(PARITY_ENA),

PARITY_TYPE(PARITY_TYPE),

STOP_BITS(STOP_BITS),

DATA_BITS(DATA_BITS),

DELAY(RX_DELAY)
) uart_rx ( .aclk(aclk), .arstn(arstn), .parity_err(parity_err), .frame_err
```

Consumes receive data for rx UART to AXIS.

| tb_cocotb.py                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTHORS                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| JAY CONVERTINO                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DATES                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2024/12/09                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| INFORMATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Brief                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Cocotb test bench                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| License MIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Copyright 2024 Jay Convertino                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without imitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:                              |
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.                                                                                                                                                                                                                                                                                                                                               |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| random_bool                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>def random_bool()</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Return a infinte cycle of random bools Returns: List                                                                                                                                                                                                                                                                                                                                                                                                                         |

start\_clock

```
def start_clock(
dut
)
```

Start the simulation clock generator.

#### **Parameters**

dut Device under test passed from cocotb test function

# reset\_dut

```
async def reset_dut(
dut
)
```

Cocotb coroutine for resets, used with await to make sure system is reset.

# single\_word

```
@cocotb.test()
async def single_word(
dut
)
```

Coroutine that is identified as a test routine. This routine tests for writing a single word, and then reading a single word.

# **Parameters**

dut Device under test passed from cocotb.

# in\_reset

```
@cocotb.test()
async def in_reset(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if device stays in unready state when in reset.

# **Parameters**

dut Device under test passed from cocotb.

# no\_clock

```
@cocotb.test()
async def no_clock(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if no ready when clock is lost and device is

left in reset.

## **Parameters**

dut Device under test passed from cocotb.

# tb cocotb.v

### **AUTHORS**

### JAY CONVERTINO

### **DATES**

# 2025/01/21

## **INFORMATION**

### **Brief**

Test bench wrapper for cocotb

### **License MIT**

Copyright 2025 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

## tb\_cocotb

```
PARITY_TYPE
 parameter
 STOP_BITS
parameter
 DATA_BITS
parameter
 RX_DELAY
parameter
RX_BAUD_DELAY
parameter
 TX_DELAY
Θ.
parameter
TX_BAUD_DELAY
 parameter
 BUS_WIDTH
) ( input aclk, input arstn, output parity_err, output frame_err, input [BU$
```

Test bench for axis uart.

#### **Parameters**

BAUD\_CLOCK\_SPEED This is the aclk frequency in Hz

parameter

**BAUD\_RATE** Serial Baud, this can be any value including non-standard.

parameter

**PARITY\_ENA** Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**RX\_DELAY** Delay in rx data input.

parameter

**RX\_BAUD\_DELAY** Delay in rx baud enable. This will delay when we sample a bit (default is

parameter midpoint when rx delay is 0).

**TX\_DELAY** Delay in tx data output. Delays the time to output of the data.

parameter

**TX\_BAUD\_DELAY** Delay in tx baud enable. This will delay the time the bit output starts.

parameter

BUS\_WIDTH AXIS data bus width in bytes.

parameter

#### **Ports**

aclk Clock for AXIS

arstn Negative reset for AXIS

parity\_err Indicates error with parity check (active high) frame\_err Indicates error with frame (active high)

s\_axis\_tdata Input data for UART TX.

s\_axis\_tvalid When set active high the input data is valids\_axis\_tready When active high the device is ready for input data.

m\_axis\_tdata Output data from UART RX

m\_axis\_tvalid When active high the output data is valid

m\_axis\_tready When set active high the output device is ready for data.

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

tx transmit for UART (output to RX)

rx receive for UART (input from TX)

rts request to send is a loop with CTS

cts clear to send is a loop with RTS

### **INSTANTIATED MODULES**

## dut

```
axis_uart #(

BAUD_CLOCK_SPEED(BAUD_CLOCK_SPEED),

BAUD_RATE(BAUD_RATE),

PARITY_ENA(PARITY_ENA),

PARITY_TYPE(PARITY_TYPE),

STOP_BITS(STOP_BITS),

DATA_BITS(DATA_BITS),

RX_DELAY(RX_DELAY),

RX_BAUD_DELAY(RX_BAUD_DELAY),

TX_DELAY(TX_DELAY),

TX_BAUD_DELAY(TX_BAUD_DELAY),

BUS_WIDTH(BUS_WIDTH)

) dut ( .aclk(aclk), .arstn(arstn), .parity_err(parity_err), .frame_err(frame)
```

Device under test, axis\_uart

| tb_cocotb.py                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTHORS                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| JAY CONVERTINO                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DATES                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2024/12/09                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| INFORMATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Brief                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Cocotb test bench                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| License MIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Copyright 2024 Jay Convertino                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without imitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:                              |
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.                                                                                                                                                                                                                                                                                                                                               |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| random_bool                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>def random_bool()</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Return a infinte cycle of random bools Returns: List                                                                                                                                                                                                                                                                                                                                                                                                                         |

start\_clock

```
def start_clock(
dut
)
```

Start the simulation clock generator.

#### **Parameters**

dut Device under test passed from cocotb test function

# reset\_dut

```
async def reset_dut(
dut
)
```

Cocotb coroutine for resets, used with await to make sure system is reset.

# single\_word

```
@cocotb.test()
async def single_word(
dut
)
```

Coroutine that is identified as a test routine. This routine tests for writing a single word, and then reading a single word.

# **Parameters**

dut Device under test passed from cocotb.

# in\_reset

```
@cocotb.test()
async def in_reset(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if device stays in unready state when in reset.

# **Parameters**

dut Device under test passed from cocotb.

# no\_clock

```
@cocotb.test()
async def no_clock(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if no ready when clock is lost and device is

left in reset.

## **Parameters**

dut Device under test passed from cocotb.

# tb coctb.v

### **AUTHORS**

## **JAY CONVERTINO**

## **DATES**

# 2025/01/23

# **INFORMATION**

### **Brief**

Test bench wrapper for cocotb

### **License MIT**

Copyright 2024 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

## tb\_cocotb

```
module tb_cocotb #(
parameter
PARITY_ENA
=
0,
parameter
PARITY_TYPE
=
0,
parameter
STOP_BITS
=
1,
parameter
```

```
DATA_BITS
=
8,
parameter
DELAY
=
0,
parameter
BUS_WIDTH
=
1
) ( input aclk, input arstn, output parity_err, output frame_err, output [BU
```

Test bench for axis uart rx.

#### **Parameters**

PARITY\_ENA Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**DELAY** Delay in rx data input.

parameter

BUS\_WIDTH BUS\_WIDTH for axis bus in bytes.

parameter

### **Ports**

aclk Clock for AXIS

arstn Negative reset for AXIS

parity\_err Indicates error with parity check (active high)
frame\_err Indicates error with frame (active high)

m\_axis\_tdata Output data from UART RX

 $\begin{tabular}{ll} \textbf{m\_axis\_tvalid} & \textbf{When active high the output data is valid} \\ \end{tabular}$ 

 $\label{eq:m_axis_tready} \textbf{ When set active high the output device is ready for data.}$ 

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

uart\_ena Enable UART data processing from RX.

rxd receive for UART (input from TX)

# **INSTANTIATED MODULES**

### dut

```
PARITY_TYPE(PARITY_TYPE),

STOP_BITS(STOP_BITS),

DATA_BITS(DATA_BITS),

DELAY(DELAY),

BUS_WIDTH(BUS_WIDTH)

) dut ( .aclk(aclk), .arstn(arstn), .parity_err(parity_err), .frame_err(frame)
```

Device under test, axis\_uart\_rx

| tb_cocotb.py                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTHORS                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| JAY CONVERTINO                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DATES                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2024/12/09                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| INFORMATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Brief                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Cocotb test bench                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| License MIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Copyright 2024 Jay Convertino                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without imitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:                              |
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.                                                                                                                                                                                                                                                                                                                                               |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
| FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| random_bool                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>def random_bool()</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Return a infinte cycle of random bools Returns: List                                                                                                                                                                                                                                                                                                                                                                                                                         |

start\_clock

```
def start_clock(
dut
)
```

Start the simulation clock generator.

#### **Parameters**

dut Device under test passed from cocotb test function

# reset\_dut

```
async def reset_dut(
dut
)
```

Cocotb coroutine for resets, used with await to make sure system is reset.

# single\_word

```
@cocotb.test()
async def single_word(
dut
)
```

Coroutine that is identified as a test routine. This routine tests for writing a single word, and then reading a single word.

# **Parameters**

dut Device under test passed from cocotb.

# in\_reset

```
@cocotb.test()
async def in_reset(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if device stays in unready state when in reset.

# **Parameters**

dut Device under test passed from cocotb.

# no\_clock

```
@cocotb.test()
async def no_clock(
dut
)
```

Coroutine that is identified as a test routine. This routine tests if no ready when clock is lost and device is

left in reset.

## **Parameters**

dut Device under test passed from cocotb.

# tb coctb.v

### **AUTHORS**

## **JAY CONVERTINO**

### **DATES**

# 2024/12/10

## **INFORMATION**

### **Brief**

Test bench wrapper for cocotb

### **License MIT**

Copyright 2024 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

## tb\_cocotb

```
module tb_cocotb #(
parameter
PARITY_ENA
=
0,
parameter
PARITY_TYPE
=
1,
parameter
STOP_BITS
=
1,
parameter
```

```
DATA_BITS

=
8,
parameter
DELAY

=
0,
parameter
BUS_WIDTH
=
1
) ( input aclk, input arstn, input [BUS_WIDTH*8-1:0] s_axis_tdata, input s_a
```

Test bench for AXIS UART TX, simple UART TX from AXI Streaming interface.

#### **Parameters**

PARITY\_ENA Enable Parity for the data in and out.

parameter

**PARITY\_TYPE** Set the parity type, 0 = even, 1 = odd, 2 = mark, 3 = space.

parameter

**STOP\_BITS** Number of stop bits, 0 to crazy non-standard amounts.

parameter

**DATA\_BITS** Number of data bits, 1 to crazy non-standard amounts.

parameter

**DELAY** Delay in tx data output. Delays the time to output of the data.

parameter

**BUS\_WIDTH** BUS\_WIDTH for axis bus in bytes.

parameter

### **Ports**

aclk Clock for AXIS

arstnNegative reset for AXISs\_axis\_tdataInput data for UART TX.

 $\textbf{s\_axis\_tvalid} \qquad \text{When set active high the input data is valid}$ 

s\_axis\_tready When active high the device is ready for input data.

uart\_clk Clock used for BAUD rate generation

uart\_rstn Negative reset for UART, for anything clocked on uart\_clk

uart\_ena When active high enable UART transmit state.

uart\_hold Output to hold back clock in reset state till uart is in transmit state.

txd transmit for UART (output to RX)

## **INSTANTIATED MODULES**

## dut

```
axis_uart_tx #(

PARITY_ENA(PARITY_ENA),

PARITY_TYPE(PARITY_TYPE),

STOP_BITS(STOP_BITS),
```

```
DATA_BITS(DATA_BITS),

DELAY(DELAY),

BUS_WIDTH(BUS_WIDTH)
) dut ( .aclk(aclk), .arstn(arstn), .s_axis_tdata(s_axis_tdata), .s_axis_tva
```

Device under test, axis\_uart\_tx