

# **GateMate<sup>TM</sup> FPGA**PHY Interface for the PCIe Architecture

Vinh Hai Luong, B.Sc. Research&Development Cologne Chip AG



### PIPE Overview





- PIPE Interface with MAC layer.
- Custom Support Signals (CSS) Interface for internal PIPE IP Core logic. These signals are mainly used for simulation purposes or to generate signals for PIPE Interface.
- Register interface for SerDes configuration.

## General PIPE Logic Block diagram









- Reference clock from ADPLL.
  - Parallel Interface Clock for MAC and PHY synchronization.
  - Asynchronous Reset for Transceiver.
  - Power states.



| PIPE                                                                                     |  |
|------------------------------------------------------------------------------------------|--|
| clk_core_pll<br>i_Reset<br>i_PowerDown[1:0]                                              |  |
| i_TxData[63:0] i_TxDataK[7:0] i_TxElecIdle i_TxDetectRx i_TxCompliance[7:0] i_RxPolarity |  |
| o_PCLK                                                                                   |  |



Control signals triggered by MAC layer.

o\_RxDataK[7:0]

o\_RxData[63:0]

- o\_RxStatus[2:0]
- o\_PhyStatus
- o\_RxElecIdle
- o\_RxValid



PIPE clk\_core\_pll i Reset i PowerDown[1:0] i TxData[63:0] i TxDataK[7:0] i TxElecIdle i TxDetectRx i\_TxCompliance[7:0] i RxPolarity o PCLK o\_RxData[63:0] o RxDataK[7:0] o\_RxStatus[2:0] o PhyStatus o RxElecIdle

o\_RxValid

Data from SerDes Receiver.

| PIPE                                                                                     |  |
|------------------------------------------------------------------------------------------|--|
| clk_core_pll<br>i_Reset<br>i_PowerDown[1:0]                                              |  |
| i_TxData[63:0] i_TxDataK[7:0] i_TxElecIdle i_TxDetectRx i_TxCompliance[7:0] i_RxPolarity |  |
| o_PCLK                                                                                   |  |
| o_RxData[63:0]<br>o_RxDataK[7:0]                                                         |  |
| o_RxStatus[2:0]<br>o_PhyStatus<br>o_RxElecIdle                                           |  |
| o_RxValid                                                                                |  |

| RxStatus | Description                                                           |
|----------|-----------------------------------------------------------------------|
| 000      | Received Data OK (P0),<br>Receiver not detected (P1)                  |
| 001      | SKP added                                                             |
| 010      | SKP removed                                                           |
| 011      | Receiver detected (P1)                                                |
| 100      | 8b/10b Error and optionally<br>Disparity Error                        |
| 101      | Elastic Buffer Overflow                                               |
| 110      | Elastic Buffer Underflow                                              |
| 111      | Disparity Error. Unused if reported together with 8b/10b Error (100). |



- RxStatus: Status of the received data.
- PhyStatus: Successful power state change or finished Receiver Detection.



| PIPE                                                                                     |
|------------------------------------------------------------------------------------------|
| clk_core_pll<br>i_Reset<br>i_PowerDown[1:0]                                              |
| i_TxData[63:0] i_TxDataK[7:0] i_TxElecIdle i_TxDetectRx i_TxCompliance[7:0] i_RxPolarity |
| o_PCLK                                                                                   |
| o_RxData[63:0]<br>o_RxDataK[7:0]                                                         |
| o_RxStatus[2:0]<br>o_PhyStatus<br>o_RxElecIdle                                           |
| o_RxValid                                                                                |

RxValid: Indicates symbol lock/Received data is valid.

### **CSS** Interface



#### PIPE

#### SerDes signals:

i\_rx\_buf\_reset

#### SerDes signals:

- o\_tx\_buf\_err
- o clk core rx rec
- o rx buf err

#### PIPE FSM signals:

- o fsm state pipe[3:0]

#### Word Alignment FSM signals:

- o\_fsm\_state\_align[1:0]

#### Generate Block:

- o\_RxDataComma[7:0]
- o RxDataDispErr[7:0]
- o\_RxDataDecErr[7:0]

#### SerDes signals:

- i\_rx\_buf\_reset: trigger a reset for the elastic buffer.
- o\_tx\_buf\_err: Overflow or Underflow in Transmitter buffer.
- o\_clk\_core\_rx\_rec: Recovered Clock from the received data.
- o\_rx\_buf\_err: Overflow or Underflow in Elastic Buffer of SerDes Receiver.

### **CSS** Interface



#### PIPE

#### SerDes signals:

i\_rx\_buf\_reset

#### SerDes signals:

- o\_tx\_buf\_err
- o\_clk\_core\_rx\_rec
- o\_rx\_buf\_err

#### PIPE FSM signals:

- o fsm state pipe[3:0]

#### Word Alignment FSM signals:

- o\_fsm\_state\_align[1:0]

#### Generate Block:

- o\_RxDataComma[7:0]
- o\_RxDataDispErr[7:0]
- o\_RxDataDecErr[7:0]

#### PIPF FSM:

- o\_fsm\_state\_pipe [3:0]: current state of the PIPE FSM.
- Word Alignment FSM:
  - o\_fsm\_state\_align [1:0]: current state of the Word Alignment FSM.
