

## 8b/10b Decoder V1.0

November 3, 2000

**Product Specification** 



## **Features**

- Drop in module for Virtex<sup>™</sup>, Virtex<sup>™</sup>-E, Virtex<sup>™</sup>-II and Spartan®-II FPGAs.
- Decoding of 10-bit symbols into 8-bit bytes and an accompanying "K" bit.
- Decoding of 268 unique transmitted characters: 256 byte values and 12 special ("K") characters
- · Fully synchronous operation
- Decoder tracks "running disparity" to verify that disparity sequence of the received symbols is valid
- Optional RUN\_DISP output tracks the running disparity of the decoder
- Optional DISP\_ERR output indicates a violation of the running disparity rules
- Optional SINIT input forces the decoder into a userdefined known state
- Optional CE input can be used to selectively enable or stall the Decoder
- Optional DISP\_IN supports chaining multiple decoders together
- Optional CODE\_ERR output indicates that the input symbol did not correspond to a valid member of the code set
- Optional SYM\_DISP output provides disparity information on the current symbol being decoded
- Optional ND (new data) output indicates DOUT has a new decoded symbol on its output
- Block RAM implementation can implement secondary ("B") decoder with almost no additional resource overhead



X9164



## Notice

This byte oriented DC balanced 8b/10b partitioned block transmission code may contain material covered by patents owned by third parties including International Business Machines Corporation. By providing this core as one possible implementation of this standard, Xilinx is making no representation that the provided implementation of this standard is free from any claims of infringement by any third party. Xilinx expressly disclaims any warranty with respect to the adequacy of the implementation, including but not limited to any warranty or representation that the implementation is free from claims of any third party. Futhermore, Xilinx is providing this core as a courtesy to you and suggests that you contact all third parties including IBM to obtain the necessary rights to use this implementation.



X9165

Figure 2: Dual Decoder Schematic Symbol

## **Functional Description**

The 8B/10B Decoder core implements the full code set proposed by A.X. Widmer and P.A. Franaszek<sup>1</sup>. The code specifies the encoding of an 8-bit byte (256 unique data words) and an additional 12 special (or "K") characters into a 10-bit symbol, hence the 8b/10b designation. A number or characteristics of the code scheme make it ideally suited for high-speed local area networks, computer links, or any serial data link. The code scheme is DC-balanced, which is of particular benefit for active gain, threshold setting and equalization of optical receivers. The code has a limited run length, no more than 5 consecutive ones or zeros, and a guaranteed transition density, which permits clock recovery from the data stream. The special (K) characters are useful as packet delimiters. A subset of them, referred to as commas, are unique in that their bit pattern never occurs in a string of data symbols and hence can be used to determine symbol boundaries at the receiving end. Additional rules embedded in the code design allow many errors to be detected at the receiving end. The combination of these features allows the receiving end of an encoded 8b/10b data stream to extract the bit rate clock, to determine symbol (and packet) boundaries, and to detect most transmission errors. This is all done with a comparatively low overhead of 25 percent (each 10-bit symbol contains 8 bits of information) versus, for example, a Manchester code with its 100 percent overhead. Because of its many features, the code has been used in the physical layer (PHY) of a number of current and emerging standards, including Fibre Channel, Gigabit Ethernet, and Rapid I/O to name a few.

#### **Disparity:**

This datasheet uses a number of terms present in the original *IBM Journal* paper. Understanding this terminology is critical to a successful application of this core. Most important is the concept of "Disparity."

The disparity of any block of data is defined as the difference between the number of ones and zeros in the block. Positive and negative refer to an excess of 1s over 0s, or 0s over 1s respectively. Each encoded symbol can be considered to be a block. The code scheme guarantees that an encoded symbol's disparity is always either 0 (five ones, five zeros), +2 (six ones four zeros) or -2 (four ones, six zeros). Some byte values will have more that one potential symbol encoding with the encoded symbol pattern determined by the "Running Disparity." Running disparity is simply a record of the disparity for the aggregate of all the previously encoded symbols. For packet-based networking applications, the running disparity is typically tracked from the start of a packet.

