

# Analyzing 8b/10b Encoded Signals with a Real-time Oscilloscope

Real-time triggering up to 6.25 Gb/s on 8b/10b encoded data streams

Application Note



Modern standards are moving away from parallel data links to serial data links. Although a serial link needs a much higher data rate compared to a parallel link to achieve the same throughput, designers prefer serial links because of less complexity, lower costs, and the possibility of higher data rates. Parallel busses need a compensation of the delay between each data line and their clock signals. Serial busses have a differential data pair for each direction, their clocks are embedded in the data signal and will be recovered in the receiver. However, the higher frequencies used in high speed serial (HSS) data streams require more focus on signal integrity issues. In addition, debugging of HSS signals is more challenging.

Most HSS signals are already in the range of Gigabits and require very high bandwidth in the physical layer for their links. One way to verify the performance of serial links is compliance testing. Usually compliance tests are used for characterization at a final state of the design. If the compliance test "passes" everything is fine. If not, debugging of the physical layer might become necessary.

A first step of investigation could be to look for measurements that are out of range related to the appropriate standard's specifications. The results can enable an experienced engineer to perform further measurements and actions to solve the problem.

If this does not solve the problem, the engineer can look at a composite of all data values and transitions on the bus using an eye diagram. The eye diagram can show issues related to noise, jitter, and signal integrity. It can also be used to check for violations of an eye diagram mask which are specified

#### Jitter and Eye Diagram Analysis Tools : Measurement Report

| Configuration                        |
|--------------------------------------|
|                                      |
| <ul> <li>Setup Configurat</li> </ul> |

| Setup Configuration  |                |
|----------------------|----------------|
| Oscilloscope Version | 5.1.0 Build 34 |
| DPO.IET Version      | 250 Build 7    |

| ersion | 2.5.0 Build 7 |  |
|--------|---------------|--|
|        | Deen          |  |

Status Measurement Results

| Description               | Mean      | Std Dev  | Max      | Min       | p-p      | Population | Max-cc   | Min-cc    |
|---------------------------|-----------|----------|----------|-----------|----------|------------|----------|-----------|
| PCIe UI1, Math1           | 400.01ps  | 0.0000s  | 400.01ps | 400.01ps  | 0.0000s  | 1          | 0.0000s  | 0.0000s   |
| Current Acquisition       | 400.01ps  | 0.0000s  | 400.01ps | 400.01ps  | 0.0000s  | 1          | 0.0000s  | 0.0000s   |
| Height1, Math1            | 519.50mV  | V0000.0  | 519.50mV | 519.50mV  | V0000.0  | 1          | V0000 0  | V0000.0   |
| Current Acquisition       | 519.50mV  | V0000.0  | 519.50mV | 519.50mV  | 0.0000V  | 1          | V0000.0  | 0.0000V   |
| PCIe Med-Mx Jitter, Math1 | -398.69fs | 3.6641ps | 14.687ps | -15.754ps | 30.441ps | 247434     | 21 088ps | -19.067ps |
| Current Acquisition       | -398.69fs | 3.6641ps | 14.687ps | -15.754ps | 30.441ps | 247434     | 21.088ps | -19.067ps |
| Mask Hits1, Math1         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     |          |           |
| Hits In Segment 1         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     |          |           |
| Hits In Segment 2         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     |          |           |
| Hits In Segment 3         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     |          |           |
| Mask Hits2, Math1         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     | 1        |           |
| Hits In Segment 1         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     | 1        |           |
| Hits In Segment 2         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     | U        |           |
| Hits In Segment 3         | 0.0000    |          | 0.0000   | 0.0000    |          | 499983     | 1        |           |
| TIE1, Math1               | 223.31fs  | 3.6641ps | 15.309ps | -15 132ps | 30.441ps | 247434     | 21.088ps | -19.067ps |
| Current Acquisition       | 223.31fs  | 3.6641ps | 15.309ps | -15.132ps | 30.441ps | 247434     | 21.088ps | -19.067ps |
| Height2, Math1            | 521.76mV  | V00000   | 521.76mV | 521.76mV  | V0000.0  | 1          | 0.0000V  | 0.0000V   |
| Current Acquisition       | 521.76mV  | 0.0000V  | 521.76mV | 521.76mV  | V0000.0  | 1          | 0.0000V  | 0.0000V   |
| Width1, Math1             | 369.57ps  | 0.0000s  | 369.57ps | 369.57ps  | 0.0000s  | 1          | 0.0000s  | 0.0000s   |
| Current Acquisition       | 369.57ps  | 0.0000s  | 369.57ps | 369.57ps  | 0.0000s  | 1          | 0.0000s  | 0.0000s   |
| PCIe VTx-Diff-PP, Math1   | 587.79mV  | 5.2247mV | 616.80mV | 559 20mV  | 57.600mV | 252491     | 31.200mV | -28.800mV |
| Current Acquisition       | 587.79mV  | 5 2247mV | 616.80mV | 559.20mV  | 57.600mV | 252491     | 31.200mV | -28.800mV |

