# **BUS\_GPIO**



November 14, 2024

Jay Convertino

# **Contents**

| 1 | Usa                    |                                          |  |  |  |  |
|---|------------------------|------------------------------------------|--|--|--|--|
|   |                        | Introduction                             |  |  |  |  |
|   | 1.2                    | Dependencies                             |  |  |  |  |
|   |                        | 1.2.1 axi_lite_gpio Depenecies           |  |  |  |  |
|   |                        | 1.2.2 wishbone_classic_gpio Depenecies 2 |  |  |  |  |
|   |                        | 1.2.3 up_gpio Depenecies 2               |  |  |  |  |
|   | 1.3                    | In a Project                             |  |  |  |  |
| 2 | Arc                    | hitecture 3                              |  |  |  |  |
| 3 | Bui                    | lding 3                                  |  |  |  |  |
|   | 3.1                    | fusesoc                                  |  |  |  |  |
|   | 3.2                    | Source Files                             |  |  |  |  |
|   |                        | 3.2.1 axi_lite_gpio File List            |  |  |  |  |
|   |                        | 3.2.2 wishbone_classic_gpio File List 4  |  |  |  |  |
|   |                        | 3.2.3 up_gpio File List                  |  |  |  |  |
|   | 3.3                    | Targets                                  |  |  |  |  |
|   |                        | 3.3.1 axi_lite_gpio Targets 4            |  |  |  |  |
|   |                        | 3.3.2 wishbone_classic_gpio Targets 6    |  |  |  |  |
|   |                        | 3.3.3 up_gpio Targets 6                  |  |  |  |  |
|   | 3.4                    | Directory Guide                          |  |  |  |  |
| 4 | Simulation 8           |                                          |  |  |  |  |
|   | 4.1                    | iverilog                                 |  |  |  |  |
|   | 4.2                    | cocotb                                   |  |  |  |  |
| 5 | Module Documentation 9 |                                          |  |  |  |  |
|   | 5.1                    | axi_lite_gpio                            |  |  |  |  |
|   |                        | wishbone_classic_gpio                    |  |  |  |  |
|   | 5.3                    | up_gpio                                  |  |  |  |  |
|   |                        | 5.3.1 Registers                          |  |  |  |  |

# 1 Usage

#### 1.1 Introduction

BUS GPIO is a core for interfacing over generic input/output to a bus of choice. The data can then be accessed over a BUS, currently AXI lite or Wishbone Classic, and processed as needed. All input and output over the bus goes out directly to the IO. The following is information on how to use the device in an FPGA, software, and in simulation.

### 1.2 Dependencies

The following are the dependencies of the cores.

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

### 1.2.1 axi\_lite\_gpio Depenecies

- dep
  - AFRL:utility:helper:1.0.0
  - AFRL:device:up\_gpio:1.0.0
  - AD:common:up axi:1.0.0
- · dep tb
  - AFRL:simulation:axis\_stimulator
  - AFRL:utility:sim\_helper

### 1.2.2 wishbone\_classic\_gpio Depenecies

- dep
  - AFRL:utility:helper:1.0.0
  - AFRL:device:up\_gpio:1.0.0
  - AFRL:bus:up\_wishbone\_classic:1.0.0

### 1.2.3 up\_gpio Depenecies

- dep
  - AFRL:utility:helper:1.0.0

### 1.3 In a Project

First, pick a core that matches the target bus in question. Then connect the BUS GPIO core to that bus. Once this is complete the GPIO pins will need to be routed.

### 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,

- up\_axi An AXI Lite to uP converter core (see core for documentation).
- up\_wishbone\_classic A wishbone classic to uP converter core (see core for documentation).
- up\_gpio Takes uP bus and coverts it to interface with general purpose input/output (see module documentation for information 5).

For register documentation please see up gpio in 5

# 3 Building

The BUS GPIO 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.

#### 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 axi\_lite\_gpio File List

src

Type: verilogSource

- src/axi\_lite\_gpio.v

• tb

Type: verilogSource

- tb/tb\_gpio.v

### 3.2.2 wishbone\_classic\_gpio File List

• src

Type: verilogSource

- src/wishbone\_classic\_gpio.v

• tb

Type: verilogSource

- tb/tb\_wishbone\_slave.v

### 3.2.3 up\_gpio File List

• src

Type: verilogSource