The Decoder tracks the running disparity of the input data stream for error checking purposes. At the end of each 10bit encoded symbol, the running disparity will be +1 or -1, which equates to a 1 or 0 respectively on the RUN\_DISP output. Each symbol's disparity is combined with the current running disparity to produce the new running disparity. Symbols with a disparity of 0 would then not modify the running disparity [+1 + (0) = +1] or [-1 + (0) = -1]. Symbols with a disparity of +2 or -2 would swap the running disparity between +1 and -1; e.g., [+1 + (-2) = -1] or [-1 + (+2) = +1].

If the symbol disparity is anything other than +2, 0, or -2, the disparity of the incoming data is invalid and a disparity error is flagged (DISP\_ERR = 1). Such an error also occurs if the running disparity is +1 and the symbol disparity is +2, or when the running disparity is -1 and the symbol disparity is -2. Most invalid input symbols will also result in a disparity violation.

Running disparity validity is also enforced at the sub-block level. Since the 10-bit block is actually composed of a 6-bit block and a 4-bit block, the same rules for running disparity apply at those sub-block boundaries. The disparity of each sub-block must be +2, 0, or -2. The running disparity at the end of the sub-block must follow the rule that running disparity must be -1 or +1. Failure to meet this criteria will also be flagged as a disparity error by the Decoder. The Decoder uses the scheme in Widmer and Franaszek's paper to decode the 10-bit input symbol into an 8-bit output value. The paper's nomenclature defines the bits of the 10-bit symbol as abcdei\_fghj, where 'a' is the LSB and 'j' is the MSB. This 10-bit encoded symbol is partitioned as a 6-bit sub-block (abcdei) and a 4-bit sub-block (fghj). In the same way, the 8-bit output value is defined as the concatenation of a 5-bit and a 3-bit sub-block (ABCDE and FGH respectively). As defined in the original paper, these 8 bits are named ABCDE\_FGH where A is the LSB, and H is the MSB.

When decoding the 10-bit input symbol, the decoder first decodes the 6 least significant bits abcdei of the input symbol into the 5 least significant bits of the output, ABCDE.

Table 1 shows an example of this decoding for the symbol designated D31.1. The five output bits ABCDE equate to 31 in decimal (EDCBA=1111) thus providing the first part of the symbol name. Similarly, the 4 most significant bits fghj of the input symbol decode into the three most significant bits of the output FGH. The three output bits FGH, represent a decimal 1, providing the second part of the symbol name (HGF=001).

Table 2 defines the decoding of the 12 special command symbols for both positive and negative dispartiy cases. These special characters are distinguished from the 256 standard characters by the KOUT output being asserted when the symbol is decoded. The DOUT value identifies which of the twelve special characters have been decoded.

| Table 1: Example decoding | of D31.1 for both r | running disparity | (RD) cases |
|---------------------------|---------------------|-------------------|------------|
|---------------------------|---------------------|-------------------|------------|

|       | RD      | RD DIN[9:0] |   |   |   |   |   |   |   | RD | DOUT[7:0] |         |   |   |   |   |   |   |   |   |
|-------|---------|-------------|---|---|---|---|---|---|---|----|-----------|---------|---|---|---|---|---|---|---|---|
|       | (prior) | 9           | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0         | (after) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|       |         | j           | h | g | f | i | е | d | С | b  | а         |         | Н | G | F | Е | D | С | В | А |
| D31.1 | +1      | 1           | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1  | 0         | -1      | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |
| D31.1 | -1      | 1           | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0  | 1         | +1      | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |

#### Table 2: DIN, KOUT, and DOUT for valid special character decoding