#### Pass/Fail Summary Limits Information

Location C:\TekApplications\DPOJET\Limits\PCIE\Rev1.1 File Name R11\_Tx\_ADD\_CON.xml

Description

Figure 1. Example report of a PCI Express compliance test results showing a "pass".

in many industry standard compliance tests. Any kind of degradation of the signal will cause less margin or more hits in the eye mask. This degradation can indicate significant problems in the physical layer (PHY) design. Example signal integrity issues that can lead to mask test failures are: slow signal rise time (bandwidth), small signal amplitude (attenuation), large overshoot (inductance), or large jitter and noise components (cross talk, intersymbol interference (ISI), etc).



Figure 2. Eye diagram mask testing for transition bits and non transition bits (PCI Express compliance).



Figure 3. Conversion of waveform data into protocol.

# Debugging Protocol Errors

What can you do if the physical layer (PHY) compliance test passed, but you still see errors in your protocol test? Issues with the PHY layer will often cause intermittent faults. Usually PHY verification and protocol testing are done with different test equipment and under different conditions. Why not use an oscilloscope for further investigation?

To ensure best signal fidelity and highest timing resolution, you should evaluate the link at the compliance test point with an oscilloscope and convert the acquired "analog" waveform into binary values or even characters and commands.

The Tektronix DPO/DSA/MSO70000 series oscilloscopes convert the waveform data into a binary format by recovering the clock first and comparing the voltages with a user-defined threshold and some hysteresis. A block diagram of the software's processing is shown in Figure 3, with results shown in Figure 4.

You can see a table that lists the characters and the protocol. The protocol is correlated to characters and to 0s and 1s in the analog waveform. This makes is easy to track errors in the protocol down to the physical layer.



Figure 4. Protocol view of characters, protocol and waveform.

#### **Application Note**



Figure 5. Tracking a protocol failure to a glitch in the waveform.



The displayed waveform (see Figure 5) will help you to understand why wrong 0's and 1's have been possibly misinterpreted by your receiver. Cursors and the oscilloscope's zoom window can be synchronized with the scope waveform display and can help you to find the cause of the protocol error.

## Capturing Specific Data Values

Searching for a specific character in the protocol table is a common method to locate protocol errors in the data stream. But searching is a post acquisition process and is limited to a time frame that is set by the size of the acquisition memory. The dead time between acquisitions is quite large and is caused by oscilloscope and the processing time of the software for interpreting the waveform into binary and then searching for the character. See Figure 6. Therefore the chance of capturing any infrequent and rare faults is very low. For example if you have 10 million points sampled at 50 Giga samples, your real time acquisition will stop after 200 microseconds. But it will take hundreds of milliseconds before the system can capture the next block of 10 millions points. Larger memory will even increase the problem. If you really need to find rare events, you have to trigger on those faults.

Most digital oscilloscopes provide a large portfolio of triggering capabilities. Traditionally, troubleshooting is related to time and level qualified triggering. With the advanced trigger modes available on today's oscilloscopes, it is easy to trigger on glitches, transitions, runts etc. See Figure 7.

