

# SV3D\_09 Command Interface Design

# 1 Revision History

| 1.0 | 2016/07/26 | DE: created SV3D_01 command interface document. Captures common use cases.                                                                                                                                  |
|-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.1 | 2016/07/27 | DE: modified 'Port' column in Table 9. Now indicates which commands must be set on                                                                                                                          |
|     |            | both PortA and PortB.                                                                                                                                                                                       |
| 1.2 | 2016/11/08 | DE: added missing pattern start command                                                                                                                                                                     |
| 1.3 | 2017/01/05 | DE: update pattern sequencer slots.                                                                                                                                                                         |
| 1.4 | 2017/01/13 | DE: added instruction sequencer commands. Added 'Pattern Mode' and 'Pattern Disabled State'                                                                                                                 |
| 1.5 | 2017/04/21 | DE: added User Clock Modes and Frequency commands.                                                                                                                                                          |
| 1.6 | 2017/05/03 | DE: removed reference to cmd proc ready flag.                                                                                                                                                               |
| 1.7 | 2017/08/11 | DE: Added TX fine phase delay [0x0550] and added trigger pin description to Table 16.                                                                                                                       |
| 1.8 | 2017/08/18 | DE: Added block write for Rx Phase [0x0440] and added Tx Pattern Status [0x0582].                                                                                                                           |
| 1.9 | 2017/11/10 | DE: Added commands to support Rx User Pattern Memory. Added 'Memory Underflow' command.                                                                                                                     |
| 2.0 | 2018/01/15 | DE: Added command for fan out mode. Updated Pattern sequencer description.                                                                                                                                  |
| 2.1 | 2018/03/16 | DE: Added commands for force zero, coarse skew write, fine skew write, and Rx Rate Ratio.                                                                                                                   |
| 2.2 | 2018/05/01 | DE: Added command to read module speed grade.                                                                                                                                                               |
| 2.3 | 2018/07/30 | DE: Added command to disable tx alignment data.                                                                                                                                                             |
| 2.4 | 2018/11/29 | DE: Added calibration control registers.                                                                                                                                                                    |
| 2.5 | 2019/01/14 | DE: Added PTI registers.                                                                                                                                                                                    |
| 2.6 | 2019/02/20 | DE: Modified PTI Write command and added PTI Read Memory (0x0371)                                                                                                                                           |
| 2.7 | 2023/11/21 | DE: Updated number of user slots and programming examples. Updated Global and Hardware status codes.<br>Added Fan Out Mode descriptions. Added information on Tx Channel Groupings (see Global Target Mask) |

# 2 Motivation

Provides design detail for the command interface exposed by the SV3. The SPI ports and its timing parameters are documented elsewhere.

# 3 Conventions

Unless otherwise noted, multi-byte words are always transmitted MSB-first. Signed numbers are always expressed in 2's-compliment notation.

# 4 Introduction

All control of SV3 is carried out through its command interface, depicted in Figure 1. Control is carried out through the slave SPI ports. A soft-core processor on the module parses incoming SPI data, extracts and executes the commands embedded in it, and responds appropriately. The soft-core processor exerts control over all aspects of the module's functionality, shown simply as "controlled components" in the figure.



Figure 1: Hierarchy of the command interface

| • | Program:     | A <i>program</i> runs on the host and controls the module to carry out a high-level task.<br>Examples are an eye diagram measurement, and a mask test. Programs consist of many<br><i>operations</i> chained together.                                                                                                                                                |
|---|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Operation:   | <i>Operations</i> coincide with atomic module functions. The host carries out an operation by performing a short series of <i>transactions</i> . Examples are performing a bit error rate test (BERT) and setting a threshold voltage.                                                                                                                                |
| • | Transaction: | <i>Transactions</i> are the individual reads and writes that make up an operation. For example, a BERT operation consists of two transactions: one register write to start the BERT, and one register read to retrieve the result. Each transaction consists of one or more <i>transfers</i> , and the first transfer of every transaction is an <i>instruction</i> . |
| • | Transfer:    | A <i>transfer</i> communicates a specific kind of information between the host and module.<br>Examples of transfers are an instruction, a data block, and an acknowledge. A set of<br>transaction models prescribes the sequences of transfers to follow in all communication<br>with the module.                                                                     |

# 5 Command Interface

# 5.1 The Command Hierarchy

The command interface can be described hierarchically, as depicted in Figure 1. Terminology is summarized in the figure, and each level of the hierarchy is described in the sections that follow.

# 5.1.1 Command Hierarchy Example

A concrete example demonstrating this hierarchy is shown in Figure 2. At the left lies part of a program, shown as a series of operations. Each of these operations will have an implementation on the host, though in this example only the implementation of the Single-Shot BERT operation is shown. Moving to the right, we see the Single-Shot BERT operation expanded into its two constituent transactions: a Write Data Block, to start up to 16 BERTs, and Read Data Block, to obtain the results. Each transaction consists of several transfers: the first is always an instruction, and for data block transfers the second transfer contains the data block, and the third an Acknowledgement. The following sections will elaborate on the transaction models.

The wait state between the two transactions is necessary to allow the module to complete the BERT before reading the result – this is discussed further in Section 5.2.1. The shorter, fixed wait state between transfers reflects the time needed for the Command Processor to retrieve and act on the incoming SPI data.



Figure 2: An example demonstrating the command hierarchy

# 5.2 Operations

Operations are sets of transactions, implemented on the host, designed to accomplish some goal, such as performing a Single-Shot BERT. In general, an operation consists of many transactions, though some simple operations, such as retrieving an immediately-available value, are single-transaction operations. All operations follow the operation models summarized in Table 1.

| Operation model                        | Transaction        | Transaction Description                                                                  | Example                                          |  |  |
|----------------------------------------|--------------------|------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|
| Get/set immediate                      | 1                  | Read/write register or data                                                              | Read module status                               |  |  |
| Extended operation without<br>feedback | 1<br>< wait >      | Write register / data to start operation<br>< wait for completion >                      | Set threshold voltage on multiple<br>Rx channels |  |  |
| Extended operation with<br>feedback    | 1<br>< wait ><br>2 | Write reg / data to start operation<br>< wait for completion ><br>Read result reg / data | Perform BERT                                     |  |  |

#### Table 1: Operation models and their constituent transactions

#### 5.2.1 Wait States

Most of the operation models include a *wait* state, during which the module is allowed to complete a requested action before subsequent transfers are accepted. To determine completion of an action on the module, two mechanisms are available:

- 1. Status polling over SPI
- 2. Fixed worst-case timing

Fixed timing needs to reflect the worst-case duration of variable-duration commands, making it unnecessarily pessimistic. SPI polling, on the other hand, requires the host to be actively interrogating the device, meaning it can't be doing something else in the meantime.

#### Status Polling

During a read register transaction, described below, status bits are returned in the first transaction, and reflect the busy state of the module. By repeatedly issuing a read register transaction (targeting any register) and checking the status that's returned, the busy state of the module can be assessed. The contents of the status bits are discussed in Section 5.4.2.

#### Fixed worst-case timing

This represents the longest the operation could possibly take, meaning that a fixed delay can be used by the host, after which the module is guaranteed to be ready.

One limitation of this approach is that externally-triggered operations begin at a time determined by the trigger, and so the overall completion time needs to take into account the trigger time. It's up to the host to compute the overall timing, based on documented worst-case trigger-to-completion times, and knowledge of when the trigger is asserted.

Fixed timing information is implementation-dependent, and is TBD for the moment.

# 5.3 Transactions

A transaction is the collection of transfers required to perform a complete transmission of information between host and module. Every transaction begins with the host transmitting an instruction to the module. From there, the module interprets the op code to determine which transaction model to follow. Table 2 summarizes the transaction models, showing their constituent transfers.

Note that, since SPI is a full-duplex standard, each byte written to the module is accompanied by a byte read by the host. The data shown in the Tx column is the data transmitted to the module. The data in the Rx column is transferred simultaneously, from the module to the host.

| Transaction model | Transfer | Tx                                       | Rx                  |
|-------------------|----------|------------------------------------------|---------------------|
| Read register     | 1        | Instruction: register address            | Status              |
|                   | 2        | Tx Padding (8 bytes)                     | Ack, Register value |
| Write register    | 1        | Instruction: register address, new value | Status              |
|                   | 2        | Tx Padding (8 bytes)                     | Ack                 |
| Read data block   | 1        | Instruction: data address, data length   | Status              |
|                   | 2        | Tx Padding (arbitrary length)            | Data block          |
|                   | 3        | Tx Padding (8 bytes)                     | Ack                 |
| Write data block  | 1        | Instruction: data address, data length   | Status              |
|                   | 2        | Data block to write (arbitrary length)   | Rx padding          |
|                   | 3        | Tx Padding (8 bytes)                     | Ack                 |

#### Table 2: Transaction models and their constituent transfers

As shown, different subsets of the instruction are used depending on the transaction model. Some instruction fields are omitted from this table, such as the target field, which is used in a subset of the write register transactions. Individual transfer types are described below.

### 5.4 Transfers

At the lowest level of the command interface hierarchy is the transfer. A SV3 transfer corresponds to a single SPI transfer, meaning the slave select line is asserted, bytes are transferred (in both directions), and the slave select line deasserted. The following sections describe the data types that make up the transfers in Table 2.

As indicated in the text accompanying Figure 2, a fixed, minimum delay must exist between transfers, to allow the command processor to retrieve and act on the incoming SPI data. Alternatively, a flag can be used to indicate when the Command Processor is ready to accept a new transfer.

### 5.4.1 Instruction

Every instruction is 8 bytes long, and follows the format depicted in Table 3. Table 4 summarizes the meaning of each field of the instruction, and Table 5 enumerates the transfer codes used in the opcode field. Example instructions are provided in Table 6.

| Field     | Орс           | code | Add   | ress     | Target | Data |         |
|-----------|---------------|------|-------|----------|--------|------|---------|
| Subfield  | Rsvd Transfer |      | Comp  | Comp Sub |        |      | Total   |
| Byte cnt  |               | 1    | 2     | 2        | 1      | 4    | 8 bytes |
| Byte addr | -             | 7    | 6     | :5       | 4      | 3:0  |         |
| Bit cnt   | 6 2           |      | 8     | 8        | 8      | 32   | 64 bits |
| Bit addr  | 63:58 57:56   |      | 55:48 | 47:40    | 39:32  | 31:0 |         |

| Field   | Description                                                                                                                                           | Code  | Meaning           |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------|
| Opcode  | 8 bits containing a 2-bit transfer code (see below),                                                                                                  | 00    | Read register     |
|         | and 6 reserved bits which should be written as zero                                                                                                   | 01    | Write register    |
| Address | 16 bits total consisting of component address and<br>sub-address                                                                                      | 10    | Read data block   |
| Target  | 8 bits used to specify destinations / sources for                                                                                                     | 11    | Write data block  |
|         | some registers – e.g. the User Pattern Slot ID is<br>specified as a target when addressing the User Data<br>Pattern Memory                            |       |                   |
| Data    | 32 bits used to set register values; also used as data<br>lengths in data block transfers – interpretation<br>differs depending on address and opcode | Table | 5: Transfer codes |

#### Table 4: Instruction fields

| Instruction      | Opcode                        | Address          | Target        | Data            |
|------------------|-------------------------------|------------------|---------------|-----------------|
| Read status      | 0b00000000 (Read<br>register) | 0x01 02 (Status) | 0x00<br>(N/A) | 0x0000000 (N/A) |
| Set PRBS         | 0b00000001 (Write             | 0x03 30          | 0x00          | 0x00000005      |
| Polynomial Order | register)                     | (PRBS Poly)      | (N/A)         | (PRBS-5)        |
| Download data    | 0b00000010 (Read              | 0x03 10          | 0x00          | 0x00001000      |
| pattern          | data block)                   | (User data pat)  | (N/A)         | (length)        |
| Upload data      | 0b00000011 (Write             | 0x03 10          | 0x00          | 0x00001000      |
| pattern          | data block)                   | ( User data pat) | (N/A)         | (length)        |

### Table 6: Instruction examples

#### 5.4.2 Status transfer

While an 8-byte instruction is being transmitted, the module will respond with its *status*. The status is simply a bitfield, encoded as follows:

