# 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_WIT]
```

uP based GPIO device.

#### **Parameters**

ADDRESS\_WIDTH Width of the uP address port, max 32 bit.

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

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

irq Interrupt when data is received

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

### **DIVISOR**

```
localparam DIVISOR = BUS_WIDTH/2
```

Divide the address register default location for 1 byte access to multi byte access. (register offsets are byte offsets).

## **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 >> DIVISOR
```

Defines the address offset for GPIO DATA



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

## **GPIO\_TRI**

```
localparam GPIO_TRI = 12'h004 >> DIVISOR
```

Defines the address offset for GPIO TRI.

GPIO TRI 31:0 GPIO\_WIDTH:0

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

## **GPIO2\_DATA**

```
localparam GPI02_DATA = 12'h008 >> DIVISOR
```

Defines the address offset for GPIO2 DATA



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

## GPIO2\_TRI

```
localparam GPI02_TRI = 12'h00C >> DIVISOR
```

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 >> DIVISOR
```

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 >> DIVISOR
```

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 >> DIVISOR
```

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.