# up\_apb3.v

#### **AUTHORS**

#### **JAY CONVERTINO**

#### **DATES**

#### 2024/03/19

### **INFORMATION**

### **Brief**

APB3 slave to uP interface

#### 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\_apb3

```
module up_apb3 #(
parameter
ADDRESS_WIDTH
= 16,
parameter
BUS_WIDTH
= 4
) ( input clk, input rstn, input [ADDRESS_WIDTH-1:0] s_apb_paddr, input [0:0]
```

APB3 slave to uP interface

#### **Parameters**

ADDRESS\_WIDTH Width of the APB3 address port in bits.

parameter

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

paramete

#### **Ports**

clk Clock

rstn negative reset

s\_apb\_paddr APB3 address bus, up to 32 bits wide.s\_apb\_psel APB3 select per slave (1 for this core).

**s\_apb\_penable** APB3 enable device for multiple transfers after first.

s\_apb\_preadys\_apb\_pwriteAPB3 ready is a output from the slave to indicate its able to process the request.APB3 Direction signal, active high is a write access. Active low is a read access.

s\_apb\_pwdata APB3 write data port.s\_apb\_prdata APB3 read data port.

s\_apb\_pslverror APB3 error indicates transfer failure, not implimented.

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

### **VARIABLES**

### valid

```
assign valid = s_apb_psel & s_apb_penable & rstn
```

This will add an extra clock cycle. since enable happens after select. both are needed to use the device.

# s\_apb\_pslverror

```
assign s_apb_pslverror = 1'b0
```

APB3 error is always 0, no error.

### up\_waddr

```
assign up_waddr = s_apb_paddr[ADDRESS_WIDTH-1:shift]
```

up\_waddr and s\_apb\_addr are a direct mapping.

# up\_waddr

up\_raddr and s\_apb\_addr are a direct mapping.

## up\_wdata

```
assign up_wdata = s_apb_pwdata
```

up\_wdata and s\_apb\_pwdata are a direct mapping.

# s\_apb\_prdata

```
assign s_apb_prdata = up_rdata
```

s\_apb\_prdata and up\_rdata are a direct mapping.

# up\_wreq

```
assign up_wreq = valid & s_apb_pwrite
```

uP write request is a combination of the APB3 valid and APB3 write select (active high is write).

### up\_rreq

```
assign up_rreq = valid & ~s_apb_pwrite
```

uP read request is a combination of the APB3 valid and APB3 write select (active low is read).

### s\_apb\_pready

Diagrams seem to indicate that we should indicate ready when not sel and enable, which is why valid is complimented.