| Bit  | Meaning                               | Details                                                                                                                                                    |
|------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Presence (1)                          | Always returns 1 when the module is present – useful as a debugging tool                                                                                   |
| 1    | Busy (0) / Okay (1)                   | 0: Busy: indicates the module is busy with a previously-issued command; the transaction will not proceed<br>1: Okay: the transaction will proceed normally |
| 2    | Global Status Error<br>(0) / Okay (1) | When set to 0, indicates that one of the Errors reported in the Global status<br>register has been asserted.<br>0: Global Status Error<br>1: Okay          |
| 63:3 | Reserved                              |                                                                                                                                                            |

Table 7: Status bitfield

# 5.4.3 Ack transfer

8-byte Ack transfers are used to indicate the validity of instructions and successful transmission of data blocks. They follow a similar encoding to the status bitfield, as shown below.

| Bit   | Meaning                                                     | Details                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Presence                                                    | Always returns 1 when the module is present – useful as a debugging tool                                                                                                                                                        |
| 1     | Transaction valid                                           | A 0 indicates the transaction was invalid and will be ignored – this would be the case for an invalid instruction, for example;<br>A 1 indicates the transaction was successful                                                 |
| 2     | Parameters in range<br>and valid                            | A 0 indicates the parameters of the transaction were invalid and so the transaction will be ignored – this would be the case for an out-of range voltage setting, for example;<br>A 1 indicates the transaction was successful; |
| 31:3  | Reserved                                                    |                                                                                                                                                                                                                                 |
| 63:32 | Sometimes used for<br>Register Value,<br>otherwise Reserved | Some fields piggyback on the upper 4 bytes of the Ack transfer – see<br>Register Value below                                                                                                                                    |

#### Table 8: Ack bitfield

#### Register value

In a read register transaction, the register's contents are included in the upper 4 bytes of the Ack transfer.

#### 5.4.4 Padding Transfers

Padding is used when only half of the full-duplex SPI is in use. The exact content of Tx Padding isn't strictly important, but choosing a bit-balanced padding such as all 0xAA's is a sensible approach.

Rx Padding is all 0xAA's for successfully-received data. If, for some reason, data is not being received correctly, Rx padding switches to 0xFF's, and the transaction should be aborted.

# 6 Address Map

Table 9 depicts the address map of the SV3, including both register and data block addresses. Access modes, data types and additional details are provided in subsequent sections.

Commands must be directed to the required SPI port. Unless noted otherwise, commands which target channels 1-16 must be sent to SPI port A. Commands targeting channels 17-32 must be sent via SPI port B.

Generally the 'Global Target Mask [0x0232]' is used to indicate which channels will be addressed. For example, a mask of 0x01 sent via SPI port A would be addressing Channel 1; while a mask of 0x01 sent via SPI port B would be addressing Channel 17. In general all commands can be sent to either port A or B (A/B). Some hardware specific commands need to be sent to port A first, and then to port B (A->B). Note that there are a handful for commands which will only be accepted on port A (A).

|                          | Cmpt /<br>Subaddr | R/W | Туре | Port | Default   | Data / Data Block Contents                                            | Target | Description                                                                                                                                                                                                                                                                                                                                    |
|--------------------------|-------------------|-----|------|------|-----------|-----------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module Control           | 0x01              |     |      |      |           |                                                                       |        |                                                                                                                                                                                                                                                                                                                                                |
| Global Status            | 0x02              | R   | Reg  | A/B  | 0         | Global Error Bitfield<br>0 means no errors<br>(Section 8.6, Table 17) | -      | Reflects the global module state; in case<br>of an invalid command, out-of-range<br>parameter, trigger timeout this register is<br>set to the specific error code                                                                                                                                                                              |
| Global Status Error Mask | 0x04              | RW  | Reg  | A/B  | OxFFFFFFF | Global Status Error Mask                                              | -      | Sets which Global Status error bits will be<br>used in triggering the Global Status<br>Error, and Status Transfer bits. By Default<br>all errors are monitored. Logic 0 would<br>mean a status bit is masked and<br>therefore will not generate a Global<br>status assertion. Errors will always be<br>reported in the Global Status register. |
| Clear Global Status      | 0x06              | W   | Reg  | A/B  | -         | 32-bit Error Bitfield                                                 | -      | Clears selected bits in the Global Status<br>register [0x0102]. Logic 1 indicates the<br>Error bit will be cleared.                                                                                                                                                                                                                            |
| Temperature              | 0x10              | R   | Data | A    |           | Block of 2 32 bit temperatures.                                       | -      | Temperature is specified in 1 degree (C)<br>increments. First temperature is<br>measured on dye. Second is pcb<br>temperature.                                                                                                                                                                                                                 |
| Delay                    | 0x20              | W   | Reg  | A/B  | -         | Number of microseconds                                                | -      | Generate delay, holding command processor busy.                                                                                                                                                                                                                                                                                                |
| Underflow                | 0x44              | R   | Reg  | A    | -         | 0 - No underflow, 1 - Underflow<br>Detected                           | -      | Indicates if bandwidth limitations are<br>being exceeded. Bandwidth is affected<br>by data rate and tx pattern composition.                                                                                                                                                                                                                    |

|                       | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                              | Target | Description                                                                                                                                                                                                    |
|-----------------------|-------------------|-----|------|------|---------|---------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fan Out Mode          | 0x46              | RW  | Reg  | A    | 0       | Value indicating fan out mode                           | -      | Sets the fan out mode for the module. 0<br>= $x1$ , 1 = $x2$ , 2 = $x4$ , 3 = $x8$ . If the same<br>data is being played on multiple<br>channels the fan out mode can be used<br>to mitigate bandwidth issues. |
|                       |                   |     |      |      |         |                                                         |        | X1 Mode Fan Out Disabled                                                                                                                                                                                       |
|                       |                   |     |      |      |         |                                                         |        | X2 Groups 1,3,5 and 7 of TX are<br>repeated on next group                                                                                                                                                      |
|                       |                   |     |      |      |         |                                                         |        | X4 Groups 1 and 5 of TX are repeated on all groups of respective core                                                                                                                                          |
|                       |                   |     |      |      |         |                                                         |        | X8 Group 1 is repeated on all groups of both cores                                                                                                                                                             |
| PTI Transfer Status   | 0xC0              |     | R    | Reg  | -       | Status bit indicating ready/busy                        | -      | PTI Transfer status indicates whether the<br>PTI is currently ready or busy. 0 - Busy,<br>1- Ready.                                                                                                            |
| PTI Transfer Length   | 0xC4              |     | RW   | Reg  | -       | 32-bit transfer length in bytes                         | -      | Set the transfer length in bytes for the next PTI transfer.                                                                                                                                                    |
| PTI Transfer Start    | 0xC6              |     | W    | Reg  | -       | 32-bit transfer direction                               | -      | Writing to this register starts either a<br>transfer read or transfer write. 0x01 -<br>Read, 0x02 - Write                                                                                                      |
| PTI Transfer Reset    | 0xC8              |     | W    | Reg  | -       | -                                                       | -      | Resets and clears existing PTI transfer.                                                                                                                                                                       |
| Configuration Manager | 0x02              |     |      |      |         |                                                         |        |                                                                                                                                                                                                                |
| HW, FW and SW IDs     | 0x02              | R   | Data | A/B  | -       | Three 8-byte identifiers, in the order<br>[HW, FW, SW]; | -      | Identifies the type and version of the hardware, firmware and software                                                                                                                                         |
| Module Revision       | 0x06              | R   | Reg  | A/B  | -       | Module Revision Letter                                  | -      | Identifies the revision of the module.                                                                                                                                                                         |
| Personality ID        | 0x08              | R   | Data | A/B  | -       | A 24-byte Personality ID String<br>(Section 8.5)        | -      | Identifies the currently-running personality                                                                                                                                                                   |
| SV3 Serial number     | 0x0E              | R   | Data | A/B  | -       | A 16 byte serial number.                                |        | Identifies the SV3 serial number in ASCII.                                                                                                                                                                     |

|                           | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                         | Target | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------|-------------------|-----|------|------|---------|----------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Global Target Mask        | 0x32              | RW  | Reg  | A/B  | -       | 16-bit channel bitfield or<br>4-bit group bitfield | -      | Mask indicates which channels or groups<br>are affected by various SPI commands.<br>When the mask is used as a channel<br>bitfield, the 16 LSB of the register<br>contents represent channels [15:0].<br>When the mask is used as a group<br>bitfield, the 4 LSB of the register<br>contents represent groups [3:0].<br>Group1 = Tx Channels 1,2,3,4<br>Group2 = Tx Channels 5,6,7,8<br>Group3 = Tx Channels 9,10,13,14<br>Group4 = Tx Channels 11,12,15,16. The<br>groups and channels are similarly<br>mapped on Core B. |
| Soft Reset                | 0xF0              | W   | Reg  | A->B | -       | -                                                  | -      | Writing anything to this register causes<br>all settings to revert to their power-on<br>default values for the currently-running<br>personality, except the following are<br>unchanged:<br>-Personality type<br>-User pattern memory<br>-Pattern sequence instructions<br>-Data Rate<br>-System reference clock source and<br>frequency<br>-Scripts<br>-Calibration values (Note that jitter<br>injection is disabled)                                                                                                     |
| Reset to Default Settings | 0xFE              | W   | Reg  | A->B | -       | -                                                  | -      | Writing anything to this register causes<br>all settings to revert to their power-on<br>default values for the currently-running<br>personality; does not change the<br>personality – see Firmware<br>Reconfiguration for that functionality                                                                                                                                                                                                                                                                               |

|                                             | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                          | Target                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------|-------------------|-----|------|------|---------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pattern Source                              | 0x03              |     |      |      |         |                                                                                     |                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Pattern Start<br>Condition                  | 0x04              | RW  | Dual | A/B  | 0       | Dual Access (Section 7.5), 8-bit<br>word per channel:<br>Trigger ID (Section 8.3.1) | [Channel<br>Bitfield]<br>Set via<br>'Global Target<br>Mask'                   | Assign start condition based on<br>Trigger ID; this allows an<br>'immediate' start or no start on<br>each channel. See 0x0307 for<br>Pattern/Trig Start.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Pattern Stop                                | 0x06              | W   | Reg  | A/B  | -       | Channel Bitfield:<br>Stop (1), or No Change (0)                                     | -                                                                             | Stops a previously-started pattern<br>and reverts to 'Tx Pattern Disabled<br>State [0x0334]'. If 'Tx Pattern<br>Mode = Instruction Sequence<br>[0x0336]' then all patterns will be<br>disabled regardless of the channel<br>bitfield.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Pattern Force/Trig<br>Start                 | 0x07              | W   | Reg  | A    | -       | -                                                                                   | -                                                                             | Starts all channels/patterns (1-32) that have been set to 'start immediate' via command 0x0304.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Instruction<br>Sequencer Start<br>Condition | 0x08              | RW  | Reg  | A/B  | 0       | Trigger ID (Section 8.3.1)                                                          | -                                                                             | Assign start condition based on<br>Trigger ID; this allows an<br>'immediate' start or no start on the<br>instruction sequencer. See 0x0307<br>for Pattern/Trig Start.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| User Data Pattern<br>Memory                 | 0x10              | RW  | Data | A/B  | Empty   | A preformatted data pattern (Section 8.2.2)                                         | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask' | Write loads a user data pattern into the<br>User Pattern Slot identified by Target;<br>reading retrieves a previously-written<br>pattern; reading from an empty slot<br>returns a block of zeros; Uploading to<br>memory while sourcing user patterns or<br>pattern sequencers is not recommended<br>(Section 8.2.4); A user pattern can be<br>cleared by writing a pattern of length<br>zero (Section 8.2.5); Patterns can be read<br>in chunks using the scrolling read feature<br>(Section 8.2.6). Patterns can be written in<br>chunks; and must be when their length<br>exceeds 32KB (Section 8.2.7). Note that<br>user pattern lengths will often be<br>expanded to meet with internal<br>requirements. |