|       | DIN[9:0] |   |   |   |   |   |   |   | KOUT | DOUT[7:0] |   |   |   |   |   |   | <b>DOUT</b><br>Unsigned |   |   |            |
|-------|----------|---|---|---|---|---|---|---|------|-----------|---|---|---|---|---|---|-------------------------|---|---|------------|
|       | i        | h | a | f | i | е | d | С | b    | а         | K | н | G | F | Е | D | С                       | В | А | (7 as MSB) |
| K28.0 | 0        | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 0 | 0 | 0 | 1 | 1 | 1                       | 0 | 0 | 28         |
| K28.0 | 1        | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 0 | 0 | 0 | 1 | 1 | 1                       | 0 | 0 | 28         |
| K28.1 | 0        | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 0 | 0 | 1 | 1 | 1 | 1                       | 0 | 0 | 60         |
| K28.1 | 1        | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 0 | 0 | 1 | 1 | 1 | 1                       | 0 | 0 | 60         |
| K28.2 | 1        | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 0 | 1 | 0 | 1 | 1 | 1                       | 0 | 0 | 92         |
| K28.2 | 0        | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 0 | 1 | 0 | 1 | 1 | 1                       | 0 | 0 | 92         |
| K28.3 | 1        | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 0 | 1 | 1 | 1 | 1 | 1                       | 0 | 0 | 124        |
| K28.3 | 0        | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 0 | 1 | 1 | 1 | 1 | 1                       | 0 | 0 | 124        |
| K28.4 | 0        | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 1 | 0 | 0 | 1 | 1 | 1                       | 0 | 0 | 156        |
| K28.4 | 1        | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 1 | 0 | 0 | 1 | 1 | 1                       | 0 | 0 | 156        |
| K28.5 | 0        | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 1 | 0 | 1 | 1 | 1 | 1                       | 0 | 0 | 188        |
| K28.5 | 1        | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 1 | 0 | 1 | 1 | 1 | 1                       | 0 | 0 | 188        |
| K28.6 | 0        | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 1 | 1 | 0 | 1 | 1 | 1                       | 0 | 0 | 220        |
| K28.6 | 1        | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 1 | 1 | 0 | 1 | 1 | 1                       | 0 | 0 | 220        |
| K28.7 | 0        | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0    | 0         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 0 | 0 | 252        |
| K28.7 | 1        | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1    | 1         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 0 | 0 | 252        |
| K23.7 | 0        | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1    | 1         | 1 | 1 | 1 | 1 | 1 | 0 | 1                       | 1 | 1 | 247        |
| K23.7 | 1        | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0    | 0         | 1 | 1 | 1 | 1 | 1 | 0 | 1                       | 1 | 1 | 247        |
| K27.7 | 0        | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1    | 1         | 1 | 1 | 1 | 1 | 1 | 1 | 0                       | 1 | 1 | 251        |
| K27.7 | 1        | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0    | 0         | 1 | 1 | 1 | 1 | 1 | 1 | 0                       | 1 | 1 | 251        |
| K29.7 | 0        | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0    | 1         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 0 | 1 | 253        |
| K29.7 | 1        | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1    | 0         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 0 | 1 | 253        |
| K30.7 | 0        | Ō | 0 | 1 | 0 | 1 | 1 | 1 | 1    | 0         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 1 | 0 | 254        |
| K30.7 | 1        | 1 | 1 | 0 | 1 | Ō | Ō | 0 | 0    | 1         | 1 | 1 | 1 | 1 | 1 | 1 | 1                       | 1 | 0 | 254        |

## **Implementation Guidelines**

The original paper by Widmer and Franaszek defines the 10-bit encoded symbol as a serial stream of bits named abcdei\_fghj. This encoded symbol is transmitted serially from a to j. The 10-bit symbol contains sub-blocks of 6-bits and 4-bits. Expressed in this manner, the "a" bit is actually the LSB of the value, and the "j" bit is the MSB.

In the Decoder, the 10-bit DIN bus receives the encoded symbol as DIN <9:0> where DIN <9> is the MSB (the "j" bit) and DIN<0> is the LSB (the "a" bit).

