Main Content

DDR5 SDRAM Transmitter/Receiver IBIS-AMI Model

This example shows how to create generic DDR5 transmitter and receiver IBIS-AMI models using the library blocks in SerDes Toolbox™ and have been Verified by Intel®. Since DDR5 DQ signals are bidirectional, this example creates Tx and Rx models for the SDRAM. The generated models conform to the IBIS-AMI specification.

DDR5 SDRAM Tx/Rx IBIS-AMI Model Setup in SerDes Designer App

The first part of this example sets up and explores the target transmitter and receiver architectures using the blocks required for DDR5 in the SerDes Designer app. The SerDes system is then exported to Simulink® for further customization and IBIS-AMI model generation.

Type the following command in the MATLAB® command window to open the ddr5_sdram model:

>> serdesDesigner('ddr5_sdram')

The SDRAM has a DDR5 transmitter (Tx) using no equalization. The SDRAM also has a DDR5 receiver (Rx) using a variable gain amplifier (VGA) with 7 pre-defined settings and a 4-tap decision feedback equalizer (DFE) with built-in clock data recovery.

Configuration Setup

  • Symbol Time is set to 208.3 ps, since the target operating rate is 4.8Gbps for DDR5-4800.

  • Target BER is set to 100e-18.

  • Signaling is set to Single-ended.

  • Samples per Symbol and Modulation are kept at default values, which are 16 and NRZ (nonreturn to zero), respectively.

Transmitter Model Setup

  • The DDR5 SDRAM has no transmit equalization, so only an analog model is required.

  • The Tx AnalogOut model is set up so that Voltage is 1.1 V, Rise time is 100 ps, R (output resistance) is 48 ohms, and C (capacitance) is 0.65 pF. The actual analog models used in the final model will be generated later in this example.

Channel Model Setup

  • Channel loss is set to 5 dB, which is typical of DDR channels.

  • Single-ended impedance is set to 40 ohms.

  • Target Frequency is set to 2.4 GHz, which is the Nyquist frequency for 4.8 GHz

Receiver Model Setup

  • The Rx AnalogIn model is set up so that R (input resistance) is 40 ohms and C (capacitance) is 0.65pF. The actual analog models used in the final model will be generated later in this example.

  • The VGA block is set up with a Gain of 1 and the Mode set to off. Specific VGA presets will be added later in this example after the model is exported to Simulink.

  • The DFECDR block is set up for four DFE taps by including four Initial tap weights set to 0. The Minimum tap value is set to [-0.2 -0.075 -0.06 -0.045] V, and the Maximum tap value is set to [0.05 0.075 0.06 0.045] V. The PhaseDetector is set to BangBang.

  • Note: the DFECDR offers an option for "2X Taps." Check this option to have pulse response values match convention used by JEDEC. Uncheck this option to use pulse response values directly from the plot. If unsure, leave this option checked for consistency with the JEDEC specification.

  • dfecdr_block_params.png

Plot Statistical Results

Use the SerDes Designer Add Plots button to visualize the results of the DDR5 SDRAM setup.

  • Add the BER plot from Add Plots and observe the results.

designer_ber.png

  • Add the Pulse Response plot from Add Plots and zoom into the pulse area to observe the results.

designer_pulse.png

Export SerDes System to Simulink

Click Save and then click on the Export button to export the configuration to Simulink for further customization and generation of the AMI model executables.

DDR5 SDRAM Tx/Rx IBIS-AMI Model Setup in Simulink

The second part of this example takes the SerDes system exported by the SerDes Designer app and customizes it as required for DDR5 in Simulink.

Review the Simulink Model Setup

The SerDes System imported into Simulink consists of Configuration, Stimulus, Tx, Analog Channel and Rx blocks. All the settings from the SerDes Designer app have been transferred to the Simulink model. Save the model and review each block setup.

  • Double-click the Configuration block to open the Block Parameters dialog box. The parameter values for Symbol time, Samples per symbol, Target BER, Modulation and Signaling are carried over from the SerDes Designer app.

  • Double-click the Stimulus block to open the Block Parameters dialog box. You can set the waveform creation method and the number of symbols to simulate. This block is not carried over from the SerDes Designer app.

  • Double-click the Tx block to look inside the Tx subsystem. Since there is no algorithmic model for the transmitter, the Tx subsystem is simply a pass through from the WaveIn to WaveOut ports.

  • Double-click the Analog Channel block to open the Block Parameters dialog box. The parameter values for Target frequency, Loss, Impedance and Tx/Rx Analog Model parameters are carried over from the SerDes Designer app.

  • Double-click on the Rx block to look inside the Rx subsystem. The subsystem has the VGA and DFECDR blocks carried over from the SerDes Designer app. An Init block is also introduced to model the statistical portion of the AMI model.

Run the Model