|                                      | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                                   | Target                                                                               | Description                                                                                                                                                                                                           |
|--------------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| User Data Pattern Length             | 0x11              | R   | Reg  | A/B  | 0       | Block length, in bytes                                                                                                       | User Pattern<br>Slot ID<br>Set via 'Global<br>Target Mask'                           | Returns the length of the pattern loaded<br>into the User Pattern Slot identified by<br>Target; useful as a check, and when<br>reading back user data patterns, as this is<br>the length of data block to read        |
| User Data Pattern<br>Memory Allocate | 0x14              | W   | Reg  | A/B  | -       | Size of memory to be allocated in<br>bytes. This size should correspond to<br>a pattern length that will soon be<br>written. | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask'        | For patterns over 32 KB pattern memory<br>must first be allocated. After a pattern<br>slot has been allocate you can write the<br>user pattern in chunks using the 'User<br>Data Pattern Memory' [0x0310]<br>command. |
| User Data Pattern Clear<br>Memory    | 0x16              | W   | Reg  | A/B  | -       | -                                                                                                                            | -                                                                                    | Write clears entire pattern memory and all user pattern slots.                                                                                                                                                        |
| Pattern Sequencer<br>Memory          | 0x20              | RW  | Data | A/B  | Empty   | A Pattern Sequencer Program<br>(Section 8.2.8)                                                                               | Pattern<br>Sequence Slot<br>ID (Section<br>8.2.9)<br>Set via 'Global<br>Target Mask' | Write loads a pattern sequencer<br>program into the Pattern Sequence Slot<br>identified by Target; read retrieves a<br>previously-written sequence; reading<br>from an empty slot returns a block of<br>zeros         |
| Pattern Sequencer<br>Program Length  | 0x21              | R   | Reg  | A/B  | 0       | Data block length, in bytes                                                                                                  | Pattern<br>Sequence Slot<br>ID<br>Set via 'Global<br>Target Mask'                    | Returns the length of the Pattern<br>Sequencer Program identified in Target;<br>useful as a check, and when reading<br>back the sequencer programs, as this is<br>the length of data block to read                    |
| Tx PRBS Polynomial<br>Order          | 0x30              | RW  | Reg  | A/B  | 7       | Polynomial order of the PRBS pattern generator (Section 8.2.10)                                                              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask'                             | Sets the polynomial order of the tx PRBS<br>generator on a per channel basis;<br>available orders are 5, 7, 9, 11, 13, 15, 21,<br>23 and 31                                                                           |
| Rx PRBS Polynomial<br>Order          | 0x32              | RW  | Reg  | A/B  | 7       | Polynomial order of the rx PRBS pattern generator (Section 8.2.10)                                                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask'                             | Sets the polynomial order of the rx PRBS<br>generator on a per channel basis;<br>available orders are 5, 7, 9, 11, 13, 15, 21,<br>23 and 31                                                                           |

|                                        | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                           | Target                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Tx Pattern Disabled State              | 0x34              | RW  | Reg  | A/B  | 0       | Electrical Idle (0), All Ones (1), All<br>Zeroes (2) | -                                                                             | When a pattern is stopped this is the<br>state which will be output. This state will<br>also be output during a clock commit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Tx Pattern Mode                        | 0x36              | RW  | Reg  | A/B  | 0       | Basic (0), Instruction Sequencer (1)                 | -                                                                             | Control how all patterns are controlled.<br>In 'Basic (0)' mode the pattern<br>generators are not controlled via the<br>instruction sequencer. Once enabled<br>they are active until explicitly stopped.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Instruction Sequencer<br>Force Trigger | 0x38              | W   | Reg  | A/B  | -       | -                                                    | -                                                                             | If the current instruction is waiting on a trigger this command will force the instruction sequencer to proceed to the next instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Rx User Data Pattern<br>Memory         | 0x60              | RW  | Data | A/B  | Empty   | A preformatted data pattern (Section 8.2.2)          | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask' | Write loads a user data pattern into the<br>Rx User Pattern Slot identified by Target;<br>reading retrieves a previously-written<br>pattern; reading from an empty slot<br>returns a block of zeros; Uploading to<br>memory while sourcing user patterns or<br>pattern sequencers is not recommended<br>(Section 8.2.4); A user pattern can be<br>cleared by writing a pattern of length<br>zero (Section 8.2.5); Patterns can be read<br>in chunks using the scrolling read feature<br>(Section 8.2.6). Patterns can be written in<br>chunks; and must be when their length<br>exceeds 32KB (Section 8.2.7). Note that<br>user pattern lengths will often be<br>expanded to meet with internal<br>requirements. |
| Rx User Data Pattern<br>Length         | 0x62              | R   | Reg  | A/B  | 0       | Block length, in bytes                               | User Pattern<br>Slot ID<br>Set via 'Global<br>Target Mask'                    | Returns the length of the pattern loaded<br>into the Rx User Pattern Slot identified by<br>Target; useful as a check, and when<br>reading back user data patterns, as this is<br>the length of data block to read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|                                         | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                                   | Target                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rx User Data Pattern<br>Memory Allocate | 0x64              | W   | Reg  | A/B  | -       | Size of memory to be allocated in<br>bytes. This size should correspond to a<br>pattern length that will soon be<br>written. | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask' | For patterns over 32 KB pattern memory<br>must first be allocated. After a pattern<br>slot has been allocate you can write the<br>user pattern in chunks using the 'Rx User<br>Data Pattern Memory' [0x0360]<br>command.                                                                                                                                                                                                                                                                                       |
| Rx User Data Pattern<br>Clear Memory    | 0x66              | W   | Reg  | A/B  | -       | -                                                                                                                            | -                                                                             | Write clears entire rx pattern memory and all user pattern slots.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PTI Memory Write                        | 0x70              | W   |      | Reg  | -       | Block length, in bytes                                                                                                       | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask' | Write loads the most recent PTI transfer<br>into the User Pattern Slot identified by<br>Target. Uploading to memory while<br>sourcing user patterns or pattern<br>sequencers is not recommended (Section<br>8.2.4); Patterns can be read in chunks<br>using the scrolling read feature (Section<br>8.2.6). Patterns can be written in chunks;<br>and must be when their length exceeds<br>8MB (Section 8.2.7). Note that user<br>pattern lengths will often be expanded to<br>meet with internal requirements. |
| PTI Memory Read                         | 0x71              | W   |      | Reg  | -       | Block length in bytes                                                                                                        | User Pattern<br>Slot ID (Section<br>8.2.3)<br>Set via 'Global<br>Target Mask' | Retrieves the User Pattern identified by<br>the target in preparation for a 'PTI Start'<br>read operation.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Rx Configuration                        | 0x04              |     |      |      |         |                                                                                                                              |                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Polarity Invert                         | 0x02              | RW  | Dual | A/B  | 0       | Dual Access (Section 7.5), single byte<br>per channel:<br>Inverted (1) / Normal (0)                                          | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask'                      | Selective inversion of received bitstreams on a per-channel basis                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Comparator<br>Threshold Voltage         | 0x10              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per<br>channel:<br>Signed Voltage (µV)                                                              | [Channel<br>Bitfield]<br>Set via<br>'Global Target<br>Mask'                   | Rx threshold voltage for each channel, expressed in microvolts.                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|                                           | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                 | Target                                                   | Description                                                                                                                                                                                         |
|-------------------------------------------|-------------------|-----|------|------|---------|----------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Comparator Threshold<br>Offset            | 0x14              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Signed Voltage (uV)               | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Rx threshold offset data for each<br>channel, expressed in microvolts. Applies<br>to all data rates.                                                                                                |
| Comparator Threshold<br>Offset Cal        | 0x15              | W   | Data | A    | -       | 32-bit word per channel: Voltage (uV)                                      | -                                                        | Allows programming of the threshold<br>offset calibration data. Data block must<br>be 128bytes. 32 Channels x 4 bytes per<br>offset. Note that system must be power<br>cycled after writing.        |
| Comparator Threshold<br>Linear Factor     | 0x16              | RW  | Dual | A/B  | 0       | Dual Access; 32-bit word per channel:<br>Fixed point notation <<28. ie     | [Channel<br>Bitfield]                                    | Rx threshold linear factor data for each channel. Applies to all data rates.                                                                                                                        |
|                                           |                   |     |      |      |         | int(float(2^28))                                                           | -<br>Set via 'Global<br>Target Mask'                     |                                                                                                                                                                                                     |
| Comparator Threshold<br>Linear Factor Cal | 0x17              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28)) | -                                                        | Allows programming of the threshold<br>linear factor calibration data. Data block<br>must be 128bytes. 32 Channels x 4 bytes<br>per factor. Note that system must be<br>power cycled after writing. |
| Comparator Threshold<br>Square Factor     | 0x18              | RW  | Dual | A/B  | 0       | Dual Access; 32-bit word per channel:<br>Fixed point notation <<28. ie     | [Channel<br>Bitfield]                                    | Rx threshold square factor data for each channel. Applies to all data rates.                                                                                                                        |
|                                           |                   |     |      |      |         | int(float(2^28))                                                           | Set via 'Global<br>Target Mask'                          |                                                                                                                                                                                                     |
| Comparator Threshold<br>Square Factor Cal | 0x19              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28)) | -                                                        | Allows programming of the threshold<br>square factor calibration data. Data block<br>must be 128bytes. 32 Channels x 4 bytes<br>per factor. Note that system must be<br>power cycled after writing. |
| Comparator Threshold<br>Cubic Factor      | 0x1A              | RW  | Dual | A/B  | 0       | Dual Access; 32-bit word per channel:<br>Fixed point notation <<28. ie     | [Channel<br>Bitfield]                                    | Rx threshold cubic factor data for each channel. Applies to all data rates.                                                                                                                         |
| Cubic Factor                              |                   |     |      |      |         | int(float(2^28))                                                           | Set via 'Global<br>Target Mask'                          |                                                                                                                                                                                                     |

|                                          | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                 | Target                          | Description                                                                                                                                                                                          |
|------------------------------------------|-------------------|-----|------|------|---------|----------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Comparator Threshold<br>Cubic Factor Cal | 0x1B              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28)) | -                               | Allows programming of the threshold<br>cubic factor calibration data. Data block<br>must be 128bytes. 32 Channels x 4 bytes<br>per factor. Note that system must be<br>power cycled after writing.   |
| Comparator Threshold<br>Quad Factor      | 0x1C              | RW  | Dual | A/B  | 0       | Dual Access; 32-bit word per channel:<br>Fixed point notation <<44. ie     | [Channel<br>Bitfield]           | Rx threshold quad factor data for each channel. Applies to all data rates.                                                                                                                           |
|                                          |                   |     |      |      |         | int(float(2^44))                                                           | Set via 'Global<br>Target Mask' |                                                                                                                                                                                                      |
| Comparator Threshold<br>Quad Factor Cal  | 0x1D              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<44. ie int(float(2^44)) | -                               | Allows programming of the threshold<br>quad factor calibration data. Data block<br>must be 128bytes. 32 Channels x 4 bytes<br>per factor. Note that system must be<br>power cycled after writing.    |
| Comparator Threshold<br>Quint Factor     | 0x1E              | RW  | Dual | A/B  | 0       | Dual Access; 32-bit word per channel:<br>Fixed point notation <<44. ie     | [Channel<br>Bitfield]           | power cycled after writing.<br>Rx threshold quint factor data for each<br>channel. Applies to all data rates.                                                                                        |
|                                          |                   |     |      |      |         | int(float(2^44))                                                           | Set via 'Global<br>Target Mask' |                                                                                                                                                                                                      |
| Comparator Threshold<br>Quint Factor Cal | 0x1F              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<44. ie int(float(2^44)) | -                               | Allows programming of the threshold<br>quint factor calibration data. Data block<br>must be 128bytes. 32 Channels x 4 bytes<br>per factor. Note that system must be<br>power cycled after writing.   |
| CDR Data Path Mode                       | 0x32              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:                                      | [Channel<br>Bitfield]           | Controls the CDR path mode on a per-<br>channel basis, causing the Rx channel to                                                                                                                     |
|                                          |                   |     |      |      |         | Path Rx Reference (1)                                                      | Set via 'Global<br>Target Mask' | clock either based on the CDR (clock is<br>recovered from data), or based on the Rx<br>Reference clock; the Rx reference clock is<br>configured by the Rx Reference Clock<br>Source register, below. |
| CDR LTD/LTR Lock Status                  | 0x34              | R   | Reg  | A/B  | -       | Channel Bitfield of Locked (1) or Not<br>(0)                               | -                               | Reflects the status of the RX CDR PLL on each Rx channel. Does not apply to Digital CDR                                                                                                              |