The same rule applies to the DOUT decoded output byte. Represented as ABCDE\_FGH in the original paper, with A as the LSB and H as the MSB, the DOUT <7:0> bus of the decoder stores this value with DOUT <7>, the MSB (the "H" bit) and DOUT <0> the LSB (the "A" bit).

The MSB/LSB ordering has no implications for data words, but has implications when decoding special characters (See Table 2).

Transmission is always LSB-first, so that when deserializing encoded symbols, DIN[0] (a) is received over a transmission line first, and DIN[9] (j) is received last.

The Decoder is capable of decoding only 10-bit symbols into the appropriate characters. It contains no transmission protocol semantics and is not capable of directly manipulating serial data. When receiving serial transmitted data, logic external to the decoder is needed to convert the incoming a-to-j bitstream into the DIN <9:0> symbol that the Decoder input bus requires. This external logic must also be responsible for partitioning the incoming bitstream at the proper symbol boundaries so that the decoder accurately receives the complete encoded symbol (jhgf\_iedcba). Once the data is decoded, the decoder provides only the decoded byte, K value, and error flags. All error correction and data interpretation (such as interpreting a sequence of bytes as a data packet, and recognizing the K codes as proper commands/delimeters) must all be performed external to the Decoder.

If more than one decoder is used to decode multiple symbols at a time into larger words, the running disparity inputs and outputs should be chained together. The RUN\_DISP output of the first decoder drives the DISP\_IN input of the second decoder. The final decoder's RUN\_DISP output is then connected back to the DISP\_IN of the first decoder.

Note that this example also requires that the input clocks to the two decoder stages be sequenced; *e.g.*, not the same clock or at least the same active clock edge.

## Pinout

Signal names are shown in Figures 1 and 2 and described in Table 3.

Clock - CLK [CLK\_B]

The decoder is fully synchronous to its appropriate clock port (CLK; CLK\_B for the "B" decoder). All decoder input ports have their setup time referenced to the rising edge of the CLK (or CLK\_B) input. All decoder outputs are also synchronous to their respective CLK input. Clock inputs are rising edge active by default; to make the decoder(s) respond to the falling edge of a system clock, insert an inverter between the system clock and the decoder's CLK input.

CLK\_B is the clock input for the optional secondary "B" decoder.

## Clock Enable - CE [CE\_B]

CE, an optional input, can be used to stall the decoder, preventing it from responding to changes on the inputs. If the decoder has a CE port, and the CE input is inactive (logic 0), transitions on the clock port will have no effect. If CE is active (logic 1) or is not present, then the inputs will be read and outputs updated on every rising edge of the CLK.

The CE\_B pin is the Clock Enable for the "B" Decoder.

#### Data-Input Bus - DIN<9:0> [DIN\_B<9:0>]

DIN is the input bus that provides the 10-bit encoded symbol to the decoder. In the case of serial data transmission, it is important to note that DIN(0) is the least-significant bit of the 10-bit encoded symbol. DIN must be aligned on symbol boundaries (D<0>=a, D<9>=j) for the decoder to produce correct results.

DIN\_B is the Data Input bus for the "B" decoder.

#### Synchronous Initialization - SINIT [SINIT\_B]]

SINIT, an optional input, initializes the decoder to a defined state. If SINIT is active (logic 1) and CE is active, the outputs and internal state of the decoder will be set on the rising edge of the clock. In this case, DOUT will be set to a user-defined value, KERR will be set to zero, and the internal running disparity will be set to a user-defined value. It is recommended to assert SINIT at times when the decoder's state must be known, such as before receiving a packet to insure that the running disparity is initialized correctly before receiving.

SINIT\_B is the Synchronous Initialization input for the "B" decoder.

## Data-Output Bus - DOUT [DOUT\_B

DOUT is the decoded output byte. Subsequent to every rising clock edge (provided that CE is not present and inactive), DOUT will hold the decoded data byte. The decoded data byte is the decoded value of the 10-bit symbol on the DIN bus at the clock edge.

