

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









# HOTLink® Transmitter/Receiver

## **Features**

- Fibre Channel-compliant
- IBM ESCON®-compliant
- DVB-ASI-compliant
- ATM-compliant
- 8B/10B-coded or 10-bit unencoded
- Standard HOTLink®: 160 to 330 Mbps
- High-speed HOTLink: 160 to 400 Mbps for high-speed applications
- Transistor-transistor logic (TTL)-synchronous I/O
- No external phase locked-loop (PLL) components
- Triple positive emitter coupled logic (PECL) 100 K serial outputs
- Dual PECL 100 K serial inputs
- Low-power: 350 mW (Tx), 650 mW (Rx)
- Compatible with fiber-optic modules, coaxial cable, and twisted pair media
- Built-in self-test (BIST)
- Single +5-V supply
- 28-pin small outline integrated circuit (SOIC)/plastic leaded chip carrier (PLCC)
- Pb-free packages available
- 0.8-μ bipolar complementary metal oxide semiconductor (BiCMOS)

# **Functional Description**

The CY7B923 HOTLink transmitter and CY7B933 HOTLink receiver are point-to-point communications building blocks that transfer data over high-speed serial links (fiber, coax, and twisted pair). Standard HOTLink data rates range from 160 to 330 Mbps. Higher speed HOTLink is also available for high-speed applications (160 to 400 Mbits/second). Figure 1 illustrates typical connections to host systems or controllers.

Eight bits of user data or protocol information are loaded into the HOTLink transmitter and are encoded. Serial data is shifted out of the three differential PECL serial ports at the bit rate (which is ten times the byte rate).

The HOTLink receiver accepts the serial bit stream at its differential line receiver inputs and, using a completely integrated PLL clock synchronizer, recovers the timing information necessary for data reconstruction. The bit stream is deserialized, decoded, and checked for transmission errors. Recovered bytes are presented in parallel to the receiving host along with a byte-rate clock.

The 8B/10B encoder/decoder can be disabled in systems that already encode or scramble the transmitted data. I/O signals are available to create a seamless interface with both asynchronous FIFOs (that is, CY7C42X) and clocked FIFOs (that is, CY7C44X). A BIST pattern generator and checker allows testing of the transmitter, receiver, and the connecting link as a part of a system diagnostic check.

HOTLink devices are ideal for a variety of applications where a parallel interface can be replaced with a high-speed point-to-point serial link. Applications include interconnecting workstations, servers, mass storage, and video transmission equipment.

# **CY7B923 Transmitter Block Diagram**





# CY7B933 Receiver Block Diagram



Figure 1. HOTLink System Connections





# Contents

| Pin Configurations                              | 4  |
|-------------------------------------------------|----|
| Pin Descriptions                                |    |
| CY7B923 HOTLink Transmitter                     |    |
| Block Diagram Description                       | 8  |
| Input Register                                  | 8  |
| Encoder                                         |    |
| Shifter                                         | 8  |
| OutA, OutB, OutC                                | 8  |
| Clock Generator                                 |    |
| Test Logic                                      | 9  |
| CY7B933 HOTLink Receiver                        |    |
| Block Diagram Description                       | 9  |
| Serial Data Inputs                              |    |
| PECL-TTL Translator                             | 9  |
| Clock Synchronization                           | 9  |
| Framer                                          | 9  |
| Shifter                                         | 9  |
| Decode Register                                 | 9  |
| Decoder                                         | 10 |
| Output Register                                 | 10 |
| Test Logic                                      | 10 |
| HOTLink CY7B923 Transmitter and CY7B933         |    |
| Receiver Operation                              | 10 |
| CY7B923 HOTLink Transmitter                     |    |
| Operating Mode Description                      |    |
| Encoded Mode Operation                          |    |
| Bypass Mode Operation                           |    |
| PECL Output Functional and Connection Options . | 13 |
| Transmitter Serial Data Characteristics         |    |
| Transmitter Test Mode Description               |    |
| BIST Mode                                       |    |
| Test Mode                                       | 16 |
| CY7B933 HOTLink Receiver                        |    |
| Operating Mode Description                      |    |
| Encoded Mode Operation                          |    |
| Bypass Mode Operation                           |    |
| Parallel Output Function                        | 17 |

| Receiver Seriai Data Requirements             | 17 |
|-----------------------------------------------|----|
| Receiver Test Mode Description                | 18 |
| BIST Mode                                     | 18 |
| Test Mode                                     | 18 |
| X3.230 Codes and Notation Conventions         | 18 |
| Notation Conventions                          | 18 |
| 8B/10B Transmission Code                      | 19 |
| Transmission Order                            | 19 |
| Valid and Invalid Transmission Characters     | 19 |
| Using the Tables for                          |    |
| Generating Transmission Characters            | 20 |
| Using the Tables for Checking the Validity of |    |
| Received Transmission Characters              | 20 |
| Valid Data Characters (SC/D = LOW)            | 21 |
| Valid Special Character Codes and Sequences   |    |
| (SC/D = HIGH)[1, 2]                           | 29 |
| Maximum Ratings                               |    |
| Operating Range                               |    |
| CY7B923/CY7B933 Electrical Characteristics    |    |
| Capacitance[13]                               | 31 |
| Transmitter Switching Characteristics         |    |
| Receiver Switching Characteristics            |    |
| Switching Waveforms                           |    |
| Ordering Information                          | 37 |
| Ordering Code Definitions                     |    |
| Package Diagrams                              |    |
| Acronyms                                      |    |
| Document Conventions                          |    |
| Units of Measure                              | 40 |
| Document History Page                         |    |
| Sales, Solutions, and Legal Information       |    |
| Worldwide Sales and Design Support            |    |
| Products                                      |    |
| PSoC® Solutions                               |    |
| Cypress Developer Community                   |    |
| Technical Support                             |    |



# **Pin Configurations**

Figure 2. CY7B923 Transmitter Pin Configurations





Figure 3. CY7B933 Receiver Pin Configurations





# **Pin Descriptions**

# Table 1. CY7B923 HOTLink Transmitter

| Name                                      | I/O                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>0-7</sub><br>(D <sub>b - h</sub> ) | TTL In             | Parallel data input. Data is <u>clo</u> cked into <u>the Transmitter</u> on the rising edge of CKW if ENA is LOW (or on the next rising CKW with ENN LOW). If ENA and ENN are HIGH, a Null character (K28.5) is sent. When MODE is HIGH, $D_{0, 1,7}$ become $D_{b, c,h}$ , respectively.                                                                                                                                                                                                                                                                                                                                                 |
| SC/D (D <sub>a</sub> )                    | TTL In             | Special character/data select. A HIGH on SC/D when CKW rises causes the transmitter to encode the pattern on $D_{0-7}$ as a control code (Special Character), while a LOW causes the data to be coded using the 8B/10B data alphabet. When MODE is HIGH, SC/D ( $D_a$ ) acts as $D_a$ input. SC/D has the same timing as $D_{0-7}$ .                                                                                                                                                                                                                                                                                                      |
| SVS<br>(D <sub>j</sub> )                  | TTL In             | Send violation symbol. If SVS is HIGH when CKW rises, a Violation symbol is encoded and sent while the data on the parallel inputs is ignored. If SVS is LOW, the state of $D_{0-7}$ and SC/D determines the code sent. In normal or test mode, this pin overrides the BIST generator and forces the transmission of a Violation code. When MODE is HIGH (placing the transmitter in unencoded mode), SVS ( $D_j$ ) acts as the $D_j$ input. SVS has the same timing as $D_{0-7}$ .                                                                                                                                                       |
| ENA                                       | TTL In             | Enable parallel data. If ENA is LOW on the rising edge of CKW, the data is loaded, encoded, and sent. If ENA and ENN are HIGH, the data inputs are ignored and the Transmitter will insert a Null character (K28.5) to fill the space between user data. ENA may be held HIGH/LOW continuously or it may be pulsed with each data byte to be sent. If ENA is being used for data control, ENN will normally be strapped HIGH, but can be used for BIST function control.                                                                                                                                                                  |
| ENN                                       | TTL In             | Enable next parallel data. If <u>ENN</u> is <u>LOW</u> , the data appearing on D <sub>0-7</sub> at the next rising edge of CKW is loaded, encoded, and sent. If <u>ENA</u> and <u>ENN</u> are HIGH, the data appearing on D <sub>0-7</sub> at the next rising edge of <u>CKW</u> will be ignored and the Transmitter will insert a Null character to fill the space between user data. <u>ENN</u> may be held <u>HIGH/LOW</u> continuously or it may be pulsed with each data byte sent. If <u>ENN</u> is being used for data control, <u>ENA</u> will normally be strapped HIGH, but can be used for BIST function control.              |
| CKW                                       | TTL In             | Clock write. CKW is both the clock frequency reference for the multiplying PLL that generates the high-speed transmit clock, and the byte rate write signal that synchronizes the parallel data input. CKW must be connected to a crystal controlled time base that runs within the specified frequency range of the Transmitter and Receiver.                                                                                                                                                                                                                                                                                            |
| FOTO                                      | TTL In             | Fiber optic transmitter off. FOTO determines the function of two of the three PECL transmitter output pairs. If FOTO is LOW, the data encoded by the Transmitter will appear at the outputs continuously. If FOTO is HIGH, OUTA± and OUTB± are forced to their "logic zero" state (OUT+ = LOW and OUT- = HIGH), causing a fiber-optic transmit module to extinguish its light output. OUTC is unaffected by the level on FOTO, and can be used as a loop-back signal source for board-level diagnostic testing.                                                                                                                           |
| OUTA±<br>OUTB±<br>OUTC±                   | PECL Out           | Differential serial data outputs. These PECL 100 K outputs (+5 V referenced) are capable of driving terminated transmission lines or commercial fiber optic transmitter modules. Unused pairs of outputs can be left open, or wired to $V_{CC}$ to reduce power, if the output is not required. OUTA $\pm$ and OUTB $\pm$ are controlled by the level on FOTO, and will remain at their "logical zero" states when FOTO is asserted. OUTC $\pm$ is unaffected by the level on FOTO. (OUTA $\pm$ and OUTB $\pm$ are used as a differential test clock input while in Test mode, that is, MODE = UNCONNECTED or forced to $V_{CC}/2$ ).     |
| MODE                                      | Three-<br>Level In | Encoder mode select. The level on MODE determines the encoding method to be used. When wired to GND, MODE selects 8B/10B encoding. When wired to $V_{CC}$ , data inputs bypass the encoder and the bit pattern on $D_{a-j}$ goes directly to the shifter. When left floating (internal resistors hold the input at $V_{CC}/2$ ) the internal bit-clock generator is disabled and OUTA+/OUTB+ become the differential bit clock to be used for factory test. In typical applications MODE is wired to $V_{CC}$ or GND.                                                                                                                     |
| BISTEN                                    | TTL In             | BIST enable. When BISTEN is LOW and ENA and ENN are HIGH, the transmitter sends an alternating 1–0 pattern (D10.2 or D21.5). When either ENA or ENN is set LOW and BISTEN is LOW, the transmitter begins a repeating test sequence that allows the Transmitter and Receiver to work together to test the function of the entire link. In normal use this input is held HIGH or wired to $V_{CC}$ . The BIST generator is a free-running pattern generator that need not be initialized, but if required, the BIST sequence can be initialized by momentarily asserting SVS while BISTEN is LOW. BISTEN has the same timing as $D_{0-7}$ . |
| RP                                        | TTL Out            | Read pulse. RP is a 60% <u>LO</u> W duty-cycle byte-rate pulse train suita <u>ble for the read pulse in CY7C42X FIFOs.</u> The frequency on RP is the same as CKW when enabled by ENA, and duty cycle is ind <u>ependent of the CKW duty cycle.</u> Pulse widths are set by logic internal to the transmitter. In BIST mode, RP will remain HIGH for all but the last byte of a test loop. RP will pulse LOW one byte time per BIST loop.                                                                                                                                                                                                 |
| V <sub>CCN</sub>                          |                    | Power for integral disputity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| V <sub>CCQ</sub>                          |                    | Power for internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| GND                                       |                    | Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