|                                       | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                       | Target                                                   | Description                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rx Reference Clock<br>Source          | 0x3C              | RW  | Reg  | A/B  | 0       | System Ref Clock (LTR) (0) / Extracted<br>(LTD) (1)              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | The Rx Reference Clock is used when<br>CDR Mode is set to "Reference"; "System<br>Ref Clock" (0) will use the system<br>reference clock, configurable by the<br>System Reference Clock Source register;<br>"Extracted" (1) will use either a<br>forwarded or a recovered clock, as<br>appropriate for the currently-loaded<br>personality. |
| Rx Reference Core Clock<br>Source     | 0x3F              | RW  | Reg  | A/B  | 0       | System Ref Clock (0) / Extracted (1)                             | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Sets the system core clock source.<br>Change takes effect immediately.                                                                                                                                                                                                                                                                     |
| Rx Reference Phase<br>Delay           | 0x40              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Signed Phase Delay (fc) | [Channel<br>Bitfield]                                    | Controls the Rx phase by specifying a signed delay in fs.                                                                                                                                                                                                                                                                                  |
|                                       |                   |     |      |      |         | Signed mase beidy (is)                                           | Set via 'Global<br>Target Mask'                          | The delay range is data rate dependant.                                                                                                                                                                                                                                                                                                    |
| Rx Reference Phase<br>Delay Increment | 0x44              | W   | Reg  | A/B  | -       | 32-bit word<br>Signed Phase Delay (fs)                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Modifies the current Rx phase by adding<br>the (signed fs) value to the current phase<br>setting. Affects the values read by<br>commands 0x0440 above.                                                                                                                                                                                     |
| Rx Digital Reset                      | 0x52              | W   | Reg  | A/B  | -       | -                                                                | -                                                        | Performs a reset of the Rx FIFOs.                                                                                                                                                                                                                                                                                                          |
| Rx Reference Phase Step               | 0x54              | R   | Reg  | A/B  | -       | -                                                                | -                                                        | Reads the minimum step size /<br>increment of the rx reference phase<br>delay in fs.                                                                                                                                                                                                                                                       |
| Rx EQ DC Gain                         | 0x56              | RW  | Dual | A/B  | 0       | Dual Access (Section 7.5), single byte per channel.              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Sets and reads DC gain level. Valid range is 0 – 4.                                                                                                                                                                                                                                                                                        |
| Rx EQ Control                         | 0x58              | RW  | Dual | A/B  | 0       | Dual Access (Section 7.5), single byte per channel.              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Sets and reads Rx Equalization Control<br>level. Valid range is 0 – 15.                                                                                                                                                                                                                                                                    |

|                                           | Cmpt /<br>Subaddr | R/W | Туре | Port | Default  | Data / Data Block Contents                                                          | Target                                                   | Description                                                                                                                                                                                                                                                                       |
|-------------------------------------------|-------------------|-----|------|------|----------|-------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bandwidth Control                         | 0x60              | RW  | Reg  | A/B  | 0        | CDR bandwidth setting. High (0) /<br>Medium (2) / Low (3)                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Set the cdr bandwidth on a per-channel<br>basis. Requires a clock commit to take<br>effect.                                                                                                                                                                                       |
| Clock Monitor Control                     | 0x62              | RW  | Reg  | A/B  | 0        | Disable (0) / Enable (1)                                                            | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Enables the Clock Monitor. Requires a clock commit to take effect.                                                                                                                                                                                                                |
| Tx Configuration                          | 0x05              |     |      |      |          |                                                                                     |                                                          |                                                                                                                                                                                                                                                                                   |
| Polarity Invert                           | 0x02              | RW  | Dual | A/B  | 0        | Dual Access (Section 7.5), single byte<br>per channel:<br>Inverted (1) / Normal (0) | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Selective inversion of transmitted bitstreams on a per-channel basis                                                                                                                                                                                                              |
| Data Pattern Provider                     | 0x04              | RW  | Dual | A/B  | K28.5    | Dual Access, 32-bit word per channel:<br>Pattern Selector (Section 8.2.1)           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Assigns a pattern provider on a per-<br>channel basis; Pattern Selector identifies<br>both the provider (PRBS, Preset pattern,<br>User Pattern, Pattern Sequencer,) and<br>specific source (Preset ID, User Slot ID,)                                                             |
| Instruction Sequencer<br>Pattern Provider | 0x06              | RW  | Reg  | A/B  | -        | Pattern Selector (Section 8.2.1)                                                    | -                                                        | Assigns a pattern provider to the<br>Instruction Sequencer. Pattern selector<br>identifies both the provider (User<br>Pattern, Pattern Sequencer) and specific<br>source (User Slot ID, Sequencer Slot).<br>Note that only User Patterns and Pattern<br>Sequencers are supported. |
| Output Amplitude                          | 0x10              | RW  | Dual | A/B  | 800000uV | Dual Access, 32-bit word per channel:<br>Voltage (¤V)                               | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Peak-to-peak differential Tx amplitude, expressed in microvolts.                                                                                                                                                                                                                  |
| Tx Amplitude Offset<br>Mode 1             | 0x14              | RW  | Dual | A/B  | -        | Dual Access, 32-bit word per channel:<br>Voltage (uV)                               | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Offset value applied to tx amplitude for<br>'Tx Mode 1'. Data is per channel and<br>applies to all data rates. Output<br>amplitude is updated immediately.                                                                                                                        |

|                                   | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                 | Target                                                   | Description                                                                                                                                                                                        |
|-----------------------------------|-------------------|-----|------|------|---------|--------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Tx Amplitude Cal Offset<br>Mode 1 | 0x15              | W   | Data | A    | -       | 32-bit word per channel: Voltage (uV)                                                      | -                                                        | Allows programming of the offset<br>calibration data for 'Tx Mode 1'. Data<br>block must be 128bytes. 32 Channels x 4<br>bytes per offset. Note that system must<br>be power cycled after writing. |
| Tx Amplitude Slope<br>Mode 1      | 0x16              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Voltage (uV)                                      | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Slope value applied to tx amplitude for<br>'Tx Mode 1'. Data is per channel and<br>applies to all data rates. Output<br>amplitude is updated immediately.                                          |
| Tx Amplitude Cal Slope<br>Mode 1  | 0x17              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28))                 | -                                                        | Allows programming of the slope<br>calibration data for 'Tx Mode 1'. Data<br>block must be 128bytes. 32 Channels x 4<br>bytes per offset. Note that system must<br>be power cycled after writing.  |
| Tx Amplitude Offset<br>Mode 2     | 0x18              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Voltage (uV)                                      | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Offset value applied to tx amplitude for<br>'Tx Mode 2'. Data is per channel and<br>applies to all data rates. Output<br>amplitude is updated immediately.                                         |
| Tx Amplitude Cal Offset<br>Mode 2 | 0x19              | W   | Data | A    | -       | 32-bit word per channel: Voltage (uV)                                                      | -                                                        | Allows programming of the offset<br>calibration data for 'Tx Mode 2'. Data<br>block must be 128bytes. 32 Channels x 4<br>bytes per offset. Note that system must<br>be power cycled after writing. |
| Tx Amplitude Slope<br>Mode 2      | 0x1A              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Fixed point notation <<28. ie<br>int(float(2^28)) | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Slope value applied to tx amplitude for<br>'Tx Mode 2'. Data is per channel and<br>applies to all data rates. Output<br>amplitude is updated immediately.                                          |
| Tx Amplitude Cal Slope<br>Mode 2  | 0x1B              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28))                 | -                                                        | Allows programming of the slope<br>calibration data for 'Tx Mode 2'. Data<br>block must be 128bytes. 32 Channels x 4<br>bytes per offset. Note that system must<br>be power cycled after writing.  |

|                                       | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                                   | Target                                                   | Description                                                                                                                                                                                                                                                     |  |
|---------------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pre-Emphasis Tap<br>Weights           | 0x36              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Three signed 1-byte tap weights<br>packed into each word:<br>[pre, post1, post2, 0] | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Sets Tx pre-emphasis tap weights; each<br>tap weight is an 8-bit signed integer.                                                                                                                                                                                |  |
| Tx Reference Clock<br>Source          | 0x3C              | RW  | Reg  | A/B  | 0       | System Ref Clock (0) / Extracted (1)                                                                                         | -                                                        | "System Ref Clock" (0) will use the<br>system reference clock, configurable by<br>the System Reference Clock Source<br>register; "Extracted" (1) will use either a<br>forwarded or a recovered clock, as<br>appropriate for the currently loaded<br>personality |  |
| Tx Fine Phase Delay                   | 0x50              | RW  | Reg  | A/B  | 0       | Set phase delay in femto seconds.                                                                                            | [Group Bitfield]<br>Set via 'Global<br>Target Mask'      | Allows fine phase adjustment to the 8<br>phase groups. There are 4 groups per<br>port. Valid phase range is -500000 fs to<br>500000 fs.                                                                                                                         |  |
| Tx Fine Phase Cal Data                | 0x051             | W   | Data | A    | -       | Fine phase in femto seconds. 32-bit word per value.                                                                          | -                                                        | Allows programming of the fine phase<br>calibration data. Data block must be 544<br>bytes. 8 Phase Groups x 17 Cal Rates x<br>4bytes per skew. Note that system must<br>be power cycled after writing.                                                          |  |
| Tx Coarse/Bit Delay                   | 0x52              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:                                                                                        | [Channel<br>Bitfield]                                    | Allows injection of a coarse delay, in UI<br>only), on a per-channel basis; the applied                                                                                                                                                                         |  |
|                                       |                   |     |      |      |         | Signed bit delay (01)                                                                                                        | Set via 'Global<br>Target Mask'                          | phase ranges from -1024 to 1023 UI.                                                                                                                                                                                                                             |  |
| Tx Coarse Delay Cal Data              | 0x53              | W   | Data | A    | -       | Coarse skew. 32-bit word per value.                                                                                          | -                                                        | Allows programming of the coarse skew<br>calibration data. Data block must be<br>2176 bytes. 32 Channels x 17 Cal Rates x<br>4 bytes per skew. Note that system must<br>be power cycled after writing.                                                          |  |
| Jitter Injection: Jitter<br>Amplitude | 0x60              | RW  | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Jitter amplitude (ps)                                                               | [Group Bitfield]<br>Set via 'Global                      | Requests a amplitude of jitter to inject on each group. Allowable values of jitter                                                                                                                                                                              |  |
|                                       |                   |     |      |      |         |                                                                                                                              | Target Mask'                                             | frequency/amplitude are TBD; changes<br>take effect on next jitter start                                                                                                                                                                                        |  |

|                                       | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                     | Target                                                   | Description                                                                                                                                                               |
|---------------------------------------|-------------------|-----|------|------|---------|----------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Jitter Injection: Jitter<br>Frequency | 0x62              | RW  | Dual | A/B  | 38,147  | Dual Access, 32-bit word per channel:<br>Jitter frequency (Hz) | [Group Bitfield]<br>Set via 'Global<br>Target Mask'      | Controls the frequency of jitter injected<br>on each group; allowable values of jitter<br>frequency/ amplitude are TBD; changes<br>take effect on next jitter start       |
| Random Jitter Amplitude               | 0x64              | RW  | Dual | A/B  |         | Dual Access, 32-bit word per channel:<br>Jitter Amplitude (ps) | [Group Bitfield]<br>Set via 'Global<br>Target Mask'      | Requests a amplitude of jitter to inject<br>on each group. Allowable values of jitter<br>frequency/amplitude are TBD; changes<br>take effect on next jitter start         |
| Jitter Start                          | 0x66              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Trigger ID (Section)  | [Group Bitfield]<br>Set via 'Global<br>Target Mask'      | Starts jitter with most recently provided<br>parameters, based on Trigger ID; this<br>allows an immediate start, a triggered<br>start on pins, or no start, on each group |
| Jitter Stop                           | 0x68              | W   | Reg  | A/B  | -       | Group Bitfield:<br>Stop (1), or no Change (0)                  | -                                                        | Stops a previously started jitter injection operation                                                                                                                     |
| Duty Cycle Distortion<br>Offset       | 0x70              | RW  | Reg  | A/B  | 4       | Value of DCD offset                                            | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Controls the duty cycle distortion offset<br>on a per channel basis. Valid values are 0<br>– 6.                                                                           |
| Tx Pattern Status                     | 0x82              | R   | Reg  | A/B  | 0       | -                                                              | -                                                        | Returns channel mask indicating the<br>status of each channels pattern<br>generator. 1 - Pattern Generator Active,<br>0 - Pattern Generator Stopped.                      |
| Tx Force Zero                         | 0x84              | W   | Reg  | A/B  | 0       | Normal Operation (0), Zero Data (1)                            | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | 0 specifies normal operation and 1<br>zeroes out the data on that channel.<br>Note that this mask is applied after the<br>fanout.                                         |
| Jitter Compensation<br>Offset         | 0x90              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel.                          | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Offset value applied to jitter. Data is per channel and applies to all data rates.                                                                                        |