DOUT\_B is the decoded byte output for the B decoder.





# Command Symbol Output Flag - KOUT [KOUT\_B]

KOUT indicates that the decoded 10-bit symbol was the encoding of a command symbol or special character. Like DOUT, KOUT is updated after the rising clock edge to reflect the decoded value of the input symbol on the DIN bus. When KOUT is inactive (logic 0), the 10-bit symbol decoded is an encoding of an ordinary 8-bit byte (presented on DOUT). When KOUT is active (logic 1), the 10bit symbol is an encoding of one of the 12 special characters and the value on the DOUT bus indicates the identity of the special character.

KOUT\_B is the command symbol output flag for the "B" decoder.

## Disparity Input - DISP\_IN [DISP\_IN\_B]

DISP\_IN, an optional input, overrides the decoder's internal disparity. Normally, the running disparity (seen on the RUN\_DISP output) is fed back, and on the rising edge of the clock added to the symbol disparity of the current

#### Table 3: Decoder Input and Output Ports.

| I/O Pin Name                                     | Direction<br>Port Status | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK<br>[CLK_B]                                   | Input                    | <b>Clock:</b> Clock input, all Decoder inputs are sampled and all outputs are updated syn-<br>chronously on the rising edge of the CLK input.<br>CLK_B is the clock input for the optional secondary "B" Decoder.                                                                                                                                                                                      |
| CE<br>[CE_B]<br>(optional)                       | Input                    | <b>Clock Enable:</b> The optional CE input port controls whether or not the Decoder responds to a change in the CLK input. When present, the CE input must be active (high) or the Decoder will not change state in response to the CLK input. When not present, the Decoder will always change state on the rising clock edge. CE_B is the clock enable input for the optional secondary "B" Decoder. |
| SINIT<br>[SINIT_B]<br>(optional)                 | Input                    | Synchronous Initialization: When the SINIT input port is present and set active (high), the decoder is initialized on the rising edge of the clock to a defined state. DOUT is set to a user-selectable symbol. KERR is set to 0. RUN_DISP is set to a user-defined disparity.<br>SINIT_B is the Synchronous Initialization port for the "B" Decoder.                                                  |
| DIN<9:0><br>[DIN_B<9:0>]                         | Input                    | Data Input: Encoded 10-bit symbol input bus.<br>DIN_B is the Data Input bus for the "B" Decoder.                                                                                                                                                                                                                                                                                                       |
| DISP_IN<br>[DISP_IN_B]<br>(optional)             | Input                    | <b>Disparity Input:</b> If present, this port is a manual input for the running disparity to which the current symbol's disparity is added. If not present, the running disparity used is the Decoder's internal running disparity.<br>DISP_IN_B is the Disparity Input port for the "B" Decoder.                                                                                                      |
| DOUT<7:0><br>[DOUT_B<7:0>]                       | Output                   | <b>Data Output:</b> The decoded 8-bit byte resulting from decoding the input 10-bit encoded symbol.<br>DOUT_B is the Data Output bus for the "B" Decoder.                                                                                                                                                                                                                                              |
| KOUT<br>[KOUT_B]                                 | Output                   | <b>K (Command) Output:</b> If the inputted 10-bit encoded symbol was an encoding of one of the 12 command codes, KOUT will be active (high). KOUT_B is the Command Output flag for the "B" Decoder.                                                                                                                                                                                                    |
| CODE_ERR<br>[CODE_ERR_B]<br>(optional)           | Output                   | <b>Code Error:</b> If present, CODE_ERR is active (high) whenever the inputted 10-bit encoded symbol does not correspond to a valid member of the code set. CODE_ERR_B is the Code Error output flag for the "B" Decoder.                                                                                                                                                                              |
| SYM_DISP<1:0><br>[SYM_DISP_B<1:0>]<br>(optional) | Output                   | Symbol Disparity: If present, SYM_DISP designates the disparity of the most re-<br>cently decoded symbol:<br>00 - ZERO<br>01 - ERROR<br>10 - NEGATIVE<br>11 - POSITIVE<br>SYM_DISP_B is the Symbol Disparity output for the "B" Decoder.                                                                                                                                                               |
| RUN_DISP<br>[RUN_DISP_B]<br>(optional)           | Output                   | Running Disparity: If present, RUN_DISP designates the running disparity, includ-<br>ing the disparity of the data symbol that has been decoded.<br>1 = Running Disparity of +1<br>0 = Running Disparity of -1<br>RUN_DISP_B is the Running Disparity output for the "B" Decoder.                                                                                                                      |
| DISP_ERR<br>[DISP_ERR_B]<br>(optional)           | Output                   | Disparity Error: If present, DISP_ERR is active (high) whenever the most recently decoded symbol violated running disparity rules. Causes for a disparity error include invalid symbols and running disparity violations at both the symbol block and subblock levels.<br>DISP_ERR_B is the Disparity Error output flag for the "B" Decoder.                                                           |
| ND<br>[ND_B]<br>(optional)                       | Output                   | <b>New Data:</b> If present and CE is present, ND is active (high) whenever the CE pin was high on the prior clock cycle, indicating that new data resides on the output pins. ND_B is the New Data output flag for the "B" Decoder.                                                                                                                                                                   |