Table 2. CY7B933 HOTLink Receiver

| Name                                    | I/O                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q <sub>0-7</sub><br>(Q <sub>b-h</sub> ) | TTL Out              | $Q_{0-7}$ parallel data output. $Q_{0-7}$ contain the most recently received data. These outputs change synchronously with CKR. When MODE is HIGH, $Q_{0,\ 1,\ \dots,7}$ become $Q_{b,\ c,\dots h}$ , respectively.                                                                                                                                                                                                                                                                                                                                                               |
| $SC/\overline{D}(Q_a)$                  | TTL Out              | Special character/data select. $SC/\overline{D}$ indicates the context of received data. HIGH indicates a Control (Special Character) code, $\underline{L}OW$ indicates a Data character. When MODE is HIGH (placing the receiver in Unencoded mode), $SC/\overline{D}$ acts as the $Q_a$ output. $SC/\overline{D}$ has the same timing as $Q_{0-7}$ .                                                                                                                                                                                                                            |
| RVS (Q <sub>j</sub> )                   | TTL Out              | Received violation symbol. A HIGH on RVS indicates that a code rule violation has been detected in the received data stream. A LOW shows that no error has been detected. In BIST mode, a LOW on RVS indicates correct operation of the Transmitter, Receiver, and link on a byte-by-byte basis. When MODE is HIGH (placing the receiver in Unencoded mode), RVS acts as the $Q_j$ output. RVS has the same timing as $Q_{0-7}$ .                                                                                                                                                 |
| RDY                                     | TTL Out              | Data output ready. A LOW pulse on RDY indicates that new data has been received and is ready to be delivered. A missing pulse on RDY shows that the received data is the Null character (normally inserted by the transmitter as a pad between data inputs). In BIST mode RDY will remain LOW for all but the last byte of a test loop and will pulse HIGH one byte time per BIST loop.                                                                                                                                                                                           |
| CKR                                     | TTL Out              | Clock read. This byte rate clock output is phase and frequency aligned to the incoming serial data stream. RDY, Q <sub>0-7</sub> , SC/D, and RVS all switch synchronously with the rising edge of this output.                                                                                                                                                                                                                                                                                                                                                                    |
| A/B                                     | PECL in              | Serial data input select. This PECL 100K (+5V referenced) input selects INA or INB as the active data input. If A/B is HIGH, INA is connected to the shifter and signals connected to INA will be decoded. If A/B is LOW INB is selected.                                                                                                                                                                                                                                                                                                                                         |
| INA±                                    | Diff In              | Serial data input A. The differential signal at the receiver end of the communication link may be connected to the differential input pairs INA $\pm$ or INB $\pm$ . Either the INA pair or the INB pair can be used as the main data input and the other can be used as a loopback channel or as an alternative data input selected by the state of A/B. One input of an intentionally unused differential-pair (INA $\pm$ or INB $\pm$ ) should be terminated to V <sub>CC</sub> through a 1–5-K $\Omega$ resistor to assure that no data transitions are accidentally created. |
| INB<br>(INB+)                           | PECL in<br>(Diff In) | Serial data input B. This pin is either a single-ended PECL data receiver (INB) or half of the INB differential pair. If SO is wired to $V_{CC}$ , then INB $\pm$ can be used as differential line receiver interchangeably with INA $\pm$ . If SO is normally connected and loaded, INB becomes a single-ended PECL 100K (+5 V referenced) serial data input. INB is used as the test clock while in Test mode.                                                                                                                                                                  |
| SI<br>(INB-)                            | PECL in<br>(Diff In) | Status input. This pin is either a single-ended PECL status monitor input (SI) or half of the INB differential pair. If SO is wired to $V_{CC}$ , then INB $\pm$ can be used as differential line receiver interchangeably with INA $\pm$ . If SO is normally connected and loaded, SI becomes a single-ended PECL 100K (+5V referenced) status monitor input, which is translated into a TTL-level signal at the SO pin.                                                                                                                                                         |
| SO                                      | TTL Out              | Status out. SO is the TTL-translated output of SI. It is typically used to translate the carrier detect output from a fiber-optic receiver connected to SI. When this pin is normally connected and loaded (without any external pull-up resistor), SO will assume the same logical level as SI and INB will become a single-ended PECL serial data input. If the status monitor translation is not desired, then SO may be wired to V <sub>CC</sub> and the INB± pair may be used as a differential serial data input.                                                           |
| RF                                      | TTL In               | Reframe enable. RF controls the Framer logic in the Receiver. When RF is held HIGH, each SYNC (K28.5) symbol detected in the shifter will frame the data that follows. If it is HIGH for 2,048 consecutive bytes, the internal framer switches to double-byte mode. When RF is held LOW, the reframing logic is disabled. The incoming data stream is then continuously deserialized and decoded using byte boundaries set by the internal byte counter. Bit errors in the data stream will not cause alias SYNC characters to reframe the data erroneously.                      |
| REFCLK                                  | TTL In               | Reference clock. REFCLK is the clock frequency reference for the clock/data synchronizing PLL. REFCLK sets the approximate center frequency for the internal PLL to track the incoming bit stream. REFCLK must be connected to a crystal-controlled time base that runs within the frequency limits of the Tx/Rx pair, and the frequency must be the same as the transmitter CKW frequency (within CKW ±0.1%).                                                                                                                                                                    |
| MODE                                    | Three-<br>Level In   | Decoder mode select. The level on the MODE pin determines the decoding method to be used. When wired to GND, MODE selects 8B/10B decoding. When wired to $V_{CC}$ , registered shifter contents bypass the decoder and are sent to $Q_{a-j}$ directly. When left floating (internal resistors hold the MODE pin at $V_{CC}/2$ ) the internal bit clock generator is disabled and INB becomes the bit rate test clock to be used for factory test. In typical applications, MODE is wired to $V_{CC}$ or GND.                                                                      |



| Table 2. CY7E | 3933 HOTLink | Receiver | (continued) |
|---------------|--------------|----------|-------------|
|---------------|--------------|----------|-------------|

| Name             | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BISTEN           |     | Built-in self-test enable. When $\overline{\text{BISTEN}}$ is LOW the Receiver awaits a D0.0 (sent once per BIST loop) character and begins a continuous test sequence that tests the functionality of the Transmitter, the_Receiver, and the link connecting them. In BIST mode the status of the test can be monitored with RDY and RVS outputs. In normal use BISTEN is held HIGH or wired to $V_{CC}$ . BISTEN has the same timing as $Q_{0-7}$ . |
| V <sub>CCN</sub> |     | Power for output drivers.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| V <sub>CCQ</sub> |     | Power for internal circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| GND              |     | Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# CY7B923 HOTLink Transmitter Block Diagram Description

# **Input Register**

The input register holds the data to be processed by the HOTLink transmitter and allows the input timing to be made consistent with standard FIFOs. The input register is clocked by CKW and loaded with information on the D<sub>0-7</sub>, SC/D, and SVS pins. Two enable inputs (ENA and ENN) allow the user to choose when data is loaded in the register. Asserting Enable, active LOW (ENA) causes the inputs to be loaded in the register on the rising edge of CKW. If ENN (Enable Next, active LOW) is asserted when CKW rises, the data present on the inputs on the next rising edge of CKW are loaded into the Input register. If neither ENA nor ENN are asserted LOW on the rising edge of CKW, then a SYNC (K28.5) character is sent. These two inputs allow proper timing and function for compatibility with either asynchronous FIFOs or clocked FIFOs without external logic, as shown in Figure 6.

In BIST mode, the input register becomes the signature pattern generator by logically converting the parallel input register into a linear feedback shift register (LFSR). When enabled, this LFSR generates a 511-byte sequence that includes all data and special character codes, including the explicit violation symbols. This pattern provides a predictable but pseudo-random sequence that can be matched to an identical LFSR in the receiver.

#### **Encoder**