|                                           | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                 | Target                                                   | Description                                                                                                                                                                                  |
|-------------------------------------------|-------------------|-----|------|------|---------|--------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Jitter Compensation<br>Offset Cal         | 0x91              | W   | Data | A    | -       | 32-bit word per channel: Voltage (uV)                                                      | -                                                        | Allows programming of the jitter offset<br>calibration data. Data block must be<br>32bytes. 8 Groups x 4 bytes per offset.<br>Note that system must be power cycled<br>after writing.        |
| Jitter Compensation<br>Linear Factor      | 0x92              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Fixed point notation <<28. ie<br>int(float(2^28)) | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Linear factor value applied to jitter. Data is per channel and applies to all data rates.                                                                                                    |
| Jitter Compensation<br>Linear Factor Cal  | 0x93              | W   | Data | A    | -       | 32-bit word per channel: Fixed point notation <<28. ie int(float(2^28))                    | -                                                        | Allows programming of the jitter linear<br>factor calibration data. Data block must<br>be 32bytes. 8 Groups x 4 bytes per<br>offset. Note that system must be power<br>cycled after writing. |
| Jitter Compensation<br>Squared Factor     | 0x94              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Fixed point notation <<28. ie<br>int(float(2^28)) | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Square factor value applied to jitter. Data is per channel and applies to all data rates.                                                                                                    |
| Jitter Compensation<br>Squared Factor Cal | 0x95              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28))                 | -                                                        | Allows programming of the jitter square<br>factor calibration data. Data block must<br>be 32bytes. 8 Groups x 4 bytes per<br>offset. Note that system must be power<br>cycled after writing. |
| Jitter Compensation<br>Cube Factor        | 0x96              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel:<br>Fixed point notation <<28. ie<br>int(float(2^28)) | [Channel<br>Bitfield] Set via<br>'Global Target<br>Mask' | Cube factor value applied to jitter. Data is per channel and applies to all data rates.                                                                                                      |
| Jitter Compensation<br>Cube Factor Cal    | 0x97              | W   | Data | A    | -       | 32-bit word per channel: Fixed point<br>notation <<28. ie int(float(2^28))                 | -                                                        | Allows programming of the jitter cube<br>factor calibration data. Data block must<br>be 32bytes. 8 Groups x 4 bytes per<br>offset. Note that system must be power<br>cycled after writing.   |
| Measurement And Test                      | 0x06              |     |      |      |         |                                                                                            |                                                          |                                                                                                                                                                                              |

|                               | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                                                                                                                                                                                      | Target                                                   | Description                                                                                                                                                                |
|-------------------------------|-------------------|-----|------|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BERT Data Pattern<br>Provider | 0x04              | RW  | Dual | A/B  | K28.5   | Dual Access (Section 7.5), 32-bit word<br>per channel:<br>Pattern Selector (Section 8.3.1)                                                                                                                                                                                      | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Assigns a BERT reference pattern<br>provider on a per-channel basis; similar<br>to the Pattern Source's Data Pattern<br>Provider register                                  |
| BERT Mask                     | 0x06              | RW  | Dual | A/B  | 0       | Dual Access, 32bits per channel.                                                                                                                                                                                                                                                | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Sets the BERT mask that will be applied<br>when BERT compare mode is set to<br>"BERT with generalized bit mask (1)"                                                        |
| BERT Compare Mode             | 0x08              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Standard BERT (0) / BERT with<br>generalized bit mask (1) / BERT with<br>Non-Transition (2) / BERT with worst-<br>case transition (3) / BERT with Single<br>Edge transition (4) / BERT with Pre bit<br>0 (5) / BERT with Pre bit 1 (6) | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Selects the comparison mode for the BERT on a per channel basis.                                                                                                           |
| BERT Count Mode               | 0x10              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Single-shot (0) / Continuous (1)                                                                                                                                                                                                       | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Selects single-shot or continuous count mode                                                                                                                               |
| BERT Single-Shot<br>Duration  | 0x12              | RW  | Reg  | A/B  | 106     | Duration, in bits                                                                                                                                                                                                                                                               | -                                                        | Sets the duration of all single-shot<br>BERTs; Truncated to a multiple of 32 bits;                                                                                         |
| BERT Sync Start               | 0x20              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Trigger ID (Section 8.3.1)                                                                                                                                                                                                             | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Starts based on Trigger ID; BERT sync is a busy process, returning control to the module only once it's completed.                                                         |
| BERT Sync Result              | 0x22              | R   | Reg  | A/B  | 0       | Channel Bitfield:<br>Success (1) or Failure (0)                                                                                                                                                                                                                                 | -                                                        | Reflects the status of the most recently<br>completed sync operation; each bit of<br>the bitfield represents the sync status for<br>a single channel, with Ch 1 as the LSB |
| BERT Sync Error<br>Threshold  | 0x24              | RW  | Dual | A/B  | 3       | Dual Access, 32 bits per channel: sync<br>error limit                                                                                                                                                                                                                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Maximum bit errors for successful BERT<br>or Strobe sync. Valid range: 3 to 2 <sup>32</sup> -1                                                                             |

|                                           | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                              | Target                                                   | Description                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------|-------------------|-----|------|------|---------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BERT Start                                | 0x30              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Trigger ID (Section 8.3.1)                                     | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Starts based on Trigger ID; BERT start is a busy process, returning control to the module only once it's completed.                                                                                                                                                                                                                |
| BERT Error Count                          | 0x32              | R   | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Error count, in bits                                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Reads as the number of bit errors that<br>occurred in the most recently-completed<br>BERT; max reported error count is $2^{32} - 1$ ,<br>and the count saturates at that level;<br>only valid after an explicit stop for<br>Continuous BERT, or completion of all<br>bits in a Single-Shot BERT                                    |
| BERT Received Bit Count<br>On First Error | 0x34              | R   | Data | A/B  | 0       | Channel data block (Section 8.1.4),<br>64-bit word per channel:<br>Bit count stored as a 64-bit integer | -                                                        | Reads as the number of bits that were<br>successfully received before the first bit<br>error was observed; cleared to 0 on start<br>of a new BERT; only valid after an explicit<br>stop for Continuous BERT, or completion<br>of all bits in a Single-Shot BERT                                                                    |
| BERT Received Bit Count                   | 0x36              | R   | Data | A/B  | 0       | Channel data block, 64-bit word per<br>channel:<br>Bit count stored as a 64-bit integer                 | -                                                        | Reads as the number of bits received in<br>the most recently completed BERT;<br>cleared to 0 on start of a new BERT; only<br>valid after an explicit stop for<br>Continuous BERT, or completion of all<br>bits in a Single-Shot BERT                                                                                               |
| BERT Received Bit Count<br>on Overflow    | 0x38              | R   | Data | A/B  | 0       | Channel data block, 64-bit word per<br>channel:<br>Bit count stored as a 64-bit integer                 | -                                                        | Reads as the number of bits received<br>before 2 <sup>32</sup> errors or more were observed<br>in the most recently completed BERT, or<br>as zero if no overflow occurred; cleared<br>to 0 on start of a new BERT; only valid<br>after an explicit stop for Continuous<br>BERT, or completion of all bits in a<br>Single-Shot BERT |
| BERT Stop                                 | 0x3A              | W   | Reg  | A/B  | -       | Channel Bitfield:<br>Stop (1) / No Change (0)                                                           | -                                                        | Stops a BERT running in Continuous mode                                                                                                                                                                                                                                                                                            |

|                    | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                                           | Target                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|-------------------|-----|------|------|---------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Strobe Sync Start  | 0x40              | RW  | Dual | A/B  | 0       | Dual Access, single byte per channel:<br>Trigger ID(Section 8.3.1)                                                                   | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Starts based on Trigger ID; this allows an<br>immediate start or no start, on each<br>channel; this automatically places the<br>module in Reference Clock mode: CDR is<br>disabled; strobe sync is used to initiate<br>controlled-phase measurements, such as<br>bathtub plots and mask tests – see the<br>programming examples in Section 9 for<br>more on this; strobe sync is a busy<br>process, returning control to the module<br>only once it's completed |
| Strobe Sync Result | 0x42              | R   | Reg  | A/B  | 0       | Channel Bitfield:<br>Success (1) or Failure (0)                                                                                      | -                                                        | Reflects the status of the most recently completed strobe sync operation                                                                                                                                                                                                                                                                                                                                                                                        |
| Sync Offset        | 0x43              | R   | Dual | A/B  | 0       | Dual Access, 32-bit word per channel:<br>Sync offset, in bits                                                                        | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Reflects the offset, in bits, that was<br>applied to the reference data pattern to<br>yield a successful sync in the most<br>recently completed Strobe Sync or Bert<br>Sync operation; the higher the offset, the<br>further forward in time the reference<br>data pattern was advanced; values are<br>undefined for channels that did not sync.<br>For PRBS, returns the seed value.                                                                           |
| BERT Scan Start    | 0x50              | W   | Data | A/B  | -       | Block of three two signed 32-bit<br>integers, and one unsigned 32-bit<br>integer in order:<br>[Start (ps), End (ps), Step Size (ps)] | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Writing to this address starts bathtub<br>measurements on targeted channels in a<br>true parallel manner; the direction of the<br>sweep is determined by the start and<br>end location, and not by the sign of the<br>step size. The step size should always be<br>positive. Measurements will be<br>performed based on the single shot<br>duration specified in 0x0612. BERT scans<br>may not be performed while BERT is in<br>continuous mode.                |

|                              | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                                     | Target                                                   | Description                                                                                                                                                                                                                                               |
|------------------------------|-------------------|-----|------|------|---------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BERT Scan Results            | 0x52              | R   | Data | A/B  | -       | Block of ((Abs(Endldx –<br>Startldx)/StepSize)+1) 32-bit integers:<br>Error count, in bits.<br>(Section 7.6.1) | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Reads as an array containing the number<br>of bit errors that occurred at each index<br>setting specified in the most recently<br>completed BERT Scan Start; max<br>reported error count is 2 <sup>32</sup> -1, and the<br>count saturates at that level; |
| Reset BERT Scan Read         | 0x54              | W   | Reg  | A/B  | -       | -                                                                                                              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Resets the read location of BERT Scan<br>Results [0x0652] to read from the<br>beginning of the data.                                                                                                                                                      |
| BERT Scan Length             | 0x56              | R   | Reg  | A/B  | 0       | Block length, in bytes                                                                                         | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Returns the length of the BERT scan last<br>performed on the channel identified by<br>Target; useful as a check, and when<br>reading back BERT scan results, as this is<br>the length of data block to read                                               |
| Analog Capture               | 0x60              | W   | Data | A/B  | -       | Block of two signed integers, in order:<br>[Minimum Threshold(uV), Maximum<br>Threshold (uV)]                  | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Writing to this address starts an analog capture on targeted channels in a true parallel manner.                                                                                                                                                          |
| Analog Capture Results       | 0x62              | R   | Data | A/B  | -       | Block of 4096, 32-bit integers.                                                                                | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Read results of analog capture.<br>Only a single channel result may be read<br>at a time.                                                                                                                                                                 |
| Reset Analog Capture<br>Read | 0x64              | W   | Reg  | A/B  | -       | -                                                                                                              | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Resets the read location of Analog<br>Capture Results [0x0662] to read from<br>the beginning of the data.                                                                                                                                                 |
| Bert Bit Position            | 0x78              | RW  | Dual | A/B  | -       | Dual Access, 32-bit word per channel                                                                           | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Used to set bert bit position when 'BERT<br>Compare Mode' is set to 'single edge'.<br>Position must be less than the currently<br>sourced rx pattern.                                                                                                     |