symbol to produce the new running disparity. When DISP\_IN is present, however, the new running disparity after the rising clock edge is defined as the symbol disparity combined with DISP\_IN (instead of the old running disparity). A logic 0 asserted on the DISP\_IN input indicates that an input disparity of -1 should be combined with the current symbol disparity, and a logic 1 asserted on the DISP\_IN input indicates an input disparity of +1 should be used.

DISP\_IN\_B is the disparity input for the "B" decoder.

#### Code Error Flag - CODE\_ERR [CODE\_ERR\_B]

CODE\_ERR, an optional output, indicates that the 10-bit symbol on the Data-In bus during the rising edge of the clock was not a valid member of the code set. Active (logic 1) represents a CODE\_ERR, and inactive (logic 0) indicates that the 10-bit code was a valid member of the code set (although other errors may still exist).

CODE\_ERR\_B is the code error flag for the B decoder.

#### Symbol Disparity - SYM\_DISP <1:0> [SYM\_DISP\_B <1:0>]

SYM\_DISP, an optional output, represents the disparity of the 10-bit symbol currently being decoded. It has four possible values:

00 = Symbol has disparity of 0 (equal number of 0's and 1's in the symbol (5 zeros, 5 ones) )

10 = Symbol has disparity of -2 (two more 0's in the symbol than 1's (6 zeros, 4 ones))

11 = Symbol has disparity of +2 (two more 1's in the symbol than 0's (4 zeros, 6 ones))

01 = Disparity Error (the 10-bit symbol has an invalid ratio of 0's to 1's *or* the 6-bit or 4-bit sub-blocks of the symbol have invalid disparities)

The symbol disparity is combined with the current running disparity (+1 or -1) to generate the new running disparity for the decoder.

Most applications will not require symbol dispartiy, which is mostly useful as a debugging aid. To detect transmission faults, these implementations will monitor DISP\_ERR.

SYM\_DISP\_B is the symbol disparity for the B decoder.

#### Running Disparity - RUN\_DISP [RUN\_DISP\_B]

RUN\_DISP, an optional output, exposes the current running disparity in the decoder to external logic. Running Disparity, by definition, must be +1 or -1. The RUN\_DISP output uses a logic 1 to represent a running disparity of +1, and a logic 0 to represent a running disparity of -1.

The running disparity, on each rising edge of the clock, is combined with the Symbol Disparity of the symbol being

decoded to produce the new running disparity after the clock edge.

