Ainshams university

# UCle\_PHY\_RX Team

Si-Vision Graduation Project



#### Phy model

1-FSM Controller: the role of this module is to manage the Finite State Machine (FSM) that controls the UCIE link training and associated control states, Error handling with adapter and Sideband messages with two PHY Dies

2- Data transfer: to handle when Adapter is sending data to the Physical Layer and vice versa

3- Sideband interface: is to transfer the sideband messages between two adapter Dies

#### **UCIE\_ctl\_fsm\_control Signal Table**

| Name                       | Width/value | Туре      | Functionality                 |
|----------------------------|-------------|-----------|-------------------------------|
| COUNTER_TIME_OUT           | 3           | Parameter | Timeout value for             |
|                            |             |           | training/retraining           |
|                            |             |           | operations.                   |
| i_clk                      | 1           | Input     | Clock signal for the          |
|                            |             |           | FSM.                          |
| i_rst_n                    | 1           | Input     | Global reset                  |
| i_rdi_lp_state_req         | 4           | Input     | State request signal          |
|                            |             |           | from the adapter              |
|                            |             |           | interface.                    |
| i_rdi_lp_linkerror         | 1           | Input     | Indicates a link              |
|                            |             |           | error from the                |
|                            |             |           | adapter interface.            |
| i_sb_msg_in                | 4           | Input     | Sideband message              |
|                            |             |           | input from the                |
|                            |             |           | second DUT.                   |
| i_start_ucie_link_training | 1           | Input     | Signal to initiate            |
|                            |             |           | UCIE link training.           |
| i_phy_req_trainerror       | 1           | Input     | Indicates a training          |
|                            |             |           | error from the PHY.           |
| i_phy_req_nferror          | 1           | Input     | Indicates a non-fatal         |
|                            |             |           | error from the PHY.           |
| i_phy_req_cerror           | 1           | Input     | Indicates a critical          |
|                            |             |           | error from the PHY.           |
| i_phy_req_pl_error         | 1           | Input     | Indicates a protocol-         |
|                            |             |           | level error from the          |
|                            |             |           | PHY.                          |
| o_rdi_pl_state_sts         | 4           | Output    | Current state status          |
|                            |             |           | output to the                 |
| 7. 7                       |             |           | adapter.                      |
| o_rdi_pl_error             | 1           | Output    | Protocol-level error          |
| 1. 1                       | 4           | 0         | status output.                |
| o_rdi_pl_cerror            | 1           | Output    | Critical error status         |
| li li c                    |             | 0         | output.                       |
| o_rdi_pl_nferror           | 1           | Output    | Non-fatal error               |
| 1: 1 :                     | 4           | 0         | status output.                |
| o_rdi_pl_trainerror        | 1           | Output    | Training error                |
|                            | 1           | 0.1.1     | status output.                |
| o_rdi_pl_phyinrecenter     | 1           | Output    | Indicates PHY in re-          |
| o ndi nl anosdassida       | 3           | Outnut    | center mode.                  |
| o_rdi_pl_speedmode         | 3           | Output    | Speed mode output             |
|                            |             |           | configuration to the adapter. |
| o_rdi_pl_lnk_cfg           | 3           | Output    | Link configuration            |
| o_rur_pr_mk_cig            | 3           | υμιραι    | output to the                 |
|                            |             |           | adapter.                      |
|                            |             |           | auapter.                      |
|                            | l           |           |                               |

| o_rdi_pl_inband_pres | 1 | Output   | Indicates in-band    |
|----------------------|---|----------|----------------------|
|                      |   |          | presence detection.  |
| o_sb_msg_out         | 4 | Output   | Sideband message     |
|                      |   |          | output to the second |
|                      |   |          | DUT.                 |
| r_current_state      | 4 | Internal | Current state of the |
|                      |   |          | FSM.                 |
| w_next_state         | 4 | Internal | Next state of the    |
|                      |   |          | FSM.                 |
| r_enable             | 1 | Internal | Enable signal for    |
|                      |   |          | internal operations. |
| r_linkreset_flag     | 1 | Internal | Flag indicating a    |
|                      |   |          | link reset is        |
|                      |   |          | required.            |
| r_linkerror_flag     | 1 | Internal | Flag indicating a    |
|                      |   |          | link error is        |
|                      |   |          | detected.            |
| r_nop_detected_flag  | 1 | Internal | Flag for detecting   |
|                      |   |          | NOP state.           |
| r_nop_active_flag    | 1 | Internal | Flag for NOP active  |
|                      |   |          | state.               |
| r_timeout_cntr       | 2 | Internal | Counter for timeout  |
|                      |   |          | handling.            |
| r_training_cntr      | 2 | Internal | Counter for training |
|                      |   |          | operations.          |