|                    | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                                           | Target                                                   | Description                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BERT VScan Start   | 0x80              | W   | Data | A/B  | -       | Block of two signed 32-bit integers, in<br>order:<br>[Start (¤V), End (¤V)]                          | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Writing to this address starts vertical<br>bathtub measurements on targeted<br>channels in a true parallel manner; the<br>direction of the sweep is determined by<br>the start and end location.<br>Measurements will be performed based<br>on the single shot duration specified in<br>0x0612. Vertical BERT scans may not be<br>performed while BERT is in continuous<br>mode. |
| BERT VScan Results | 0x82              | R   | Data | A/B  | -       | Block of ((Abs(End– Start)/10000)+1)<br>32-bit integers:<br>Error count, in bits.<br>(Section 7.6.1) | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Reads as an array containing the number<br>of bit errors that occurred at each index<br>setting specified in the most recently<br>completed Vertical BERT Scan Start; max<br>reported error count is 2 <sup>32</sup> -1, and the<br>count saturates at that level;                                                                                                               |
| Reset VScan Read   | 0x84              | W   | Reg  | A/B  | -       | -                                                                                                    | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Resets the read location of VScan Results<br>[0x0682] to read from the beginning of<br>the data.                                                                                                                                                                                                                                                                                 |
| BERT VScan Length  | 0x86              | R   | Reg  | A/B  | 0       | Block length, in bytes                                                                               | [Channel<br>Bitfield]<br>Set via 'Global<br>Target Mask' | Returns the length of the Vertical BERT<br>scan last performed on the channel<br>identified by Target; useful as a check,<br>and when reading back BERT scan<br>results, as this is the length of data block<br>to read                                                                                                                                                          |
| Triggers And Flags | 0x07              |     |      |      |         |                                                                                                      |                                                          |                                                                                                                                                                                                                                                                                                                                                                                  |
| User Flag LED      | 0x30              | W   | Reg  | А    | 0       | LED on (1) / LED off (0)                                                                             | -                                                        | Enables and disable the user LED.                                                                                                                                                                                                                                                                                                                                                |
| Flag State         | 0x32              | RW  | Reg  | A    | 0       | Hi-Z (0), Level High (1), Level Low (2)                                                              | [Flag Bitfield]<br>Set via 'Global<br>Target Mask'       | Allows setting or reading of 5 flag pins.<br>When writing, the following values are<br>valid. Hi-Z(0), High(1), Low(2). A flag<br>bitfield of 0x1F will set the output state<br>on all pins. When operating as a flag<br>input the flag state should first be set to<br>Hi-Z. When reading a single bit must be<br>set in the bitfield.                                          |

|                                     | Cmpt /<br>Subaddr | R/W | Туре | Port | Default      | Data / Data Block Contents                                                                               | Target | Description                                                                                                                                                                                         |
|-------------------------------------|-------------------|-----|------|------|--------------|----------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Configuration                 | 0x08              |     |      |      |              |                                                                                                          |        |                                                                                                                                                                                                     |
| System Reference Clock<br>Source    | 0x10              | RW  | Reg  | A->B | Internal (1) | External (0), Internal (1)                                                                               | -      | Changes are applied on a write to the<br>"Commit Clock Changes" register                                                                                                                            |
| System Reference Clock<br>Frequency | 0x12              | RW  | Reg  | A->B | 250000 kHz   | Frequency, expressed in increments of 1kHz, and stored as a 32-bit integer                               | -      | Changes the system reference clock<br>frequency. Value only applies when<br>System reference clock source is external.<br>Changes are applied on a write to the<br>"Commit Clock Changes" register. |
| Clock Out A Mode                    | 0x14              | RW  | Reg  | A->B | LVDS         | Number specifying output format.<br>CMOS(0), LVPECL(1), LVDS(2),<br>HCSL(3), CML(4)                      | -      | Changes the Clock A output format.<br>Change only applies following a write to<br>the "Commit Clock Changes" register.                                                                              |
| Clock Out A Frequency               | 0x16              | RW  | Reg  | A->B | 100000 Khz   | Frequency, expressed in increments<br>of 1kHz, and stored as a 32 bit<br>integer                         | -      | Changes the Clock Out A frequency.<br>Value only applies on a write to the<br>"Commit Clock Changes" register.                                                                                      |
| Clock Out B Mode                    | 0x18              | RW  | Reg  | A->B | LVDS         | Number specifying output format.<br>CMOS(0), LVPECL(1), LVDS(2),<br>HCSL(3), CML(4)                      |        | Changes the Clock B output format.<br>Change only applies following a write to<br>the "Commit Clock Changes" register.                                                                              |
| Clock Out B Frequency               | 0x20              | RW  | Reg  | A->B | 100000 Khz   | Frequency, expressed in increments of 1kHz, and stored as a 32 bit integer                               | -      | Changes the Clock Out B frequency.<br>Value only applies on a write to the<br>"Commit Clock Changes" register.                                                                                      |
| SSC Enable                          | 0x22              | RW  | Reg  | A->B | Disabled     | Disabled (0), Enabled (1)                                                                                | -      | Changes are applied on a write to the "Commit Clock Changes" register                                                                                                                               |
| SSC Frequency                       | 0x24              | RW  | Reg  | A->B | Disabled, 0  | Frequency, expressed in increments of<br>1 Hz. Minimum frequency 31.5kHz.<br>Maximum frequency is 63kHz. | -      | Value only applies on a write to the "Commit Clock Changes" register.                                                                                                                               |
| SSC Down Spread                     | 0x26              | RW  | Reg  | A->B | Disabled, 0  | Down spread percentage. Percentage<br>expressed multiplied by 100. Ex, 1%<br>would be written as 100.    | -      | Value only applies on a write to the "Commit Clock Changes" register.                                                                                                                               |
| Data Rate                           | 0x30              | RW  | Data | A->B | 8Ghz         | Frequency, expressed in<br>increments of 0.1 Hz, and stored<br>as a 64-bit integer                       | -      | Sets the data rate of the module;<br>changes are applied when "Commit<br>Clock Changes" register is written<br>to                                                                                   |

|                                | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                   | Target | Description                                                                                                                                                                                                                    |
|--------------------------------|-------------------|-----|------|------|---------|------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Rate Calibrated<br>Result | 0x31              | R   | Data | A/B  | 8Ghz    | Frequency, expressed in increments of 0.1 Hz, and stored as a 64-bit integer | -      | Returns the actual data rate obtained as<br>a result of the most recently committed<br>Data Rate; At startup, reflects the default<br>data rate; this value is updated on a<br>write to the "Commit Clock Changes"<br>register |
| Pattern Rate Ratio             | 0x40              | R   | Reg  | A/B  | 1       | Oversampling ratio                                                           | -      | Pattern rate ratio specifies oversampling<br>ratio set within the device. The value<br>read defines the following:                                                                                                             |
|                                |                   |     |      |      |         |                                                                              |        | 1: 1 to 1 oversampling ratio (No oversampling)                                                                                                                                                                                 |
|                                |                   |     |      |      |         |                                                                              |        | 2: 2 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 4: 4 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 8: 8 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 16: 16 to 1 oversampling ratio.                                                                                                                                                                                                |
|                                |                   |     |      |      |         |                                                                              |        | NOTE: Pattern Rate Ratio is updated upon "Commit Clock Changes".                                                                                                                                                               |
| Pattern Rx Rate Ratio          | 0x41              | R   | Reg  | A/B  | 1       | Rx Oversampling Ratio                                                        | -      | Pattern rx rate ratio specifies<br>oversampling ratio set within the device.<br>The value read defines the following:                                                                                                          |
|                                |                   |     |      |      |         |                                                                              |        | 1: 1 to 1 oversampling ratio (No oversampling)                                                                                                                                                                                 |
|                                |                   |     |      |      |         |                                                                              |        | 2: 2 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 4: 4 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 8: 8 to 1 oversampling ratio.                                                                                                                                                                                                  |
|                                |                   |     |      |      |         |                                                                              |        | 16: 16 to 1 oversampling ratio.                                                                                                                                                                                                |
|                                |                   |     |      |      |         |                                                                              |        | NOTE: Pattern Rx Rate Ratio is updated upon "Commit Clock Changes".                                                                                                                                                            |

|                                | Cmpt /<br>Subaddr | R/W | Туре | Port | Default | Data / Data Block Contents                                                       | Target | Description                                                                                                                                     |
|--------------------------------|-------------------|-----|------|------|---------|----------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Commit Clock Changes           | 0x80              | W   | Reg  | A->B | -       | -                                                                                | -      | Changes to the above registers have no<br>effect until this Commit register is<br>written to. Side effects:<br>• Many registers are returned to |
|                                |                   |     |      |      |         |                                                                                  |        | <ul> <li>default status</li> <li>All BERT counters and sync results cleared</li> </ul>                                                          |
|                                |                   |     |      |      |         |                                                                                  |        | Raw capture data los                                                                                                                            |
|                                |                   |     |      |      |         |                                                                                  |        | • Rx reference phase set to default                                                                                                             |
| Speed Grade                    | 0x94              | R   | R    | A/B  | -       | Speed Grade                                                                      | -      | Returns module speed grade indicating<br>the max supported data rate. 0=4.0Gbps.<br>1=8.0Gbps, 2=12.5Gbps, 3=12.8Gbps                           |
| Calibration                    | 0x09              |     |      |      |         |                                                                                  |        |                                                                                                                                                 |
| Max Data Rate                  | 0x26              | R   | Data | A/B  | -       | Max Frequency, expressed in increments of 0.1 Hz, and stored as a 64-bit integer | -      | Returns the highest achievable data rate.                                                                                                       |
| User Pattern Memory<br>Size    | 0x50              | R   | Data | A/B  | -       | Size of pattern memory in bytes.<br>Stored as 64-bit integer.                    | -      | Returns the full size of the user pattern memory in bytes.                                                                                      |
| Rx User Pattern Memory<br>Size | 0x52              | R   | Data | A/B  | -       | Size of pattern memory in bytes.<br>Stored as 64-bit integer.                    | -      | Returns the full size of the rx user pattern memory in bytes.                                                                                   |
| Disable Tx Alignment<br>Data   | 0x54              | W   | Reg  | A/B  | 0       | 0 - Default, 1 - Disable Tx Alignment<br>Data                                    | -      | Set to 1 to disable the tx alignment data.<br>Tx alignment is updated immediately.                                                              |
| Tx Amplitude State             | 0x56              | RW  | Reg  | A/B  | 0       | State 0 (0), State 1 (1),<br>State 2 (2), State 3 (3)                            | -      | State 0: use the mode 1 flash data. Data<br>in regs 0x0514, 0x0516, 0x0518, and<br>0x051A are ignored.                                          |
|                                |                   |     |      |      |         |                                                                                  |        | State 1: disable the use of mode 1 flash<br>data. Data in regs 0x0514 and 0x0516<br>are used.                                                   |
|                                |                   |     |      |      |         |                                                                                  |        | State 2: use the mode 2 flash data. Data<br>in regs 0x0514, 0x0516, 0x0518, and<br>0x051A are ignored.                                          |
|                                |                   |     |      |      |         |                                                                                  |        | State 3: disable the use of mode 2 flash<br>data. Data in regs 0x0518 and 0x051A<br>are used.                                                   |

|                                     | Cmpt /<br>Subaddr | R/W | Туре | Port | Default   | Data / Data Block Contents                                                   | Target                          | Description                                                                                                                                                    |
|-------------------------------------|-------------------|-----|------|------|-----------|------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rx Threshold State                  | 0x58              | RW  | Reg  | A/B  | 0         | State 0 (0), State 1 (1)                                                     | -                               | State 0: use the flash data for rx<br>threshold compensation. Data written to<br>0x0414, 0x0416, 0x0418, 0x041A,<br>0x041C, and 0x041E are all ignored.        |
|                                     |                   |     |      |      |           |                                                                              |                                 | State 1: disable the use of the rx<br>threshold flash data. Data in 0x0414,<br>0x0416, 0x0418, 0x041A, 0x041C, and<br>0x041E are used.                         |
| Jitter State                        | 0x5A              | RW  | Reg  | A/B  | 0         | State 0 (0), State 1 (1)                                                     | -                               | State 0: use the flash data for jitter<br>amplitude compensation. Data written to<br>0x0690, 0x692, 0x0694, and 0x0696 are<br>all ignored.                     |
|                                     |                   |     |      |      |           |                                                                              |                                 | State 1: disable the use of the jitter flash<br>data. Data in 0x0690, 0x692, 0x0694, and<br>0x0696 are used.                                                   |
| Diagnostic Control                  | OxFE              |     |      |      |           |                                                                              |                                 |                                                                                                                                                                |
| Enable Internal Serial<br>Loopback  | 0x20              | RW  | Reg  | A/B  | 0         | Channel Bitfield: Enabled (1) /<br>Disabled (0)                              | -                               | Enables internal serial loopback mode on<br>a per-channel basis. When written, if any<br>channel has CDR enabled the Rx<br>alignment data will become invalid. |
| Raw Data Capture Target             | 0x22              | RW  | Reg  | A/B  | 1         | Channel Bitfield                                                             | -                               | The channel from which to capture data<br>in a raw data capture; a single channel<br>must be selected                                                          |
| Raw Data Capture Start<br>Condition | 0x24              | RW  | Reg  | A/B  | 0         | Disabled (0) / Start on pattern start (1)<br>/ Start on first BERT error (2) | [Channel<br>Bitfield]           | The condition under which a raw data capture starts; The channel selected in                                                                                   |
|                                     |                   |     |      |      |           |                                                                              | Set via 'Global<br>Target Mask' | Target determines which BERT or Patten<br>Source to use as the start trigger; only a<br>single channel may be selected as the<br>trigger channel               |
| Raw Data Capture<br>Memory          | 0x26              | R   | Data | A/B  | Undefined | Raw capture memory, length =<br>16,384 bits (2048 bytes)                     | -                               | Reads as the data captured in the most<br>recently completed raw data capture<br>operation; capture length is fixed at<br>16,384 bits (2048 bytes)             |