When the DISP\_IN port is present, the running disparity will be based on the current 10-bit symbol and the DISP\_IN pin. When the DISP\_IN port is not present, the running disparity is based on the the current 10-bit symbol and the decoder's internal running disparity.

The initial state of the RUN\_DISP output is fixed to 0 (negative) for Virtex and is user configurable via the core's GUI for Virtex-II.

RUN\_DISP\_B is the running disparity of the B decoder.

#### Disparity Error Flag - DISP\_ERR [DISP\_ERR\_B]

DISP\_ERR, an optional output, indicates the presence of an error in the running disparity of the decoder. A disparity error (represented by a logic 1) can be caused by many things:

- If the symbol disparity of the 10-bit symbol currently being decoded does not abide by the rules for running disparity, it will produce a disparity error. It may be a valid 10-bit encoded symbol, but it must be used in the correct context of running disparity. In particular, if the current running disparity is +1, the symbol disparity must be 0 or -2. Or, if the current running disparity is -1, the symbol disparity must be 0 or +2. In general, the running disparity must always remain -1 or +1.
- The same rules for running disparity apply to the 6-bit and 4-bit symbol sub-blocks. Violating running disparity rules at this level, too, will generate a disparity error.
- A disparity error will also occur for a majority of inputs that are not a member of the valid code set. These additional cases can also be detected because the CODE\_ERR output will be set.

DISP\_ERR\_B is the Disparity Error output flag for the "B" Decoder.

## New Data Output - ND [ND\_B]

ND, an optional output, indicates that all decoder outputs have been updated on the most recent rising clock edge. This indicates to downstream logic that all outputs (DOUT, KOUT, all error flags, etc.) have been updated with the results of the newly decoded symbol at the last rising edge of the clock. The ND output is a delayed version of CE, taking on the value of CE at the rising edge of the clock on each clock cycle. If the CE input port is not present, ND is not available. ND is set to logic 0 on the clock cycle following an SINIT input of a logic 1.

ND\_B is the New Data output flag for the "B" Decoder.

| Decode 8b/10b                                           | Decode 8b/10b         Component Name         ✓ Secondary Decoder         Optional Pins         ✓ Running Disparity In         ✓ Running Disparity Violation Out         ✓ Clock Enable         ✓ Code Violation Out         ✓ Disparity Violation Out         ✓ Symbol Disparity Out         ✓ Symbol Disparity Out |
|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CE_B CODE_ERR_B<br>CLK_B DISP_ERR_B<br>CLK_B DISP_ERR_B | Synchronous Reset Synchronous Reset Synchronous Reset Synchronous Reset Value Seck Next  Page 1 of 2                                                                                                                                                                                                                |
| Display Core Viewer after Generation                    |                                                                                                                                                                                                                                                                                                                     |
| Generate Cancel Data S                                  | Sheet                                                                                                                                                                                                                                                                                                               |

Figure 3: 8b/10b Decoder Main Parameterization Window

| Decode 8b/10b                                                                                                                                                                            | Decode 8b/10b                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DISP_IN KOUT<br>SINIT SYM_DISP<br>RUN_DISP<br>CE CODE_ERR<br>CLK DISP_ERR<br>ND<br>DIN_B DOUT_B<br>DISP_IN_B KOUT_B<br>SINIT_B SYM_DISP_B<br>CE_B CODE_ERR_B<br>CLK_B DISP_ERR_B<br>ND_B | B Optional Pins<br>✓ B Running Disparity In ✓ B Running Disparity Out ✓ B Clock Enable<br>✓ B Code Violation Out ✓ B Disparity Violation Out ✓ B New Data<br>✓ B Symbol Disparity Out<br>B Synchronous Reset<br>✓ B Synchronous Reset<br>✓ B Synchronous Reset<br>✓ B Synchronous Reset<br>✓ B Synchronous Reset D.0.0 (Pos) ▼ B Synchronous Reset Value<br><a href="mailto:seat">Synchronous Reset Value</a> |
| Display Core Viewer after Generation     Generate     Cancel     Data                                                                                                                    | Sheet                                                                                                                                                                                                                                                                                                                                                                                                         |