- src/up\_gpio.v

• tb

Type: verilogSource

- tb/tb\_up\_gpio.v

# 3.3 Targets

# 3.3.1 axi\_lite\_gpio Targets

default

Info: Default for IP intergration.

- src
- dep
- sim

Info: Base simulation using icarus as default.

- src

- dep
- tb
- dep\_tb
- IN\_FILE\_NAME
- OUT\_FILE\_NAME
- RAND\_READY
- sim\_rand\_data

Info: Use random data as sim input.

- src
- dep
- tb
- dep\_tb
- IN\_FILE\_NAME=random.bin
- OUT\_FILE\_NAME=out\_random.bin
- RAND\_READY
- FIFO\_DEPTH
- sim\_rand\_ready\_rand\_data

Info: Use random data with a random ready as sim input.

- src
- dep
- tb
- dep\_tb
- IN\_FILE\_NAME=random.bin
- OUT\_FILE\_NAME=out\_random.bin
- RAND\_READY=1
- FIFO\_DEPTH
- sim\_8bit\_count\_data

Info: Use counter data as sim input.

- src
- dep
- tb
- dep\_tb
- IN\_FILE\_NAME=8bit\_count.bin

- OUT\_FILE\_NAME=out\_8bit\_count.bin
- RAND\_READY
- FIFO\_DEPTH
- sim\_rand\_ready\_8bit\_count\_data

Info: Use counter data with a random ready as sim input.

- src
- dep
- tb
- dep\_tb
- IN\_FILE\_NAME=8bit\_count.bin
- OUT\_FILE\_NAME=out\_8bit\_count.bin
- RAND\_READY=1
- FIFO\_DEPTH

### 3.3.2 wishbone\_classic\_gpio Targets

default

Info: Default for IP intergration.

- src
- dep

### 3.3.3 up\_gpio Targets

default

Info: Default for IP intergration.

- src
- dep
- sim

Info: Base simulation using icarus as default.

- src
- dep
- tb

# 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.

# 4.2 cocotb

Future simulations will use cocotb. This feature is not yet implemented.

# 5 Module Documentation

up\_gpio is the module that provides the general purpose input/output. The uP bus is the microprocessor bus based on Analog Devices design. It resembles a APB bus in design, and is the bridge to other buses BUS UART can use. This makes changing for AXI Lite, to Wishbone to whatever quick and painless.

axi\_lite\_gpio module adds a AXI Lite to uP (microprocessor) bus converter. The converter is from Analog Devices.

wishbone\_classic\_gpio module adds a Wishbone Classic to uP (microprocessor) bus converter. This converter was designed for Wishbone Classic only, NOT pipelined.

The next sections document these modules in great detail. up\_gpio contains the register map explained, and what the various bits do.

# axi\_lite\_gpio.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

### 2024/07/25

### **INFORMATION**

#### **Brief**

AXI Lite GPIO is a core for creating a generic programmable input/output

#### **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.

### axi\_lite\_gpio

```
module axi_lite_gpio #(
parameter
ADDRESS_WIDTH
=
32,
parameter
GPIO_WIDTH
=
32,
parameter
IRQ_ENABLE
```

```
) ( input aclk, input arstn, input s_axi_aclk, input s_axi_aresetn, input s_
```

AXI Lite based gpio device.

#### **Parameters**

ADDRESS\_WIDTH Width of the axi address bus

parameter

**GPIO WIDTH** Width of the GPIO for inputs and outputs

IRQ\_ENABLE Enable interrupt

parameter

#### **Ports**

aclk Clock for all devices in the core

arstn Negative reset Axi Lite aw valid s\_axi\_awvalid s\_axi\_awaddr Axi Lite aw addr s\_axi\_awprot Axi Lite aw prot s\_axi\_awready Axi Lite aw ready Axi Lite w valid s\_axi\_wvalid Axi Lite w data s\_axi\_wdata s\_axi\_wstrb Axi Lite w strb s\_axi\_wready Axi Lite w ready s\_axi\_bvalid Axi Lite b valid s\_axi\_bresp Axi Lite b resp s\_axi\_bready Axi Lite b ready Axi Lite ar valid s\_axi\_arvalid s\_axi\_araddr Axi Lite ar addr s\_axi\_arprot Axi Lite ar prot s\_axi\_arready Axi Lite ar ready s\_axi\_rvalid Axi Lite r valid s\_axi\_rdata Axi Lite r data s axi rresp Axi Lite r resp s\_axi\_rready Axi Lite r ready irq Interrupt when data is received

