**Journal – How I did it !!!!  
Part 1 - Ideation  
How to design PCie component using verilog step by step**

Designing a PCI Express (PCIe) component from scratch using Verilog is a complex task due to the high-speed, layered, and intricate nature of the PCIe protocol. The most common and practical approach is to leverage the hardened PCIe IP cores provided by FPGA vendors like Xilinx, Intel, and Lattice Semiconductor, and then design your custom logic (the "user logic") to interface with it.

This guide outlines the step-by-step process of designing user logic for a PCIe component that integrates with a vendor-provided IP core, which is the industry-standard method.

**1. Understand the PCIe protocol and architecture**

1. Before writing any code, you must understand the PCIe stack. Your Verilog user logic will primarily interface with the Transaction Layer, using a high-level bus like AXI, not the low-level physical layer.
2. Physical Layer: Manages the low-level electrical signaling, serialization/deserialization, and 128b/130b encoding.
3. Data Link Layer: Handles error checking, link management, and flow control with ACK/NACK protocols.
4. Transaction Layer: Creates and processes Transaction Layer Packets (TLPs), which include Memory Read/Write, I/O, and Configuration transactions. This is the layer your custom logic will interact with.

**2. Define your application and microarchitecture**

1. Determine what your PCIe component needs to do and how it will be structured.
2. Functionality: Will it perform Direct Memory Access (DMA) to and from system memory? Will it act as a simple register-based interface? A DMA engine is a common, complex use case.
3. Interfaces: Sketch out your user logic modules. A common structure includes:
   1. Configuration Logic: Handles requests to the PCIe Configuration Space.
   2. DMA Controller: Manages memory read and write transfers if DMA is needed.
   3. Application Logic: The core functionality that processes data.

**3. Generate the PCIe IP core**

1. Use the IP generation tool provided by your FPGA vendor to create a PCIe core. This process will create all the necessary low-level Verilog files and constraints.
2. Launch the Tool: Open your FPGA design suite (e.g., Xilinx Vivado, Intel Quartus, Lattice Diamond).
3. Select the Core: Find the "PCIe IP Core" or "Integrated Block for PCIe" and add it to your project.
4. Configure Parameters: Set up the core's parameters based on your requirements:
5. Lane Width: x1, x4, x8, or x16.
6. Link Speed: Gen1, Gen2, or Gen3.
7. Interface Type: AXI4 is the most common and robust interface for connecting your user logic to the PCIe core.
8. BARs (Base Address Registers): Configure the memory-mapped regions that the host will use to communicate with your device.

**4. Design the user logic using Verilog**

1. Write the Verilog code for your custom modules to connect to the AXI interface of the generated PCIe IP core.
2. User Logic Top Module: Instantiate your custom modules and the vendor's PCIe IP core. Connect the AXI signals between the two.
3. AXI Masters and Slaves: Depending on your application, you will design your user logic to act as either an AXI master (initiating memory transfers) or an AXI slave (responding to transfers).
4. Example: AXI-Lite Slave for register access
5. Design a simple module with an axil\_awaddr, axil\_wdata, and axil\_rdata interface.
6. Use a state machine to decode the incoming AXI address and read/write the internal registers. This is the foundation for a control and status register (CSR) block.
7. Example: AXI Master for DMA
8. Design a DMA engine that takes read/write requests from your application logic.
9. This logic will then generate AXI transactions (address, data, and control signals) to be sent through the PCIe core to the host's memory.

**5. Create a testbench for simulation**

1. A comprehensive testbench is crucial for verifying the correctness of your design before hardware synthesis.
2. Instantiate your design: The testbench will contain your top-level user logic module.
3. PCIe Bus Functional Model (BFM): The most effective way to test PCIe logic is with a PCIe BFM. You do not need to write this from scratch; open-source or vendor-provided BFMs can simulate a root complex and generate PCIe transactions.
4. Simulate Host Actions: Use the BFM to simulate the host performing the following actions:
5. Enumeration: Simulate the bus enumeration process.
6. Configuration Space Access: Read and write to your configured BARs.
7. Memory Access: Initiate memory read/write requests to test your data path.
8. Verification: Check that your user logic correctly processes the incoming transactions and produces the expected output.

**6. Synthesize and implement the design**

1. After successful simulation, move to the hardware implementation phase.
2. Add Files to Project: Include all your Verilog user logic files and the generated IP core files in your FPGA project.
3. Add Constraints: Apply the necessary constraints, including clock periods and pin assignments. The IP core generation should provide many of these automatically, but you may need to add constraints for your custom logic.
4. Synthesize and Place and Route: Run the synthesis, place, and route tools in your FPGA suite to convert your Verilog code into a hardware bitstream.
5. Timing Closure: Address any timing violations reported by the tools to ensure your design operates reliably at the required clock frequencies.