Figure 4: Secondary Decoder Parameterization Window

#### Table 4: XCO File Parameters and the Default Settings.

| Parameter                 | XCO File Values                                                                                                                                                                          | Default GUI Setting              |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| component_name            | ASCII text starting with a letter and based upon the following character set: a-z, 0-9, and _                                                                                            | blank                            |
| code_violation_out        | One of the following keywords: true, false                                                                                                                                               | true                             |
| b_code_violation_out      | One of the following keywords: true, false                                                                                                                                               | false                            |
| new_data                  | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_new_data                | One of the following keywords: true, false                                                                                                                                               | false                            |
| synchronous_reset         | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_synchronous_reset       | One of the following keywords: true, false                                                                                                                                               | false                            |
| synchronous_reset_value   | Virtex: D0.0<br>Virtex-II: D10.2, D21.5 with positive or negative disparity, or K21.5<br>with positive or negative disparity.<br>(Note: DOUT will be set to the synchronous reset value) | Virtex: D0.0<br>Virtex-II: D10.2 |
| clock_enable              | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_clock_enable            | One of the following keywords: true, false                                                                                                                                               | false                            |
| running_disparity_in      | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_running_disparity_in    | One of the following keywords: true, false                                                                                                                                               | false                            |
| running_disparity_out     | One of the following keywords: true, false                                                                                                                                               | true                             |
| b_running_disparity_out   | One of the following keywords: true, false                                                                                                                                               | false                            |
| symbol_disparity_out      | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_symbol_disparity_out    | One of the following keywords: true, false                                                                                                                                               | false                            |
| disparity_violation_out   | One of the following keywords: true, false                                                                                                                                               | false                            |
| b_disparity_violation_out | One of the following keywords: true, false                                                                                                                                               | false                            |
| secondary_decoder         | One of the following keywords: true, false                                                                                                                                               | false                            |

#### **CORE Generator Parameters**

The main Core Generator parameterization screen for this module is shown in Figure 4 and 5.

The XCO file parameters, values, and GUI defaults are shown below in Table 4. Names of XCO file parameters and their parameter values are identical to the names and values shown in the GUI, except that underscore characters (\_) are used instead of spaces. The text in an XCO file is case insensitive.

# Core Resource Utilization & Performance

The BlockRAM-based encoder requires three (4K-bit) Virtex BlockRAMs plus a single additional slice, as well as no more than 4 CLB's for the Running Disparity and New Data logic. If a Virtex-II device is targeted, only one (16K-bit) BlockRAM is required, plus the same additional slice and extra logic.

For either architecture, a second decoder can be generated using the same BlockRAM resource, configured in a dual-port mode. The only additional logic needed to implement the second Decoder is a second additional slice and no more than 4 more CLBs for the second set of Running Disparity and New Data logic. The core performance is gated entirely by the clock to out and setup times of the targeted device. The worst-case performance for all Virtex families will be 100MHz.

## **Ordering Information**

This core can be downloaded, free of cost, from the Xilinx IP Center (http://www.xilinx.com/ipcenter) for use with the Xilinx CORE Generator<sup>™</sup> System V3.1i and later. The CORE Generator System tool is bundled with all Xilinx Alliance and Foundation Series Software packages.

To order online, visit the Xilinx Silicon Expresso Cafe at http://toolbox.xilinx.com/cgi-bin/xilinx.storefront/ 241669816/catalog//1006).

Xilinx software can also be ordered through your local Xilinx sales office. Information on the sales office nearest you is available at http://www.xilinx.com/company/sales.htm.

<sup>1</sup> A.X. Widmer and P.A. Franaszek A DC-BALANCED, PARTI-TIONED-BLOCK, 8B/10B TRANSMISSION CODE, IBM Journal of Research and Development, Vol. 27, Number 5, September 1983.