#### **UCIE\_ctl\_phy\_data\_transfer Table**

#### **Parameters**

| Parameter Name | Width   | Description          |
|----------------|---------|----------------------|
| NBYTES         | Integer | Number of data bytes |
|                |         | (default: 32).       |

#### **Inputs**

| Signal Name          | Width              | Description                |
|----------------------|--------------------|----------------------------|
| i_clk                | 1-bit              | Clock signal.              |
| i_rst_n              | 1-bit              | Global reset               |
| i_rdi_lp_irdy        | 1-bit              | Indicates Adapter (LP) is  |
|                      |                    | ready.                     |
| i_rdi_lp_valid       | 1-bit              | Valid signal from Adapter  |
|                      |                    | (LP).                      |
| i_rdi_lp_data        | [NBYTES -1:0][7:0] | Data from Adapter (LP).    |
| i_data_received      | [NBYTES -1:0][7:0] | Data received from Second  |
|                      |                    | DUT.                       |
| i_data_valid         | 1-bit              | Indicates validity of      |
|                      |                    | received data.             |
| i_enable             | 1-bit              | FSM enable control input.  |
| i_phy_req_data_error | 1-bit              | Error injection signal for |
|                      |                    | test bench.                |

#### **Outputs**

| Signal Name    | Width              | Description                  |
|----------------|--------------------|------------------------------|
| o_rdi_pl_trdy  | 1-bit              | Indicates readiness for data |
|                |                    | transfer to Adapter (LP).    |
| o_rdi_pl_valid | 1-bit              | Valid signal for Adapter     |
|                |                    | (LP) output data.            |
| o_rdi_pl_data  | [NBYTES -1:0][7:0] | Data sent to Adapter (LP).   |
| o_data_sent    | [NBYTES -1:0][7:0] | Data sent to the Second      |
|                |                    | DUT.                         |
| o_data_valid   | 1-bit              | Indicates validity of data   |
|                |                    | sent to Second DUT.          |

#### **Internal Signals**

| Signal Name     | Width | Description               |
|-----------------|-------|---------------------------|
| r_current_state | 2-bit | Current state of the FSM. |
| w_next_state    | 2-bit | Next state of the FSM.    |

#### UCIE\_ctl\_phy\_sb\_msg\_interface Table

| Signal Name        | Width   | Туре   | Functionality                                                             |
|--------------------|---------|--------|---------------------------------------------------------------------------|
| i_clk              | 1-bit   | Input  | Clock signal for synchronization.                                         |
| i_rst_n            | 1-bit   | Input  | Active-low reset signal for initializing the system.                      |
| i_rdi_lp_cfg_crd   | 1-bit   | Input  | Credit signal for receiving data from LP adapter.                         |
| i_rdi_lp_cfg_valid | 1-bit   | Input  | Valid signal indicating the availability of LP configuration data.        |
| i_sb_data_valid    | 1-bit   | Input  | Valid signal indicating the availability of sideband data.                |
| i_data_received_sb | NC bits | Input  | Sideband data received from PHY.                                          |
| i_rdi_lp_cfg       | NC bits | Input  | Configuration data received from LP adapter.                              |
| o_rdi_pl_cfg_crd   | 1-bit   | Output | Credit signal indicating availability to send data to LP adapter.         |
| o_rdi_pl_cfg_vld   | 1-bit   | Output | Valid signal indicating the validity of configuration data to LP adapter. |

| o_sb_data_valid    | 1-bit   | Output   | Valid signal indicating the availability of sideband data for PHY. |
|--------------------|---------|----------|--------------------------------------------------------------------|
| o_rdi_pl_cfg       | NC bits | Output   | Configuration data sent to LP adapter.                             |
| o_data_sent_sb     | NC bits | Output   | Sideband data sent to PHY.                                         |
| r_current_state    | 2 bits  | Internal | Current state of the state machine.                                |
| w_next_state       | 2 bits  | Internal | Next state of the state machine based on current conditions.       |
| r_internal_counter | 1-bit   | Internal | Counter indicating PHY credit availability.                        |
| r_data_received_sb | NC bits | Internal | Latches the sideband data received from PHY.                       |
| r_rdi_lp_cfg       | NC bits | Internal | Latches the configuration data received from LP adapter.           |







# RDI bring up flow





Link Reset



Link Error

## Link Error has Prioirty than Link reset



## Link Error has Prioirty than Active





# Link Error has Prioirty than Retrain



## Link Error has Prioirty than Retrain