Run the model to simulate the SerDes system.

Two plots are generated. The first is a live time domain (GetWave) eye diagram that is updated as the model is running.

td_eye_diagram.png

After the simulation has completed the second plot contains views of the Statistical (Init) and Time Domain (GetWave) results, along with reported Eye metrics for each.

init_and_td_results.png

Review Rx VGA Block

  • Inside the Rx subsystem, double-click the VGA block to open the VGA Block Parameters dialog box.

  • The Mode and Gain settings are carried over from the SerDes Designer app.

Update Rx DFECDR Block

  • Inside the Rx subsystem, double-click the DFECDR block to open the DFECDR Block Parameters dialog box.

  • The Initial tap weights, Minimum DFE tap value, and Maximum tap value RMS settings are carried over from the SerDes Designer app. The Adaptive gain and Adaptive step size are set to 3e-06 and 1e-06, respectively, which are reasonable values based on DDR5 SDRAM expectations.

  • Expand the IBIS-AMI parameters to show the list of parameters to be included in the IBIS-AMI model.

  • Deselect Phase offset and Reference offset to remove these parameters from the AMI file, effectively hard-coding these parameters to their current values.

Generate DDR5 SDRAM IBIS-AMI Models

The final part of this example takes the customized Simulink model, modifies the AMI parameters for a DDR5 SDRAM, and then generates IBIS-AMI compliant DDR5 SDRAM model executables, IBIS and AMI files.

Open the Block Parameter dialog box for the Configuration block and click on the Open SerDes IBIS-AMI Manager button. In the IBIS tab inside the SerDes IBIS-AMI manager dialog box, the analog model values are converted to standard IBIS parameters that can be used by any industry-standard simulator.

Review Transmitter (Tx) AMI Parameters

Open the AMI-Tx tab in the SerDes IBIS-AMI manager dialog box. Notice that there are no model-specific parameters since the DDR5 SDRAM Tx does not have any equalization.

Add Tx Jitter Parameters

To add Jitter parameters for the Tx model click the Reserved Parameters... button to bring up the Tx Add/Remove dialog, then select the Tx_Dj and Tx_Rj boxes and click OK to add these parameters to the Reserved Parameters section of the Tx AMI file. The following values allow you to fine-tune the jitter values to meet DDR5 jitter mask requirements.

Note: All JEDEC DDR5 SDRAM values are currently available for DDR5-4800.

Set Tx Deterministic Jitter Value

  • Select Tx_Dj, then click the Edit... button to bring up the Add/Edit AMI Parameter dialog.

  • Verify the Type is set to UI.

  • Verify the Format is set to Value.

  • Set the Current Value to 0.1000

  • Click OK to save the changes.

Set Tx Random Jitter Value

  • Select Tx_Rj, then click the Edit... button to bring up the Add/Edit AMI Parameter dialog.

  • Verify the Type is set to UI.

  • Verify the Format is set to Value.

  • Set the Current Value to 0.0050

  • Click OK to save the changes.

Update Receiver (Rx) AMI Parameters

Open the AMI-Rx tab in the SerDes IBIS-AMI manager dialog box. The reserved parameters are listed first followed by the model-specific parameters adhering to the format of a typical AMI file.

Set the VGA Gain:

  • Highlight Gain.

  • Click the Edit… button to launch the Add/Edit AMI Parameter dialog box.

  • In the Description box, type Rx Amplifier Gain.

  • Make sure Format is set to List, then set Default to 1.

  • In the List values box, enter [0.5 0.631 0.794 1 1.259 1.585 2]

  • In the List_Tip values box, enter ["-6 dB" "-4 dB" "-2 dB" "0 dB" "2 dB" "4 dB" "6 dB"]

  • Click OK to save the changes.

Set First DFE Tap Weight

  • Highlight TapWeight 1.

  • Click the Edit… button to launch the Add/Edit AMI Parameter dialog box.

  • Make sure Format is set to Range and set Typ = 0, Min = -0.2, and Max = 0.05.

  • Click OK.

Set Second DFE Tap Weight

  • Highlight TapWeight 2.

  • Click the Edit… button to launch the Add/Edit AMI Parameter dialog box.

  • Make sure Format is set to Range and set Typ = 0, Min = -0.075, and Max = 0.075

  • Click OK.

Set Third DFE Tap Weight

  • Highlight TapWeight 3.

  • Click the Edit… button to launch the Add/Edit AMI Parameter dialog box.

  • Make sure Format is set to Range and set Typ = 0, Min = -0.06, and Max = 0.06

  • Click OK.

Set Fourth DFE Tap Weight

  • Highlight TapWeight 4.

  • Click the Edit… button to launch the Add/Edit AMI Parameter dialog box.

  • Make sure Format is set to Range and set Typ = 0, Min = -0.045, and Max = 0.045

  • Click OK.