Input for GPIO gpio\_io\_i gpio\_io\_o Output for GPIO Tristate for GPIO gpio\_io\_t

#### up\_rreq

wire up\_rreq

uP read bus request

# up\_rack

```
wire up_rack
```

uP read bus acknowledge

# up\_raddr

```
wire [ADDRESS_WIDTH-3:0] up_raddr
```

uP read bus address

# up\_rdata

```
wire [31:0] up_rdata
```

uP read bus request

### up\_wreq

wire up\_wreq

uP write bus request

# up\_wack

```
wire up_wack
```

uP write bus acknowledge

# up\_waddr

```
wire [ADDRESS_WIDTH-3:0] up_waddr
```

uP write bus address

# up\_wdata

```
wire [31:0] up_wdata
```

uP write bus data

# **INSTANTIANTED MODULES**

# inst\_up\_axi

```
up_axi #(

AXI_ADDRESS_WIDTH(ADDRESS_WIDTH)
) inst_up_axi ( .up_rstn (arstn), .up_clk (aclk), .up_axi_awvalid(s_axi_awvalid)
```

Module instance of up\_axi for the AXI Lite bus to the uP bus.

# inst\_up\_gpio

```
up_gpio #(
ADDRESS_WIDTH(32),
BUS_WIDTH(2),
GPIO_WIDTH(GPIO_WIDTH),
IRQ_ENABLE(IRQ_ENABLE)
) inst_up_gpio ( .clk(aclk), .rstn(arstn), .up_rreq(up_rreq), .up_rack(up_rack)
```

Module instance of up\_gpio.

# wishbone\_classic\_gpio.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

#### 2024/07/25

### **INFORMATION**

#### **Brief**

Wishbone classic UART core.

#### **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.

### wishbone\_classic\_gpio

```
module wishbone_classic_gpio #(
parameter
ADDRESS_WIDTH
=
32,
parameter
BUS_WIDTH
=
4,
parameter
GPIO_WIDTH
```

```
= 32,
parameter
IRQ_ENABLE
= 0
) ( input clk, input rst, input s_wb_cyc, input s_wb_stb, input s_wb_we, input s_
```

AXI Lite based uart device.

#### **Parameters**

**ADDRESS\_WIDTH** Width of the address bus in bits.

parameter

**BUS\_WIDTH** Width of the data bus in bytes.

parameter

**GPIO\_WIDTH** Width of the GPIO for inputs and outputs

parameter

IRQ\_ENABLE Enable interrupt

parameter

#### **Ports**

clk Clock for all devices in the core

**rst** Positive reset

s\_wb\_cycs\_wb\_stbS\_wb\_weBus Cycle in processValid data transfer cycleActive High write, low read

s\_wb\_addr Bus address
s\_wb\_data\_i Input data
s\_wb\_sel Device Select

**s\_wb\_bte** Burst Type Extension

**s\_wb\_cti** Cycle Type

**s\_wb\_ack** Bus transaction terminated

s\_wb\_data\_o Output data

**s\_wb\_err** Active high when a bus error is present

irq Interrupt when data is received

gpio\_io\_ilnput for GPIOgpio\_io\_oOutput for GPIOgpio\_io\_tTristate for GPIO

### up\_rreq

wire up\_rreq

uP read bus request

### up\_rack

wire up\_rack

uP read bus acknowledge

### up\_raddr

wire [ADDRESS\_WIDTH-3:0] up\_raddr

uP read bus address

### up\_rdata

wire [31:0] up\_rdata

uP read bus request

### up\_wreq

wire up\_wreq

uP write bus request

# up\_wack

wire up\_wack

uP write bus acknowledge

# up\_waddr

wire [ADDRESS\_WIDTH-3:0] up\_waddr

uP write bus address

# up\_wdata

wire [31:0] up\_wdata

uP write bus data

### **INSTANTIANTED MODULES**

# inst\_up\_wishbone\_classic

```
up_wishbone_classic #(
ADDRESS_WIDTH(ADDRESS_WIDTH),
BUS_WIDTH(BUS_WIDTH)
) inst_up_wishbone_classic ( .clk(clk), .rst(rst), .s_wb_cyc(s_wb_cyc), .s_v
```

