# **IBM Research Report**

## **DC-Balanced 6B/8B-P Transmission Code with Local Parity**

Albert X. Widmer

IBM Research Division Thomas J. Watson Research Center P.O. Box 218 Yorktown Heights, NY 10598



March 2, 2004

## DC-Balanced 6B/8B-P Transmission Code with Local Parity

### Albert X. Widmer

IBM T.J. Watson Research Center 1101 Kitchawan Rd. Route 134, Yorktown Heights, NY 10598-0218 914-945-2047, widmer@us.ibm.com

**Abstract:** A transmission code which packs six bits of data and four control vectors into an eight-bit format is presented. All 68 valid 8-bit vectors are dc-balanced with a maximum digital sum variation of 6 and a maximum run length of 6. Any single error can be instantly detected and attributed to a particular 8-bit vector. So a parity vector computed over a block of vectors can be used to correct the error. The circuit implementation requires no more than 69 standard primitive logic cells for encoding and 78 cells for the combined operations of decoding and validity checks. There are at most 5 primitive logic gates in any logical path.

### Introduction

Since the start of the digital age, it has been common practice to append a parity bit to a group of bits such as a byte so a byte afflicted with a single error could be identified and perhaps corrected by another set of parity bits. For reliable serial transmission, redundancy is often added to control the run length and bandwidth characteristics of the serial bit stream. While transmission codes usually can detect many types of errors in a string of coded vectors, they usually cannot always point to the exact error location or identify the specific faulty vector; extra redundancy is required to do so. References 2, 3, and 4 are examples of this approach. The overall coding efficiency can be raised if parity and transmission aspects are solved by a single solution as was done in reference 1 for a dcbalanced 8B/10B code. However, the encoding and decoding circuitry for reference 1 is complex and difficult to implement for very fast serial links while preserving low latency as required for computer bus applications. For new applications of transmission codes in wide computer busses, compatibility with the 8-bit byte format carries less weight. Remainders of a few bits may be allotted to spare assignments or are readily handled by compatible codes such as 1B/2B, 3B/4B, or 5B6B, or any combination thereof. In other situations, where the bus width n is a multiple of 6 and 8 such as  $n \times 24$ , it is just the number of coding circuits and perhaps transmission lanes which changes.

A new solution with the 6B/8B-P code is presented here. The code is slightly less efficient than reference 1 but for applications which require error correction, it can be more efficient

than solutions according to reference 2, 3, or 4 depending on the particular configuration. It is implemented with very simple circuits suitable for extremely high operating rates. Short circuit delays are compatible with low latency requirements. Also, the ratio of the serial transmission rate and the parallel electrical interface clocks is a preferred power of two versus a multiple of 3 or 5 for solutions based on any of the above references. The simple circuitry also helps to contain power dissipation in a critical area.

While the new code is primarily aimed at applications with statistically independent single errors, such as well designed optical links, it can also have advantages for applications with no forward error correction where the local parity feature has a subordinated role.

Additionally, the 6B/8B code provides another design point among several alternatives. As an example, an electrical bus with 72 data lines may be transmitted over nine 8B/10B coded lines. If the distance and baud rate of the electrical lines is aggressive, Decision Feedback Equalizers may be required which have a tendency to generate multiple errors. To overcome this problem, five lines are added carrying an error correction Hamming code. To transport a single 72-bit word over the 14 high speed lines requires then  $14 \times 10 =$ 140 bits. Using 6B/8B code over 12+5 = 17 high speed lines requires only 17x8 = 136bits which is surprising considering the larger overhead of 6B/8B code. The savings result from less overhead for error correction, because of the wider correction entities. The larger number of serial lines can be used to either lower the serial transmission rate to 8 times the bus rate rather than 10 times. Alternatively, the bus rate and throughput can be increased by 25% assuming in both cases an entire 72-bit word is dispatched with each bus-rate clock cycle. For comparison, similar performance can be obtained using the more complex 7B/8B code which can transmit words of 77 bits with Hamming correction on just 16 lines operating at eight times the bus rate. The well known 5B/6B code can handle 75-bit words with Hamming correction on 20 lines at a serial rate of just six times the word rate.

### General Description and Novelty of the 6B/8B-P Code

The input to the encoding apparatus consists of seven lines plus a clock. Six unrestricted lines represent 64 data vectors if the seventh line, the control line, is not asserted. If the control line is asserted together with one of four specified data vectors, a coded control vector is generated which is recognizable as other than data. So there are a total of 68 coded vectors and they are all balanced. Therefore, any single bit error or any odd number of bit errors in the coded domain will generate an invalid vector instantly recognizable as such.

For purposes of encoding and decoding, the 64 source vectors are classified into four sets:

- 1. A first set of 20 source vectors comprises all balanced 6B vectors.
- 2. A second set of 14 source vectors comprises all 6B vectors with a disparity of plus two with the exception of the vector with a trailing run of four ones.
- 3. A third set of 14 source vectors comprises all 6B vectors with a disparity of minus two with the exception of the vector with a trailing run of four zeros.

4. A fourth set of 20 source vectors comprises the 14 vectors with a disparity of four or six, the two vectors with a disparity of two and a trailing run of four, and the four control vectors.

In the encoding process, all four sets obtain a two-bit prefix as described in more detail below. Alternatively, the two bits could also be added as a suffix or at other specified positions. However, the prefix is the preferred implementation for reasons explained below. The source bits of the first three sets remain unchanged for encoding and decoding. Only the 16 data vectors of set four require changes in two or three bit positions to generate balanced coded vectors. The prefix is selected as follows:

- 1. The first set takes a two-bit prefix with complementary bit values, i.e. bit values of 10, or 01 in an alternate implementation.
- 2. The second set takes a two-bit prefix with bit values of 00.
- 3. The third set takes a two-bit prefix with bit values of 11.
- 4. The fourth set takes a two-bit prefix which is the complement of that of the first set, i.e. bit values of 01, or 10 in an alternate implementation.

### Notation

The six bits of the source vectors are identified by the capital letters A, B, C, D, E, and F. An additional control input carries the label K. The eight bits of the coded vectors are identified by the respective lower case letters a, b, c, d, e, and f; the two extra bits are identified by the letters g and h. In the circuit diagrams described below in reference to FIGS. 7A/B and 8A/B, the coded inputs and outputs 'a' through 'h' are prefixed with the capital letter C because some chip design tools do not differentiate between lower and upper case letters. All vectors are assigned a name starting with the letter D or K for data or control vectors, respectively, followed by a two position octal number for source vectors, or a three position octal number for coded vectors. The octal number represents the binary bit pattern with the low order bit on the right side (bit A or a). The high order octal position for coded vectors indicates the value of the bits g and h which identify the class to which the vector belongs.

This document assumes, that the high order bit h is transmitted first. The code is not sensitive to the order, but because the bits g and h are used to classify the coded vectors, it is conceivable that their position at the leading end of coded vectors could be used to slightly reduce the latency of the receiver or to improve the timing margin. Note that a reversal of the transmission order requires reversals in the definition of the synchronizing vector pair described below.

The signal names used in the equations of this document do not reflect any logic levels, they are to be interpreted as abstract logic statements. However, in the circuit diagrams, the signal names may be prefixed with the letter P or N to indicate whether the function is true at the upper or lower level, respectively. The P and N prefixes are normally not used for net names which start with P and N, respectively. Net numbers starting with 'n' or 'm' are true at the lower level and take the P prefix if true at the upper level. In the logic