Add Rx Jitter Parameters

To add Jitter parameters for the Rx model click the Reserved Parameters... button to bring up the Rx Add/Remove dialog, then select the Rx_Rj, Rx_Dj and Rx_Receiver_Sensitivity boxes and click OK to add these parameters to the Reserved Parameters section of the Rx AMI file. The following values allow you to fine-tune the jitter values to meet DDR5 jitter mask requirements.

Note: All JEDEC DDR5 SDRAM values are currently available for DDR5-4800.

Set Rx Random Jitter Value

  • Select Rx_Rj, then click the Edit... button to bring up the Add/Edit AMI Parameter dialog.

  • Verify the Type is set to UI.

  • Verify the Format is set to Value.

  • Set the Current Value to 0.00375

  • Click OK to save the changes.

Set Rx Deterministic Jitter Value

  • Select Rx_Dj, then click the Edit... button to bring up the Add/Edit AMI Parameter dialog.

  • Verify the Type is set to UI.

  • Verify the Format is set to Value.

  • Set the Current Value to 0.01750

  • Click OK to save the changes.

Set Rx Receiver Sensitivity Value

  • Select Rx_Receiver_Sensitivity, then click the Edit... button to bring up the Add/Edit AMI Parameter dialog.

  • Verify the Format is set to Value.

  • Set the Current Value to 0.040

  • Click OK to save the changes.

Export Models

Open the Export tab in the SerDes IBIS-AMI manager dialog box.

  • Update the Tx model name to ddr5_sdram_tx.

  • Update the Rx model name to ddr5_sdram_rx.

  • Note that Tx and Rx corner percentage is set to 10. This scales the minimum/maximum analog model corner values by +/-10%.

  • Verify that Dual model is selected for both the Tx and the Rx AMI model settings. This creates model executables that support both statistical (Init) analysis and time-domain (GetWave) simulation.

  • Set the Rx model Bits to ignore value to 250000 to allow sufficient time for the Rx DFE taps to settle during time domain simulations.

  • Set the Models to export to Both Tx and Rx and ensure that all files have been selected to be generated (IBIS file, AMI file(s) and DLL file(s)). Note that while the Tx does not implement any equalization, we are still generating a pass-through model that will allow Tx jitter to be added to the simulation if desired.

  • Set the IBIS file name to temp_ddr5_sdram.ibs

  • Click the Export button to generate models in the Target directory.

Note: If additional Simulink simulations are run, the Rx Bits to Ignore value will need to be set a value less than the Number of symbols set in the Stimulus block dialog in order for the time domain results to be output.

Update DDR5 Analog Models

To accommodate different topologies, loading configurations, data rates and transfers, DDR5 requires variable output drive strength and input on-die termination (ODT). While the same algorithmic AMI model is used, multiple analog models are required to cover all these use cases. The generation of these analog models is out of scope for this example, so a completed IBS file with the following analog models in it is available in the current example directory:

  • POD11_IO_ZO34_ODTOFF: 34 ohm output impedance with no input ODT.

  • POD11_IO_ZO48_ODTOFF: 48 ohm output impedance with no input ODT.

  • POD11_IN_ODT34_C: Input with 34 ohm ODT.

  • POD11_IN_ODT40_C: Input with 40 ohm ODT.

  • POD11_IN_ODT48_C: Input with 48 ohm ODT.

  • POD11_IN_ODT60_C: Input with 60 ohm ODT.

  • POD11_IN_ODT80_C: Input with 80 ohm ODT.

  • POD11_IN_ODT120_C: Input with 120 ohm ODT.

  • POD11_IN_ODT240_C: Input with 240 ohm ODT.

To generate this complete IBIS file, the following changes were made to temp_ddr5_sdram.ibs using a text editor:

  • Created one pin with a signal_name of DQ1_sdram and model_name of dq.

  • Added two drivers with Model_type of I/O and named them POD11_IO_Z034_ODTOFF and POD11_IO_Z048_ODTOFF, respectively.

  • Added seven receiver models and named them:

a) POD11_IN_ODT34_C

b) POD11_IN_ODT40_C

c) POD11_IN_ODT48_C

d) POD11_IN_ODT60_C

e) POD11_IN_ODT80_C

f) POD11_IN_ODT120_C

g) POD11_IN_ODT240_C

  • Added VI curves and Algorithmic Model sections to all above mentioned models.

  • Added a Model Selector section that references all above mentioned models.

Test Generated IBIS-AMI Models

The DDR5 transmitter and receiver IBIS-AMI models are now complete and ready to be tested in any industry-standard AMI model simulator.

References

[1] IBIS 7.0 Specification, https://ibis.org/ver7.0/ver7_0.pdf.

See Also

| |

Related Topics

Go to top of page