# **Guzik AXIe-1 Local Bus Description**

**Rev 1.0** 

## **Table of Contents**

| 1 Overview                             | 3  |
|----------------------------------------|----|
| 2 Architecture                         | 3  |
| 2.1 Overview                           | 3  |
| 2.2 Reference Clock                    | 4  |
| 2.3 Synchronization Line               | 4  |
| 2.4 Transceiver                        | 5  |
| 2.4.1 Protocol TX and RX               |    |
| 2.4.2 Synchronization                  | 6  |
| 2.4.2.1 Synchronizer                   | 6  |
| 2.4.2.2 Word Aligner                   |    |
| 2.4.2.3 Channel Bonder                 |    |
| 2.4.3 Diagnostics                      |    |
| 2.4.4 Byte Serializer and Deserializer |    |
| 2.4.5 8B/10B Encoder and Decoder       |    |
| 2.4.6 Serializer and Deserializer      |    |
| 2.4.7 Clock Data Recovery (CDR)        | 9  |
| 3 Guzik AXIe ADC 6044 Interface        | 9  |
| 3.1 Data Groups                        | 9  |
| 3.2 Setup Sequence                     |    |
| 3.2.1 Reset Sequence                   |    |
| 3.2.2 Synchronization Sequence         |    |
| 3.2.2.1 Word Alignment Sequence        |    |
| 3.2.2.2 Channel Bonding Sequence       |    |
| 3.2.3 Diagnostics Sequence             | 12 |
| 4 Zone 2 Connector Specification       | 13 |
| 5 7one 2 Pinout                        | 13 |

#### 1 Overview

Guzik local bus delivers 40 GBytes/sec data transfer between adjacent blades connected through AXIe zone 2. Figure 1-1 illustrates the connections between multiple blades.



Figure 1-1. Guzik Local Bus Connections Between Multiple Blades

Each blade can transmit data to the next adjacent slot and receive data from the previous adjacent slot. A blade's transmit and receive operations are independent from each other. They can each operate at 40 GBytes/sec simultaneously. Guzik local bus uses dedicated transmitters and receivers, therefore data can only be transferred in one direction between two adjacent boards. However, with a modified backplane, two blades can transfer data between each other in both directions.

## 2 Architecture

#### 2.1 Overview

Guzik Local bus is a point-to-point connection between two adjacent blades. It contains 62 differential lines. In order to achieve 40 GBytes/sec, 60 lines are used for data transfer. Each data line runs at 6.8 Gbits/sec. The data lines are DC coupled and operate on 1.4-V PCML I/O standard. Guzik local bus uses 8B/10B encoding and user bandwidth is 40 GBytes/sec. However, with a modified backplane, each transceiver can run up to 8.5 Gbits/sec yielding a user bandwidth of 51 GBytes/sec. Next, one differential line is the 340 MHz reference clock. The reference clock is described in *Reference Clock* on page 4. Lastly, one differential line is the synchronization signal, which is used for data control handshaking. This is described in *Synchronization Line* on page 4. Each blade has one local bus for transmit and one local bus for receive. Each bus is connected to a different adjacent blade. As shown in Figure 2-1, Guzik local bus signals are the following:

60 data differential lines

(6.8 Gbits/sec each line)

1 reference clock differential line

(340 MHz)

1 synchronization differential line



Figure 2-1. Guzik Local Bus

## 2.2 Reference Clock

The Guzik local bus reference clock is the reference clock for data transfer between adjacent blades. The clock frequency is 340 MHz. The transceiver PLL multiplies the reference clock by 20 to generate a high-speed clock. The high-speed clock is directly related to the Guzik local bus data rates (6.8 Gbits/sec). The reference clock transmitted to an adjacent blade is an AC coupled LVDS I/O standard signal. A blade's transmit and receive circuitry share the same reference clock. It is generated on the transmitter blade with an onboard 340 MHz oscillator. This reference clock is sent to an adjacent blade through zone 2. Receivers should use their adjacent transmitter blades' reference clock from zone 2 instead of their own onboard oscillator. Figure 2-2 shows the Guzik local bus clock circuitry between two blades.



Figure 2-2. Guzik Local Bus Reference Clock

## 2.3 Synchronization Line

The Guzik local bus synchronization line is used for data control handshaking. This is a DC coupled unidirectional LVDS I/O standard communication line from the receiver to the transmitter. Handshaking can implement by two methods. First, it can be implemented with one asynchronous signal. For instance, a "stop" signal can be sent back to the transmitter to request a stop in data flow. Second, it can be implemented with serial data protocol. This method allows additional information to be sent back to the transmitter. Choosing an implementation method will depend on system requirements. Figure 2-3 shows how the Guzik local bus synchronization line is connected between two boards.