equations, the symbols  $\bullet$ , +, and  $\oplus$  represent the Boolean AND, OR, and EXCLUSIVE OR functions, respectively. The apostrophe (') represents negation.

### **Source Vectors and Coded Vectors**

FIG. 1 is a trellis diagram of the 64 source vectors, ignoring the value of the K-input. FIG. 2 is a trellis diagram of the 68 coded vectors which include four control vectors which are other than data. The numbers in the diagrams indicate the number of vectors ending with the node to the left.

### Low Frequency Characteristics

From the trellis of FIG. 2 it is evident, that the code is dc-balanced with a maximum digital sum variation of six. The normalized dc-offset which is related to the area between the zero disparity level and the extreme contour of the trellis is 1.75. As a point of reference, the offset value for the Fibre Channel 8B/10B code of Ref. 5 is 1.9. The low frequency cut-off point for high pass filters can be located as low or below that for 8B/10B code depending on the low pass filter parameters for equal eye closure (Ref. 6).



### Synchronization Characteristics

The maximum run length is six centered across the 8B boundaries. There are no contiguous runs of six. The run of six is singular, i.e. it cannot appear with any other alignment with reference to the 8B boundaries and can serve as the comma.

To generate the comma of six zeros in the context of a control character, one of the control characters (K170) is defined with a trailing run of three zeros. This character may be followed by any of the four data characters (D027, D033, D035, D036) from the set of FIG. 5 with a leading run of three zeros. An equivalent, alternate comma of six ones is generated from another control character (K107) with a trailing run of three ones followed

by any of the four data characters (D341, D342, D344, D350) from the set of FIG. 6 with a leading run of three ones. These two vector pairs allow the signalling and checking of both the vector alignment and the start or the end of a frame.

In normal data traffic, there are also sequences of six ones or zeros with identical alignment which can also be used for alignment or alignment checks. A third possibility to gain alignment with a random sequence of coded vectors is to monitor the validity of the received coded vectors or the running disparity at 6-baud intervals and stepping the alignment until no invalid characters appear or until the running disparity value at the boundaries assumes a steady value which then can be assumed to be zero and should remain there in the absence of errors.

### 6B/8B Encoding Table

As described in the General Description above, for purposes of this design, the sixty-eight coded 8B vectors of FIG. 2 are divided into four sets as illustrated by the trellis diagrams of FIG. 3, 4, 5, and 6. The solid lines in FIG. 3, 5, and 6 represent 48 of the source vectors which remain unchanged in the encoded domain except for the two-bit dotted prefix. The trellis of FIG. 4 represents the four control vectors and the remaining 16 data vectors.



The 48 coded 8-bit vectors of FIG. 3, 5, and 6 which require no changes for encoding are listed in Table 1.

|      | FIG. 3   |      | FIG. 5   |      | FIG. 6   |
|------|----------|------|----------|------|----------|
| Name | hgfedcba | Name | hgfedcba | Name | hgfedcba |
| D207 | 10000111 | D027 | 00010111 | D303 | 11000011 |
| D213 | 10001011 | D033 | 00011011 | D305 | 11000101 |
| D215 | 10001101 | D035 | 00011101 | D306 | 11000110 |
| D216 | 10001110 | D036 | 00011110 | D311 | 11001001 |
| D223 | 10010011 | D047 | 00100111 | D312 | 11001010 |
| D225 | 10010101 | D053 | 00101011 | D314 | 11001100 |
| D226 | 10010110 | D055 | 00101101 | D321 | 11010001 |
| D231 | 10011001 | D056 | 00101110 | D322 | 11010010 |
| D232 | 10011010 | D063 | 00110011 | D324 | 11010100 |
| D234 | 10011100 | D065 | 00110101 | D330 | 11011000 |
| D243 | 10100011 | D066 | 00110110 | D341 | 11100001 |
| D245 | 10100101 | D071 | 00111001 | D342 | 11100010 |
| D246 | 10100110 | D072 | 00111010 | D344 | 11100100 |
| D251 | 10101001 | D074 | 00111100 | D350 | 11101000 |
| D252 | 10101010 |      |          |      |          |
| D254 | 10101100 |      |          |      |          |
| D261 | 10110001 |      |          |      |          |
| D262 | 10110010 |      |          |      |          |
| D264 | 10110100 |      |          |      |          |
| D270 | 10111000 |      |          |      |          |

 Table 1.
 48 Encoded Vectors with no Changes

The 20 vectors of FIG. 4 are listed in Table 2. The ten source vectors on the left side of the table have a negative disparity. The ten source vectors with positive disparity on the right side are the exact complements of those on the left side. Sixteen of these vectors require changes for encoding as follows:

- 1. The two vectors with all ones or zeros and a disparity of six are balanced by complementing three bits.
- 2. The 12 vectors with a disparity of four are encoded by complementing two bits.
- 3. The two data vectors with a disparity of two and a trailing run length of four are balanced by the complementation of a single bit.

In Table 2 and 3, the coded bits which are the complements of the respective source bits are printed in bold type and underlined. Note the symmetries for the set of 16 data vectors between the left and right side of Table 2 and between the 'abc' bits of the vectors D10, D20, and D40 and the 'def' bits of the vectors D04, D02, and D01, respectively. The bit positions complemented for encoding are identical for both vectors of a complementary pair. This feature can be exploited for simplifications in the encoding and decoding equations as described below under Alternate Implementation of Encoder and Decoder.

The complete 6B/8B coding assignments are shown in Table 3.

| Name | к | FEDCBA | Name | hgfedcba                  | Name | K F | EDCBA  | Name | hgfedcba                  |
|------|---|--------|------|---------------------------|------|-----|--------|------|---------------------------|
| D00  | 0 | 000000 | D131 | 010 <u>11</u> 00 <u>1</u> | D42  | 0 1 | 00010  | D342 | 11100010                  |
| D01  | 0 | 000001 | D161 | 01 <u>11</u> 0001         | D43  | 0 1 | 00011  | D243 | 10100011                  |
| D02  | 0 | 000010 | D162 | 01 <u>11</u> 0010         | D44  | 0 1 | 00100  | D344 | 11100100                  |
| D03  | 0 | 000011 | D303 | 11000011                  | D45  | 0 1 | 00101  | D245 | 10100101                  |
| D04  | 0 | 000100 | D145 | 01 <u>1</u> 0010 <u>1</u> | D46  | 0 1 | 00110  | D246 | 10100110                  |
| D05  | 0 | 000101 | D305 | 11000101                  | D47  | 0 1 | 00111  | D047 | 00100111                  |
| D06  | 0 | 000110 | D306 | 11000110                  | D50  | 0 1 | 01000  | D350 | 11101000                  |
| D07  | 0 | 000111 | D207 | 10000111                  | D51  | 0 1 | 01001  | D251 | 10101001                  |
| D10  | 0 | 001000 | D151 | 01 <u>1</u> 0100 <u>1</u> | D52  | 0 1 | 01010  | D252 | 10101010                  |
| D11  | 0 | 001001 | D311 | 11001001                  | D53  | 0 1 | 01011  | D053 | 00101011                  |
| D12  | 0 | 001010 | D312 | 11001010                  | D54  | 0 1 | 01100  | D254 | 10101100                  |
| D13  | 0 | 001011 | D213 | 10001011                  | D55  | 0 1 | 01101  | D055 | 00101101                  |
| D14  | 0 | 001100 | D314 | 11001100                  | D56  | 0 1 | 01110  | D056 | 00101110                  |
| D15  | 0 | 001101 | D215 | 10001101                  | D57  | 0 1 | 01111  | D154 | 011011 <u>00</u>          |
| D16  | 0 | 001110 | D216 | 10001110                  | D60  | 0 1 | 10000  | D164 | 01110 <u>1</u> 00         |
| D17  | 0 | 001111 | D113 | 01001 <u>0</u> 11         | D61  | 0 1 | 10001  | D261 | 10110001                  |
| D20  | 0 | 010000 | D123 | 010100 <u>11</u>          | D62  | 0 1 | 10010  | D262 | 10110010                  |
| D21  | 0 | 010001 | D321 | 11010001                  | D63  | 0 1 | 10011  | D063 | 00110011                  |
| D22  | 0 | 010010 | D322 | 11010010                  | D64  | 0 1 | 10100  | D264 | 10110100                  |
| D23  | 0 | 010011 | D223 | 10010011                  | D65  | 0 1 | 10101  | D065 | 00110101                  |
| D24  | 0 | 010100 | D324 | 11010100                  | D66  | 0 1 | 10110  | D066 | 00110110                  |
| D25  | 0 | 010101 | D225 | 10010101                  | D67  | 0 1 | 10111  | D126 | 01 <u>0</u> 1011 <u>0</u> |
| D26  | 0 | 010110 | D226 | 10010110                  | D70  | 0 1 | 11000  | D270 | 10111000                  |
| D27  | 0 | 010111 | D027 | 00010111                  | D71  | 0 1 | 11001  | D071 | 00111001                  |
| D30  | 0 | 011000 | D330 | 11011000                  | D72  | 0 1 | 11010  | D072 | 00111010                  |
| D31  | 0 | 011001 | D231 | 10011001                  | D73  | 0 1 | 11011  | D132 | 01 <u>0</u> 1101 <u>0</u> |
| D32  | 0 | 011010 | D232 | 10011010                  | D74  | 0 1 | 11100  | D074 | 00111100                  |
| D33  | 0 | 011011 | D033 | 00011011                  | D75  | 0 1 | 11101  | D115 | 01 <u>00</u> 1101         |
| D34  | 0 | 011100 | D234 | 10011100                  | D76  | 0 1 | 11110  | D116 | 01 <u>00</u> 1110         |
| D35  | 0 | 011101 | D035 | 00011101                  | D77  | 0 1 | 11111  | D146 | 011 <u>00</u> 11 <u>0</u> |
| D36  | 0 | 011110 | D036 | 00011110                  | K07  | 1 0 | 00111  | K107 | 01000111                  |
| D37  | 0 | 011111 | D134 | 010111 <b>00</b>          | K25  | 1 0 | 010101 | K125 | 01010101                  |
| D40  | 0 | 100000 | D143 | 011000 <u>11</u>          | K52  | 1 1 | 01010  | K152 | 01101010                  |
| D41  | 0 | 100001 | D341 | 11100001                  | K70  | 1 1 | 11000  | K170 | 01111000                  |

Table 3.6B/8B Code

| Name | K FEDCBA | Name | hgfedcba                  | Name | K FEDCBA | Name | hgfedcba                  |
|------|----------|------|---------------------------|------|----------|------|---------------------------|
| D00  | 0 000000 | D131 | 010 <u>11</u> 00 <u>1</u> | D77  | 0 111111 | D146 | 011 <u>00</u> 11 <u>0</u> |
| D01  | 0 000001 | D161 | 01 <u>11</u> 0001         | D76  | 0 111110 | D116 | 01 <u>00</u> 1110         |
| D02  | 0 000010 | D162 | 01 <u>11</u> 0010         | D75  | 0 111101 | D115 | 01 <u>00</u> 1101         |
| D04  | 0 000100 | D145 | 01 <u>1</u> 0010 <u>1</u> | D73  | 0 111011 | D132 | 01 <u>0</u> 1101 <u>0</u> |
| D10  | 0 001000 | D151 | 01 <u>1</u> 0100 <u>1</u> | D67  | 0 110111 | D126 | 01 <u>0</u> 1011 <u>0</u> |
| D20  | 0 010000 | D123 | 010100 <u>11</u>          | D57  | 0 101111 | D154 | 011011 <u>00</u>          |
| D40  | 0 100000 | D143 | 011000 <u>11</u>          | D37  | 0 011111 | D134 | 010111 <u>00</u>          |
| D60  | 0 110000 | D164 | 01110 <u>1</u> 00         | D17  | 0 001111 | D113 | 01001 <u>0</u> 11         |
| K07  | 1 000111 | K107 | 01000111                  | K70  | 1 111000 | K170 | 01111000                  |
| K25  | 1 010101 | K125 | 01010101                  | K52  | 1 101010 | K152 | 01101010                  |

 Table 2.
 20 Encoded Vectors of FIG. 4 with individual Bit Changes

### **Generation of Encoded 8B Vectors**

For the derivation of the encoding equations refer to the Tables 2 and/or 3. Generally, the encoded bits retain the value of the unencoded bit (a=A, b=B, etc), but a specific source bit is complemented (a=A', b=B', etc) if and only if (iff) the respective equation is true. In the Coding Labels and equations, some bit values are included redundantly to allow more circuit sharing for the complementation of other bits of the same vector which are also typed in bold type and underlined in the Tables 2 and 3. Redundant bit values in the Tables 4 through 18 and in the equations are overlined and the names of redundant vectors in the tables are preceded by an asterisk.

### Encoded Bit a

*The 'a' column* has bold entries for D00, D04, D10, D20, D40, D37, D57, D67, D73, and D77. The respective uncoded bits FEDCBA are listed in Table 4, the A-bit is overlined, and common patterns in the source bits are marked by bold type to logically classify the vectors by simple expressions.

| Name | K FEDCBA                  | Coding Label                   | a | Name | K FEDCBA                  | Coding Label | a |
|------|---------------------------|--------------------------------|---|------|---------------------------|--------------|---|
| D00  | x 000000                  | Ā <sup>′</sup> •B′•C′•D′•E′•F′ | 1 | D77  | x 111111                  | Ā•B•C•D•E•F  | 0 |
| D04  | x <b>00</b> 01 <b>0</b> 0 | Ā'•B'•E'•F'•C≠D                | 1 | D73  | x <b>11</b> 10 <b>1</b> 1 | Ā•B•E•F•C≠D  | 0 |
| D10  | x <b>00</b> 10 <b>0</b> 0 | Ā'•B'•E'•F'•C≠D                | 1 | D67  | x <b>11</b> 01 <b>1</b> 1 | Ā•B•E•F•C≠D  | 0 |
| D20  | x 01 <b>000</b> 0         | Ā'•B'•C'•D'•E≠F                | 1 | D57  | x 101 <b>11</b> 1         | Ā•B•C•D•E≠F  | 0 |
| D40  | x 10 <b>000</b> 0         | Ā'•B'•C'•D'•E≠F                | 1 | D37  | x 011 <b>11</b> 1         | Ā•B•C•D•E≠F  | 0 |

Table 4. a-bit Encoding

Using these identifiers, the encoding equation for bit 'a' can be written as follows:

```
a = A \bullet [\overline{A} \bullet B \bullet E \bullet F \bullet C \oplus D + \overline{A} \bullet B \bullet C \bullet D \bullet E \oplus F + \overline{A} \bullet B \bullet C \bullet D \bullet E \bullet F]' + \overline{A'} \bullet B' \bullet E' \bullet F' \bullet C \oplus D + \overline{A'} \bullet B' \bullet C' \bullet D' \bullet E \oplus F + \overline{A'} \bullet B' \bullet C' \bullet D' \bullet E' \bullet F'
```

In the circuit diagram s68encode of FIG. 7B, the following net names are used:

$$n1 = A^{\bullet}B^{\bullet}E^{\bullet}F^{\bullet}C \oplus D + A^{\bullet}B^{\bullet}C^{\bullet}D^{\bullet}E \oplus F + A^{\bullet}B^{\bullet}C^{\bullet}D^{\bullet}E^{\bullet}F^{*}$$
  

$$n2 = A^{\bullet}(n3)^{'}$$
  

$$n3 = \overline{A}^{\bullet}B^{\bullet}E^{\bullet}F^{\bullet}C \oplus D + \overline{A}^{\bullet}B^{\bullet}C^{\bullet}D^{\bullet}E \oplus F + \overline{A}^{\bullet}B^{\bullet}C^{\bullet}D^{\bullet}E^{\bullet}F$$

Encoded Bit b

*The 'b' column* has bold entries for D20, D40, D37, and D57. The respective uncoded bits FEDCBA are listed in Table 5, the B-bit is overlined, and common patterns are marked.

| Name | K FEDCBA          | Coding Label                 | b | Name | K FEDCBA          | Coding Label | b |
|------|-------------------|------------------------------|---|------|-------------------|--------------|---|
| D20  | x 01 <b>00</b> 00 | A'• <del>B</del> '•C'•D'•E≠F | 1 | D57  | x 10 <b>11</b> 11 | A∙B•C•D•E≠F  | 0 |
| D40  | x 10 <b>00</b> 00 | A'• <del>B</del> '•C'•D'•E≠F | 1 | D37  | x 01 <b>1111</b>  | A∙B∙C∙D∙E≠F  | 0 |

Using these identifiers, the encoding equation for bit 'b' can be written as follows:

 $b = B \bullet (A \bullet \overline{B} \bullet C \bullet D \bullet E \oplus F)' + A' \bullet \overline{B'} \bullet C' \bullet D' \bullet E \oplus F$ 

In the circuit diagram of FIG. 7B, the following net name is used:  $n11 = B \cdot (A \cdot \overline{B} \cdot C \cdot D \cdot E \oplus F)'$ 

Encoded Bit c

*The 'c' column* has bold entries for D60 and D17. The respective uncoded bits FEDCBA are listed in Table 6, the C-bit is overlined.

| Name | K FEDCBA | Coding Label | C | Name | K FEDCBA | Coding Label | c |
|------|----------|--------------|---|------|----------|--------------|---|
| D60  | x 110000 | A'•B'•D'•E•F | 1 | D17  | x 001111 | A•B•D•E'•F'  | 0 |

Using these identifiers, the encoding equation for bit 'c' can be written as follows:

 $c = C \bullet (A \bullet B \bullet D \bullet E' \bullet F')' + A' \bullet B' \bullet D' \bullet E \bullet F$ 

In the circuit diagram of FIG. 7B, the following net name is used:  $n21 = C \cdot (A \cdot B \cdot D \cdot E' \cdot F')'$ 

Encoded Bit d

*The 'd' column* has bold entries for D00 and D77. The respective uncoded bits FEDCBA are listed in Table 7, the D-bit is overlined.

Table 7. d-bit Encoding

| Name | K FEDCBA | Coding Label      | d | Name | K FEDCBA | Coding Label | d |
|------|----------|-------------------|---|------|----------|--------------|---|
| D00  | x 000000 | A'•B'•C'•D'•E'•F' | 1 | D77  | x 111111 | A•B•C•D•E•F  | 0 |

Using these identifiers, the encoding equation for bit 'd' can be written as follows:

 $d = D \bullet (A \bullet B \bullet C \bullet \overline{D} \bullet E \bullet F)' + A' \bullet B' \bullet C' \bullet \overline{D'} \bullet E' \bullet F'$ 

In the circuit diagram of FIG. 7B, the following net name is used:  $n31 = D \cdot (A \cdot B \cdot C \cdot \overline{D} \cdot E \cdot F)'$ 

### Encoded Bit e

*The 'e' column* has bold entries for D00, D01, D02, D75, D76, and D77. Table 8 lists the respective uncoded bits FEDCBA, the E-bit is overlined, and common patterns are marked by bold entries.

Table 8. e-bit Encoding

| Name | K FEDCBA          | Coding Label       | е | Name | K FEDCBA                  | Coding Label | е |
|------|-------------------|--------------------|---|------|---------------------------|--------------|---|
| D00  | x 0 <u>0</u> 0000 | A'∙B'∙C'∙D'∙Ē'́∙F' | 1 | D77  | x 111111                  | A•B•C•D•Ē•F  | 0 |
| D01  | x <b>0</b> 0001   | C'•D'•Ē'•F'•A≠B    | 1 | D76  | x <b>1</b> 1 <b>11</b> 10 | C•D•Ē•F•A≠B  | 0 |
| D02  | x <b>0</b> 0010   | C'•D'•Ē'•F'•A≠B    | 1 | D75  | x <b>1</b> 1 <b>11</b> 01 | C•D•Ē•F•A≠B  | 0 |

Using these identifiers, the encoding equation for bit 'e' can be written as follows:

```
e = E \bullet (C \bullet D \bullet \overline{E} \bullet F \bullet A \oplus B + A \bullet B \bullet C \bullet D \bullet \overline{E} \bullet F)' + C' \bullet D' \bullet \overline{E'} \bullet F' \bullet A \oplus B + A' \bullet B' \bullet C' \bullet D' \bullet \overline{E'} \bullet F'
```

In the circuit diagram of FIG. 7B, the following net name is used:

 $n41 = E \cdot (n42)'$ 

 $n42 = C \bullet D \bullet \overline{E} \bullet F \bullet A \oplus B + A \bullet B \bullet C \bullet D \bullet \overline{E} \bullet F$ 

### Encoded Bit f

*The 'f' column* has bold entries for *D01*, *D02*, D04, D10, D67, D73, D75, and D76. The respective uncoded bits FEDCBA are listed in Table 9. The F-bit is overlined, and common patterns are marked by bold entries.

| Name | K FEDCBA          | Coding Label                 | f | Name | K FEDCBA | Coding Label | f |
|------|-------------------|------------------------------|---|------|----------|--------------|---|
| D01  | x 0 <b>000</b> 01 | C'•D'•E'• <del>F</del> '•A≠B | 1 | D76  | x 111110 | C•D•E•F•A≠B  | 0 |
| D02  | x 000010          | C'•D'•E'•F'•A≠B              | 1 | D75  | x 111101 | C•D•E•F•A≠B  | 0 |
| D04  | x 000100          | A'•B'•E'• <del>F</del> '•C≠D | 1 | D73  | x 111011 | A•B•E•F•C≠D  | 0 |
| D10  | x 001000          | A'•B'•E'• <del>F</del> '•C≠D | 1 | D67  | x 110111 | A•B•E•F•C≠D  | 0 |

Table 9. f-bit Encoding

The encoding equation for bit 'f' can be written as follows:

$$f = F \bullet (C \bullet D \bullet E \bullet \overline{F} \bullet A \oplus B + A \bullet B \bullet E \bullet \overline{F} \bullet C \oplus D)' + C' \bullet D' \bullet E' \bullet \overline{F'} \bullet A \oplus B + A' \bullet B' \bullet E' \bullet \overline{F'} \bullet C \oplus D$$

### In the circuit diagram of FIG. 7B, the following net name is used: $n51 = F \cdot (n52)'$

$$n52 = C \bullet D \bullet E \bullet \overline{F} \bullet A \oplus B + A \bullet B \bullet E \bullet \overline{F} \bullet C \oplus D$$

### Encoded Bit g

The value for bit 'g' is one for the 34 vectors of FIG. 4 and FIG. 6. These vectors are enumerated in the right column of Table 1 and in Table 2. Note that the source vectors for all coded vectors of Table 1 are identical to the trailing 6 bits of the respective coded vector and are not listed explicitly.

The 34 source vectors for which the value for bit 'g' is one are listed again in Table 10. All 22 source vectors with four or more zeros are part of this set. For the derivation of logical encoding equations, these 22 vectors are grouped into 3 overlapping sets. The redundant vectors are marked by an asterisk. The set of 7 source vectors at the top left side of the table is characterized by three trailing zeros and at least one bit with a value of zero in the leading three bit positions which is described by the logic expression  $A' \cdot B' \cdot C' \cdot (D' + E' + F')$ . The set of 6 source vectors (not counting the redundant vector \*D00) at the top right side of the table is characterized by three trailing three bit positions which is described by the logic expression (A'+B'+C') \cdot D' \cdot E' \cdot F'. The set of nine vectors (not counting the redundant vectors) at the bottom of the left side is characterized by at least 2 zeros in the leading three positions and at least 2 zeros in the trailing three positions which is described by the logic expression (A'+B'+C') \cdot D' \cdot E' \cdot F'. The set of nine vectors (not counting the redundant vectors) at the bottom of the left side is characterized by at least 2 zeros in the leading three positions and at least 2 zeros in the trailing three positions which is described by the logic expression (A'+B'+A') \cdot D' \cdot E' \cdot E' \cdot C') \cdot (D' \cdot E' + D' \cdot F' + E' \cdot F').

The four vectors on the right side with a trailing run of four ones are identified by the logic expression  $A \cdot B \cdot C \cdot D$ . The two vectors with four leading ones are identified by the logic expression  $C \cdot D \cdot E \cdot F \cdot A \oplus B$  and the two vectors with two leading ones and two trailing ones are identified by the logic expression  $A \cdot B \cdot E \cdot F \cdot A \oplus B$  and the two vectors with two leading ones and two trailing ones are identified by the logic expression  $A \cdot B \cdot E \cdot F \cdot C \oplus D$ .

Finally, all four control vectors identified by a K-value of one have a g-value of one.

The logic equation for the encoding of the g-bit can thus be expressed as follows:

 $g = A' \bullet B' \bullet C' \bullet (D' + E' + F') + (A' + B' + C') \bullet D' \bullet E' \bullet F' + (A \bullet B \bullet C \bullet D) + C \bullet D \bullet E \bullet F \bullet A \oplus B + A \bullet B \bullet E \bullet F \bullet C \oplus D + (A' \bullet B' + A' \bullet C' + B' \bullet C') \bullet (D' \bullet E' + D' \bullet F' + E' \bullet F') + K$ 

In the circuit diagram of FIG. 7B, the following net names are used:

| 0                                     | 0                                                                                                  |
|---------------------------------------|----------------------------------------------------------------------------------------------------|
| n61 = n64 • n65                       | $n62 = n66 + A \bullet B \bullet C \bullet D + A \bullet B \bullet E \bullet F \bullet C \oplus D$ |
| n63 = n67 + n68 + K                   | n64 = A'•B'+A'•C'+B'•C'                                                                            |
| n65 = D'•E'+D'•F'+E'•F'               | n66 = C∙D∙E∙F∙A⊕B                                                                                  |
| n67 = A'•B'•C'•(D'+E'+F')             | n68 = (A'+B'+C')•D'•E'•F'                                                                          |
| · · · · · · · · · · · · · · · · · · · |                                                                                                    |

| Name | K FEDCBA                  | Coding Label                                      | g | Name | K FEDCBA                 | Coding Label        | g |
|------|---------------------------|---------------------------------------------------|---|------|--------------------------|---------------------|---|
| D00  | x 000 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | *D00 | x <b>000</b> 000         | (A'+B'+C')•D'•E'•F' | 1 |
| D10  | x 001 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D01  | x <b>000</b> 001         | (A'+B'+C')•D'•E'•F' | 1 |
| D20  | x 010 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D02  | x <b>000</b> 010         | (A'+B'+C')•D'•E'•F' | 1 |
| D30  | x 011 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D03  | x <b>000</b> 011         | (A'+B'+C')•D'•E'•F' | 1 |
| D40  | x 100 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D04  | x <b>000</b> 100         | (A'+B'+C')•D'•E'•F' | 1 |
| D50  | x 101 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D05  | x <b>000</b> 101         | (A'+B'+C')•D'•E'•F' | 1 |
| D60  | x 110 <b>000</b>          | $A' \bullet B' \bullet C' \bullet (D' + E' + F')$ | 1 | D06  | x <b>000</b> 110         | (A'+B'+C')•D'•E'•F' | 1 |
| D11  | x <b>00</b> 1001          | (A'•B'+A'•C'+B'•C')•E'•F'                         | 1 | D17  | x 00 <b>1111</b>         | A•B•C•D             | 1 |
| D12  | x <b>00</b> 1010          | (A'•B'+A'•C'+B'•C')•E'•F'                         | 1 | D37  | x 01 <b>1111</b>         | A•B•C•D             | 1 |
| D14  | x <b>00</b> 1100          | (A'•B'+A'•C'+B'•C')•E'•F'                         | 1 | D57  | x 10 <b>1111</b>         | A•B•C•D             | 1 |
| D21  | x <b>0</b> 1 <b>0</b> 001 | (A'•B'+A'•C'+B'•C')•D'•F'                         | 1 | D77  | x 11 <b>1111</b>         | A•B•C•D             | 1 |
| D22  | x <b>0</b> 1 <b>0</b> 010 | (A'•B'+A'•C'+B'•C')•D'•F'                         | 1 | D75  | x <b>1111</b> 01         | C∙D∙E∙F∙A≠B         | 1 |
| D24  | x <b>0</b> 1 <b>0</b> 100 | (A'•B'+A'•C'+B'•C')•D'•F'                         | 1 | D76  | x <b>1111</b> 10         | C∙D∙E∙F∙A≠B         | 1 |
| D41  | x 1 <b>00</b> 001         | (A'•B'+A'•C'+B'•C')•D'•E'                         | 1 | D67  | x <b>11</b> 01 <b>11</b> | A•B•E•F•C≠D         | 1 |
| D42  | x 1 <b>00</b> 010         | (A'•B'+A'•C'+B'•C')•D'•E'                         | 1 | D73  | x <b>11</b> 10 <b>11</b> | A•B•E•F•C≠D         | 1 |
| D44  | x 1 <b>00</b> 100         | (A'•B'+A'•C'+B'•C')•D'•E'                         | 1 | K07  | <b>1</b> 000111          | К                   | 1 |
| *D00 | x 000000                  |                                                   | 1 | K25  | <b>1</b> 010101          | К                   | 1 |
| *D01 | x 000001                  |                                                   | 1 | K52  | <b>1</b> 101010          | К                   | 1 |
| *D02 | x 000010                  |                                                   | 1 | K70  | <b>1</b> 111000          | К                   | 1 |
| *D04 | x 000100                  |                                                   | 1 |      |                          |                     |   |
| *D10 | x 001000                  |                                                   | 1 |      |                          |                     |   |
| *D20 | x 010000                  |                                                   | 1 |      |                          |                     |   |
| *D40 | x 100000                  |                                                   | 1 |      |                          |                     |   |

Table 10. g-bit Encoding

### Encoded Bit h

The value for bit 'h' is zero for the vectors of FIG. 4 and FIG. 5. These vectors are enumerated in the center column of Table 1 and in Table 2. Note that the source vectors for all coded vectors of Table 1 are identical to the trailing 6 bits of the respective coded vector and are not listed explicitly.

The 34 source vectors for which the value for bit 'h' is zero are listed again in Table 11. All 22 source vectors with four or more ones are part of this set. For the derivation of logical encoding equations, these 22 vectors are grouped into 3 overlapping sets. The names of redundant vectors are marked by an asterisk.

| Name | K FEDCBA                  | Coding Label      | h | Name | K FEDCBA                 | Coding Label    | h |
|------|---------------------------|-------------------|---|------|--------------------------|-----------------|---|
| D17  | x 001 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D71  | x <b>111</b> 001         | (A+B+C)•D•E•F   | 0 |
| D27  | x 010 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D72  | x <b>111</b> 010         | (A+B+C)•D•E•F   | 0 |
| D37  | x 011 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D73  | x <b>111</b> 011         | (A+B+C)•D•E•F   | 0 |
| D47  | x 100 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D74  | x <b>111</b> 100         | (A+B+C)•D•E•F   | 0 |
| D57  | x 101 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D75  | x <b>111</b> 101         | (A+B+C)•D•E•F   | 0 |
| D67  | x 110 <b>111</b>          | A•B•C•(D+E+F)     | 0 | D76  | x <b>111</b> 110         | (A+B+C)•D•E•F   | 0 |
| D77  | x 111 <b>111</b>          | A•B•C•(D+E+F)     | 0 | *D77 | x <b>111</b> 111         | (A+B+C)•D•E•F   | 0 |
| D33  | x 0 <b>11</b> 011         | (A•B+A•C+B•C)•D•E | 0 | D00  | x 00 <b>0000</b>         | A'∙B'∙C'∙D'     | 0 |
| D35  | x 0 <b>11</b> 101         | (A•B+A•C+B•C)•D•E | 0 | D20  | x 01 <b>0000</b>         | A'•B'•C'•D'     | 0 |
| D36  | x 0 <b>11</b> 110         | (A•B+A•C+B•C)•D•E | 0 | D40  | x 10 <b>0000</b>         | A'•B'•C'•D'     | 0 |
| D53  | x <b>1</b> 0 <b>1</b> 011 | (A•B+A•C+B•C)•D•F | 0 | D60  | x 11 <b>0000</b>         | A'∙B'∙C'∙D'     | 0 |
| D55  | x <b>1</b> 0 <b>1</b> 101 | (A•B+A•C+B•C)•D•F | 0 | D01  | x <b>0000</b> 01         | C'∙D'∙E'∙F'∙A≠B | 0 |
| D56  | x <b>1</b> 0 <b>1</b> 110 | (A•B+A•C+B•C)•D•F | 0 | D02  | x <b>0000</b> 10         | C'∙D'∙E'∙F'∙A≠B | 0 |
| D63  | x <b>11</b> 0011          | (A•B+A•C+B•C)•E•F | 0 | D04  | x <b>00</b> 01 <b>00</b> | A'•B'•E'•F'•C≠D | 0 |
| D65  | x <b>11</b> 0101          | (A•B+A•C+B•C)•E•F | 0 | D10  | x <b>00</b> 10 <b>00</b> | A'•B'•E'•F'•C≠D | 0 |
| D66  | x <b>11</b> 0110          | (A•B+A•C+B•C)•E•F | 0 | K07  | <b>1</b> 000111          | К               | 0 |
| *D37 | x 011111                  |                   | 0 | K25  | <b>1</b> 010101          | К               | 0 |
| *D57 | x 101111                  |                   | 0 | K52  | <b>1</b> 101010          | К               | 0 |
| *D67 | x 110111                  |                   |   | K70  | <b>1</b> 111000          | К               | 0 |
| *D73 | x 111011                  |                   |   |      |                          |                 |   |
| *D75 | x 111101                  |                   |   |      |                          |                 |   |
| *D76 | x 111110                  |                   |   |      |                          |                 |   |
| *D77 | x 111111                  |                   |   |      |                          |                 |   |

Table 11. h-bit Encoding

The set of 7 source vectors at the top of the left side is characterized by three trailing ones and at least one bit with a value of one in the leading three bit positions which is described by the logic expression  $A \cdot B \cdot C \cdot (D + E + F)$ . The set of 6 source vectors (not counting the redundant vector \*D77) at the top of the right side is characterized by three leading ones and at least one bit with a value of one in the trailing three bit positions which is described by the logic expression  $(A+B+C) \cdot D \cdot E \cdot F$ . The set of nine vectors (not counting the redundant vectors) at the bottom of the left side is characterized by at least two ones in the trailing three positions and at least two ones in the leading three positions which is described by the logic expression  $(A \cdot B + A \cdot C + B \cdot C) \cdot (D \cdot E + D \cdot F + E \cdot F)$ .

The four vectors with a trailing run of four zeros on the right side are identified by the logic expression  $A' \cdot B' \cdot C' \cdot D'$ . The two vectors with four leading zeros are identified by the logic expression  $C' \cdot D' \cdot E' \cdot F' \cdot A \neq B$ . The two vectors with two leading and two trailing zeros are identified by the logic expression  $A' \cdot B' \cdot E' \cdot F' \cdot A \neq B$ .

Finally, all four control vectors identified by a K-value of one have an h-value of zero. The logic equation for the encoding of the h-bit can thus be expressed as follows:

 $h = [A \bullet B \bullet C \bullet (D + E + F) + (A + B + C) \bullet D \bullet E \bullet F + (A \bullet B + A \bullet C + B \bullet C) \bullet (D \bullet E + D \bullet F + E \bullet F) + (A' \bullet B' \bullet C' \bullet D') + C' \bullet D' \bullet E' \bullet F' \bullet A \oplus B + A' \bullet B' \bullet E' \bullet F' \bullet C \oplus D + K]'$ 

In the circuit diagram of FIG. 7B, the following net names are used:

| n71 = n74 • n75                               | $n72 = n78 + A' \bullet B' \bullet C' \bullet D' + A' \bullet B' \bullet E' \bullet F' \bullet C \oplus D$ |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------|
| n73 = n76 + n77 + K                           | $n74 = A \bullet B + A \bullet C + B \bullet C$                                                            |
| n75 = D•E+D•F+E•F                             | $n76 = A \bullet B \bullet C \bullet (D + E + F)$                                                          |
| $n77 = (A+B+C) \bullet D \bullet E \bullet F$ | n78 = C'∙D'∙E'•F'•A⊕B                                                                                      |

#### - PA PCa -- PB NCb 0-PC NCc 🖓 PF PC NCd PCe PF PCf A Co NCd PCe PCg A Co NCd PCe PCg A Co NCd PCg S S - PD - PE ▪ PF ⊷ NA ••• NB ⊷ NC ⊷ ND ⊷NE - PK

FIG. 7A.

### Circuit Implementation of the 6B/8B-P Encoder

FIG.7A is a symbol of the encoder circuit showing the inputs and outputs.

FIG. 7B is the logic diagram of the encoder circuit. It has not yet been simulated and verified by design tools, so it may be afflicted with minor errors.

### **Alternate Implementation of Encoder**

Because of the symmetries between the left and the right side of Table 2, all the encoding equations for the bits 'a' through 'f' have

complementary features which can be exploited by the extensive use of the Exclusive OR function. The transformed coding equations for the bits 'a' thorough 'f' are presented here:

 $a = A \oplus [\overline{A} \oplus B' \bullet (B \oplus E' \bullet E \oplus F' \bullet C \oplus D + B \oplus C' \bullet C \oplus D' \bullet E \oplus F + B \oplus C' \bullet C \oplus D' \bullet D \oplus E' \bullet E \oplus F')]$ 

 $b = B \oplus (A \oplus \overline{B'} \bullet \overline{B} \oplus C' \bullet C \oplus D' \bullet E \oplus F)$ 

 $c = C \oplus (A \oplus B' \bullet B \oplus D' \bullet D \oplus E \bullet E \oplus F')$ 

 $d = D \oplus (A \oplus B' \bullet B \oplus C' \bullet C \oplus \overline{D} \bullet \overline{D} \oplus E' \bullet E \oplus F')$ 

 $e = E \oplus [(C \oplus D' \bullet D \oplus \overline{E}' \bullet \overline{E} \oplus F') \bullet (A \oplus B + A \oplus B' \bullet B \oplus C')]$ 

 $f = F \oplus [(E \oplus \overline{F'}) \bullet (C \oplus D' \bullet D \oplus E' \bullet A \oplus B + A \oplus B' \bullet B \oplus E' \bullet C \oplus D)]$ 

An implementation based on these alternate equations may be advantageous in terms of silicon area. To support a selection for a particular technology and application, the circuit delay and the total circuit capacity related to power dissipation must also be considered.



### **Generation of Decoded 6B Vectors**

For all encoded vectors 'hgfedcba' with a value  $hg \neq 01$  the decoded bits FEDCBA are equal to the encoded bits 'fedcba' and the value of the K-bit is zero. If hg=01, the decoding equations can be derived from Table 2 or 3 as shown below similar to encoding. Redundancies are introduced for the same purposes as for encoding and marked in the same way.

### Decoded Bit A

*The 'a' column* of Table 2 has bold entries for D131, D145, D151, D123, D143, D146, D132, D126, D154, and D134. The respective coded bits 'hgfedcba' are listed in Table 12, the a-bit is overlined to indicate redundancy, and common patterns are marked by bold type to logically classify the vectors by simple expressions.

| Table | 12. | A-bit | Decoding |
|-------|-----|-------|----------|
|-------|-----|-------|----------|

| Name | hgfedcba                  | Coding Label           | AK | Name | hgfedcba                  | Coding Label                | AK |
|------|---------------------------|------------------------|----|------|---------------------------|-----------------------------|----|
| D131 | 0101100 <u>1</u>          | a∙b'∙c'∙d∙e∙f'∙g∙h'    | 00 | D146 | 0110011 <u>0</u>          | <u>a'</u> ∙b∙c∙d'∙e'•f∙g∙h' | 10 |
| D145 | 01100101                  | a∙b'∙e'∙f∙g∙h'∙c≠d     | 00 | D132 | <b>0101</b> 10 <b>1</b> 0 | ā'∙b∙e∙f'•g∙h'•c≠d          | 10 |
| D151 | <b>0110</b> 10 <b>0</b> 1 | a<br>∙b'∙e'∙f∙g∙h'•c≠d | 00 | D126 | <b>0101</b> 01 <b>1</b> 0 | ā'∙b∙e∙f'∙g∙h'∙c≠d          | 10 |
| D123 | <b>01</b> 01 <b>001</b> 1 | a•b∙c'∙d'∙g∙h'∙e≠f     | 00 | D154 | <b>01</b> 10 <b>110</b> 0 | ā'•b'∙c∙d∙g∙h'∙e≠f          | 10 |
| D143 | <b>01</b> 10 <b>001</b> 1 | a•b∙c'∙d'∙g∙h'∙e≠f     | 00 | D134 | <b>01</b> 01 <b>110</b> 0 | ā'•b'•c∙d∙g∙h'•e≠f          | 10 |

Using these identifiers, the decoding equation for bit 'A' can be written as follows:

# $A = a \cdot (\overline{a} \cdot b' \cdot c' \cdot d \cdot e \cdot f' \cdot g \cdot h' + \overline{a} \cdot b' \cdot e' \cdot f \cdot g \cdot h' \cdot c \oplus d + \overline{a} \cdot b \cdot c' \cdot d' \cdot g \cdot h' \cdot e \oplus f)' + \overline{a'} \cdot b \cdot c \cdot d' \cdot e' \cdot f \cdot g \cdot h' + \overline{a'} \cdot b \cdot e \cdot f' \cdot g \cdot h' \cdot c \oplus d + \overline{a'} \cdot b' \cdot c \cdot d \cdot g \cdot h' \cdot e \oplus f$

In the circuit diagram r86decode of FIG.8B, the following net names are used:

 $\begin{array}{l} n1 = a \bullet n3' \\ n2 = a' \bullet b \bullet c \bullet d' \bullet e' \bullet f \bullet g \bullet h' + a' \bullet b \bullet e \bullet f' \bullet g \bullet h' \bullet c \oplus d + a' \bullet b' \bullet c \bullet d \bullet g \bullet h' \bullet e \oplus f \\ n3 = a \bullet b' \bullet c' \bullet d \bullet e \bullet f' \bullet g \bullet h' + a \bullet b' \bullet e' \bullet f \bullet g \bullet h' \bullet c \oplus d + a \bullet b \bullet c' \bullet d' \bullet g \bullet h' \bullet e \oplus f \end{array}$ 

### Decoded Bit B

*The 'b' column* of Table 2 has bold entries for D123, D143, D154, and D134. The respective coded bits 'hgfedcba' are listed in Table 13, the b-bit is overlined, and common patterns are marked by bold type.

| Fable | 13. | <b>B-bit</b> | Decoding |
|-------|-----|--------------|----------|
|-------|-----|--------------|----------|

| Name | hgfedcba                  | Coding Label        | BK | Name | hgfedcba                  | Coding Label                      | BK |
|------|---------------------------|---------------------|----|------|---------------------------|-----------------------------------|----|
| D123 | <b>01</b> 01 <b>00</b> 11 | a∙b∙c'∙d'•g∙h'∙e≠f  | 00 | D154 | <b>01</b> 10 <b>11</b> 00 | a'• <mark>b'</mark> •c∙d∙g•h'•e≠f | 10 |
| D143 | <b>01</b> 10 <b>00</b> 11 | a∙b̄∙c'∙d'•g∙h'∙e≠f | 00 | D134 | <b>01</b> 01 <b>11</b> 00 | a'• <mark>b'</mark> •c∙d∙g•h'•e≠f | 10 |

Using these identifiers, the decoding equation for bit 'B' can be written as follows:

### $B = b \bullet (a \bullet \overline{b} \bullet c' \bullet d' \bullet g \bullet h' \bullet e \oplus f)' + a' \bullet \overline{b'} \bullet c \bullet d \bullet g \bullet h' \bullet e \oplus f$

In the circuit diagram of FIG.8B, the following net name is used:

 $n11 = b \bullet (a \bullet b \bullet c' \bullet d' \bullet g \bullet h' \bullet e \oplus f)'$ 

### Decoded Bit C

*The 'c' column* of Table 2 has bold entries for D164 and D113. The respective coded bits 'hgfedcba' are listed in Table 14.

| Name | hgfedcba          | Coding Label      | СК | Name | hgfedcba | Coding Label     | CI |  |
|------|-------------------|-------------------|----|------|----------|------------------|----|--|
| D164 | 01110 <u>1</u> 00 | a'•b'•d'•e•f•g•h' | 00 | D113 | 01001011 | a∙b∙d∙e'•f'•g•h' | 10 |  |
|      |                   |                   |    |      |          |                  |    |  |

| Table | 14. | C-bit | Decod | ling |
|-------|-----|-------|-------|------|
|       |     |       |       |      |

Using these identifiers, the decoding equation for bit 'C' can be written as follows:  $C = c \cdot (a' \cdot b' \cdot d' \cdot e \cdot f \cdot g \cdot h')' + a \cdot b \cdot d \cdot e' \cdot f' \cdot g \cdot h'$ 

In the circuit diagram of FIG.8B, the following net name is used:  $n21 = c \cdot (a' \cdot b' \cdot d' \cdot e \cdot f \cdot g \cdot h')'$ 

Decoded Bit D

*The 'd' column* of Table 2 has bold entries for D131 and D146. The respective coded bits 'hgfedcba' are listed in Table 15.

Table 15. D-bit Decoding

| Name | hgfedcba | Coding Label         | DK | Name | hgfedcba          | Coding Label                     | DK |
|------|----------|----------------------|----|------|-------------------|----------------------------------|----|
| D131 | 01011001 | a∙b'∙c'∙d̄∙e∙f'•g∙h' | 00 | D146 | 0110 <u>0</u> 110 | a'•b•c• <del>d</del> '•e'•f•g•h' | 10 |

Using these identifiers, the decoding equation for bit 'D' can be written as follows:

 $D = d \bullet (a \bullet b' \bullet c' \bullet \overline{d} \bullet e \bullet f' \bullet g \bullet h')' + a' \bullet b \bullet c \bullet \overline{d'} \bullet e' \bullet f \bullet g \bullet h'$ 

In the circuit diagram of FIG.8B, the following net name is used:  $n31 = d \cdot (a \cdot b' \cdot c' \cdot d \cdot e \cdot f' \cdot g \cdot h')'$ 

Decoded Bit E

*The 'e' column* of Table 2 has bold entries for D131, D161, D162, D146, D116, and D115. Table 16 lists the respective coded bits 'hgfedcba', the e-bit is overlined, and common patterns are marked by bold entries.

| Name | hgfedcba         | Coding Label         | ΕK | Name | hgfedcba                  | Coding Label                     | EK |
|------|------------------|----------------------|----|------|---------------------------|----------------------------------|----|
| D131 | 01011001         | a∙b'∙c'∙d∙e⊄•f'•g∙h' | 00 | D146 | 01100110                  | a'•b•c•d'• <del>e'</del> •f•g•h' | 10 |
| D161 | <b>011</b> 10001 | c'∙d'∙e •f∙g∙h'∙a≠b  | 00 | D116 | <b>010</b> 0 <b>11</b> 10 | c∙d∙ <del>e</del> '•f'•g•h'•a≠b  | 10 |
| D162 | <b>011</b> 10010 | c'•d'•e¯•f•g•h'•a≠b  | 00 | D115 | <b>010</b> 0 <b>11</b> 01 | c∙d∙ <del>e</del> '∙f'•g∙h'•a≠b  | 10 |

Table 16. E-bit Decoding

Using these identifiers, the encoding equation for bit 'e' can be written as follows:

$$E = e \cdot (a \cdot b' \cdot c' \cdot d \cdot \overline{e} \cdot f' \cdot g \cdot h' + c' \cdot d' \cdot \overline{e} \cdot f \cdot g \cdot h' \cdot a \oplus b)' + a' \cdot b \cdot c \cdot d' \cdot \overline{e'} \cdot f \cdot g \cdot h' + c \cdot d \cdot \overline{e'} \cdot f' \cdot g \cdot h' \cdot a \oplus b$$

In the circuit diagram of FIG.8B, the following net name is used:

n41 =  $e \cdot n43'$ n42 =  $a' \cdot b \cdot c \cdot d' \cdot e' \cdot f \cdot g \cdot h' + c \cdot d \cdot e' \cdot f' \cdot g \cdot h' \cdot a \oplus b$ n43 =  $(a \cdot b' \cdot c' \cdot d \cdot e \cdot f' \cdot g \cdot h' + c' \cdot d' \cdot e \cdot f \cdot g \cdot h' \cdot a \oplus b)'$ 

### Decoded Bit F

*The 'f' column* of Table 2 has bold entries for D161, D162, D145, D151, D116, D115, D132, and D126. The respective coded bits 'hgfedcba' are listed in Table 17, the e-bit is overlined, and common patterns are marked by bold entries.

Table 17. F-bit Decoding

| Name | hgfedcba                          | Coding Label        | FK | Name | hgfedcba                          | Coding Label                    | FK |
|------|-----------------------------------|---------------------|----|------|-----------------------------------|---------------------------------|----|
| D161 | <b>01</b> 1 <b>100</b> 01         | c'∙d'∙e∙f̄∙g∙h'•a≠b | 00 | D116 | <b>01</b> 0 <b>011</b> 10         | c∙d∙e'•f̄'•g∙h'•a≠b             | 10 |
| D162 | <b>01</b> 1 <b>100</b> 10         | c'∙d'∙e∙f∙g∙h'∙a≠b  | 00 | D115 | <b>01</b> 0 <b>011</b> 01         | c∙d∙e'•f̄'•g•h'•a≠b             | 10 |
| D145 | <b>01</b> 1 <b>0</b> 01 <b>01</b> | a∙b'∙e'∙f∙g∙h'∙c≠d  | 00 | D132 | <b>01</b> 0 <b>1</b> 10 <b>10</b> | a'•b∙e∙ <del>f</del> '•g•h'•c≠d | 10 |
| D151 | <b>01</b> 101001                  | a∙b'∙e'∙f∙g∙h'∙c≠d  | 00 | D126 | <b>01</b> 010110                  | a'∙b∙e∙f́'∙g∙h'∙c≠d             | 10 |

The decoding equation for bit 'F' can be written as follows:

$$\begin{split} F = f \bullet (c' \bullet d' \bullet e \bullet \overline{\mathbf{f}} \bullet g \bullet h' \bullet a \oplus b + a \bullet b' \bullet e' \bullet \overline{\mathbf{f}} \bullet g \bullet h' \bullet c \oplus d)' + \\ c \bullet d \bullet e' \bullet \overline{\mathbf{f}}' \bullet g \bullet h' \bullet a \oplus b + a' \bullet b \bullet e \bullet \overline{\mathbf{f}}' \bullet g \bullet h' \bullet c \oplus d \end{split}$$

In the circuit diagram of FIG.8B, the following net names are used:

 $n51 = f \bullet n52' \qquad n52 = c' \bullet d' \bullet e \bullet f \bullet g \bullet h' \bullet a \oplus b + a \bullet b' \bullet e' \bullet f \bullet g \bullet h' \bullet c \oplus d$ 

Decoded Bit K

The 'K' column of Table 2 and 3 has a value of one for the four coded vectors K107, K125, K170, and K152. The respective coded bits 'hgfedcba' are listed in Table 18.

 Table 18. K-bit Decoding

| Name | hgfedcba                  | Coding Label       | K | Name | hgfedcba                  | Coding Label       | K |
|------|---------------------------|--------------------|---|------|---------------------------|--------------------|---|
| K107 | <b>010</b> 0 <b>01</b> 11 | a∙c∙d'•f'•g•h'•b≠e | 1 | K170 | <b>011</b> 1 <b>10</b> 00 | a'∙c'∙d∙f∙g∙h'•b≠e | 1 |
| K125 | <b>010</b> 1 <b>01</b> 01 | a∙c∙d'•f'•g•h'•b≠e | 1 | K152 | <b>011</b> 01 <b>0</b> 10 | a'∙c'∙d∙f∙g∙h'•b≠e | 1 |

The decoding equation for bit 'K' can be written as follows:

 $K = a \bullet c \bullet d' \bullet f' \bullet g \bullet h' \bullet b \oplus e + a' \bullet c' \bullet d \bullet f \bullet g \bullet h' \bullet b \oplus e$ 

In the circuit diagram of FIG.8B, the following net name is used:  $n60 = c' \cdot d \cdot g \cdot h' \cdot b \oplus e$ 

### Validity Checks

Any received vector which does not fit the trellis of FIG.2 is invalid. Since only 68 vectors out of the total of 256 8-bit vectors are valid, there are a total of 188 invalid vectors. The circuitry to verify that a vector belongs to the set of valid vectors is less complex than circuitry which flags invalid vectors. The validity checks can be derived directly from the trellis of FIG.2 by using three sets of overlapping complementary circuits which pass through the center nodes labelled with the numbers 4, 6, and 4.

```
VALID = (a \oplus b \circ c \oplus d + b \oplus c \circ a \oplus d) \circ (e \oplus f \circ g \oplus h + f \oplus g \circ e \oplus h) + (c \circ d \circ a \oplus b + a \circ b \circ c \oplus d) \circ (g' \circ h' \circ e \oplus f + e' \circ f' \circ g \oplus h) + (a \oplus b \circ c' \circ d' + a' \circ b' \circ c \oplus d) \circ (g \circ h \circ e \oplus f + e \circ f \circ g \oplus h)
```

In the circuit diagram of FIG.8B, the following net names are used:

```
n61 = a \oplus b \circ c \oplus d + b \oplus c \circ a \oplus d

n63 = c \circ d \circ a \oplus b + a \circ b \circ c \oplus d

n65 = c' \circ d' \circ a \oplus b + a' \circ b' \circ c \oplus d

n67 = n61 \circ n62

n69 = n65 \circ n66
```

n62 =  $e \oplus f \bullet g \oplus h + f \oplus g \bullet e \oplus h$ n64 =  $g' \bullet h' \bullet e \oplus f + e' \bullet f' \bullet g \oplus h$ n66 =  $g \bullet h \bullet e \oplus f + e \bullet f \bullet g \oplus h$ n68 = n63 • n64

| 8           | PCa | PA     |    |
|-------------|-----|--------|----|
|             | PCb | NB     | b⊸ |
| <b>9</b>    | PCc | NC     | P∎ |
| 8           | PCd | ND     | þ⊷ |
| 8           | PCe | ΡE     |    |
| 8           | PCf | PF     |    |
| 8           | PCg | ΡK     |    |
| <b>s</b>    | PCh | NVAL   | þ- |
| <b>₽</b> -O | NCa |        |    |
| <b>-</b> O  | NCb | d e    |    |
| <b>₽</b> -O | NCc | 0      |    |
| ⊶⊖          | NCd | сc     |    |
| <b>₽</b> -O | NCe | b d    |    |
| ⊷           | NCf | 8      |    |
| <b>-</b> -0 | NCg | 1<br>L |    |
| ⊶0          | NCh |        |    |
|             | FIG | . 8A   |    |

### Circuit Implementation of the 8B/6B-P Decoder

FIG.8A is a symbol of the decoder circuit showing the inputs and outputs. FIG.8B is the logic diagram of the decoder circuit. It has not yet been simulated and verified by design tools, so it may be afflicted with minor errors.

### **Alternate Implementation of Decoder**

As for encoding, all the decoding equations for the bits A through F, bit K, and the validity check have complementary features which can be exploited for simplification by the use of the Exclusive OR function. The transformed equations A through F, bit K, and VALID are presented here:

 $B = b \oplus (a \oplus \overline{b}' \bullet \overline{b} \oplus c \bullet c \oplus d' \bullet e \oplus f \bullet g \bullet h')$ 

 $C = c \oplus (a \oplus b' \bullet b \oplus d' \bullet d \oplus e \bullet \oplus ' \bullet g \bullet h')$ 

 $D = d \oplus (a \oplus b \bullet b \oplus c' \bullet c \oplus \overline{d'} \bullet \overline{d} \oplus e' \bullet e \oplus f \bullet g \bullet h')$ 

 $A = a \oplus [(e \oplus f \bullet g \bullet h') \bullet (\overline{a} \oplus b \bullet b \oplus c' \bullet c \oplus d \bullet d \oplus e' + \overline{a} \oplus b \bullet b \oplus e' \bullet c \oplus d + \overline{a} \oplus b' \bullet b \oplus c \bullet c \oplus d')]$ 

 $E = e \oplus [(a \oplus b \bullet g \bullet h') \bullet (b \oplus c' \bullet c \oplus d \bullet d \oplus \overline{e'} \bullet \overline{e} \oplus f \bullet c \oplus d' \bullet d \oplus \overline{e} \bullet \overline{e} \oplus f')]$ 

 $F = f \oplus [(a \oplus b \bullet g \bullet h') \bullet (c \oplus d' \bullet d \oplus e \bullet e \oplus \overline{f'} + b \oplus e' \bullet c \oplus d \bullet e \oplus \overline{f})]$ 

 $K = d \oplus [(b \oplus e \bullet g \bullet h') \bullet (a \oplus c' \bullet c \oplus \bar{d} \bullet d \oplus f')]$ 

 $(a \oplus b \bullet c \oplus d' + a \oplus b' \bullet c \oplus d) \bullet (e \oplus f \bullet g \oplus h' + e \oplus f' \bullet g \oplus h) \bullet (c \oplus g \bullet d \oplus h + a \oplus e \bullet b \oplus f)$ 



### **Implementation Summary**

An encoding circuit for the 6B/8-P code can be built with 69 Standard Primitive Logic Cells (2 x INV, 8 x NAND3, 20 x NAND2, 26 x NOR3, 10 x NOR2, 3 x XNOR2). Assuming complementary inputs, there are no more than five cells in any logic path. Similarly, the decoding circuit including the validity check requires no more than 78 cells (2 x INV, 3 x NAND3, 19 x NAND2, 10 x NOR4, 7 x NOR3, 28 x NOR2, 9 x XNOR2) and no more than five cells in any logic path.

### References

- 1. IBM US Patent 5,699,062, Widmer, "DC Balanced (0,5) 8B/10B Transmission Code having Local Parity", Dec. 16, 1997.
- 2. IBM Research Report RC19106 (83280) 8/13/93, A. X. Widmer, "Error Correction Based on Transmission Code Violations and Parity".
- 3. IBM US Patent 5,740,186, Widmer, "Apparatus and Method for Error Correction Based on Transmission Code Violations and Parity", Apr. 14, 1998.
- 4. US Patent Application Serial No. 10\323,520, A. X. Widmer, "Error Correction with Low Latency for Bus Structures".
- 5. IBM US Patent 4,486,739, Franaszek and Widmer, "Byte Oriented DC Balanced (0,4) 8B/10B Partitioned Block Transmission Code", Dec. 4, 1984.
- 6. Petar Pepeljugoski, "Comparison of ISI penalty and sensitivity to low-frequency cutoff for 5B/6B, 6B/8B and 8B/10B codes, Internal Memo, dated Sept. 2003.