The encoder transforms the input data held by the input register into a form more suitable for transmission on a serial interface link. The code used is specified by ANSI X3.230 (Fibre Channel) and the IBM ESCON channel (see the table Valid Data Characters (SC/D = LOW) on page 21). The eight  $D_{0-7}$  data inputs are converted to either a data symbol or a special character, depending upon the state of the SC/D input. If SC/D is HIGH, the data inputs represent a control code and are encoded using the special character code table. If SC/D is LOW, the data inputs are converted using the data code table. If a byte time passes with the inputs disabled, the encoder outputs a special character comma K28.5 (or SYNC) that maintains link synchronization. SVS input forces the transmission of a specified violation symbol to allow the user to check the error handling system logic in the controller or for proprietary applications.

The 8B/10B coding function of the encoder can be bypassed for systems that include an external coder or scrambler function as part of the controller. This bypass is controlled by setting the MODE select pin HIGH. When in bypass mode,  $D_{a-j}$  (note that

the bit order is specified in the fibre channel 8B/10B code) become the ten inputs to the shifter, with  $D_a$  being the first bit to be shifted out.

#### Shifter

The shifter accepts parallel data from the encoder after each byte time and shifts it to the serial interface output buffers using a PLL multiplied bit clock that runs at 10 times the byte clock rate. Timing for the parallel transfer is controlled by the counter included in the clock generator and is not affected by signal levels or timing at the input pins.

# OutA, OutB, OutC

The serial interface PECL output buffers (ECL100K referenced to +5 V) are the drivers for the serial media. They are all connected to the shifter and contain the same serial data. Two of the output pairs (OUTA± and OUTB±) are controllable by the FOTO input and can be disabled by the system controller to force a logical zero (that is, "light off") at the outputs. The third output pair (OUTC±) is not affected by FOTO and supplies a continuous data stream suitable for loopback testing of the subsystem.

OUTA± and OUTB± responds to FOTO input changes within a few bit times. However, since FOTO is not synchronized with the transmitter data stream, the outputs will be forced off or turned on at arbitrary points in a transmitted byte. This function is intended to augment an external laser safety controller and as an aid for Receiver PLL testing.

In wire-based systems, control of the outputs may not be required, and FOTO can be strapped LOW. The three outputs are intended to add system and architectural flexibility by offering identical serial bit streams with separate interfaces for redundant connections or for multiple destinations. Unneeded outputs can be wired to VCC to disable and power down the unused output circuitry.

#### **Clock Generator**

The clock generator is an embedded PLL that takes a byte-rate reference clock (CKW) and multiplies it by 10 to create a bit rate clock for driving the serial shifter. The byte rate reference comes from CKW, the rising edge of which clocks data into the input register. This clock must be a crystal referenced pulse stream that has a frequency between the minimum and maximum specified for the HOTLink transmitter/receiver pair. Signals controlled by this block form the bit clock and the timing signals that control internal data transfers between the input register and the shifter.



The read pulse  $(\overline{RP})$  is derived from the feedback counter used in the PLL multiplier. It is a byte-rate pulse stream with the proper phase and pulse widths to allow transfer of data from an asynchronous FIFO. Pulse width is independent of CKW duty cycle, since proper phase and duty cycle is maintained by the PLL. The  $\overline{RP}$  pulse stream ensures correct data transfers between asynchronous FIFOs and the transmitter input latch with no external logic.

## **Test Logic**

Test logic includes the initialization and control for the BIST generator, the multiplexer for test mode clock distribution, and control logic to properly select the data encoding. Test logic is discussed in detail in CY7B923 HOTLink Transmitter Operating Mode Description on page 11.

# CY7B933 HOTLink Receiver Block Diagram Description

### Serial Data Inputs

Two pairs of differential line receivers are the inputs for the serial data stream. INA± or INB± can be selected with the A/B input. INA± is selected with A/B HIGH and INB± is selected with A/B LOW. The threshold of A/B is compatible with the ECL 100K signals from PECL fiber optic interface modules. TTL logic elements can be used to select the A or B inputs by adding a resistor pull-up to the TTL driver connected to A/B. The differential threshold of INA± and INB± will accommodate wire interconnect with filtering losses or transmission line attenuation greater than 20 db ( $V_{\rm DIF} \ge 50$  mv) or can be directly connected to fiber optic interface modules (any ECL logic family, not limited to ECL 100K). The common mode tolerance will accommodate a wide range of signal termination voltages. The highest HIGH input that can be tolerated is  $V_{\rm IN} = V_{\rm CC}$ , and the lowest LOW input that can be interpreted correctly is  $V_{\rm IN} = {\rm GND} + 2.0V$ .

## **PECL-TTL Translator**

The function of the INB(INB+) input and the SI(INB-) input is defined by the connections on the SO output pin. If the PECL/TTL translator function is not required, the SO output is wired to VCC. A sensor circuit detects this connection and causes the inputs to become INB± (a differential line-receiver serial-data input). If the PECL/TTL translator function is required, the SO output is connected to its normal TTL load (typically one or more TTL inputs, but no pull-up resistor) and the INB+ input becomes single-ended ECL 100K, serial data input (INB) and the INB- input becomes single-ended, ECL 100K status input (SI).

This positive-referenced PECL-to-TTL translator is provided to eliminate external logic between an PECL fiber-optic interface module "carrier detect" output and the TTL input in the control logic. The input threshold is compatible with ECL 100K levels (+5-V referenced). It can also be used as part of the link status indication logic for wire connected systems.

### **Clock Synchronization**

The clock synchronization function is performed by an embedded PLL that tracks the frequency of the incoming bit stream and aligns the phase of its internal bit rate clock to the

serial data transitions. This block contains the logic to transfer the data from the shifter to the decode register once every byte. The counter that controls this transfer is initialized by the framer logic. CKR is a buffered output derived from the bit counter used to control the decode register and the output register transfers.

Clock output logic is designed so that when reframing causes the counter sequence to be interrupted, the period and pulse width of CKR is never less than normal. Reframing may stretch the period of CKR by up to 90%, and either CKR Pulse Width HIGH or Pulse Width LOW may be stretched, depending on when reframe occurs

The REFCLK input provides a byte-rate reference frequency to improve PLL acquisition time and limit unlocked frequency excursions of the CKR when no data is present at the serial inputs. The frequency of REFCLK is required to be within ±0.1% of the frequency of the clock that drives the transmitter CKW pin.

#### Framer

Framer logic checks the incoming bit stream for the pattern that defines the byte boundaries. This combinatorial logic filter looks for the X3.230 symbol defined as a Special Character Comma (K28.5). When it is found, the free-running bit counter in the Clock Synchronization block is synchronously reset to its initial state, thus framing the data correctly on the correct byte boundaries.

Random errors that occur in the serial data can corrupt some data patterns into a bit pattern identical to a K28.5, and thus cause an erroneous data-framing error. The RF input prevents this by inhibiting reframing during times when normal message data is present. When RF is held LOW, the HOTLink receiver will deserialize the incoming data without trying to reframe the data to incoming patterns. When RF rises, RDY will be inhibited until a K28.5 has been detected, after which RDY will resume its normal function. While RF is HIGH, it is possible that an error could cause misframing, after which all data will be corrupted. Likewise, a K28.7 followed by D11.x, D20.x, or an SVS (C0.7) followed by D11.x will create alias K28.5 characters and cause erroneous framing. These sequences must be avoided while RF is HIGH.

If RF remains HIGH for greater than 2048 bytes, the framer converts to double-byte framing, requiring two K28.5 characters aligned on the same byte boundary within 5 bytes in order to reframe. Double-byte framing greatly reduces the possibility of erroneously reframing to an aliased K28.5 character.

#### Shifter

The shifter accepts serial inputs from the serial data inputs one bit at a time, as clocked by the clock synchronization logic. Data is transferred to the framer on each bit, and to the decode register once per byte.

#### **Decode Register**

The decode register accepts data from the shifter once per byte as determined by the logic in the clock synchronization block. It is presented to the decoder and held until it is transferred to the output latch.



#### Decoder

Parallel data is transformed from ANSI-specified X3.230 8B/10B codes back to 'raw data' in the decoder. This block uses the standard decoder patterns shown in Valid Data Characters (SC/D = LOW) on page 21 and Valid Special Character Codes and Sequences (SC/D = HIGH)[1, 2] on page 29. Data patterns are signaled by a LOW on the SC/D output and special character patterns are signaled by a HIGH on the SC/D output. Unused patterns or disparity errors are signaled as errors by a HIGH on the RVS output and by specific special character codes.

## **Output Register**

The output register holds the recovered data ( $Q_{0-7}$ , SC/D, and RVS) and aligns it with the recovered byte clock (CKR). This synchronization insures proper timing to match a FIFO interface or other logic that requires glitch-free and specified output behavior. Outputs change synchronously with the rising edge of CKR.

In BIST mode, this register becomes the signature pattern generator and checker by logically converting itself into a linear feedback shift register (LFSR) pattern generator. When enabled, this LFSR generates a 511-byte sequence that includes all data and special character codes, including the explicit violation symbols. This pattern provides a predictable but pseudo-random sequence that can be matched to an identical LFSR in the Transmitter. When synchronized, it checks each byte in the Decoder with each byte generated by the LFSR and shows errors at RVS. Patterns generated by the LFSR are compared after being buffered to the output pins and then fed back to the comparators, allowing test of the entire receive function.

In BIST mode, the LFSR is initialized by the first occurrence of the transmitter BIST loop start code D0.0 (D0.0 is sent only once per BIST loop). Once the BIST loop has been started, RVS will be HIGH for pattern mismatches between the received sequence and the internally generated sequence. Code rule violations or running disparity errors that occur as part of the BIST loop will not cause an error indication. RDY will pulse HIGH once per BIST loop and can be used to check test pattern progress. The receiver BIST generator can be reinitialized by leaving and re-entering BIST mode.

### **Test Logic**

Test logic includes the initialization and control for the Built-In Self-Test (BIST) generator, the multiplexer for Test mode clock distribution, and control logic for the decoder. Test logic is discussed in more detail in the CY7B933 HOTLink Receiver Operating Mode Description.

# HOTLink CY7B923 Transmitter and CY7B933 Receiver Operation