- Generate Block: Module that has received and transmitted data along with their error flags as inputs and generate status signals accordingly.
  - o\_RxDataComma [7:0]: Each bit represents if the symbol at that position is a COM or not.
  - o\_RxDataDispErr [7:0]: Each bit represents if the symbol at that position has disparity error or not.
  - o\_RxDataDecErr [7:0]: Each bit represents if the symbol at that position has 8b/10b Decode error or not.

### Register Interface



### E Register Interface

clk\_reg
regfile\_en
regfile\_we
regfile\_addr
regfile\_di

regfile\_do regfile\_rdy

- clk\_reg: reference clock for the dynamic reconfiguration port.
- regfile\_en: enable control signal to access the dynamic reconfiguration feature.
- regfile\_we: provides the write enable control signal to write the data on the data input port into the register selected by the address bus.
- regfile\_addr: dynamic reconfiguration address.
- regfile\_di: provides reconfiguration data that writes into a specified address of the register set.
- regfile\_do: provides data output of the register selected by the address bus.
- regfile\_rdy: provides the response to the enable signal for the PLL's dynamic reconfiguration feature. This signal is pulsed High when a write or read operation is successful.
- Register mapping can be found in <u>Gatemate datasheet</u> (Page 90-97).

### PIPE FSM



### \_

#### **PIPE FSM**

i\_pw\_state[1:0]
i\_tx\_elec\_idle
i\_tx\_detect\_or\_loop
i\_rx\_detect\_done
i\_clk

o\_fsm\_state\_pipe[3:0]
o\_rx\_status[2:0]
o\_phy\_status
o\_rx\_detect\_start
o\_tx\_elec\_idle
o\_enable\_align

#### • Inputs:

- i\_pw\_state [1:0]: current power state.
- i\_tx\_elec\_idle: set transmitter in electrical idle state when set.
- i\_detect\_or\_loop: trigger receiver detection or loopback mode when set.
- i rx detect done: receiver detection is done.
- i\_clk: input clock.

#### • Outputs:

- o\_fsm\_state\_pipe [3:0]: current state of PIPE FSM.
- o\_rx\_status [2:0]: receiver status.
- o\_phy\_status: physical status flag.
- o\_rx\_detect\_start: initiate receiver detection.
- o\_tx\_elec\_idle: set transmitter in electrical idle state.
- o\_enable\_align: enable word alignment.

### States in PIPE FSM

| PIPE FSM     |                                                             |  |
|--------------|-------------------------------------------------------------|--|
| RESET        | Reset state                                                 |  |
| P1_IDLE      | Transmitter in Electrical Idle state                        |  |
| P1_DET_START | Trigger Receiver Detection operation, set i_TxDetectRx to 1 |  |
| P1_DET_GOOD  | Receiver detected (RxStatus = 011)                          |  |
| P1_DET_BAD   | Receiver not detected (RxStatus = 000)                      |  |
| P1_DET_WAIT  | Wait for i_TxDetectRx back to 0                             |  |
| P0_NORMAL    | Normal operation                                            |  |
| P0_LOOP      | Loopback mode                                               |  |
| P0_IDLE      | Transmitter in Electrical Idle state                        |  |
| P1_SET_IDLE  | Trigger transition from power state P0 to P1                |  |



- Prefix Px represents the current power state.
- Each state transition where a power state change is
  possible would also require a PRE-state in between. This
  state will set the PhyStatus flag to 1'b1. The flag is
  deasserted when the power state change is successfully
  completed. The behavior follows the PIPE Specs.
- Power state change possible for:
  - From P1\_IDLE to all P0 states.
  - From P0 states through P1\_SET\_IDLE to P1\_IDLE.

### States in PIPE FSM

s\_transit = { i\_pw\_state , i\_tx\_elec\_idle , i\_tx\_detect\_or\_loop }





### Word Alignment FSM



#### Word Alignment FSM

i\_clk i\_enable i\_byte\_locked

o\_fsm\_state\_align[1:0] o\_rx\_valid o\_mcomma\_align o\_pcomma\_align

#### Inputs:

- i\_enable: enable word alignment.
- i\_byte\_locked: byte is locked.
- i\_clk: input clock.

#### Outputs:

- o\_fsm\_state\_align [1:0]: current state of Word Alignment FSM.
- o rx valid: received data is valid.
- o\_mcomma\_align: activate word alignment of SerDes (negative comma sequence).
- o\_pcomma\_align: activate word alignment of SerDes (positive comma sequence).

# States in Word Alignment FSM



| Word Alignment FSM |                                              |  |
|--------------------|----------------------------------------------|--|
| WAIT               | Reset state                                  |  |
| ALIGN_START        | Alignment enabled but byte is not locked     |  |
| COUNT_START        | Byte is locked, start counter                |  |
| RX_VALID           | Target value reached, received data is valid |  |



### References



- PHY Interface for the PCI Express\* Architecture (PIPE) Specs
- AMD DRP Definition
- Philipp Ledüc's Masterthesis



Luong Vinh Hai, B.Sc.

Cologne Chip AG

Eintrachtstr. 113 50668 Köln

