readme.md 2024-09-07

# FPGA Targeted Design: PRBS-15 Block and Pattern Detector

This project involves the design of a Pseudo-Random Binary Sequence (PRBS-15) generator and a Pattern Detector using Verilog: PRBS-15 Block and Pattern Detector

### Table of Contents

- Project Description
- Deliverables
- Design Overview
  - o PRBS-15 Block
  - Pattern Detector
  - Top Module
- Testbenches

## **Project Description**

This project provides an FPGA-targeted design in Verilog, containing:

- A PRBS-15 block that outputs a custom pseudo-random sequence.
- A pattern detector block that identifies when a specific pattern repeats correctly n times.

### **Deliverables**

### 1. Custom PRBS-15 Block:

- o Takes a 4-byte pattern as input.
- Outputs these 4 bytes after each other n times.
- Implements a custom PRBS equation with XOR of bit 13 and bit 14.

### 2. Pattern Detector:

- o FSM-based.
- Detects if the pattern is correctly repeated n times.
- Raises a flag once the pattern is found.

### 3. Top Module:

Integrates the PRBS-15 and Pattern Detector blocks.

### 4. Testbenches:

Provided for each block and the top-level module to validate the functionality.

# **Design Overview**

PRBS-15 Block

readme.md 2024-09-07

This module generates a pseudo-random binary sequence using a custom PRBS-15 equation. It accepts a 32-bit input pattern and repeats it n times before applying a shift-left operation with XORing of bit 13 and bit 14 to generate the PRBS sequence.

### Ports:

- clk: Clock signal.
- rst\_n: Active-low reset signal.
- pattern\_in: 32-bit input pattern.
- **n\_repeats**: 8-bit input specifying the number of times to repeat the pattern.
- prbs\_out: 8-bit output PRBS sequence.

### **Internal Registers:**

- pattern\_counter: Count the patterns to reach n\_repeats.
- **byte\_counter**: Count the 4 Bytes for every pattern.

### Pattern Detector

This block uses a finite state machine (FSM) to detect if a given pattern is repeated n times in the input data stream. The FSM transitions between IDLE, MATCHING, and FOUND states to ensure that the pattern is correctly detected.

#### **Ports:**

- clk: Clock signal.
- rst n: Active-low reset signal.
- data\_in: 8-bit input data stream from the PRBS block.
- pattern: 32-bit input pattern to detect.
- **n\_repeats**: 8-bit input specifying the number of times the pattern should repeat.
- pattern\_found: Output flag that is asserted when the pattern is detected.

### Top Module

The top module integrates the PRBS-15 block and the Pattern Detector. It connects the <a href="mailto:prbs\_out">prbs\_out</a> from the PRBS block to the <a href="mailto:data\_in">data\_in</a> of the Pattern Detector, ensuring that the detector checks the PRBS sequence for repeated patterns.

### Ports:

- clk: Clock signal.
- rst\_n: Active-low reset signal.
- pattern\_in: 32-bit input pattern.
- **n\_repeats**: 8-bit input specifying the number of repeats.
- pattern\_found: Output flag indicating if the pattern was detected.

readme.md 2024-09-07



### **Testbenches**

Testbenches are provided for:

- 1. **PRBS-15 Block**: Validates the PRBS output for different input patterns and repeat counts.
- 2. **Pattern Detector**: Tests whether the detector correctly identifies patterns.
- 3. **Top Module**: Verifies the integration of the PRBS-15 and Pattern Detector blocks.