The CY7B923 Transmitter operating with the CY7B933 Receiver form a general purpose data communications subsystem capable of transporting user data at up to 33 Mbytes per second (40 Mbytes per second for -400 devices) over several types of serial interface media. Figure 10 on page 34 illustrates the flow of data through the HOTLink CY7B923 transmitter pipeline. Data is latched into the transmitter on the rising edge of CKW when enabled by ENA or ENN. RP is asserted LOW with a 60% LOW/40% HIGH duty cycle when ENA is LOW. RP may be used as a read strobe for accessing data stored in a FIFO. The parallel data flows through the encoder and is then shifted out of the OUTx± PECL drivers. The bit-rate clock is generated internally from a multiply-by-ten PLL clock generator. The latency through the transmitter is approximately  $21t_B - 10$  ns over the operating range. A more complete description is found in the section CY7B923 HOTLink Transmitter Operating Mode Description.

Figure 5 illustrates the data flow through the HOTLink CY7B933 receiver pipeline. Serial data is sampled by the receiver on the INx± inputs. The receiver PLL locks onto the serial bit stream and generates an internal bit rate clock. The bit stream is deserialized, decoded and then presented at the parallel output pins. A byte rate clock (bit clock ÷ 10) synchronous with the parallel data is presented at the CKR pin. The RDY pin will be asserted to LOW to indicate that data or control characters are present on the outputs. RDY will not be asserted LOW in a field of K28.5s except for any single K28.5 or the last one in a continuous series of K28.5's. The latency through the receiver is approximately 24t<sub>B</sub> + 10 ns over the operating range. A more complete description of the receiver is in the section CY7B933 HOTLink Receiver Operating Mode Description.

The HOTLink receiver has a built-in byte framer that synchronizes the Receiver pipeline with incoming SYNC (K28.5) characters. Figure illustrates the HOTLink CY7B933 Receiver framing operation. The Framer is enabled when the RF pin is asserted HIGH. RF is latched into the receiver on the falling edge of CKR. The framer looks for K28.5 characters embedded in the serial data stream. When a K28.5 is found, the framer sets the parallel byte boundary for subsequent data to the K28.5 boundary. While the framer is enabled, the RDY pin indicates the status of the framing operation.

When the RF pin is asserted HIGH, RDY leaves it normal mode of operation and is asserted HIGH while the framer searches the data stream for a K28.5 character. After the framer has synchronized to a K28.5 character, the Receiver will assert the RDY pin LOW when the K28.5 character is present at the parallel output. The RDY pin will then resume its normal operation as dictated by the MODE and BISTEN pins.

The normal operation of the  $\overline{\text{RDY}}$  pin in encoded mode is to signal when parallel data is present at the outp<u>ut pins</u> by pulsing LOW with a 60% LOW/40% HIGH duty cycle.  $\overline{\text{RDY}}$  does not pulse LOW in a field of K28.5 characters; however,  $\overline{\text{RDY}}$  does pulse LOW for the last K28.5 character in the field or for any single K28.5. In unencoded mode, the normal operation of the RDY pin is to signal when any K28.5 is at the parallel output pins.





Figure 4. CY7B933 Receiver Data Pipeline in Encoded Mode

Figure 5. CY7B933 Framing Operation in Encoded Mode



The transmitter and receiver parallel interface timing and functionality can be made to match the timing and functionality of either an asynchronous FIFO or a clocked FIFO by appropriately connecting signals (see Figure 6 on page 12). Proper operation of the FIFO interface depends upon various FIFO-specific access and response specifications.

The HOTLink transmitter and receiver serial interface provides a seamless interface to various types of media. A minimal number of external components are needed to properly terminate transmission lines and provide PECL loads. For proper power supply decoupling, a single 0.01  $\mu F$  for each device is all that is required to bypass the  $V_{CC}$  and GND pins. Figure 7 on page 14 illustrates a HOTLink transmitter and receiver interface to fiber-optic and copper media. More information on interfacing HOTLink to various media can be found in the HOTLink Design Considerations application note.

# **CY7B923 HOTLink Transmitter Operating Mode Description**

In normal operation, the transmitter can operate in either of two modes. The encoded mode allows a user to send and receive eight-bit data and control information without first converting it to transmission characters. The bypass mode is used for systems in which the encoding and decoding is performed in an external protocol controller.

In either mode, data is loaded into the Input register of the Transmitter on the rising edge of CKW. The input timing and functional response of the Transmitter input can be made to match the timing and functionality of either an asynchronous FIFO or a clocked FIFO by an appropriate connection of input signals (see Figure 6 on page 12). Proper operation of the FIFO interface depends upon various FIFO-specific access and response specifications.



## **Encoded Mode Operation**

In the encoded mode, the input data is interpreted as eight bits of data  $(D_0-D_7)$ , a context control bit  $(SC/\overline{D})$ , and a system diagnostic input bit (SVS). If the context of the data is to be normal message data, the  $SC/\overline{D}$  input should be LOW, and the data should be encoded using the valid data character set described in Valid Data Characters (SC/D=LOW) on page 21. If the context of the data is to be control or protocol information, the  $SC/\overline{D}$  input is HIGH, and the data is encoded using the valid special character set described in Valid Special Character Codes and Sequences (SC/D=HIGH)[1,2] on page 29. Special characters include all protocol characters necessary to encode packets for Fibre Channel, ESCON, proprietary systems, and diagnostic purposes.

The diagnostic characters and sequences available as special characters include those for Fibre Channel link testing, as well as codes to be used for testing system response to link errors and timing. A Violation symbol can be explicitly sent as part of a user data packet (i.e., send C0.7;  $D_{7-0} = 111\ 00000$  and SC/D = 1), or it can be sent in response to an external system using the SVS input. This allows the system diagnostic logic to evaluate the errors in an unambiguous manner, and does not require any modification to the transmission interface to force transmission errors for testing purposes.

Figure 6. Seamless FIFO Interface





# **Bypass Mode Operation**

In the bypass mode, the input data is interpreted as 10 bits  $(D_{b-h}),\,SC/D\,\,(D_a),\,$  and  $SVS\,\,(D_j)$  of pre-encoded transmission data to be serialized and sent over the link. This data can use any encoding method suitable to the designer. The only restrictions upon the data encoding method is that it contain suitable transition density for the receiver PLL data synchronizer (one per 10-bit byte), and that it be compatible with the transmission media.

Data loaded into the Input register on the rising edge of CKW is loaded into the shifter on the subsequent rising edges of CKW. It will then be shifted to the outputs one bit at a time using the internal clock generated by the clock generator. The first bit of the transmission character ( $D_a$ ) appears at the output (OUTA $\pm$ , OUTB $\pm$ , and OUTC $\pm$ ) after the next CKW edge.

While in either the encoded mode or bypass mode, if a CKW edge arrives when the inputs are not enabled (ENA and ENN both HIGH), the encoder inserts a pad character K28.5 (for example, C5.0) to maintain proper link synchronization (in the bypass mode the proper sense of running disparity cannot be guaranteed for the first pad character, but is correct for all pad characters that follow). This automatic insertion of pad characters can be inhibited by insuring that the transmitter is always enabled (that is, ENA or ENN is hard-wired LOW).

## **PECL Output Functional and Connection Options**

The three pairs of PECL outputs all contain the same information and are intended for use in systems with multiple connections. Each output pair may be connected to a different serial media, each of which may be a different length, link type, or interface technology. For systems that do not require all three output pairs, the unused pairs should be wired to  $V_{\rm CC}$  to minimize the power dissipated by the output circuit, and to minimize unwanted noise generation. An internal voltage comparator detects when an output differential pair is wired to  $V_{\rm CC}$ , causing the current source for that pair to be disabled. This results in a power savings of around 5 mA for each unused pair.

In systems that require the outputs to be shut off during some periods when link transmission is prohibited (for example, for laser safety functions), the FOTO input can be asserted. While it is possible to insure that the output state of the PECL drivers is LOW (that is, light is off) by sending all 0s in bypass mode, it is often inconvenient to insert this level of control into the data transmission channel, and it is impossible in encoded mode. FOTO is provided to simplify and augment this control function (typically found in laser-based transmission systems). FOTO will force OUTA+ and OUTB+ to go LOW, OUTA- and OUTB- to go HIGH, while allowing OUTC± to continue to function normally (OUTC is typically used as a diagnostic feedback and cannot be disabled). This separation of function allows various system configurations without undue load on the control function or data channel logic.

### Transmitter Serial Data Characteristics

The CY7B923 HOTLink transmitter serial output conforms to the requirements of the Fibre Channel specification. The serial data output is controlled by an internal PLL that multiplies the frequency of CKW by 10 to maintain the proper bit clock frequency. The jitter characteristics (including both PLL and logic components) are as follows:

- Deterministic Jitter (D<sub>j</sub>) < 35 ps (peak-peak). Typically measured while sending a continuous K28.5 (C5.0).
- Random Jitter (R<sub>j</sub>) < 175 ps (peak-peak). Typically measured while sending a continuous K28.7 (C7.0).</p>

# **Transmitter Test Mode Description**

The CY7B923 transmitter offers two types of test mode operation, BIST mode and Test mode. In a normal system application, the BIST mode can be used to check the functionality of the transmitter, the receiver, and the link connecting them. This mode is available with minimal impact on user system logic, and can be used as part of the normal system diagnostics. Typical connections and timing are shown in Figure 8 on page 15.





Figure 7. HOTLink Connection Diagram





Figure 8. BIST Illustration

# **BIST Mode**

The BIST mode functions as follows:

- 1. Set BISTEN LOW to begin test pattern generation. The transmitter begins sending bit rate ...1010...
- 2. Set either ENA or ENN LOW to begin pattern sequence generation (use of the Enable pin not being used for normal FIFO or system interface can minimize logic delays between the controller and transmitter).
- 3. Allow the transmitter to run through several BIST loops or until the receiver test is complete. RP will pulse LOW once per

BIST loop, and can be used by an external counter to monitor the number of test pattern loops.

4. When testing is completed, set BISTEN HIGH and ENA and ENN HIGH and resume normal function.

**Note**: It may be advisable to send violation characters to test the RVS output in the receiver. This can be done by explicitly sending a violation with the SVS input, or allowing the transmitter BIST loop to run while the receiver runs in normal mode. The BIST loop includes deliberate violation symbols and will adequately test the RVS function.