|                                    | Cmpt /<br>Subaddr | R/W | Туре | Port | Default     | Data / Data Block Contents           | Target | Description                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------|-------------------|-----|------|------|-------------|--------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Raw Data Capture Status            | 0x27              | R   | Reg  | A/B  | 0 (stopped) | Stopped (0) / Running or pending (1) | -      | Current state of raw capture logic. 1<br>means either running or waiting for<br>pattern start to run                                                                                                                                                                                                                                                |
| Raw Data Capture Stop<br>Condition | 0x28              | RW  | Reg  | A/B  | -           | FF = immediate stop                  | -      | Arms stop trigger when FE24 is in mode<br>2. Starts capture if not already running.<br>Pattern triggers can be any channel.                                                                                                                                                                                                                         |
| Hardware Status                    | 0x32              | R   | Reg  | A/B  | 0           | A hardware status code<br>(0 is ok)  | -      | Bitfield indicating the status of various<br>hardware elements throughout the<br>DJ60HS (Table 17).                                                                                                                                                                                                                                                 |
| Hardware Status Mask               | 0x34              | RW  | Reg  | A/B  | OxFFFFFFF   | Hardware Status Error Mask           | -      | Sets which Hardware Status error bits will<br>be used in triggering the Hardware<br>Status Error pin. By default, all errors are<br>monitored. Logic 0 would mean a status<br>bit is masked and therefore will not<br>generate a Hardware status pin<br>assertion. Errors will always be reported<br>in the Hardware and Global Status<br>register. |
| Clear Hardware Status              | 0x36              | W   | Reg  | A/B  | -           | 32-bit Hardware Bitfield             | -      | Clears selected bits in the Hardware<br>Status register [0xFE32]. Logic 1<br>indicates the Error bit will be cleared.                                                                                                                                                                                                                               |

Table 9: SV3 Address Map – component addresses are bolded

# 7 Access Modes

# 7.1 Simple Registers

Values that fit in 32 bits and support only register reads/writes. e.g. PRBS Polynomial Order exposes a single word, ignoring the Target field and rejecting data block transactions.

# 7.2 Targeted Registers

A collection of several single-word elements that are associated with a group of Targets, such as channels, channel banks, or user pattern slots. The individual elements are addressed using the 'Global Target Mask' command. Data block transactions are rejected. e.g. User Data Pattern Length reads as the length of the user data pattern identified by the 'Global Target Mask' – there is one Length element per user pattern slot.

### 7.3 Simple Data Blocks

These blocks of data ignore the Target field / 'Global Target Mask' and reject register transactions. e.g. Module Temperature reads the temperature from several sensors and exposes them as a single data block.

### 7.4 Targeted Data Blocks

These are used where larger blocks of data are to be associated with a group. As with targeted registers, the elements are identified by the 'Global Target Mask'. Register accesses are rejected. e.g. Pattern Sequence Memory allows storage of Pattern Sequencer Programs in a set of slots, where the slot to address is identified using the Target field.

### 7.5 Dual-Access Addresses

These addresses accept both register and data transfers, allowing flexible access to groups of settings. They appear as either a register or a data block depending on the access mode:

# 7.5.1 Register Read of Dual-Access Address

This behaves identically to a targeted register. Performing a register read on Threshold Voltage, for example, with 'Global Target Mask' set to the channel bitfield 0x04 (third bit on), will read the threshold voltage for Channel 3. Target must identify a single element in this mode – for a Target which is a bitfield, there must be a single bit set.

# 7.5.2 Register Write of Dual-Access Address

A register write takes the content of the Data field and applies it to all the entries identified in the Target field. 'Global Target Mask' may address multiple elements in this mode. For example, performing a register write of 0 to Threshold Voltage, with 'Global Target Mask' set to the channel bitfield 0x1F, will write the threshold voltage 0 to Channels 1 through 5.

# 7.5.3 Data Read of Dual-Access Address

A data read always reads all of the entries in a group and returns them as a data block. The 'Global Target Mask' field is ignored. For example, performing a data read of Threshold Voltage will yield all 8 settings in a Channel Data Block (Section 8.1.4).

# 7.5.4 Data Write of Dual-Access Address

A data write accepts a data block containing entries for all the elements of a group, but only applies those addressed in the 'Global Target Mask' field. The 'Global Target Mask' field may identify multiple elements in this mode. For example, performing a data write to Threshold Voltage, with a data block containing the values 00,11,22,33,44,55,66,77, and with the 'Global Target Mask' bitfield set to 0x81, will write the threshold voltages 00 and 77 to Channels 1 and 8, respectively, ignoring the data block entries for Channels 2 through 7.

### 7.6 Multi-Transfer Data Block

These are used where larger blocks of data are to be associated with a group. As with targeted registers, the elements are identified by the Target field. Register accesses are rejected. The Target field of these registers only accept single index values.

# 7.6.1 Data Read of Multi-Transfer Data Block

Rather than reading an entire data block at once, which may not be possible depending on interface being used, data blocks can be read back in smaller chunks. This feature is performed automatically on specified registers. The length of

data transfers may be set to any length less than 128kBytes. Each successive read yields the next section of data. All read lengths should be a multiple of 4 bytes.

For example, if you wish to read a data block of 64kBytes from channel 1 the following will read back the block in four chunks of size 16 kBytes (0x4000 bytes):

- 1. Data read, Target = 0x01, DataField = 0x00004000, yields bytes 0x00000-0x03FFF
- 2. Data read, Target = 0x01, DataField = 0x00004000, yields bytes 0x04000-0x07FFF
- 3. Data read, Target = 0x01, DataField = 0x00004000, yields bytes 0x08000-0x0BFFF
- 4. Data read, Target = 0x01, DataField = 0x00004000, yields bytes 0x0C000-0x0FFFF

# 8 Data Types

# 8.1 Channel Addressing

### 8.1.1 Channel Bitfield

These simply map one bit to each channel, with the LSB always corresponding to the lowest-numbered channel. So Bit 0 corresponds to Channel 1, Bit 1 to Channel 2, and so on. This is used in reporting synchronization success, for example, where a value in Bit 0 means Channel 1 successfully synchronized.

When passed as the target of a register read operation, channel bitfields must have only one bit set, as only one entry can be read at a time in a register read.

#### 8.1.2 Single-Ended Channel Bitfield

Like the channel bitfield, except this maps a bit to each of a set of single-ended channels, such that the first bit corresponds to Channel 1 negative, the second to Channel 1 positive, the third to Channel 2 negative, and so on.

#### 8.1.3 Channel Bank Bitfield

Maps a single bit to each of the module's two channel banks. The first bit maps to the first bank, and the second bit maps to the second bank.

#### 8.1.4 Channel Data Blocks

A data block which maps at least a single byte, and possibly a wider word, to each channel. The width of each entry in the data block is specified in the register map. The first entry in the data block always corresponds to Channel 1, the second to Channel 2, and so on. Channel Data Blocks are generally exposed as part of Dual-Type registers (Section 7.5).

# 8.1.5 Single-ended Channel Data Blocks

This is similar to a Channel Data Block, except there are 16 entries in a single-ended channel data block, one for each single-ended channel, in the same order as in the Single-Ended Channel Bitfield: Channel 1 negative, Channel 1 positive, Channel 2 negative, and so on....

# 8.1.6 Channel Bank Data Blocks

Similar to Channel Data Blocks, these registers map two entries to the module's two channel banks, where the first entry maps to the first Bank, and the second to the second. The width and interpretation of the entries is provided in the address map.

# 8.2 Pattern Configuration

A set of pattern providers is available to drive the 32 Tx data patterns and the 32 BERT reference patterns, as shown in. Providers are the green objects to the left, and are identified by a Pattern Provider ID. Within each provider lies the possibility of several *Sources*, such as each of the PRBS generator, or the user slots in a user pattern provider. Details are provided below.



Figure 3: The Pattern Sources and Consumers Model

#### 8.2.1 Pattern Selector

Pattern selectors are used to identify both the provider (e.g. PRBS) and specific source (e.g. User Pattern Slot ID). The 4-byte Selector is split up as follows:

| Field     | Provider ID | Source ID | Total   |
|-----------|-------------|-----------|---------|
| Byte cnt  | 2           | 2         | 4 bytes |
| Byte addr | 3:2         | 1:0       |         |

Table 10: Pattern Selector Fields

Each field is described below. Note that there is presently a single PRBS generator available globally, so the Source ID for PRBS is always written as zero. The Pattern Selector for a PRBS would be 0x0001 0000. And the User Pattern in Slot #3: 0x0004 0003.

| Provider ID | Meaning           | Provider                | Source ID | Meaning                   |  |
|-------------|-------------------|-------------------------|-----------|---------------------------|--|
| 1           | PRBS              | Sequencer               | 0-15      | Pattern Sequence Slot IDs |  |
| 2           | Rx Loopback       | User                    | 0-127     | User Pattern Slot IDs     |  |
| 3           | Pattern sequencer | Others                  | Others    | Reserved                  |  |
| 4           | User Pattern      | Table 12: Source ID Map |           |                           |  |
| Others      | Reserved          |                         |           |                           |  |

Table 11: Pattern Provider ID Map

### 8.2.2 Preformatted Data Patterns

User data patterns are transmitted to the module as a raw block of packed binary data. A 2048-bit data pattern is packed into 2048/8 bytes, for example, with the first bit packed into the MSB of the first byte of the block, the next bit to follow, and so forth for 256 bytes.

# 8.2.3 User Pattern Slot ID

User patterns are uploaded into slots, and later recalled from those slots, using unique Pattern Slot IDs. There are 1024 slots available, and each slot has its own ID, in the range 0 to 1023. User Pattern Slot IDs are used when uploading to, or downloading from, the User Data Pattern Memory. Similarly, the Source ID field of a Pattern Selector accepts a User Pattern Slot ID, when the Pattern Provider is set to User Pattern. Note that User Patterns can only be a multiple of 8 bits.

# 8.2.4 Writing to User Pattern Memory

User pattern memory is automatically managed so that a total of up to 1 GB of data pattern can be stored across the 1024 slots. The downside of this memory management is that uploading a pattern to memory can cause already-uploaded patterns to be moved to keep them contiguous. If a pattern gets moved while it is being sourced, either directly as a User

Pattern or through a Pattern Sequencer, then the output pattern will be corrupted until it is restarted. The same applies to an overwritten pattern: if you source the pattern in Slot 1, then overwrite the contents of that slot, the output pattern will be incorrect until you restart it.

The recommended use of user pattern memory is therefore to stop sourcing User Patterns and Pattern Sequencers before uploading to pattern memory.

#### 8.2.5 Clearing a user pattern

Writing a pattern of length zero to a slot will empty it, freeing any memory that was previously occupied by that slot. When writing a pattern of length zero, a data transfer is still required – even though a length of zero is indicated, any length of transfer is accepted by the command processor without raising errors, and the contents of that transfer are simply ignored.

#### 8.2.6 Scrolling Readback from User Pattern Memory

Rather than reading an entire user pattern at once, user patterns can be read back in smaller chunks. This feature is enabled by first performing a normal data read, with the data size set to any length desired, then repeating that read command with the uppermost bit of the Target bitfield set. Each read yields the next section of the user data pattern, until the entire pattern is read back. All reads must be a multiple of 512 bits (64 bytes) long.

For example, if a user pattern of length 128 kBytes (1MBit) has been loaded into Slot 2, the following will read back the pattern in four chunks of size 32 kBytes (0x8000 bytes):

- 1. Data read, Target = 0x01, Length = 0x8000, yields bytes 0x00000-0x07FFF
- 2. Data read, Target = 0x81, Length = 0x8000, yields bytes 0x08000-0x0FFFF
- 3. Data read, Target = 0x81, Length = 0x8000, yields bytes 0x10000-0x17FFF
- 4. Data read, Target = 0x81, Length = 0x8000, yields bytes 0x18000-0x1FFFF