**Part 2: Step 1 – Understanding Architecture and designing basic Modules  
A) PCIe FIFO   
![](data:image/png;base64,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)  
Concept: Why this module exists**

In PCIe, *Transaction Layer Packets (TLPs)* flow between blocks. But different parts of the design may operate at different rates or segment widths.  
So, we need a FIFO:

* Store incoming TLPs (with data, headers, sequence numbers, etc.)
* Output them when downstream logic is ready
* Handle segmentation: input TLPs may come in multiple segments, and output TLPs may require re-packing.

This module is a wrapper FIFO that:

* Uses pcie\_tlp\_fifo\_raw as the actual storage.
* Adds segment packing/unpacking logic when IN\_TLP\_SEG\_COUNT ≠ OUT\_TLP\_SEG\_COUNT.
* Provides status signals like half\_full and watermark.

**Structure (big picture)**

* Parameters: configure depth, widths, number of segments.
* I/O: TLP input (AXI-like interface), TLP output, status.
* Internal wires: connect to the underlying raw FIFO.
* Generate block:
  + If segment counts match → simple direct FIFO.
  + Else → complicated re-packing + an additional small output FIFO.

**Breaking down code step by step**

**Header & parameters**

`resetall

`timescale 1ns / 1ps

`default\_nettype none

* Reset compiler directives to default.
* Set simulation timescale (1ns steps, 1ps precision).
* Disallow implicit wire declaration.

module pcie\_tlp\_fifo #(

parameter DEPTH = 2048,

parameter TLP\_DATA\_WIDTH = 256,

parameter TLP\_STRB\_WIDTH = TLP\_DATA\_WIDTH/32,

parameter TLP\_HDR\_WIDTH = 128,

parameter SEQ\_NUM\_WIDTH = 6,

parameter IN\_TLP\_SEG\_COUNT = 1,

parameter OUT\_TLP\_SEG\_COUNT = IN\_TLP\_SEG\_COUNT,

parameter WATERMARK = DEPTH/2

)

* Configurable FIFO. For example: 256-bit data width, 128-bit header, up to 2048 entries.

**I/O definitions**

input wire clk, rst;

* Clock & reset.

TLP Input bus

in\_tlp\_data, in\_tlp\_strb, in\_tlp\_hdr, in\_tlp\_seq, ...

* These carry PCIe TLP data, byte-enable strobes, headers, sequence numbers, etc.
* in\_tlp\_valid/in\_tlp\_ready → handshake.
* in\_tlp\_sop/in\_tlp\_eop → start and end of packet markers.

TLP Output bus

out\_tlp\_data, out\_tlp\_strb, out\_tlp\_hdr, ...

* Same as input, but for reading out from the FIFO.
* Controlled by out\_tlp\_ready.

Status

output wire half\_full, watermark;

* Indicators for monitoring FIFO usage.

**Internal Parameters**

parameter INT\_TLP\_SEG\_COUNT = IN\_TLP\_SEG\_COUNT > OUT\_TLP\_SEG\_COUNT ? IN\_TLP\_SEG\_COUNT : OUT\_TLP\_SEG\_COUNT;

* Normalize segment count → ensures FIFO can handle whichever side has more segments.

Other parameters compute widths for strb/data per segment.

**Sanity checks**

initial begin

if (TLP\_HDR\_WIDTH != 128) ...

if (TLP\_STRB\_WIDTH\*32 != TLP\_DATA\_WIDTH) ...

end

* Makes sure configuration is PCIe-compliant.
* Header must be 128 bits, data must be aligned to 32-bit boundaries.

**FIFO instantiation**

pcie\_tlp\_fifo\_raw #(...params...)

pcie\_tlp\_fifo\_raw\_inst (...connections...);

* The *raw storage FIFO*.
* It stores everything (data, headers, sop/eop, etc.).
* Exposes read/write interfaces.

**Generate block**

generate

if (INT\_TLP\_SEG\_COUNT == 1) begin

// simpler case: pass-through

end else begin

// complex repacking logic

end

end generate

* If no segment mismatch → just connect raw FIFO to outputs.
* If mismatch → add extra logic.

**Concept Requirement :**

**PCIe / TLP essentials (what matters for the FIFO)**

These are the spec details / conventions you need for implementing a PCIe TLP FIFO:

* **TLP (Transaction Layer Packet)** = header + optional payload + CRC (CRC often removed before this FIFO). The FIFO here deals with header + data payload + control/meta (SOP/EOP/valid/ready).
* **DW granularity (32-bit)**: PCIe payloads are organized in 32-bit words (DWords). Byte strobe (strb) is typically payload\_width/32 bits per DWord lane. The code you started with enforces TLP\_STRB\_WIDTH \* 32 == TLP\_DATA\_WIDTH.
* **TLP header length**:
  + Typical TLP header sizes: **3 DW (12 bytes)** for 32-bit addressing and **4 DW (16 bytes)** for 64-bit addressing / 64-bit requester IDs etc.
  + Many implementations use **128 bits (16 bytes)** for header storage to keep alignment and to hold all metadata (hence TLP\_HDR\_WIDTH = 128 in your code). That’s a design choice — the PCIe spec allows 3 or 4 DW, but using 4 DW (128 bits) simplifies aligning to 128b lanes.
* **Start/End markers**: SOP (start of packet) and EOP (end of packet) flags let you pack/unpack variable-length payloads across segments.
* **Sequence numbers (SEQ)**: used by some blocks (ordering, replay). Your FIFO stores a SEQ\_NUM\_WIDTH per TLP segment.
* **Fields often stored with each segment**: header, sequence number, BAR ID, function number, error bits, valid/sop/eop, data, and data strobe.
* **Backpressure handshake**: valid + ready style handshake. The producer asserts valid; the consumer asserts ready; transfer happens when both valid && ready.
* **Segmentation**: Input may present multiple *segments* per cycle or segment count differs between in/out sides. The wrapper must repack segments so downstream sees expected segment count(s).  
    
  **line-by-line / sentence-by-sentence explanation**:
* `timescale 1ns / 1ps — sets the resolution/time unit for simulation (1 ns time unit, 1 ps precision).
* `default\_nettype none — prevents implicit wire declaration when you forget wire or reg; helps catch typos.
* module tlp\_fifo\_simple #(...) (...); — define a module named tlp\_fifo\_simple with parameters and ports.
* parameter DEPTH = 16 — number of FIFO entries; small for teaching.
* parameter ADDR\_WIDTH = 4 — address width to index DEPTH entries. For DEPTH=16, width=4.
* parameter TLP\_DATA\_WIDTH = 128 — width of payload data bus in bits.
* parameter TLP\_HDR\_WIDTH = 128 — width of header field. We pick 128 for alignment.
* input wire clk, rst — clock and synchronous reset inputs.
* Input side ports (in\_data, in\_hdr, in\_valid, in\_sop, in\_eop, in\_ready) — producer sends data when in\_valid asserted; in\_ready indicates FIFO can accept.
* Output side ports (out\_data, out\_hdr, out\_valid, out\_ready) — FIFO presents data when out\_valid high; consumer accepts when out\_ready high.
* reg [ADDR\_WIDTH:0] wr\_ptr = 0; — write pointer is ADDR\_WIDTH+1 bits. An extra MSB simplifies full/empty detection (a common circular buffer trick).
* reg [ADDR\_WIDTH:0] rd\_ptr = 0; — read pointer.
* reg [TLP\_DATA\_WIDTH-1:0] mem\_data [0:DEPTH-1]; — array of DEPTH registers holding payloads.
* reg [TLP\_HDR\_WIDTH-1:0] mem\_hdr [0:DEPTH-1]; — array holding headers.
* reg mem\_valid[0:DEPTH-1]; — optional per-entry valid flags for clarity (helps show entry state).
* wire full = (wr\_ptr MSB != rd\_ptr MSB) && (lower bits equal) — full detection: when pointers wrap and lower index matches but MSB different, FIFO is full.
* wire empty = (wr\_ptr == rd\_ptr) — FIFO empty when both pointers equal.
* assign in\_ready = !full; — FIFO can accept if not full.
* assign out\_valid = !empty; — FIFO has data if not empty.
* assign out\_data = mem\_data[rd\_ptr[ADDR\_WIDTH-1:0]]; — present head-of-queue data on output bus (combinational read).
* assign out\_hdr = mem\_hdr[rd\_ptr[ADDR\_WIDTH-1:0]]; — present head-of-queue header on output bus.
* always @(posedge clk) write block — synchronous write/initialization on reset.
* On reset: wr\_ptr <= 0; and clear mem\_valid[].
* Else: if in\_valid && in\_ready then write data/header into memory at write index, set valid bit, and increment wr\_ptr.
* always @(posedge clk) read block — synchronous read.
* On reset: rd\_ptr <= 0;
* Else: if out\_valid && out\_ready then consumer accepted the data; clear entry valid and increment rd\_ptr.