Figure 2-3. Guzik Local Bus Synchronization line

## 2.4 Transceiver

The transceiver logic behind the Guzik local bus consists of several transmit and receive blocks. A blade instantiates sixty transceivers to drive all sixty transmit and sixty receive data lines. However the user may operate each transceiver independently. The FPGA fabric is running at 170 MHz (half the reference clock speed). For simplicity, this section will describe one transceiver (one channel). Figure 2-4 shows the block diagram and datapath for a transceiver.



Figure 2-4. Transceiver Block Diagram

#### Transmitter Blocks:

- Protocol TX
- Diagnostics
- Synchronizer
- Byte Serializer
- 8B/10B Encoder
- Serializer

#### ■ Receiver Blocks:

- Protocol RX
- Diagnostics
- Channel Bonder
- Byte Deserializer
- 8B/10B Decoder
- Word Aligner
- Deserializer
- CDR

#### 2.4.1 Protocol TX and RX

The protocol blocks provide a simple user interface to the transceiver datapath. Both blocks' interfaces include 32-bit data, 4-bit valid and 4-bit mode. The protocol blocks data word size is 32 bits. This word is evenly divided into four groups (one byte per group). Each byte group has a corresponding valid and mode bit. When the valid bit is asserted, the corresponding byte group contains meaningful data. When the mode bit is asserted, the corresponding byte group is converted to a control tag. Typically the mode bit for highest byte group is used to determine that the entire word is a control word. In this case, the mode bit is asserted for highest byte group, while the 3 remaining lower byte groups are de-asserted. Data on the highest byte group is discarded and used as a control tag. The 3 remaining lower byte groups can carry user specified control data. In order to send a control word, all 4 valid bits must also be asserted. Refer to Figure 2-5 for protocol timing diagram.



Figure 2-5. Protocol Timing Diagram

## 2.4.2 Synchronization

Guzik local bus synchronization between two blades is required to ensure data passed into one blade's protocol TX will be the same data out of the adjacent blade's protocol RX. Since data is transmitted serially, certain data misalignment may occur during transmission. This can be due to skew in the physical medium or other electrical inconsistencies. The synchronizer, word aligner, and channel bonder blocks work together to restore the proper alignment. All three blocks utilizes data and k-characters to send and receive special 8B/10B control values for alignment purposes. Synchronization must be performed before any user data transfers. It is the user's responsibility to synchronize the Guzik local bus prior to usage.

#### 2.4.2.1 Synchronizer

The synchronizer block sends special 8B/10B control values to the receiver in order to perform word alignment and channel bonding. A rising edge on  $tx\_sendwordalign$  will send the word alignment pattern (32'h00005C3C) and its k-character (4'b0011) for one clock cycle. Thereafter the synchronizer will send zeros on both data and k-character busses until  $tx\_sendwordalign$  is de-asserted. A rising edge on  $tx\_sendchanbond$  will send channel alignment pattern (32'h0000007C) and its k-character (4'0001) for one clock cycle. Thereafter the synchronizer will send zeros on both data and k-character busses until  $tx\_sendchanbond$  is de-asserted. Figure 2-6 shows its timing diagram.



Figure 2-6. Synchronizer Timing Diagram

#### 2.4.2.2 Word Aligner

