

# Simple GPIO Specification

## Introduction

The Simple General Purpose IO (GPIO) core is a basic 8-bit GPIO module designed for interfacing with external devices through general-purpose input/output pins. It adheres to a simple WISHBONE bus interface for communication, allowing for easy integration into larger systems. The module supports both input and output modes for each GPIO pin, configurable through a control register. This design is suitable for applications requiring basic GPIO functionality with minimal complexity.

## Architecture

The Simple GPIO module consists of a single top-level module named `simple_gpio`. The architecture is centered around two primary registers: the Control Register and the Line Register. The Control Register determines the mode (input or output) of each GPIO pin, while the Line Register is used to read the status of input pins or set the output level of output pins.

## Key Operations

- **Control Register (0x00):** Configures each GPIO pin as input ('0') or output ('1').
- **Line Register (0x01):**
  - In input mode, it reads the current level of the GPIO pins.
  - In output mode, it sets the output level of the GPIO pins.

## Implementation Details

- The module supports up to 8 GPIO pins, configurable via the `io` parameter.
- The design includes mechanisms to reduce metastability by double-latching the GPIO inputs.
- The WISHBONE interface is used for communication, with signals for clock, reset, cycle, strobe, address, write enable, data input, and data output.

## Interface

| Signal             | Width | In/Out | Description                                                                   |
|--------------------|-------|--------|-------------------------------------------------------------------------------|
| <code>clk_i</code> | 1     | In     | Clock input signal.                                                           |
| <code>rst_i</code> | 1     | In     | Asynchronous active-low reset signal.                                         |
| <code>cyc_i</code> | 1     | In     | WISHBONE cycle signal.                                                        |
| <code>stb_i</code> | 1     | In     | WISHBONE strobe signal.                                                       |
| <code>adr_i</code> | 1     | In     | Address input signal (1 bit for selecting between Control and Line Register). |
| <code>we_i</code>  | 1     | In     | Write enable signal for WISHBONE interface.                                   |
| <code>dat_i</code> | 8     | In     | Data input for WISHBONE interface.                                            |
| <code>dat_o</code> | 8     | Out    | Data output for WISHBONE interface.                                           |
| <code>ack_o</code> | 1     | Out    | Acknowledge signal for WISHBONE interface.                                    |
| <code>gpio</code>  | io    | In/Out | General-purpose input/output pins.                                            |

## Timing

- **Latency:** The module operates synchronously with the clock signal `clk_i`. The output

data `dat_o` and acknowledge signal `ack_o` are updated on the rising edge of the clock.

- **Signal Behavior:**

- The GPIO inputs are latched twice to mitigate metastability issues.
- The acknowledge signal `ack_o` is asserted one clock cycle after a valid WISHBONE access is detected.

## Usage

To use the Simple GPIO module: 1. **Configure GPIO Pins:** - Set the desired mode (input or output) for each GPIO pin by writing to the Control Register (address 0x00). - For input mode, set the corresponding bit to '0'. - For output mode, set the corresponding bit to '1'.

2. **Read/Write GPIO Pins:**

- In input mode, read the current level of the GPIO pins from the Line Register (address 0x01).
- In output mode, write the desired output level to the Line Register.

3. **Integration with WISHBONE:**

- Ensure proper WISHBONE cycle (`cyc_i`) and strobe (`stb_i`) signals are asserted for valid transactions.
- Use the `ack_o` signal to confirm the completion of a transaction.

This module provides a straightforward interface for controlling GPIO pins, suitable for various digital interfacing tasks in embedded systems.

---

## Functional Description (Generated by funcgen)

## Verilog Design Modules Functional Description

### Module: simple\_gpio (File: simple\_gpio.v)

#### Purpose

The `simple_gpio` module is a simple 8-bit General Purpose Input/Output (GPIO) core that interfaces with a WISHBONE bus. The module allows each GPIO pin to be configured as either an input or an output. GPIO pins can read input signals from external devices or drive output signals based on the configuration.

#### Parameters

- **io:** Default = 8. This parameter specifies the number of GPIO pins supported by the module. The module supports up to a maximum of 8 GPIO pins.

#### Ports

- **clk\_i** (input, 1-bit): The clock signal driving the sequential logic of the module.
- **rst\_i** (input, 1-bit): Asynchronous active-low reset signal that initializes the module's state.
- **cyc\_i** (input, 1-bit): Indicates a valid bus cycle in conjunction with `stb_i`.
- **stb\_i** (input, 1-bit): Strobe signal indicating a valid data transfer cycle.
- **adr\_i** (input, 1-bit): Address line to select between the Control Register (`adr_i = 0`) and the Line Register (`adr_i = 1`).
- **we\_i** (input, 1-bit): Write enable signal for the WISHBONE interface.
- **dat\_i** (input, 8-bit): Data bus used for writing data into the module.
- **dat\_o** (output, 8-bit): Data bus used for reading data from the module.

- **ack\_o** (output, 1-bit): Acknowledgment signal indicating the completion of a bus transaction.
- **gpio** (inout, io-bit): Bidirectional GPIO pins interface for external signal interaction.

## Internal Signals

- **ctrl** (reg, io-bit): Control register that determines the mode (input/output) of each GPIO pin.
- **line** (reg, io-bit): Line register utilized to read current pin states or set output levels.
- **l gpio** (reg, io-bit): Latches the states of gpio input pins on the clock edge.
- **ll gpio** (reg, io-bit): Further latches l gpio to reduce the risk of metastability.
- **igpio** (reg, io-bit): Temporary internal signal used to assign GPIO outputs.
- **dat\_o** (reg, 8-bit): Register holding the current output data on the dat\_o port.
- **ack\_o** (reg, 1-bit): Register managing the acknowledgment signal logic.

## Functionality

### Sequential Logic

1. **Reset Logic:** On a low edge of rst\_i, the ctrl and line registers are reset to zero. Similarly, ack\_o is reset to zero.
2. **Control and Line Register Update:** If a valid write (wb\_wr) is detected:
  - If adr\_i is high, the line register is updated with dat\_i to set output levels.
  - If adr\_i is low, the ctrl register is updated with dat\_i to configure pin modes.
3. **GPIO Latching:** The l gpio and ll gpio registers are sequentially updated with the current input levels on the gpio pins to manage metastability.

### Combinational Logic

- **Data Output Muxing:** The dat\_o output data is multiplexed between the ctrl register and the ll gpio level according to the adr\_i address signal.
- **GPIO Output Assignment:** The GPIO's output behavior is controlled by checking ctrl bits. If the bit is set ('1'), the corresponding line bit is driven on the gpio; otherwise, the pin is left in high impedance ('z').

### Control Logic

- **Acknowledgment Signal:** The ack\_o signal is used to confirm the termination of bus transactions. It remains high for one cycle after detecting a WISHBONE access.

## Instantiations

There are no sub-module instantiations in the simple\_gpio module.

## Inter-Module Connections

Since simple\_gpio is a standalone module in this design, there are no hierarchical interconnections to describe. The module interfaces directly with a WISHBONE bus and external GPIO signals through its ports.

---

This document provides a detailed examination of the simple\_gpio Verilog module, offering insights into its design and functionality, which can guide hardware developers in further implementing or verifying similar GPIO interfaces.