Module instance of up\_wishbone\_classic for the Wishbone Classic bus to the uP bus.

# inst\_up\_gpio

```
up_gpio #(
ADDRESS_WIDTH(ADDRESS_WIDTH),
BUS_WIDTH(BUS_WIDTH),
GPIO_WIDTH(GPIO_WIDTH),
IRQ_ENABLE(IRQ_ENABLE)
) inst_up_gpio ( .clk(aclk), .rstn(arstn), .up_rreq(up_rreq), .up_rack(up_rack)
```

Module instance of up\_gpio.

# up gpio.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

#### 2024/07/25

### **INFORMATION**

#### **Brief**

uP Core for interfacing with general purpose input/output.

#### **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.

# up\_gpio

```
module up_gpio #(
parameter
ADDRESS_WIDTH
=
32,
parameter
BUS_WIDTH
=
4,
parameter
GPIO_WIDTH
```

```
= 32,
parameter
IRQ_ENABLE
= 0
) ( input clk, input rstn, input up_rreq, output up_rack, input [ADDRESS_WII
```

uP based GPIO device.

#### **Parameters**

ADDRESS\_WIDTH Width of the uP address port.

parameter

**BUS\_WIDTH** Width of the uP bus data port.

parameter

**GPIO\_WIDTH** Width of the GPIO for inputs and outputs

parameter

IRQ\_ENABLE Enable interrupt

parameter

#### **Ports**

clk Clock for all devices in the core

rstn Negative reset

uP bus read request up\_rreq uP bus read ack up\_rack up\_raddr uP bus read address up\_rdata uP bus read data uP bus write request up\_wreq up\_wack uP bus write ack up\_waddr uP bus write address up\_wdata uP bus write data

irq Interrupt when data is received

gpio\_io\_ilnput for GPIOgpio\_io\_oOutput for GPIOgpio\_io\_tTristate for GPIO

### **REGISTER INFORMATION**

Core has 4 registers at the offsets that follow.

 GPIO\_DATA
 h000

 GPIO\_TRI
 h004

 GPIO2\_DATA
 h008 N/A

 GPIO2\_TRI
 h00C N/A

 GIER
 h11C

 IP\_ISR
 h120

 IP\_IER
 h128

### **GPIO\_DATA**

```
localparam GPIO_DATA = 12'h000
```

Defines the address offset for GPIO DATA

```
GPIO DATA
31:0
GPIO_WIDTH:0
```

Valid bits are from GPIO\_WIDTH:0, input or output data.

### **GPIO TRI**

```
localparam GPIO_TRI = 12'h004
```

Defines the address offset for GPIO TRI.

Valid bits are from  $GPIO\_WIDTH:0$ , 1 indicates input, 0 is output.

# GPIO2\_DATA

```
localparam GPI02_DATA = 12'h008
```

Defines the address offset for GPIO2 DATA



Valid bits are from  $\mathsf{GPIO2\_WIDTH:0}$ , input or output data. This Register is not implimented in this design.

# GPIO2\_TRI

```
localparam GPIO2_TRI = 12'h00C
```

Defines the address offset for GPIO2 TRI.



Valid bits are from  $GPIO2\_WIDTH:0$ , 1 indicates input, 0 is output. This register is not implimented in this design.

### **GIER**

```
localparam GIER = 12'h11C
```

Defines the address offset for GIER.

| GIER           |        |  |
|----------------|--------|--|
| 31             | 30:0   |  |
| Global IRQ Ena | UNUSED |  |

Bit 31 is the Global interrupt enable. Write a 1 to enable interrupts.

# IP\_ISR

```
localparam IP_ISR = 12'h120
```

Defines the address offset for IP\_ISR.

| IP ISR |            |  |
|--------|------------|--|
| 31:1   | 0          |  |
| UNUSED | IRQ Status |  |

Bit 0 is GPIO IRQ status, On write this will toggle(acknowledge) the interrupt.

# **IP\_IER**

```
localparam IP_IER = 12'h128
```

Defines the address offset to set the control bits.

| IP IER |         |  |
|--------|---------|--|
| 31:1   | 0       |  |
| UNUSED | IRQ Ena |  |

Bit 0 is GPIO IRQ enable interrupt. Write a 1 to bit 0 to enable interrupt.