Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create CMIS-custom-SI-settings.md #1334

Merged
merged 10 commits into from
Jul 14, 2023
256 changes: 256 additions & 0 deletions doc/sfp-cmis/CMIS-custom-SI-settings.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,256 @@
# Feature Name
Custom SI settings for CMIS modules

# High Level Design Document
#### Rev 0.1

# Table of Contents
* [List of Tables](#list-of-tables)
* [Revision](#revision)
* [About This Manual](#about-this-manual)
* [Abbreviation](#abbreviation)
* [References](#references)
* [Problem Definition](#problem-definition)
* [Objective](#objective)
* [Plan](#plan)
* [Proposed Work-Flows](#proposed-work-flow)
* [Feature Enablement](#feature-enablement)
* [No Transceiver Present](#no-transceiver-present)
* [Out Of Scope](#out-of-scope)

# List of Tables
* [Table 1: Definitions](#table-1-definitions)
* [Table 2: References](#table-2-references)

# Revision
| Rev | Date | Author | Change Description |
|:---:|:-----------:|:----------------------------------:|-------------------------------------|
| 0.1 | 05/05/2023 | Anoop Kamath | Initial version

# About this Manual
This is a high-level design document describing the way to apply custom SI settings for CMIS supported modules

# Abbreviation

# Table 1: Definitions
| **Term** | **Definition** |
| -------------- | ------------------------------------------------ |
| xcvrd | Transceiver Daemon |
| CMIS | Common Management Interface Specification |
| DP | Data Path |
| DPInit | Data-Path Initialization |
| QSFP-DD | QSFP-Double Density (i.e. 400G) optical module |
| SI | Signal Integrity |
| EC | Explicit Control |
| TX | Transmit |
| RX | Recieve |
| EQ | Equalizer |

# References

# Table 2 References

| **Document** | **Location** |
|---------------------------------------------------------|---------------|
| CMIS v5 | [CMIS5p0.pdf](http://www.qsfp-dd.com/wp-content/uploads/2021/05/CMIS5p0.pdf) |

# Problem Definition

Certain high-speed QSFP_DD, OSFP and QSFP modules require Signal Integrity (SI) settings to match platform media settings in order to achieve link stability, right tunning and optimal performance.

## Clause from CMIS5.0 spec for Signal Integrity
Excerpt from CMIS5.0 spec providing definition of Signal Integrity:

![image](https://user-images.githubusercontent.com/115578705/236561523-8999b615-b271-4e28-9fbe-d0c9d414bdb8.png)

These SI settings can vary based on combination of the module vendor plus platform vendor. The module will have default TX/RX SI settings programmed in its EEPROM by module vendor, but platform vendor has provision to overwrite these settings to match their platform requirements.
The host can apply new TX SI settings when TX Input Adaptive EQ is disabled for all TX Data Path lanes but RX SI settings can be applied directly. These TX/RX setting should be applied with Explicit Control bit is set to 1.

## Clause from CMIS5.0 spec for Explicit Control
Excerpt from CMIS5.0 spec providing definition of Explicit Control:

![image](https://user-images.githubusercontent.com/115578705/236561421-d960d243-cd26-4087-88fe-c621867ffaa7.png)

# Objective
SI parameters can be vendor and module specific. The vendor can populate desired SI param values in a JSON file. Provide an approach in the CMIS state machine to generate and apply host defined SI parameters to module eeprom.

![image](https://user-images.githubusercontent.com/115578705/236575703-aea7f377-ba5e-4e96-b18e-920f93e19774.png)

# Plan
The SI media setting file optics_si_setting.json needs to be defined by each platform_vendor that will need SI settings. All SKUs of the platform will share the same optics_si_setting.json file. If no file is found, then this mechanism will be ignored.

This file will have TX, RX setting blocks, and each block will have two subblocks: the first is global level setting and the next is port level setting. These subblocks will eventually contain per-lane SI parameter setting values based on the type of vendor and speed that are expected to be programmed.

## TX_SETTING:
This section will provide details on whether the TX EQ (TX input equalizer control) setting is FIXED or ADAPTIVE. Only adaptive EQ should be used for TX input, and it's enabled as the default setting in module. Fixed EQ is not recommended for TX direction and will not work until the SI/Hardware team explicitly recommends it.

If the EQ_FIXED flag is false or not present, then the SI param generation flow will come out of TX_SETTING and continue with the RX_SETTING block. But if the EQ_FIXED flag is true for TX_SETTING, then we need to disable AdaptiveInputEqEnableTx.

The TX Input EQ register control: Page 10h Byte 153 – 159

| **Byte** | **Field Name** |
| -------------- | ----------------------------------------- |
| 153 | AdaptiveInputEqEnableTx1..8 (lane 1-8) |
| 154 - 155 | AdaptiveInputEqRecallTx1..8 (lane 1-8) |
| 156 - 159 | FixedInputEqTargetTx1..8 (lane 1-8) |

## RX_SETTING:
The RX_SETTING block contains the same sections as TX_SETTING, but the EQ_FIXED flag should always be true. The SI settings can be directly written and applied for RX output equalization.

The RX Output EQ register control: Page 10h Byte 162 – 173

| **Byte** | **Field Name** |
| -------------- | ----------------------------------------- |
| 162 - 165 | OutputEqPreCursorTargetRx1..8 (lane 1-8) |
| 166 - 169 | OutputEqPostCursorTargetRx1..8 (lane 1-8) |
| 170 - 173 | OutputAmplitudeTargetRx1..8 (lane 1-8) |

## GLOBAL_MEDIA_SETTINGS:
This block's first level of identification will be the range of port numbers. The ports can be defined as a range of 0-31 or a list of multiple ports: 1, 2, 3, or a list of ports in the range of 5–10, 25–31, matching the index number in the port_config.ini file. This port range will have a unique defined lane speed, which will have unique vendor and vendor part number entries supporting this speed. Module key will be created based on speed and vendor details.
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved

Each vendor will have per-lane SI param attribute entries applicable for the identified port + speed for the platform vendor. This value will be searched through the module key.

## PORT_MEDIA_SETTINGS:
The entries in this block will be unique single port numbers. The control of SI attribute list generation search will reach the PORT_MEDIA_SETTINGS block only when no attribute list is generated in the GLOBAL_MEDIA_SETTINGS block.

There will be unique speed and vendor/vendor_PN entries in each identified port block.

Default values can be platform defaults for multiple vendors in each section.

## List of standard TX/RX SI parameters
- SI_PARAM_TX_INPUT_EQ
- SI_PARAM_RX_OUTPUT_PRE
- SI_PARAM_RX_OUTPUT_POST
- SI_PARAM_RX_OUTPUT_AMP

## Sample Optics SI setting file:
```
{
“TX_SETTING”: {
“EQ_FIXED”: “false”,
“GLOBAL_MEDIA_SETTINGS” : {},
“PORT_MEDIA_SETTINGS” : {}
},

“RX_SETTING”: {
“EQ_FIXED”: “true”,
“GLOBAL_MEDIA_SETTINGS” : {
“1-20”: {
“100G_SPEED”: {
“CREDO”: {
“CREDO_PN”: {
“SI_PARAM_RX_OUTPUT_PRE” : {
“lane0” : “5”,
“lane1” : “5”,
“lane2” : “5”,
“lane3” : “5”,
“lane4” : “5”,
“lane5” : “5”,
“lane6” : “5”,
“lane7” : “5”,
}
}
},
“INNOLIGHT”: {
“INNOLIGHT_PN”: {
“SI_PARAM_RX_OUTPUT_POST” : {
“lane0” : “8”,
“lane1” : “8”,
“lane2” : “8”,
“lane3” : “8”,
“lane4” : “8”,
“lane5” : “8”,
“lane6” : “8”,
“lane7” : “8”,
}
}
}
}
},
“25,28,30”: {
“100G_SPEED”: {
“Default”: {
“SI_PARAM_RX_INPUT_AMP” : {
“lane0” : “7”,
“lane1” : “7”,
“lane2” : “7”,
“lane3” : “7”,
“lane4” : “7”,
“lane5” : “7”,
“lane6” : “7”,
“lane7” : “7”
}
}
}
}
},
“PORT_MEDIA_SETTINGS” : {
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved
“32”: {
“EOPTOLINK”: {
"Default": {
“SI_PARAM_RX_OUTPUT_PRE” : {
“lane0” : “9”,
“lane1” : “9”,
“lane2” : “9”,
“lane3” : “9”,
“lane4” : “9”,
“lane5” : “9”,
“lane6” : “9”,
“lane7” : “9”,
}
}
}
}
}
}
```

# Proposed Work-Flow
Please refer below points in line with flow diagram.

1. When CMIS-supported module insertion happens in XCVRD, the module will progress to the AP_CONFIG state (after DP_DEINIT state) in the CMIS state machine. During which, when the module is in DataPathDeactivated or Disabled state, check if the optics_si_setting.json file is parsed successfully and if lane speed needs special Signal Integrity (SI) settings.
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved

2. If both of the above conditions are met, then proceed to generate the key (module key) and retrieve the SI attribute list.
2.1. The JSON file has two directions (TX_SETTING and RX_SETTING) blocks. Each of these blocks contains sub-blocks of module vendors and other details that will help identify the best match to generate the SI attribute list, if applicable.
2.2. The EQ_FIXED flag is required to validate if the TX input EQ (equalization) setting is adaptive or fixed. TX EQ settings are adaptive by default and should be disabled to apply host-defined SI settings. Currently, fixed EQ settings are not recommended for TX input EQ settings. This kind of validation is not required to apply RX EQ settings. If EQ_FIXED is set to true only, then flow will move ahead with list generation, or else it will return an empty list for the direction (TX/RX) setting (2.10).
2.3. Generate module key based on Data Path(DP) lane speed + module vendor name, + module vendor part number.
2.4. Using this module key (2.3), the search begins for the detected port in the GLOBAL_MEDIA_SETTINGS section of the applicable direction (TX/RX) setting block. If the module key matches any entries or any search that matches for (2.5) to (2.8) sections, then SI attributes from this section are copied to the SI param attribute list (2.9).
2.5. If no match happens in 2.4, reduce the search to module default + speed of the detected port in GLOBAL_MEDIA_SETTINGS
2.6. If no match happens in 2.5, reduce the search to the speed of the detected port in GLOBAL_MEDIA_SETTINGS
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved
2.7. If no match happens in the GLOBAL_MEDIA_SETTINGS block, the search now begins in the PORT_MEDIA_SETTINGS block for the detected port. If no match happens in the PORT_MEDIA_SETTINGS block, the final search for the default block is done.
2.8. If no match happens to the default block, then an empty attribute list (2.10) is returned.

3. Get the attribute list and validate if the list is not empty, then proceed to process the SI setting param list. If the list is empty, continue with the AP_CONF (applying app code, EC = 0) and DP_INIT state in the CMIS state machine.

AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved
4. Apply the application code to the configuration with Explicit Control (EC) = 0, and commit to the activate state.
Reference Register: Upper Page 10h bytes 145 –152 (desired ApSel Code)

AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved
5. Read and cache the default or active TX/RX SI settings.
Reference Register: Upper Page 11h bytes 214 to 234

6. Update the new values from the attribute list (3) to the cached SI list (5).
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved

7. Write new EQ settings to Staged Control Set 0. EQ settings include: new SI attribute list from (6), disabling adaptive TX input EQ settings if applicable. Apply application code to config with EC = 1 and commit to the active set.
Reference Register: Upper Page 10h bytes 143 (Applying APSel Config using ApplyDPInit, Copying from Staged Control Set to Active Control Set).
Reference Register: Upper Page 10h bytes 145 –152 (desired ApSel Code).
Reference Register: Upper page 10h byte 153-173 (desired Host defined SI settings for EC=1 mode)

8. Validate the config_status code, if the status is not config success, then force CMIS to reinit and retry. If the configuration fails after 3 retry attempts, print an error message and exit from initializing this port. If config_status is successful, then continue with the DP_INIT state in the CMIS state machine.
Reference Register: Upper Page 11h Byte 202-205 (config_status register)
AnoopKamath marked this conversation as resolved.
Show resolved Hide resolved


![CMIS_HLD2 drawio-2-2-6](https://user-images.githubusercontent.com/115578705/236578644-fff87bf9-3c0b-4120-9b29-456661a365b3.png)

SI attribute generation flow:

![Untitled Diagram drawio-4](https://user-images.githubusercontent.com/115578705/236578658-fe24292d-a0b1-4f89-a588-d4fa5fe449de.png)

# Feature Enablement
This feature would be enabled per platform basis. If platform wants to use this feature, they would need to provide optics_si_setting.json file during init for XCVRD to parse it.

# No Transceiver Present
If transceiver is not present:
- All the workflows mentioned above will not invoke

# Out Of Scope
Modules that do not support CMIS and not part of CMIS state machine are not int he scope of this document.