BIST mode is intended to check the entire function of the transmitter (except the transmitter input pins and the bypass function in the Encoder), the serial link, and the receiver. It augments normal factory ATE testing and provides the designer with a rigorous test mechanism to check the link transmission system without requiring any significant system overhead.

While in bypass mode, the BIST logic will function in the same way as in the encoded mode. MODE = HIGH and BISTEN = LOW causes the transmitter to switch to encoded mode and begin sending the BIST pattern, as if MODE = LOW. When BISTEN returns to HIGH, the Transmitter resumes normal Bypass operation. In Test mode the BIST function works as in the Normal mode. For more information on BIST, consult the "HOTLink Built-In Self-Test" application note.

#### **Test Mode**

The MODE input pin selects between three transmitter functional modes. When wired to  $V_{CC}$ , the  $D(_{a-j})$  inputs bypass the encoder and load directly from the input register into the shifter. When wired to GND, the inputs  $D_{0-7},\, SVS,\,$  and SC/D are encoded using the Fibre Channel 8B/10B codes and sequences (shown at the end of this datasheet). Since the transmitter is usually hardwired to encoded or bypass mode and not switched between them, a third function is provided for the MODE pin. The test mode is selected by floating the MODE pin (internal resistors hold the MODE pin at  $V_{CC}/2$ ). Test mode is used for factory or incoming device tests.

The test mode causes the transmitter to function in its encoded mode, but with OutA+/OutB+ (used as a differential test clock input) as the bit rate clock input instead of the internal PLL-generated bit clock. In this mode, inputs are clocked by CKW and transfers between the Input register and Shifter are timed by the internal counters. The bit-clock and CKW must maintain a fixed phase and divide-by-ten ratio. The phase and pulse width of RP are controlled by phases of the bit counter (PLL feedback counter) as in normal mode. Input and output patterns can be synchronized with internal logic by observing the state of RP or the device can be initialized to match an ATE test pattern using the following technique:

- With the MODE pin either HIGH or LOW, stop CKW and bit-clock.
- 2. Force the MODE pin to MID (open or  $V_{\rm CC}/2$ ) while the clocks are stopped.
- 3. Start the bit-clock and let it run for at least two cycles.
- 4. Start the CKW clock at the bit-clock/10 rate.

Test mode is intended to allow logical, DC, and AC testing of the transmitter without requiring that the tester check output data patterns at the bit rate, or accommodate the PLL lock, tracking, and frequency range characteristics that are required when the HOTLink part operates in its normal mode. To use OutA+/OutB+ as the test clock input, the FOTO input is held HIGH while in Test mode. This forces the two outputs to go to a 'PECL LOW' which can be ignored while the test system creates a differential input signal at some higher voltage.

# CY7B933 HOTLink Receiver Operating Mode Description

In normal user operation, the receiver can operate in either of two modes. The encoded mode allows a user system to send and receive eight-bit data and control information without first converting it to transmission characters. The bypass mode is used for systems in which the encoding and decoding is performed by an external protocol controller.

In either mode, serial data is received at one of the differential line receiver inputs and routed to the shifter and the clock synchronization. The PLL in the clock synchronizer aligns the internally generated bit rate clock with the incoming data stream and clocks the data into the shifter. At the end of a byte time (ten bit times), the data accumulated in the shifter is transferred to the decode register.

To properly align the incoming bit stream to the intended byte boundaries, the bit counter in the clock synchronizer must be initialized. The framer logic block checks the incoming bit stream for the unique pattern that defines the byte boundaries. This combinatorial logic filter looks for the X3.230 symbol defined as 'Special Character Comma' (K28.5). After K28.5 is found, the free running bit counter in the clock synchronizer block is synchronously reset to its initial state, thus 'framing' the data to the correct byte boundaries.

Since noise-induced errors can cause the incoming data to be corrupted, and because many combinations of error and legal data can create an alias K28.5, an option is included to disable resynchronization of the bit counter. The framer will be inhibited when the RF input is held LOW. When RF rises, RDY will be inhibited until a K28.5 has been detected, and RDY will resume its normal function. Data will continue to flow through the Receiver while RDY is inhibited.

#### **Encoded Mode Operation**

In encoded mode the serial input data is decoded into eight bits of data ( $Q_0-Q_7$ ), a context control bit (SC/D), and a system diagnostic output bit (RVS). If the pattern in the decode register is found in the Valid Data Characters table, the context of the data is decoded as normal message data and the SC/D output will be LOW. If the incoming bit pattern is found in the Valid Special Character Codes and Sequences table, it is interpreted as 'control' or 'protocol information', and the SC/D output will be HIGH. Special characters include all protocol characters defined for use in packets for Fibre Channel, ESCON, and other proprietary and diagnostic purposes.

The violation symbol that can be explicitly sent as part of a user data packet (that is, transmitter sending C0.7;  $D_{7-0} = 111\ 00000$  and SC/D = 1; or SVS = 1) will be decoded and indicated in exactly the same way as a noise-induced error in the transmission link. This function will allow system diagnostics to evaluate the error in an unambiguous manner, and will not require any modification to the receiver data interface for error-testing purposes.



### **Bypass Mode Operation**

In bypass mode the serial input data is not decoded, and is transferred directly from the decode register to the output register's 10 bits (Q( $_{a-j}$ ). It is assumed that the data has been preencoded prior to transmission, and will be decoded in subsequent logic external to HOTLink. This data can use any encoding method suitable to the designer. The only restrictions upon the data encoding method is that it contain suitable transition density for the Receiver PLL data synchronizer (one per 10-bit byte) and that it be compatible with the transmission media.

The framer function in bypass mode is identical to encoded mode, so a K28.5 pattern can still be used to reframe the serial bit stream.

## **Parallel Output Function**

The 10 outputs ( $Q_{0-7}$ , SC/ $\overline{D}$ , and RVS) all transition simultaneously, and are aligned with RDY and CKR with timing allowances to interface directly with either an asynchronous FIFO or a clocked FIFO. Typical FIFO connections are shown in Figure 6 on page 12.

Data outputs can be clocked into the system using either the rising or falling edge of CKR, or the rising or falling edge of RDY. If CKR is used, RDY can be used as an enable for the receiving logic. A LOW pulse on RDY shows that new data has been received and is ready to be delivered. The signal on RDY is a 60%-LOW duty cycle byte-rate pulse train suitable for the write pulse in asynchronous FIFOs such as the CY7C42X, or the enable write input on Clocked FIFOs such as the CY7C44X. HIGH on RDY shows that the received data appearing at the outputs is the null character (normally inserted by the transmitter as a pad between data inputs) and should be ignored.

When the transmitter is disabled it will continuously send pad characters (K28.5). To assure that the receive FIFO will not be overfilled with these dummy bytes, the RDY pulse output is inhibited during fill strings. Data at the  $Q_{0-7}$  outputs will reflect the correct received data, but will not appear to change, since a string of K28.5s all are decoded as  $Q_{7-0}$  =000 00101 and SC/D = 1 (C5.0). When new data appears (not K28.5), the RDY output will resume normal function. The "last" K28.5 will be accompanied by a normal RDY pulse.

Fill characters are defined as any K28.5 followed by another K28.5. All fill characters will not cause RDY to pulse. Any K28.5 followed by any other character (including violation or illegal characters) will be interpreted as usable data and will cause RDY to pulse.

As noted above,  $\overline{RDY}$  can also be used as an indication of correct framing of received data. While the receiver is awaiting receipt of a K28.5 with RF HIGH, the  $\overline{RDY}$  outputs will be inhibited. When  $\overline{RDY}$  resumes, the received data will be properly framed and will be decoded correctly. In Bypass mode with RF HIGH,  $\overline{RDY}$  will pulse once for each K28.5 received. For more information on the  $\overline{RDY}$  pin, consult the "HOTLink CY7B933  $\overline{RDY}$  Pin Description" application note.

Code rule violations and reception errors will be indicated as follows:

| ionowo.                                                     |     |      |        |             |
|-------------------------------------------------------------|-----|------|--------|-------------|
| <u> </u>                                                    | RVS | SC/D | Qouts  | <u>Name</u> |
| Good Data code received<br>with good running disparity (RD) | 0 ( | 0    | 00-FF  | 0.0-31.7    |
| Good Special Character code received with good RD           | 0   | 1    | 00-0BC | 0.0-11.0    |
| 3. K28.7 immediately following K28.1 (ESCON Connect_SOF)    | 0   | 1    | 27     | C7.1        |
| 4. K28.7 immediately following K28.5 (ESCON Passive_SOF)    | 0   | 1    | 47     | C7.2        |
| 5. Unassigned code received                                 | 1   | 1    | E0     | C0.7        |
| 6K28.5+ received when RD was +                              | 1   | 1    | E1     | C1.7        |
| 7. +K28.5– received when RD was –                           | 1   | 1    | E2     | C2.7        |
| 8. Good code received with wrong RD                         | 1   | 1    | E4     | C4.7        |

# **Receiver Serial Data Requirements**

The CY7B933 HOTLink Receiver serial input capability conforms to the requirements of the Fibre Channel specification. The serial data input is tracked by an internal PLL that is used to recover the clock phase and to extract the data from the serial bit stream. Jitter tolerance characteristics (including both PLL and logic component requirements) are shown below:

- Deterministic Jitter Tolerance (Dj) > 40% of t<sub>B</sub>. Typically measured while receiving data carried by a bandwidth-limited channel (e.g., a coaxial transmission line) while maintaining a Bit Error Rate (BER) < 10–12.
- Random Jitter Tolerance (Rj) > 90% of t<sub>B</sub>. Typically measured while receiving data carried by a random-noise-limited channel (e.g., a fiber-optic transmission system with low light levels) while maintaining a Bit Error Rate (BER) < 10–12.</p>
- Total Jitter Tolerance > 90% of t<sub>B</sub>. Total of Dj + Rj.
- PLL-acquisition time < 500-bit times from worst-case phase or frequency change in the serial input data stream, to receiving data within BER objective of 10–12. Stable power supplies within specifications, stable REFCLK input frequency and normal data framing protocols are assumed.

**Note** Acquisition time is measured from worst-case phase or frequency change to zero phase and frequency error. As a result of the receiver's wide jitter tolerance, valid data appears at the receiver's outputs a few byte times after a worst-case phase change.



## Receiver Test Mode Description

The CY7B933 receiver offers two types of test mode operation, BIST mode and Test mode. In a normal system application, the Built-In Self-Test (BIST) mode can be used to check the functionality of the transmitter, the receiver and the link connecting them. This mode is available with minimal impact on user system logic, and can be used as part of the normal system diagnostics. Typical connections and timing are shown in Figure 8 on page 15.

#### **BIST Mode**

The BIST mode function is as follows:

- Set BISTEN LOW to enable self-test generation and await RDY LOW indicating that the initialization code has been received
- Monitor RVS and check for any byte time with the pin HIGH to detect pattern mismatches. RDY will pulse HIGH once per BIST loop, and can be used by an external counter to monitor test pattern progress. Q<sub>0-7</sub> and SC/D will show the expected pattern and may be useful for debug purposes.
- When testing is completed, set BISTEN HIGH and resume normal function.

**Note** A specific test of the RVS output may be required to assure an adequate test. To perform this test, it is only necessary to have the transmitter send violation (SVS = HIGH) for a few bytes before beginning the BIST test sequence. Alternatively, the receiver could enter BIST mode after the transmitter has begun sending BIST loop data, or be removed before the transmitter finishes sending BIST loops, each of which contain several deliberate violations and should cause RVS to pulse HIGH.

BIST mode is intended to check the entire function of the Transmitter, serial link, and receiver. It augments normal factory ATE testing and provides the user system with a rigorous test mechanism to check the link transmission system, without requiring any significant system overhead.

When in bypass mode, the BIST logic will function in the same way as in the encoded mode. MODE = HIGH and BISTEN = LOW causes the receiver to switch to encoded mode and begin checking the decoded received data of the BIST pattern, as if MODE = LOW. When BISTEN returns to HIGH, the receiver resumes normal bypass operation. In test mode the BIST function works as in the normal mode.

#### **Test Mode**

The MODE input pin selects between three receiver functional modes. When wired to VCC, the shifter contents bypass the decoder and go directly from the decoder latch to the  $Q_{a-j}$  inputs of the output latch. When wired to GND, the outputs are decoded using the 8B/10B codes shown at the end of this datasheet and become  $Q_{0-7}$ , RVS, and SC/D. The third function is test mode, used for factory or incoming device test. This mode can be selected by leaving the MODE pin open (internal circuitry forces the open pin to  $V_{\rm CC}/2$ ).

Test mode causes the Receiver to function in its Encoded mode, but with INB (INB+) as the bit rate Test clock instead of the Internal PLL generated bit clock. In this mode, transfers between the Shifter, Decoder register and Output register are controlled by their normal logic, but with an external bit rate clock instead of the PLL (the recovered bit clock). Internal logic and test pattern

inputs can be synchronized by sending a SYNC pattern and allowing the Framer to align the logic to the bit stream. The flow is as follows:

- 1. Assert Test mode for several test clock cycles to establish normal counter sequence.
- 2. Assert RF to enable reframing.
- 3. Input a repeating sequence of bits representing K28.5 (Sync).
- RDY falling shows the byte boundary established by the K28.5 input pattern.
- Proceed with pattern, voltage and timing tests as is convenient for the test program and tester to be used.

(While in Test mode and in BIST mode with RF HIGH, the  $Q_{0-7}$ , RVS, and SC/ $\overline{D}$  outputs reflect various internal logic states and not the received data.)

Test mode is intended to allow logical, DC, and AC testing of the Receiver without requiring that the tester generate input data at the bit rate or accommodate the PLL lock, tracking and frequency range characteristics that are required when the part operates in its normal mode.

### X3.230 Codes and Notation Conventions

Information to be transmitted over a serial link is encoded eight bits at a time into a 10-bit Transmission Character and then sent serially, bit by bit. Information received over a serial link is collected ten bits at a time, and those Transmission Characters that are used for data (Data Characters) are decoded into the correct eight-bit codes. The 10-bit Transmission Code supports all 256 8-bit combinations. Some of the remaining Transmission Characters (Special Characters) are used for functions other than data transmission.

The primary rationale for use of a Transmission Code is to improve the transmission characteristics of a serial link. The encoding defined by the Transmission Code ensures that sufficient transitions are present in the serial bit stream to make clock recovery possible at the Receiver. Such encoding also greatly increases the likelihood of detecting any single or multiple bit errors that may occur during transmission and reception of information. In addition, some Special Characters of the Transmission Code selected by Fibre Channel Standard consist of a distinct and easily recognizable bit pattern (the Special Character Comma) that assists a Receiver in achieving word alignment on the incoming bit stream.

#### **Notation Conventions**

The documentation for the 8B/10B Transmission Code uses letter notation for the bits in an 8-bit byte. Fibre Channel Standard notation uses a bit notation of A, B, C, D, E, F, G, H for the 8-bit byte for the raw 8-bit data, and the letters a, b, c, d, e, i, f, g, h, j for encoded 10-bit data. There is a correspondence between bit A and bit a, B and b, C and c, D and d, E and e, F and f, G and g, and H and h. Bits i and j are derived, respectively, from (A,B,C,D,E) and (F,G,H).

The bit labeled A in the description of the 8B/10B Transmission Code corresponds to bit 0 in the numbering scheme of the FC-2 specification, B corresponds to bit 1, as shown below.

FC-2 bit designation— 7 6 5 4 3 2 1 0 HOTLink D/Q designation— 7 6 5 4 3 2 1 0 8B/10B bit designation— H G F E D C B F



To clarify this correspondence, the following example shows the conversion from an FC-2 Valid Data Byte to a Transmission Character (using 8B/10B Transmission Code notation)

FC-2 45

Bits:  $\frac{7654}{0100}$   $\frac{3210}{0101}$ 

Converted to 8B/10B notation (note carefully that the order of bits is reversed):

Data Byte NameD5.2
Bits: ABCDE FGH 10100 010

Translated to a transmission Character in the 8B/10B Transmission Code:

Bits: <u>abcdei</u> <u>fghj</u> 101001 0101

Each valid Transmission Character of the 8B/10B Transmission Code has been given a name using the following convention: cxx.y, where c is used to show whether the Transmission Character is a Data Character (c is set to D, and the SC/D pin is LOW) or a Special Character (c is set to K, and the SC/D pin is HIGH). When c is set to D, xx is the decimal value of the binary number composed of the bits E, D, C, B, and A in that order, and the y is the decimal value of the binary number composed of the bits H, G, and F in that order. When c is set to K, xx and y are derived by comparing the encoded bit patterns of the Special Character to those patterns derived from encoded Valid Data bytes and selecting the names of the patterns most similar to the encoded bit patterns of the Special Character.

Under the above conventions, the Transmission Character used for the examples above, is referred to by the name D5.2. The Special Character K29.7 is so named because the first six bits (abcdei) of this character make up a bit pattern similar to that resulting from the encoding of the unencoded 11101 pattern (29), and because the second four bits (fghj) make up a bit pattern similar to that resulting from the encoding of the unencoded 111 pattern (7).

**Note**: This definition of the 10-bit Transmission Code is based on (and is in basic agreement with) the following references, which describe the same 10-bit transmission code.

A.X. Widmer and P.A. Franaszek. "A DC-Balanced, Partitioned-Block, 8B/10B Transmission Code" *IBM Journal of Research and Development*, 27, No. 5: 440-451 (September, 1983).

U.S. Patent 4, 486, 739. Peter A. Franaszek and Albert X. Widmer. "Byte-Oriented DC Balanced (0.4) 8B/10B Partitioned Block Transmission Code" (December 4, 1984).

Fibre Channel Physical and Signaling Interface (dpANS X3.230-199X ANSI FC-PH Standard).

IBM Enterprise Systems Architecture/390 ESCON I/O Interface (document number SA22-7202).

### 8B/10B Transmission Code

The following information describes how the tables shall be used for both generating valid Transmission Characters (encoding) and checking the validity of received Transmission Characters (decoding). It also specifies the ordering rules to be followed when transmitting the bits within a character and the characters within the higher-level constructs specified by the standard.

#### **Transmission Order**

Within the definition of the 8B/10B Transmission Code, the bit positions of the Transmission Characters are labeled a, b, c, d, e, i, f, g, h, j. Bit "a" shall be transmitted first followed by bits b, c, d, e, i, f, g, h, and j in that order. (Note that bit i shall be transmitted between bit e and bit f, rather than in alphabetical order.)

#### Valid and Invalid Transmission Characters

The following tables define the valid Data Characters and valid Special Characters (K characters), respectively. The tables are used for both generating valid Transmission Characters (encoding) and checking the validity of received Transmission Characters (decoding). In the tables, each Valid-Data-byte or Special-Character-code entry has two columns that represent two (not necessarily different) Transmission Characters. The two columns correspond to the current value of the running disparity ("Current RD—" or "Current RD+"). Running disparity is a binary parameter with either the value negative (–) or the value positive (+).

After powering on, the Transmitter may assume either a positive or negative value for its initial running disparity. Upon transmission of any Transmission Character, the transmitter will select the proper version of the Transmission Character based on the current running disparity value, and the Transmitter shall calculate a new value for its running disparity based on the contents of the transmitted character. Special Character codes C1.7 and C2.7 can be used to force the transmission of a specific Special Character with a specific running disparity as required for some special sequences in X3.230.

After powering on, the Receiver may assume either a positive or negative value for its initial running disparity. Upon reception of any Transmission Character, the Receiver shall decide whether the Transmission Character is valid or invalid according to the following rules and tables and shall calculate a new value for its Running Disparity based on the contents of the received character.

The following rules for running disparity shall be used to calculate the new running-disparity value for Transmission Characters that have been transmitted (Transmitter's running disparity) and that have been received (Receiver's running disparity).

Running disparity for a Transmission Character shall be calculated from sub-blocks, where the first six bits (abcdei) form one sub-block and the second four bits (fghj) form the other sub-block. Running disparity at the beginning of the 6-bit sub-block is the running disparity at the end of the previous Transmission Character. Running disparity at the beginning of the 4-bit sub-block is the running disparity at the end of the 6-bit sub-block. Running disparity at the end of the Transmission Character is the running disparity at the end of the 4-bit sub-block.



Running disparity for the sub-blocks shall be calculated as follows:

- Running disparity at the end of any sub-block is positive if the sub-block contains more ones than zeros. It is also positive at the end of the 6-bit sub-block if the 6-bit sub-block is 000111, and it is positive at the end of the 4-bit sub-block if the 4-bit sub-block is 0011.
- Running disparity at the end of any sub-block is negative if the sub-block contains more zeros than ones. It is also negative at the end of the 6-bit sub-block if the 6-bit sub-block is 111000, and it is negative at the end of the 4-bit sub-block if the 4-bit sub-block is 1100.
- 3. Otherwise, running disparity at the end of the sub-block is the same as at the beginning of the sub-block.

# Using the Tables for Generating Transmission Characters

The appropriate entry in the table shall be found for the valid data byte or the special character byte for which a transmission character is to be generated (encoded). The current value of the transmitter's running disparity shall be used to select the trans-

mission character from its corresponding column. For each transmission character transmitted, a new value of the running disparity shall be calculated. This new value shall be used as the transmitter's current running disparity for the next valid data byte or special character byte to be encoded and transmitted. Table 3 shows naming notations and examples of valid transmission characters.

# Using the Tables for Checking the Validity of Received Transmission Characters

The column corresponding to the current value of the receiver's running disparity shall be searched for the received transmission character. If the received transmission character is found in the proper column, then the transmission character is valid and the associated data byte or special character code is determined (decoded). If the received transmission character is not found in that column, then the transmission character is invalid. This is called a code violation. Independent of the transmission character's validity, the received transmission character shall be used to calculate a new value of running disparity. The new value shall be used as the receiver's current running disparity for the next received transmission character.

**Table 3. Valid Transmission Characters** 

| Data      |                 |                     |           |  |  |  |  |  |
|-----------|-----------------|---------------------|-----------|--|--|--|--|--|
| Byte Name | D <sub>IN</sub> | or Q <sub>OUT</sub> | Hex Value |  |  |  |  |  |
| byte Name | 765             | 43210               | nex value |  |  |  |  |  |
| D0.0      | 000             | 00000               | 00        |  |  |  |  |  |
| D1.0      | 000             | 00001               | 01        |  |  |  |  |  |
| D2.0      | 000             | 00010               | 02        |  |  |  |  |  |
|           |                 |                     |           |  |  |  |  |  |
| D5.2      | 010             | 000101              | 45        |  |  |  |  |  |
| ·         | :               | :                   | ·         |  |  |  |  |  |
| D30.7     | 111             | 11110               | FE        |  |  |  |  |  |
| D31.7     | 111             | 11111               | FF        |  |  |  |  |  |

Detection of a code violation does not necessarily show that the transmission character in which the code violation was detected is in error. Code violations may result from a prior error that altered the running disparity of the bit stream which did not result in a detectable error at the transmission character in which the error occurred. Table 4 shows an example of this behavior.

Table 4. Code Violations Resulting from Prior Errors

| Description                | RD | Character   | RD | Character   | RD | Character      | RD |
|----------------------------|----|-------------|----|-------------|----|----------------|----|
| Transmitted data character | _  | D21.1       | _  | D10.2       | _  | D23.5          | +  |
| Transmitted bit stream     | _  | 101010 1001 | _  | 010101 0101 | -  | 111010 1010    | +  |
| Bit stream after error     | _  | 101010 1011 | +  | 010101 0101 | +  | 111010 1010    | +  |
| Decoded data character     | _  | D21.0       | +  | D10.2       | +  | Code Violation | +  |



# Valid Data Characters (SC/ $\overline{D}$ = LOW)

| Data Byte |     | Bits  | Current | t RD- | Curren | it RD+ |
|-----------|-----|-------|---------|-------|--------|--------|
| Name      | HGF | EDCBA | abcdei  | fghj  | abcdei | fghj   |
| D0.0      | 000 | 00000 | 100111  | 0100  | 011000 | 1011   |
| D1.0      | 000 | 00001 | 011101  | 0100  | 100010 | 1011   |
| D2.0      | 000 | 00010 | 101101  | 0100  | 010010 | 1011   |
| D3.0      | 000 | 00011 | 110001  | 1011  | 110001 | 0100   |
| D4.0      | 000 | 00100 | 110101  | 0100  | 001010 | 1011   |
| D5.0      | 000 | 00101 | 101001  | 1011  | 101001 | 0100   |
| D6.0      | 000 | 00110 | 011001  | 1011  | 011001 | 0100   |
| D7.0      | 000 | 00111 | 111000  | 1011  | 000111 | 0100   |
| D8.0      | 000 | 01000 | 111001  | 0100  | 000110 | 1011   |
| D9.0      | 000 | 01001 | 100101  | 1011  | 100101 | 0100   |
| D10.0     | 000 | 01010 | 010101  | 1011  | 010101 | 0100   |
| D11.0     | 000 | 01011 | 110100  | 1011  | 110100 | 0100   |
| D12.0     | 000 | 01100 | 001101  | 1011  | 001101 | 0100   |
| D13.0     | 000 | 01101 | 101100  | 1011  | 101100 | 0100   |
| D14.0     | 000 | 01110 | 011100  | 1011  | 011100 | 0100   |
| D15.0     | 000 | 01111 | 010111  | 0100  | 101000 | 1011   |
| D16.0     | 000 | 10000 | 011011  | 0100  | 100100 | 1011   |
| D17.0     | 000 | 10001 | 100011  | 1011  | 100011 | 0100   |
| D18.0     | 000 | 10010 | 010011  | 1011  | 010011 | 0100   |
| D19.0     | 000 | 10011 | 110010  | 1011  | 110010 | 0100   |
| D20.0     | 000 | 10100 | 001011  | 1011  | 001011 | 0100   |
| D21.0     | 000 | 10101 | 101010  | 1011  | 101010 | 0100   |
| D22.0     | 000 | 10110 | 011010  | 1011  | 011010 | 0100   |
| D23.0     | 000 | 10111 | 111010  | 0100  | 000101 | 1011   |
| D24.0     | 000 | 11000 | 110011  | 0100  | 001100 | 1011   |
| D25.0     | 000 | 11001 | 100110  | 1011  | 100110 | 0100   |
| D26.0     | 000 | 11010 | 010110  | 1011  | 010110 | 0100   |
| D27.0     | 000 | 11011 | 110110  | 0100  | 001001 | 1011   |
| D28.0     | 000 | 11100 | 001110  | 1011  | 001110 | 0100   |
| D29.0     | 000 | 11101 | 101110  | 0100  | 010001 | 1011   |
| D30.0     | 000 | 11110 | 011110  | 0100  | 100001 | 1011   |
| D31.0     | 000 | 11111 | 101011  | 0100  | 010100 | 1011   |



| Data Byte |     | Bits  | Curren | t RD- | Current RD+ |      |  |
|-----------|-----|-------|--------|-------|-------------|------|--|
| Name      | HGF | EDCBA | abcdei | fghj  | abcdei      | fghj |  |
| D0.1      | 001 | 00000 | 100111 | 1001  | 011000      | 1001 |  |
| D1.1      | 001 | 00001 | 011101 | 1001  | 100010      | 1001 |  |
| D2.1      | 001 | 00010 | 101101 | 1001  | 010010      | 1001 |  |
| D3.1      | 001 | 00011 | 110001 | 1001  | 110001      | 1001 |  |
| D4.1      | 001 | 00100 | 110101 | 1001  | 001010      | 1001 |  |
| D5.1      | 001 | 00101 | 101001 | 1001  | 101001      | 1001 |  |
| D6.1      | 001 | 00110 | 011001 | 1001  | 011001      | 1001 |  |
| D7.1      | 001 | 00111 | 111000 | 1001  | 000111      | 1001 |  |
| D8.1      | 001 | 01000 | 111001 | 1001  | 000110      | 1001 |  |
| D9.1      | 001 | 01001 | 100101 | 1001  | 100101      | 1001 |  |
| D10.1     | 001 | 01010 | 010101 | 1001  | 010101      | 1001 |  |
| D11.1     | 001 | 01011 | 110100 | 1001  | 110100      | 1001 |  |
| D12.1     | 001 | 01100 | 001101 | 1001  | 001101      | 1001 |  |
| D13.1     | 001 | 01101 | 101100 | 1001  | 101100      | 1001 |  |
| D14.1     | 001 | 01110 | 011100 | 1001  | 011100      | 1001 |  |
| D15.1     | 001 | 01111 | 010111 | 1001  | 101000      | 1001 |  |
| D16.1     | 001 | 10000 | 011011 | 1001  | 100100      | 1001 |  |
| D17.1     | 001 | 10001 | 100011 | 1001  | 100011      | 1001 |  |
| D18.1     | 001 | 10010 | 010011 | 1001  | 010011      | 1001 |  |
| D19.1     | 001 | 10011 | 110010 | 1001  | 110010      | 1001 |  |
| D20.1     | 001 | 10100 | 001011 | 1001  | 001011      | 1001 |  |
| D21.1     | 001 | 10101 | 101010 | 1001  | 101010      | 1001 |  |
| D22.1     | 001 | 10110 | 011010 | 1001  | 011010      | 1001 |  |
| D23.1     | 001 | 10111 | 111010 | 1001  | 000101      | 1001 |  |
| D24.1     | 001 | 11000 | 110011 | 1001  | 001100      | 1001 |  |
| D25.1     | 001 | 11001 | 100110 | 1001  | 100110      | 1001 |  |
| D26.1     | 001 | 11010 | 010110 | 1001  | 010110      | 1001 |  |
| D27.1     | 001 | 11011 | 110110 | 1001  | 001001      | 1001 |  |
| D28.1     | 001 | 11100 | 001110 | 1001  | 001110      | 1001 |  |
| D29.1     | 001 | 11101 | 101110 | 1001  | 010001      | 1001 |  |
| D30.1     | 001 | 11110 | 011110 | 1001  | 100001      | 1001 |  |
| D31.1     | 001 | 11111 | 101011 | 1001  | 010100      | 1001 |  |
| D0.2      | 010 | 00000 | 100111 | 0101  | 011000      | 0101 |  |



| Data Byte |     | Bits  | Current | RD-  | t RD+  |      |
|-----------|-----|-------|---------|------|--------|------|
| Name      | HGF | EDCBA | abcdei  | fghj | abcdei | fghj |
| D1.2      | 010 | 00001 | 011101  | 0101 | 100010 | 0101 |
| D2.2      | 010 | 00010 | 101101  | 0101 | 010010 | 0101 |
| D3.2      | 010 | 00011 | 110001  | 0101 | 110001 | 0101 |
| D4.2      | 010 | 00100 | 110101  | 0101 | 001010 | 0101 |
| D5.2      | 010 | 00101 | 101001  | 0101 | 101001 | 0101 |
| D6.2      | 010 | 00110 | 011001  | 0101 | 011001 | 0101 |
| D7.2      | 010 | 00111 | 111000  | 0101 | 000111 | 0101 |
| D8.2      | 010 | 01000 | 111001  | 0101 | 000110 | 0101 |
| D9.2      | 010 | 01001 | 100101  | 0101 | 100101 | 0101 |
| D10.2     | 010 | 01010 | 010101  | 0101 | 010101 | 0101 |
| D11.2     | 010 | 01011 | 110100  | 0101 | 110100 | 0101 |
| D12.2     | 010 | 01100 | 001101  | 0101 | 001101 | 0101 |
| D13.2     | 010 | 01101 | 101100  | 0101 | 101100 | 0101 |
| D14.2     | 010 | 01110 | 011100  | 0101 | 011100 | 0101 |
| D15.2     | 010 | 01111 | 010111  | 0101 | 101000 | 0101 |
| D16.2     | 010 | 10000 | 011011  | 0101 | 100100 | 0101 |
| D17.2     | 010 | 10001 | 100011  | 0101 | 100011 | 0101 |
| D18.2     | 010 | 10010 | 010011  | 0101 | 010011 | 0101 |
| D19.2     | 010 | 10011 | 110010  | 0101 | 110010 | 0101 |
| D20.2     | 010 | 10100 | 001011  | 0101 | 001011 | 0101 |
| D21.2     | 010 | 10101 | 101010  | 0101 | 101010 | 0101 |
| D22.2     | 010 | 10110 | 011010  | 0101 | 011010 | 0101 |
| D23.2     | 010 | 10111 | 111010  | 0101 | 000101 | 0101 |
| D24.2     | 010 | 11000 | 110011  | 0101 | 001100 | 0101 |
| D25.2     | 010 | 11001 | 100110  | 0101 | 100110 | 0101 |
| D26.2     | 010 | 11010 | 010110  | 0101 | 010110 | 0101 |
| D27.2     | 010 | 11011 | 110110  | 0101 | 001001 | 0101 |
| D28.2     | 010 | 11100 | 001110  | 0101 | 001110 | 0101 |
| D29.2     | 010 | 11101 | 101110  | 0101 | 010001 | 0101 |
| D30.2     | 010 | 11110 | 011110  | 0101 | 100001 | 0101 |
| D31.2     | 010 | 11111 | 101011  | 0101 | 010100 | 0101 |
| D0.3      | 011 | 00000 | 100111  | 0011 | 011000 | 1100 |
| D1.3      | 011 | 00001 | 011101  | 0011 | 100010 | 1100 |



| Data Byte<br>Name | Bits |       | Current RD- |      | Current RD+ |      |
|-------------------|------|-------|-------------|------|-------------|------|
|                   | HGF  | EDCBA | abcdei      | fghj | abcdei      | fghj |
| D2.3              | 011  | 00010 | 101101      | 0011 | 010010      | 1100 |
| D3.3              | 011  | 00011 | 110001      | 1100 | 110001      | 0011 |
| D4.3              | 011  | 00100 | 110101      | 0011 | 001010      | 1100 |
| D5.3              | 011  | 00101 | 101001      | 1100 | 101001      | 0011 |
| D6.3              | 011  | 00110 | 011001      | 1100 | 011001      | 0011 |
| D7.3              | 011  | 00111 | 111000      | 1100 | 000111      | 0011 |
| D8.3              | 011  | 01000 | 111001      | 0011 | 000110      | 1100 |
| D9.3              | 011  | 01001 | 100101      | 1100 | 100101      | 0011 |
| D10.3             | 011  | 01010 | 010101      | 1100 | 010101      | 0011 |
| D11.3             | 011  | 01011 | 110100      | 1100 | 110100      | 0011 |
| D12.3             | 011  | 01100 | 001101      | 1100 | 001101      | 0011 |
| D13.3             | 011  | 01101 | 101100      | 1100 | 101100      | 0011 |
| D14.3             | 011  | 01110 | 011100      | 1100 | 011100      | 0011 |
| D15.3             | 011  | 01111 | 010111      | 0011 | 101000      | 1100 |
| D16.3             | 011  | 10000 | 011011      | 0011 | 100100      | 1100 |
| D17.3             | 011  | 10001 | 100011      | 1100 | 100011      | 0011 |
| D18.3             | 011  | 10010 | 010011      | 1100 | 010011      | 0011 |
| D19.3             | 011  | 10011 | 110010      | 1100 | 110010      | 0011 |
| D20.3             | 011  | 10100 | 001011      | 1100 | 001011      | 0011 |
| D21.3             | 011  | 10101 | 101010      | 1100 | 101010      | 0011 |
| D22.3             | 011  | 10110 | 011010      | 1100 | 011010      | 0011 |
| D23.3             | 011  | 10111 | 111010      | 0011 | 000101      | 1100 |
| D24.3             | 011  | 11000 | 110011      | 0011 | 001100      | 1100 |
| D25.3             | 011  | 11001 | 100110      | 1100 | 100110      | 0011 |
| D26.3             | 011  | 11010 | 010110      | 1100 | 010110      | 0011 |
| D27.3             | 011  | 11011 | 110110      | 0011 | 001001      | 1100 |
| D28.3             | 011  | 11100 | 001110      | 1100 | 001110      | 0011 |
| D29.3             | 011  | 11101 | 101110      | 0011 | 010001      | 1100 |
| D30.3             | 011  | 11110 | 011110      | 0011 | 100001      | 1100 |
| D31.3             | 011  | 11111 | 101011      | 0011 | 010100      | 1100 |
| D0.4              | 100  | 00000 | 100111      | 0010 | 011000      | 1101 |
| D1.4              | 100  | 00001 | 011101      | 0010 | 100010      | 1101 |
| D2.4              | 100  | 00010 | 101101      | 0010 | 010010      | 1101 |



| Data Byte<br>Name | Bits |       | Current RD- |      | Curren | t RD+ |
|-------------------|------|-------|-------------|------|--------|-------|
|                   | HGF  | EDCBA | abcdei      | fghj | abcdei | fghj  |
| D3.4              | 100  | 00011 | 110001      | 1101 | 110001 | 0010  |
| D4.4              | 100  | 00100 | 110101      | 0010 | 001010 | 1101  |
| D5.4              | 100  | 00101 | 101001      | 1101 | 101001 | 0010  |
| D6.4              | 100  | 00110 | 011001      | 1101 | 011001 | 0010  |
| D7.4              | 100  | 00111 | 111000      | 1101 | 000111 | 0010  |
| D8.4              | 100  | 01000 | 111001      | 0010 | 000110 | 1101  |
| D9.4              | 100  | 01001 | 100101      | 1101 | 100101 | 0010  |
| D10.4             | 100  | 01010 | 010101      | 1101 | 010101 | 0010  |
| D11.4             | 100  | 01011 | 110100      | 1101 | 110100 | 0010  |
| D12.4             | 100  | 01100 | 001101      | 1101 | 001101 | 0010  |
| D13.4             | 100  | 01101 | 101100      | 1101 | 101100 | 0010  |
| D14.4             | 100  | 01110 | 011100      | 1101 | 011100 | 0010  |
| D15.4             | 100  | 01111 | 010111      | 0010 | 101000 | 1101  |
| D16.4             | 100  | 10000 | 011011      | 0010 | 100100 | 1101  |
| D17.4             | 100  | 10001 | 100011      | 1101 | 100011 | 0010  |
| D18.4             | 100  | 10010 | 010011      | 1101 | 010011 | 0010  |
| D19.4             | 100  | 10011 | 110010      | 1101 | 110010 | 0010  |
| D20.4             | 100  | 10100 | 001011      | 1101 | 001011 | 0010  |
| D21.4             | 100  | 10101 | 101010      | 1101 | 101010 | 0010  |
| D22.4             | 100  | 10110 | 011010      | 1101 | 011010 | 0010  |
| D23.4             | 100  | 10111 | 111010      | 0010 | 000101 | 1101  |
| D24.4             | 100  | 11000 | 110011      | 0010 | 001100 | 1101  |
| D25.4             | 100  | 11001 | 100110      | 1101 | 100110 | 0010  |
| D26.4             | 100  | 11010 | 010110      | 1101 | 010110 | 0010  |
| D27.4             | 100  | 11011 | 110110      | 0010 | 001001 | 1101  |
| D28.4             | 100  | 11100 | 001110      | 1101 | 001110 | 0010  |
| D29.4             | 100  | 11101 | 101110      | 0010 | 010001 | 1101  |
| D30.4             | 100  | 11110 | 011110      | 0010 | 100001 | 1101  |
| D31.4             | 100  | 11111 | 101011      | 0010 | 010100 | 1101  |
| D0.5              | 101  | 00000 | 100111      | 1010 | 011000 | 1010  |
| D1.5              | 101  | 00001 | 011101      | 1010 | 100010 | 1010  |
| D2.5              | 101  | 00010 | 101101      | 1010 | 010010 | 1010  |
| D3.5              | 101  | 00011 | 110001      | 1010 | 110001 | 1010  |