The word aligner block detects the word boundary on the received parallel data from the deserializer. Since data is transmitter serially, the word boundary of the upstream transmitter is lost upon deserialization. The word aligner restores the word boundary based on a pre-defined alignment pattern. It is located before the 8B/10B decoder, therefore it must word align to a 20-bit 8B/10B encoded pattern. The word alignment pattern (32'h00005C3C) 8B/10B encoded is 20'b10101111001001111100. The word aligner is controlled by the rising edge of rx\_enapatternalign. A rising edge will trigger the word aligner to look for the alignment pattern. Word alignment will only be performed once after each rising edge. Once word alignment is successful, the rx\_syncstatus signal will be asserted. It is recommended to deassert rx\_enapatternalign after alignment is successful. Figure 2-7 shows the word aligner input and output timing diagram.



Figure 2-7. Word Aligner Timing Diagram

#### 2.4.2.3 Channel Bonder

The channel bonder block is used to align skewed data across all receiver channels. Data in each channel can be misaligned with respect to one another due to skew in the physical medium. In order to align the channels, a channel alignment pattern 32'h0000007C along with k-character 4'b0001 is defined. All transmitters will synchronously send the channel alignment pattern for one clock cycle (refer to Figure 2-8). The channel alignment pattern may arrive at the receivers in different clock cycles (refer to Figure 2-9). Channel bonder blocks in each transceiver work together in order to perform channel bonding. First, the channel bonder blocks will count the clock cycle delays relative to each other. Then all channels are bonded based on the delays. Once bonded, the channelsbonded signal will be asserted and the channel alignment pattern will be clocked in the same clock cycle for all channels (refer to Figure 2-10). All data words received after the channel alignment pattern will also be bonded. Additionally, each k-character words also are bonded along with their respective data words.



1 CYCLE DELAY h2222222 h000007C h11111111 h33333333 hCCCCCCC hBBBBBBBB hAAAAAAAA Channel 1 h11111111 h2222222 h33333333 h44444444 hBBBBBBBB hAAAAAAAA h000007C Channel 2 2 CYCLE DELAY hCCCCCCC h11111111 hDDDDDDDDhBBBBBBBBB hAAAAAAAA h000007C h2222222 Channel 3 1 CYCLE DELA hBBBBBBBB hAAAAAAAA h000007C h11111111 h2222222 h33333333 hCCCCCCC Channel 4

Figure 2-9. Channel Bonder Input Data (Skewed)



Figure 2-10. Channel Bonder Output Data (Bonded)

## 2.4.3 Diagnostics

Diagnostics is used to assess transmitter and receiver functionality. This is necessary before any data transfers. Both transmitter and receiver have independent diagnostics blocks. The transmitter diagnostics block is enabled by asserting  $tx_diag_en$ ; the receiver diagnostics block is enabled by asserting  $tx_diag_en$ . The transmitter diagnostics block will send a series of pseudo-random numbers. These pseudo-random numbers are calculated by a predetermined formula. When the receiver diagnostics block receives a value in the series, it will calculate the next value using the predetermined formula. Then it will compare the calculated value to the next value it receives, and so forth. If the received data matches the expected value, then the data is received correctly. Otherwise, it will increment an error counter. The error counter will reset to zero on every rising edge of  $tx_diag_en$ . In order for correct operation, diagnostics data must arrive at receiver diagnostics block before the receiver diagnostics block begins assessment.

## 2.4.4 Byte Serializer and Deserializer

The byte serializer converts four bytes datapaths into two bytes datapaths. It will also convert the 4-bit k-characters to 2-bit k-characters. This allows the transceivers to run at higher data rates while the FPGA fabric runs at a lower clock frequency. The byte deserializer has the reversed operation which converts two bytes datapaths to four bytes datapaths. Additionally, it will convert the 2-bit k-characters to 4-bit k-characters.

## 2.4.5 8B/10B Encoder and Decoder

The 8B/10B encoder generates a 10-bit value from an 8-bit data and 1-bit k-character. The 8B/10B decoder has the reversed operation which generates an 8-bit data and 1-bit k-character from a 10-bit value. Two encoders are used on the transmit side to match the byte serializer output, while two decoders are used on the receiver side to match the byte deserializer input. A typical user does not need to interface directly with the 8B/10B encoders and decoders. Instead, the user will interface directly with the protocol blocks. This simplifies the Guzik local bus usage.

#### 2.4.6 Serializer and Deserializer

The serializer block converts low-speed 20-bit parallel data to high-speed serial data. The output is directly connected to the transmitter buffers. The deserializer block clocks in high-speed serial data from the receiver buffer and converts it to low-speed 20-bit parallel data.

## 2.4.7 Clock Data Recovery (CDR)

The clock data recovery block is necessary to recover the clock and data from the high-speed serial data stream. The CDR provides high-speed and low-speed clocks used throughout the transceiver.

## 3 Guzik AXIe ADC 6044 Interface

## 3.1 Data Groups

The Guzik AXIe ADC 6044 evenly divides the 60 Guzik local bus data lines into four data groups. Figure 3-1 illustrates how the data groups are divided and connected. Each data group is independently connected to an Altera Stratix IV FPGA device through 15 transceivers. The first data group (Group 1) is comprised of data lines from index 14:0. The second data group (Group 2) is comprised of data lines from 29:15. The third data group (Group 3) is comprised of data lines from 44:30. The fourth data group (Group 4) is comprised of data lines from 59:45. Refer to Figure 5-1 for a detailed zone 2 pinout. The reference clock and synchronization lines are common for all data groups. The *Setup Sequence* on page 10 must be performed separately for each data group. Therefore, channel bonding is also performed independently in each FPGA device.



Figure 3-1. Guzik AXIe ADC 6044 Data Groups

## 3.2 Setup Sequence

This section describes an example setup sequence to prepare two adjacent blades for data transfer. The setup sequence involves a reset sequence, synchronization sequence and a diagnostics sequence. Each sequence must be performed for each of the four data groups. This example uses two Guzik AXIe ADC 6044s.

## 3.2.1 Reset Sequence

The reset sequence is necessary to properly reset all analog and digital logic. This sequence must be performed prior to any other operation.

- 1. On the transmitter side, reset all digital logic in transmitter PCS by asserting tx digitalreset.
- 2. On the receiver side, reset all analog circuitry in receiver PMA by asserting  $rx\_analogreset$ .
- 3. On the receiver side, reset all digital logic in receiver PCS by asserting  $rx\_digitalreset$ .
- 4. On the transmitter side, power down the CMU PLLs by asserting pll powerdown.
- 5. On the receiver side, power down the CMU PLLs by asserting pll powerdown.
- 6. Wait 1us.
- 7. On the transmitter side, power up the CMU PLLs by de-asserting pll powerdown.
- 8. On the receiver side, power up the CMU PLLs by de-asserting pll powerdown.
- 9. On the transmitter side, poll the PLL status pll\_locked until CMU PLL is locked to the incoming reference clock frequency
- 10. On the transmitter side, release digital logic reset for the transmitter PCS by de-asserting tx digitalreset.
- 11. On the receiver side, poll the reconfiguration clock status reconfig\_busy until busy signal de-asserts which indicates the reconfiguration clock offset cancellation is complete.
- 12. On the receiver side, release analog circuitry reset for PMA by de-asserting rx analogreset.
- 13. On the receiver side, poll the receiver status rx\_freqlocked until the receiver is in lock-to-data mode.
- 14. Wait 4000ns.
- 15. On the receiver side, release digital logic reset for receiver PCS by de-asserting  ${\tt rx\_digitalreset}.$



Figure 3-2. Reset Sequence Timing Diagram

## 3.2.2 Synchronization Sequence

The synchronization sequence comprises of two parts. The first part performs word alignment as described in *Word Aligner* on page 7. The second part performs channel bonding as described in *Channel Bonder* on page 7.

#### 3.2.2.1 Word Alignment Sequence

- 1. On the receiver side, enable the word alignment block by asserting rx enapatternalign.
- 2. On the transmitter side, send a word alignment pattern 32'h00005C3C by asserting tx sendwordalign.
- 3. On the receiver side, poll word alignment status  $\verb"rx_syncstatus"$  until it verifies word boundary has been found.
- 4. On the receiver side, disable the word alignment block by de-asserting rx\_enapatternalign. Since the word boundary has been found, disable the word alignment block to avoid accidentally realignment.
- 5. On the transmitter side, de-assert tx\_sendwordalign.

#### 3.2.2.2 Channel Bonding Sequence

- 1. On the transmitter side, send a channel alignment pattern 32'h0000007C by asserting tx sendchanbond.
- 2. On the receiver side, poll channel alignment status channels bonded until channels are bonded.
- 3. On the transmitter side, de-assert tx sendchanbond.

## 3.2.3 Diagnostics Sequence

The diagnostics sequence uses the diagnostics blocks on both blades to perform data verification.

- 1. On the transmitter side, enable the transmitter diagnostics block to send diagnostics data by asserting tx diag en.
- 2. Wait minimum 500ns for data reach receiver. (minimum wait time will vary based on system layout)
- 3. On the receiver side, enable the receiver diagnostics block to begin data assessment by asserting rx diag en.
- 4. Run diagnostics for desired amount of time.
- 5. On the receiver side, disable the receiver diagnostics block by de-asserting rx diag en.
- 6. On the transmitter side, disable the transmitter diagnostics block by de-asserting tx diag en.



Figure 3-3. Diagnostics Sequence Timing Diagram

## **Zone 2 Connector Specification**

Guzik Local Bus synchronization

The zone 2 connector follows the same mechanical specifications as the AXIe-1 specification. In order to improve the reliability between boards, ZD Plus connectors are used. ZD Plus connectors are rated at 15 Gbits/sec. Figure 4-1 shows the Guzik local bus connector front view of a blade.



2 pairs Figure 4-1. Guzik Local Bus Connector (Blade Front View)

#### **Zone 2 Pinout**

An AXIe zone 2 connector includes 2 sets of Guzik local bus. One bus used to transmit data to the next adjacent blade. The second bus used to receive data from the previous adjacent blade. Refer to Figure 5-1 for pinout.



Figure 5-1. Guzik Local Bus Pinout



2443 Wyandotte Street Mountain View, CA 94043 Phone: (650) 625-8000 Fax: (650) 625-9325

E-mail: modularsales@guzik.com

http://www.guzik.com/

https://www.twitter.com/GuzikTest http://www.facebook.com/GuzikTest