Note that reading with the uppermost bit of Target cleared will always reset to reading from byte 0 of the pattern.

# 8.2.7 Writing User Pattern Memory in Blocks

Patterns that exceed 32KB need to be written as a series of blocks. First a memory space must be allocated for the entire pattern length [0x0314] and then the data pattern must be written to this allocated space [0x0310]. This feature is enabled by performing the user pattern memory command with the uppermost bit of the Global Target Mask [0x0232] set. Each write then stores the next section of the user data pattern, until the entire pattern is written. Note, user patterns can only be written in blocks following memory allocation [0x0314]. All pattern lengths must be a multiple of 4 bytes.

For example, if a user pattern of length 64 kBytes is to be written the following commands will perform the write to Slot 2 in 4 blocks of 16 kB.

- 1. Register Write, Set user slot via Global Target. Command = 0x0232, Target = 0x00, Data = 0x0000002
- 2. Register Write, Allocate Pattern Space. Command = 0x0314, Target = 0x00, Data = 0x10000
- 3. Register Write. Set repeated write bit and user slot via Global Target. Command = 0x0232, Target = 0x00, Data = 0x80000002
- 4. Data Write, Command = 0x0310, Target=0x00, Data = 0x4000, Pattern Bytes
- 5. Data Write, Command = 0x0310, Target=0x00, Data = 0x4000, Pattern Bytes
- 6. Data Write, Command = 0x0310, Target=0x00, Data = 0x4000, Pattern Bytes
- 7. Data Write, Command = 0x0310, Target=0x00, Data = 0x4000, Pattern Bytes

#### 8.2.8 Pattern sequencer programs

Pattern sequencer programs are expressed as a block of up to twelve 4-byte *pattern commands* and a four-byte external loop count. The format is summarized in Table 13.

| Byte Range | Content             | Meaning                                           |
|------------|---------------------|---------------------------------------------------|
| 3:0        | Pattern Command 0   | Entry slot - not affected by external loop count. |
| 7:4        | Pattern Command1    |                                                   |
|            |                     |                                                   |
| 47:44      | Pattern Command 11  | Exit slot - not affected by external loop count.  |
| <51:48>    | External Loop Count | Indicates number of times program will loop.      |

Table 13: Pattern Sequencer Format

Each 4-byte pattern command follows this format:

| Field     | Repetition<br>count | Padding | User Pattern<br>Slot ID |         |
|-----------|---------------------|---------|-------------------------|---------|
| Byte cnt  | 2                   | 1       | 1                       | 4 bytes |
| Byte addr | 2                   | 1       | 0                       |         |

Table 14: The 2-byte pattern command format

Repetition count is 2 bytes, and so valid repetition counts are from 0 to 65535. There are two special cases of values. Writing a repetition count of 0 causes the pattern slot to be skipped, writing a value of 65535 will cause the pattern slot to repeat infinitely. Any other count causes the pattern to run the requested number of times – i.e. a value of 1 causes the pattern to run twice, and so on.

Valid External Loop Counts are from 1 to 65535. Writing the maximum value of 65535 in the loop count will cause this outer loop to repeat infinitely. Please note that the external loop count only affects Pattern Slot 1 to Slot 10. Pattern slots 0 and 11 are the entry and exit slot and do not loop based on the external loop count.



Block diagram of the Pattern Sequencers within each Pattern Generator.

### 8.2.9 Pattern Sequence Slot ID

Similar to the scheme with User Patterns, Pattern Sequences are uploaded into slots with unique IDs. These unique IDs are then used to identify the pattern sequences when uploading, downloading, and as the Source ID field of a Pattern Selector, when the Pattern Provider is set to Pattern Sequencer. There are 16 Pattern Sequence slots, numbered from 0 to 15.

### 8.2.10 PRBS Generator

There is a onboard PRBS generator for each channel which can be configured via the PRBS Polynomial Order registers. The available orders are 5, 7, 9, 11, 13, 15, 21, 23 and 31.

## 8.3 Triggers and Flags

## 8.3.1 Trigger ID

Each triggerable component accepts as a parameter a Trigger ID. BERTs, pattern sources and jitter injection, for example, all start based on the Trigger ID written to their Start registers.

Table 15 summarizes the available Trigger IDs: "no start" (0x00), "start now" (0xFF), and "start on trigger event going active" (others). Note that "no start" is not the same as "stop" – processes that can be stopped have separate stop registers.

| Trigger ID  | Meaning               |
|-------------|-----------------------|
| 0x00        | No start              |
| 0x01 - 0x02 | Trigger Pins #1 to #2 |
| OxFF        | Start immediately     |
|             |                       |

Table 15: Trigger IDs

#### 8.4 Fixed point formats

In some registers, fixed point notation is used to represent fractional numbers. The format is specified in three parts: signed/unsigned, bits dedicated to the whole number, and bits dedicated to the fractional number. The latter two are shown as <whole>:<fractional>.

For example, an unsigned fixed point 8:24 format means an unsigned number is represented with 8 whole number bits and 24 fractional bits. In this format, the number 0x02 8000000 decodes to 2  $\frac{1}{2}$ , and the number 0xFF 400000 to 255  $\frac{1}{4}$ . The minimum fraction that can be expressed in this format is  $2^{-24}$ .

# 8.5 ID Strings

# 8.5.1 Personality ID String

This is a NULL-terminated (and NULL-padded) string with a length of 24 bytes. It contains the personality part number stripped of its dashes and padded, at the end, with NULL characters. The personality part numbering scheme is documented elsewhere.

Below is the String numbering definition with examples:



From the stated example, FW-60HS-IESP-01-B000 would appear in the Personality ID String without dashes and with null-padding at the end, as in:

| 'F' 'W' '6' '0' 'H' 'S' '1' 'E' 'S' 'P' '0' '1' 'B' '0' '0' '0' '0' 0 0 0 0 0 0 | 0 | 0 | ) |
|---------------------------------------------------------------------------------|---|---|---|
|---------------------------------------------------------------------------------|---|---|---|

#### 8.6 Error Codes

The various error codes that appear throughout the interface are summarized in the tables below.

| Global Error Status | Meaning                                                                                                    | Hardware status bit | Meaning                                                           |
|---------------------|------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------|
| bit                 | <u> </u>                                                                                                   | 0                   | Clock Reconfiguration Complete                                    |
| 0                   | Generic invalid command                                                                                    | 1                   | System Clock Locked                                               |
| 1                   | Generic parameter out of range                                                                             | 2                   | Secondary Clock Locked                                            |
| 2                   | Voltage parameter out of range                                                                             | 3                   |                                                                   |
| 3                   | Transfer too short: too few bits                                                                           | 6                   | Memory Calibration Complete                                       |
|                     | were included in the most                                                                                  | 7                   | Memory Initialization Complete                                    |
|                     |                                                                                                            | 8                   | Memory Locked                                                     |
| 4                   | a number of hardware-related                                                                               | Others              | Reserved                                                          |
|                     | issues, including<br>overtemperature, undervoltage, Table 17: Hardwa<br>and loss of clock lock means OK, a |                     | are Status Bits – in all cases, a 0<br>and a 1 indicates an error |
| 6                   | Trigger Timeout                                                                                            |                     |                                                                   |
| 7                   | Digital CDR lock failed                                                                                    |                     |                                                                   |
| 31                  | Licence Error                                                                                              |                     |                                                                   |

Table 16: Global Error Codes

# 9 Programming Examples

# 9.1 Pattern Source

A PRBS-7 pattern source on all 32 channels with parameterized pre-emphasis. Prerequisite is that the module be in its default state.

| Operation                    | Transaction / comments                                                                  | Addr    | Target | Data / Data Block                                                                    |
|------------------------------|-----------------------------------------------------------------------------------------|---------|--------|--------------------------------------------------------------------------------------|
| Set Global Target Mask       | Write reg: Configuration Manager: Global Target Mask. Written to SPI Port               | 0x2 32  | -      | OxFFFF                                                                               |
|                              | A                                                                                       |         |        | Select channels 1-16 for modification.                                               |
| Set Global Target Mask       | Write reg: Configuration Manager: Global Target Mask. Written to SPI Port               | 0x2 32  | -      | 0xFFFF                                                                               |
|                              | В                                                                                       |         |        | Select channels 17-32 for modification.                                              |
| Set output amplitude         | Write dual as reg: Tx Configuration: Output Amplitude. Written to SPI Port              | 0x05 10 | -      | 0x00124F80                                                                           |
| to 1200 mV                   | A                                                                                       |         |        | (Amplitudes expressed in $\Box V$ , channels 1-16)                                   |
| Set output amplitude         | Write dual as reg: Tx Configuration: Output Amplitude. Written to SPI Port<br>B         | 0x05 10 | -      | 0x00124F80                                                                           |
| to 1200 mV                   |                                                                                         |         |        | (Amplitudes expressed in ¤V, channels 17-<br>32)                                     |
| Set pre-emphasis tap weights | Write dual as reg: Tx Configuration: Pre-emphasis Settings. Written to SPI<br>Port A    | 0x05 36 | -      | 0x01020300                                                                           |
|                              |                                                                                         |         |        | Sets pre-cursor to 1, post-cursor #1 to 2, and post-cursor #2 to 3, , channels 1-16  |
| Set pre-emphasis tap weights | Write dual as reg: Tx Configuration: Pre-emphasis Settings. Written to SPI<br>Port B    | 0x05 36 | -      | 0x01020300                                                                           |
|                              |                                                                                         |         |        | Sets pre-cursor to 1, post-cursor #1 to 2, and post-cursor #2 to 3, , channels 17-32 |
| Set Tx data pattern          | Write dual as reg: Tx Configuration: Tx Data Pattern Provider. Written to SPI<br>Port A | 0x05 04 | -      | 0x0001 0000                                                                          |
|                              |                                                                                         |         |        | (Pattern Selector for PRBS, channels 1-16)                                           |

| Set Tx data pattern            | ern Write dual as reg: Tx Configuration: Tx Data Pattern Provider. Written to SPI |         | - | 0x0001 0000                                 |
|--------------------------------|-----------------------------------------------------------------------------------|---------|---|---------------------------------------------|
|                                | Port B                                                                            |         |   | (Pattern Selector for PRBS, channels 17-32) |
| Set PRBS Order to 7            | Write reg: Pattern Source: PRBS Polynomial Order. Written to SPI Port A           | 0x03 30 | - | 7 (PRBS Polynomial Order)                   |
| Set PRBS Order to 7            | Write reg: Pattern Source: PRBS Polynomial Order. Written to SPI Port B           | 0x03 30 | - | 7 (PRBS Polynomial Order)                   |
| Set pattern to run immediately | Write dual as reg: Pattern Source: Pattern Start. Written to SPI Port A           | 0x03 04 | - | OxFF                                        |
|                                |                                                                                   |         |   | (Start immediately, all channels)           |
| Set pattern to run immediately | Write dual as reg: Pattern Source: Pattern Start. Written to SPI Port B           | 0x03 04 | - | OxFF                                        |
|                                |                                                                                   |         |   | (Start immediately, all channels)           |

### 9.2 Data Rate Change

Demonstrates changing the operating rate of the SV3D. In this example we use polling to determine when the clock change is complete.

| Operation          | Transaction / comments                                                                                                                                                                                                                                       | Addr    | Target | Data                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|-------------------------------------------------------|
| Set Data Rate      | Write data: Clock Configuration: Data Rate. Written to SPI Port A                                                                                                                                                                                            | 0x08 30 | -      | 0x00000003 7e11d600<br>(set data rate to 1500.0 Mbps) |
| Set Data Rate      | Write data: Clock Configuration: Data Rate. Written to SPI Port B                                                                                                                                                                                            | 0x08 30 | -      | 0x00000003 7e11d600<br>(set data rate to 1500.0 Mbps) |
| Poll on Completion | Read reg: Module Control: Global Status. Written to SPI Port A<br>Command is repeated until expected status is returned. A response of '05<br>05 05 05 05 05 05 05' indicates the system is busy. '07 07 07 07 07 07 07 07 07'<br>indicates it is available. | 0x01 02 | -      | 0x0000000                                             |
| Poll on Completion | Read reg: Module Control: Global Status. Written to SPI Port B<br>Command is repeated until expected status is returned.                                                                                                                                     | 0x01 02 | -      | 0x0000000                                             |