If you are looking for protocol errors, you would rather trigger on commands, characters, or bit sequences. Unfortunately a serial trigger circuit designed for NRZ patterns cannot find those faults because most high speed serial data signals are 8b/10b coded and require a dedicated hardware solution. See 8b/10b Encoding section below for details.



Figure 7. Trigger selection of an digital oscilloscope.

| A Event |              |         |        |     |              |        |                                  |                       |  |
|---------|--------------|---------|--------|-----|--------------|--------|----------------------------------|-----------------------|--|
|         | Trigger Type | Clk Src | Data 1 | Sec | Standard     |        |                                  | Trigger On<br>Pattern |  |
|         |              | in can  | Con t  |     | - Contoni    |        | JUL DAY                          | ( and ( )             |  |
|         |              |         | Codir  | ng  | Bit Rate     |        | 0005                             |                       |  |
| Mode    | Select       |         | NRZ    |     | 1.2566-5     |        | RCIKJUUU                         |                       |  |
|         | Settings     | -       |        |     | 1100 0001 01 | 01 010 | 01 0101 0101 0101 0111 0110 0011 |                       |  |
|         | Shared *     |         |        |     | Forma        |        |                                  |                       |  |

Figure 8. Standard serial pattern trigger for NRZ coding.



Figure 9. DC drifts without 8b/10b encoding.



Figure 10. 8b/10b coding maintains DC level and ensures clock recovery.

| 8b/10b Code Table |                                                                          |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------------|--|--|--|--|--|
| RD (-)            | RD (+)                                                                   |  |  |  |  |  |
| 001111 1010       | 110000 0101                                                              |  |  |  |  |  |
| 101010 1010       | 010101 0101                                                              |  |  |  |  |  |
| 110110 0011       | 001001 1100                                                              |  |  |  |  |  |
|                   | RD (-)           001111 1010           101010 1010           110110 0011 |  |  |  |  |  |

Figure 11. Examples of negative and positive disparities.

# 8b/10b Encoding

The intent of 8b/10b line coding is to achieve DC balance and provide enough state changes to ensure stable clock recovery. You can find 8b/10b coding used in standards like PCI-Express (1.x and 2.x), Serial ATA, SAS (Serial Attached SCSI), Fibre Channel, InfiniBand, FireWire (IEEE1394b), MIPI® M-PHY, HDMI, DisplayPort, CIPRI, OBSAI, XAUI, USB3.0 and others. Since DC balance is maintained, 8b/10b signals can be transmitted through transformers, optical channels or AC coupled links which have DC offsets at the pins of their integrated circuits.

AC coupled data signals would have DC drifts depending zon the data content. A long sequence of 1's will lead into positive drift and many 0's will drift toward negative voltage. Without correction it will cause errors at the receiver side since a fixed threshold is being compared to the drifting voltage level of the data signal. See Figure 9.

8b/10b line coding will compensate these effects by mapping 8 bits of data to 10 bit symbols (or characters). Each 8 bit word corresponds to two 10b characters to ensure the long term ratio between 1's and 0's is nearly 50%. See Figure 10. The difference in numbers between 1's and 0's is called "running disparity" (RD) and it is either +1 or -1. Therefore the encoding of one 8 bit data word will change depending on the preceding symbol at the speed of the data rate. See Figure 11. A standard NRZ trigger cannot trigger on words of 8b/10b coded data streams because of two reasons. First, the coding of the 8 bit word to 10b symbol will change at the speed of the data rate and would require an adjustment of the symbol rate in the trigger memory to the same speed.

Second, triggering on the right 8b/10b symbol requires synchronization or alignment of the 8b/10b codes to the data stream. For real time triggering the hardware must be capable to synchronize to one of the "comma symbols" (K.28.1, K.28.5, and K.28.7) which are unique and can not be found in the data stream at any bit position in the code. The synchronization character can be somewhere in the data stream and might be very infrequent or appear only once. One example for a synchronization character is the comma symbol, K28.5 (011110101). Once the alignment symbol has been found, the decoding of the subsequent symbol values can proceed. See Figure 12.

Software "triggering" solutions actually perform a search through the acquired data and therefore have long dead times that cause very large gaps between the acquisitions and increase the chances of missing the character you are looking for.

Tektronix MSO/DPO/DSA70000 Series oscilloscopes are equipped with a dedicated trigger chip for triggering on 8b/10b data patterns in high speed serial signals up to 6.25 Gb/s. This ensures you will find even rare events.

The 70000 Series oscilloscopes with 8b/10b serial bus triggering support several 8b/10b data values for triggering (see Figures 13 and 14).

First of all, the oscilloscope supports triggering on 8b/10b characters. Characters are acronyms for a pattern of 10 bits of the 8b/10b code, i.e. D31.6 or K28.5. A second option related to a high speed serial standard's protocol is triggering on 8b/10b words (commands), where words consist of multiple characters (commonly 4 words or 40 bits). Every standard has its own word definitions.

A very unique feature and perhaps the most powerful debugging tool is the capability to trigger on 8b/10b code errors. No serial trigger would be able to trigger on all possible character errors, disparity errors or losses of byte synchronization, but Tektronix' 8b/10b serial trigger allows you to trigger on common errors such as disparity or character errors. 

| 0011111010 | 0101010101 | 0101010101 | 0010011100 |
|------------|------------|------------|------------|
| K28.5      | D10.2      | D10.2      | D27.3      |

Figure 12. Synchronization and character alignment using K28.5.

|              | Bu        | 5           | Trigge                      | On                                 |            |       | Logic      |
|--------------|-----------|-------------|-----------------------------|------------------------------------|------------|-------|------------|
| Trigger Type | B1        |             | Pattern                     |                                    |            |       | Thresholds |
| Select       | 8us<br>88 | Type<br>108 | Edit<br>Character<br>Symbol | Characters<br>K28.5<br>Symbols RD+ | D10.2      | D10.1 | D10.1      |
|              |           |             |                             |                                    | 0101010101 |       |            |
|              |           |             | Disparity                   | Symbols RD-                        |            |       |            |
|              |           |             | Either 🔻                    |                                    |            |       |            |

Figure 13. Trigger setup for 8b/10b.

| 8b/10b Character Keypad<br>K28.5 Cisar Apply | * |
|----------------------------------------------|---|
|                                              |   |
|                                              |   |
| OK Cancel                                    |   |

Figure 14. Entering 8b/10b characters for the trigger.

| 57 |                               | Trigger - Bus |                   |                     |   |  |
|----|-------------------------------|---------------|-------------------|---------------------|---|--|
|    | A Event                       | Trigger Type  | Bus<br>B1 T       | Trigger On<br>Error | T |  |
|    | A->B Seq<br>B Event<br>Visual | Bus V         | Bus Type<br>8B10B | Character Error     |   |  |
|    | Trigger<br>Options            |               |                   |                     |   |  |
|    |                               |               |                   |                     |   |  |

Figure 15. Trigger on error capabilities for 8b/10b.



Figure 16. Time delay measurement setup.

## Using 8b/10b Serial Pattern Triggering for Measuring Delay in Network Elements

In this section, we will show how Tektronix' 8b/10b serial pattern triggering can be used for measuring the time delay of an active network element. One might think this an easy task to solve even without special triggering on 8b/10b. But we will see it can be challenging if you have to measure the time delay under real conditions.

The setup for this measurement is shown in Figure 16. The input signal of the network element is connected to Channel 1 and the output data stream is connected to channel 2 of the oscilloscope. A data generator will provide the required data stream to the input of the network element (DUT). A unique pattern inside the data stream will perform as a timing reference. This timing reference needs to be a very rare pattern to prevent confusion with another timing position. If the pattern has been defined you can search for that pattern in the acquired signal of channel 1 and channel 2 and then measure the time between the two locations.

The 8b/10b decoding and search built into the Tektronix DPO/DSA/MSO70000 series oscilloscopes could help to find the sequence in the data stream. Because of its infrequent occurrence the search for the pattern can be very difficult. As we have discussed earlier in this application note, the acquisition memory of an oscilloscope is limited and will allow you to capture a very short time window only. Therefore the chance to find the pattern for the timing reference is very low. Unlike searching, the 8b/10b triggering of the 70000 Series oscilloscopes makes it very easy to find the sequence, because the triggering ensures that the pattern will always be inside of the acquisition window.

Without 8b/10b triggering the delay measurement would require a trigger signal from the data generator to the oscilloscope. That would be the only way to synchronize the starting point of the 8b/10b timing reference at the output of the data generator with the acquisition window of the oscilloscope.

However, this method will not work if you want to test an active network component under "real world" conditions. These conditions require a different setup as shown in Figure 16.

Here we have two network elements connected together with a bidirectional link. Network element A will act as a data source and is needed to ensure that network element B (DUT) will work in a desired operating mode. The communication link has to be established by proprietary commands and the data flow of this commands needs to be maintained during the measurements to keep the DUT in the desired operation mode. Therefore a static data pattern provided by any data generator will not work.

Similar to the previous example a unique pattern is required for a timing reference (marker) in the data stream. Since the pattern is very infrequent and there is no trigger signal available from the source network element A you will need the 8b/10b trigger to find the pattern in the input and the output signal of the DUT.

Finally the best way to see and measure the delay between the input and output of the network element is to use two zoom windows. The first zoom window will be placed at the beginning of the pattern sequence at channel 1 and the second zoom window at the beginning of the pattern sequence at channel 2. For the delay measurement you have to make sure that the acquisition time window of the oscilloscope is equal or greater than the delay time. With the help of the 8b/10b serial bus search function localisation of the two timing locations is very easy. The exact delay time can now be determined with two cursors or an automated measurement of the oscilloscope.

### Summary

As more systems move from parallel bus architectures to serial buses, users need test equipment with unique serial bus features, such as triggering on and decoding of serial data. This application note focussed on 8b/10b coding which is widely used for high speed data links. Troubleshooting and verifying devices with 8b/10b serial buses can done using the Tektronix DPO/DSA/MSO70000 Series oscilloscopes with their powerful real time triggering of for 8b/10b serial buses.

ASEAN / Australasia (65) 6356 3900 Austria\* 00800 2255 4835 Balkans, Israel, South Africa and other ISE Countries +41 52 675 3777 Belgium\* 00800 2255 4835 Brazil +55 (11) 3759 7627 Canada 1 (800) 833-9200 Central East Europe and the Baltics +41 52 675 3777 Central Europe & Greece +41 52 675 3777 Denmark +45 80 88 1401 Finland +41 52 675 3777 France\* 00800 2255 4835 Germany\* 00800 2255 4835 Hong Kong 400-820-5835 India 000-800-650-1835 Italy\* 00800 2255 4835 Japan 81 (3) 6714-3010 Luxembourg +41 52 675 3777 Mexico, Central/South America & Caribbean 52 (55) 56 04 50 90 Middle East, Asia and North Africa +41 52 675 3777 The Netherlands\* 00800 2255 4835 Norway 800 16098 People's Republic of China 400-820-5835 Poland +41 52 675 3777 Portugal 80 08 12370 Republic of Korea 001-800-8255-2835 Russia & CIS +7 (495) 7484900 South Africa +27 11 206 8360 Spain\* 00800 2255 4835 Sweden\* 00800 2255 4835 Switzerland\* 00800 2255 4835 Taiwan 886 (2) 2722-9622 United Kingdom & Ireland\* 00800 2255 4835 USA 1 (800) 833-9200

> \* If the European phone number above is not accessible, please call +41 52 675 3777

> > Contact List Updated 10 February 2011

#### For Further Information

Tektronix maintains a comprehensive, constantly expanding collection of application notes, technical briefs and other resources to help engineers working on the cutting edge of technology. Please visit www.tektronix.com

Ð

Copyright © 2011, Tektronix. All rights reserved. Tektronix products are covered by U.S. and foreign patents, issued and pending. Information in this publication supersedes that in all previously published material. Specification and price change privileges reserved. TEKTRONIX and TEK are registered trademarks of Tektronix, Inc. All other trade names referenced are the service marks, trademarks or registered trademarks of their respective companies.

07/11 EA/FCA-POD

55W-26438-2



#### **Contact Tektronix:**