

# Quarch Technology Ltd Gen 5 EDSFF x4 Breakers Technical Manual

For use with:

# QTL2892 – Gen5 EDSFF x4 Breaker QTL2925 – Gen5 EDSFF x4 Breaker + Triggering

# Using Quarch firmware version 5.000 and above



Wednesday, 17 May 2023



# **Change History**

| 1.0 | 19/01/2023 | Initial Release                    |
|-----|------------|------------------------------------|
| 1.1 | 17/05/2023 | Updated mechanical characteristics |
|     |            |                                    |
|     |            |                                    |
|     |            |                                    |



# Contents

| Change History                               | 2  |
|----------------------------------------------|----|
| Introduction                                 | 4  |
| Technical specifications                     | 5  |
| Power requirements                           | 5  |
| Switching characteristics                    | 5  |
| Mechanical characteristics                   | 6  |
| Control Interfaces                           |    |
| Basic Concepts                               | 9  |
| Signal Configuration                         |    |
| Power Up vs. Power Down Timing               | 14 |
| Glitch Control                               |    |
| Signal Driving                               |    |
| Signal Monitoring                            |    |
| Voltage Measurements                         |    |
| Default Startup State                        |    |
| Controlling the Module                       |    |
| Terminal Command Set                         |    |
| Appendix 1 - Signal Names                    |    |
| Appendix 2 – Signals supporting 'Monitoring' |    |
| Appendix 3 – Signals supporting 'Driving'    | 40 |



# Introduction

The **GEN5 EDSFF x4 Breakers** allow remote switching of the data and sideband pins on an EDSFF drive for test automation or fault injection purposes.

The modules support data rates up to 32GT/s.

Each pin is individually switched, allowing complete control over the mating sequence of a drive connector.

The switches can be sequenced at precise timings to simulate a hot-swap event, including pin bounce. Individual pins can also be broken or glitched at any time to simulate a fault in the system.

The breaker module can be sold as various kits to ensure it fits various EDSFF host enclosures as detailed in the mechanical characteristic section. The kits contain the module and appropriate metalwork to fit the host systems.

This module supports the 'High Resolution' firmware feature, which allows for more detailed time resolution for initial delay and bounce period timing.

The triggering version of the module includes trigger IN and OUT connectors to allow sync with other test equipment, such as analyzers or power modules.

Two versions of the module are available:

QTL2892 - The basic module

QTL2925 – Module with additional external triggering, allowing sync with external equipment and additional monitoring of sideband signals



# **Technical specifications**

# **Power requirements**

The modules take power from its controller: Either a QTL1260 Interface Kit, or a QTL1461/QTL1079 Array Controller. No power is required from the host/device.

# **Switching characteristics**

| Drive pins     | Description                        | Switching Action                                                  |
|----------------|------------------------------------|-------------------------------------------------------------------|
| PCIe data      | 4 lanes of GEN5<br>PCIe data       | Each signal is individually<br>switched by a high-speed<br>Switch |
| 12v<br>3v3_aux | Power supply                       | Individually switched by power FET                                |
| REFCLK         | 2x differential RefClk signals     | Each signal is individually<br>switched by a high-speed<br>Switch |
| Sideband       | PRSNT, PERST#,<br>LED, SM BUS, etc | Each signal is individually switched                              |

# **Protocol Compatibility**

The modules are protocol agnostic and can switch any protocol which is compatible with EDSFF electrical specification.

Depending on the quality of your host, device and cabling, there may be some cases where the highest speed protocols do not work error-free through the modules. We always recommend that you evaluate a module in your live system before purchasing, especially when long traces are used, or where the mechanical fit may be tight.



# **Mechanical characteristics**

The table below shows dimensions for each of the modules. The drive offset distance assumes the use of an Amphenol MET00843140110X receptacle on the host side.

|                             | Height (H) /<br>mm | Thickness (T) /<br>mm | Drive offset (O) /<br>mm | Module length (L) /<br>mm |
|-----------------------------|--------------------|-----------------------|--------------------------|---------------------------|
| E1 Caseless                 | 31.50              | 6.40                  | 93.10                    | 98.30                     |
| E1 (E1.S) Kit               | 33.75              | 9.50                  | 93.10                    | 98.30                     |
| E3 (E3.S,<br>E3.L)          | 76.00              | 7.50                  | 93.10                    | 98.30                     |
| E3 2T (E3.S<br>2T, E3.L 2T) | 76.00              | 16.80                 | 93.10                    | 98.30                     |

Below is a drawing for the E1 Caseless module with the corresponding dimension variables. (Not to scale)





# E1 (E1.S) Kit:



E3 (E3.S, E3.L) Kit:

and

E3 2T (E3.S 2T, E3.L 2T) Kit:





# **Control Interfaces**

All Torridon modules are designed to be used with a Torridon Array Controller (QTL1461, QTL1079) or a single Torridon Interface Kit (QTL1260).

The control cable is an ultra-thin flex cable.

| Control<br>Interface                                      | Form Factor                                                 | Torridon Ports                   | Control<br>Methods<br>Available              | Interfaces                                                           |
|-----------------------------------------------------------|-------------------------------------------------------------|----------------------------------|----------------------------------------------|----------------------------------------------------------------------|
| <b>QTL1079</b><br>28 Port<br>Torridon Array<br>Controller | 1U 19" Rack<br>Mounted unit                                 | 24 at the front<br>4 at the rear | Terminal<br>Scripting<br>TestMonkey 2<br>GUI | Serial via DB9<br>or RJ45<br>Ethernet<br>USB                         |
| <b>QTL1461</b><br>4 Port Array<br>Controller              | 160x165x53mm<br>Enclosure<br>1U Enclosure<br>also available | 4 ports on<br>front              | Terminal<br>Scripting<br>TestMonkey 2<br>GUI | Serial via<br>RJ45<br>Ethernet<br>USB                                |
| <b>QTL1461</b><br>Torridon<br>Interface Kit               | 60mm x 45mm<br>x 30mm Box                                   | 1 port                           | Terminal<br>Scripting<br>TestMonkey 2<br>GUI | Serial via RJ-<br>45<br>Serial via<br>USB/Serial<br>convertor<br>USB |



# **Basic Concepts**

Each controlled pin is connected to a separate switch on the module, so it can be connected or isolated on command.



Each switch on the module is called a 'Signal' and can be programmed to follow one of six programmable delay and bounce profiles (called 'Sources'). This allows the user to sequence the signal connections in the cable in up to six programmable steps.

This allows us to create virtually any hot-swap scenario. The default scenario on the module is based on the pin lengths on the connector, so that the long pins mate first, followed by shorter pins.





Each of the programmable delay and bounce profiles is called a control source, S1 to S6. For each control source the user sets up a delay, and bounce parameters. Three special sources (S0, S7 and S8) are also provided as described in the table below.



Control Source Parameters for a power up event (Basic Pin Bounce)

Once each delay period is set up, the user assigns each signal to follow the relevant control source, then uses the "**run:power up**" and "**run:power down**" commands to initiate the hot-swap.

The BUSY bit 1 in the control register is set during a power up, power down and short operation. This may be used to monitor for the completion of timed events.





Power up and Power down example



# **Signal Configuration**

Each signal that is switched by the module is usually assigned to one of the 6 timed sources, S1 - S6. Each signal can also be assigned directly to 'always off' (source 0), 'immediate change' (source 7) or 'Always on' (source 8).

Signals assignment is done through the command:

# SIGnal:[name]:SOURce [Source#]

| Source Number | Description                         |
|---------------|-------------------------------------|
| 0             | Signal is always OFF                |
| 1             | Signal assigned to control source 1 |
| 2             | Signal assigned to control source 2 |
| 3             | Signal assigned to control source 3 |
| 4             | Signal assigned to control source 4 |
| 5             | Signal assigned to control source 5 |
| 6             | Signal assigned to control source 6 |
| 7             | Signal changes with HOT_SWAP state  |
| 8             | Signal is always ON                 |





This diagram shows the 9 possible source settings entering the control MUX for a switched signal. The value of the control register will determine which of the sources are used to control the signal. When enabled, the hot-swap line will cause the MUX to pass the control signal from that source through to the switch.



# Power Up vs. Power Down Timing

Each control source is always configured with power-up parameters. The powerdown profile is automatically generated by the module, and is the mirror image of the power up:



If you require a different power down sequence then you can alter any of the source timing values, pin bounce or signal assignments while the module is in the plugged state. When you initiate the 'pull' action, the new settings will be used.



# **Glitch Control**

Any control signal may be glitched for a pre-determined length of time using the glitch generator logic.

Each Signal Control register contains a "GLITCH: ENABLE" bit which determines whether the glitch logic will affect that signal. The setting, defaults to off, so any glitches will have no effect unless explicitly set to do so.

Glitches will invert the current state of the switched signal. Therefore if a switch is currently OFF, a glitch will turn it ON, and if the switch is ON, it will turn OFF.

For modules that support signal driving, the glitch action will drive the signal following the 'DRIVE:OPEN' and 'DRIVE:CLOSED' settings

Glitches may be applied in 3 modes:

### **Glitch Once**



A single glitch is generated when the **RUN:GLITch ONCE** command is executed.

The length of the glitch is determined by using the **GLITch:SETup** command or the **GLITch:MULTiplier** and **GLITch:LENgth** commands:

# PULSE LENGTH = GLITch:MULTiplier x GLITch:LENgth

Repeated use of the **RUN:GLITch:ONCE** command will generate multiple glitches, it is not necessary to use the **RUN:GLITch OFF** command after a single glitch.



### **Glitch Cycle**



A sequence of glitches is generated when the **RUN:GLITch CYCLE** command is executed, and continues until **RUN:GLITch OFF** is executed.

The length of the glitch is determined by using the **GLITch:SETup** command or the **GLITch:MULTiplier** and **GLITch:LENgth** commands:

PULSE LENGTH = GLITch:MULTiplier x GLITch:LENgth

The length of time between each glitch pulse is set in the same way as the glitch length, The length of the gap is determined by using the GLITch:CYCle:SETup command or the GLITch:CYCle:MULTiplier and GLITch:CYCle:LENgth commands:

OFF TIME = GLITch:CYCle:MULTiplier x GLITch:CYCle:LENgth



### **Glitch PRBS**



A pseudo random sequence of glitches is generated when the **RUN:GLITch PRBS** command is executed, and continues until **RUN:GLITch OFF** is executed.

The length of the glitch is determined by using the **GLITch:SETup** command or the **GLITch:MULTiplier** and **GLITch:LENGTH** commands:

#### PULSE LENGTH = GLITch:MULTiplier x GLITch:LENgth

The number of glitches in a set length of time is determined by the **GLITch:PRBS** command. A value of 2 will result in glitches at a ratio of 1:2 (the line will be in a glitched state 50% of the time), whilst a value of 256 will produce glitches in a ratio of 1:256.



# **Signal Driving**

The module has the ability to drive the following sideband signals in certain configurations. See the appendix for a list.

For these signals, the user can specify a behaviour using the SIGnal:[SIG\_NAME]:DRIve:[OPEN] CLOSED] [NONE|HIGH|LOW] command. The OPEN parameter is used to specify the action that the module should take when the switch is open (following a RUN:POWer DOWN command or when the signal is assigned to source 0), and the CLOSED parameter is used to specify the action to take when the switch should be closed (following a RUN:POWer UP command or when the signal is assigned to Source 8). The default behavior for both OPEN and CLOSED states is NONE, which tells the module not to drive the signal lines at all (just open and close the switch as usual).

The behavior of the module when signal driving is enabled (set to **HIGH** or **LOW**) is different depending on the signal being driven to avoid hardware conflicts:

# Examples:

### PERST

Note that PERST is used as a general example, your module may have signals with different names. Please check the list of available signals in the appendix of this document

To issue a fundamental reset to the device under test:

PERST is an active low signal so to assert one we need to drive it low. Assuming the module is already powered up then we need to change the **CLOSED** behavior from **NONE** to **LOW**, and then back again to clear the reset.

# >SIGnal:PERST:DRIVE CLOSED LOW

(Line is driven low: reset is asserted)

# >SIGnal:PERST:DRIVE CLOSED NONE

(Line driving is disabled: reset is de-asserted)



#### Advanced Usage:

If we want to assert PERST for a set period of time, we can set the **OPEN** behavior and use the glitch function on the PERST signal to control the "open" time.

### >SIGnal:PERST:GLITch:ENAble ON

### >SIGnal:PERST:GLITch:SETup 500us 2

### >SIGnal:PERST:DRIVE OPEN LOW

### >RUN:GLITch ONCE

During the glitch event, the switch would normally be open for 1mS. The addition of the driving setting changes this to instead drive the signal low for 1mS



# **Signal Monitoring**

The 'signal monitoring' feature allows specific signals on a module (normally sideband signals) to be tracked.

The state of a monitored signal can be requested from the module at any time via a command

On 'triggering' modules, the state of a signal can be output in real time to one of the triggering ports. As there are two trigger ports, two signals can be monitored at a time. This is ideal for diverting SM\_BUS to an analyser.

For a list of signals on the module that support triggering, see the annex at the end of the manual.

#### Requesting signal state

To get the state of a monitored signal:

#### SIGnal:[SIGNAL-NAME]:STATus:[HOST?|DEVice?]

Returns the current state of the monitored signal as **HIGH** or **LOW**. The signal state can (if supported) be monitored independently on both the host and device side of the module.

#### Live monitoring

This feature is supported on 'Triggering' modules only. Both the trigger IN and OUT ports can be used to monitor a signal.

WARNING: As the trigger IN port can be ordered to OUTPUT a status, there is a risk of two devices driving against each other and causing damage. Before using the live monitoring feature, you must ensure that you do not have any equipment attached that may try to drive the trigger IN port.

To begin live monitoring, first enable the trigger ports you want to use. This is done via additional options to the existing trigger setup commands:

Trigger OUT port: # Set the trigger mode to sideband monitor TRIGger:OUT:MODE:SIDEband

Trigger IN port (requires double verification)
# Set the trigger mode to sideband monitor
TRIGger:IN:MODE:SIDEband
# Also set the trigger IN source to sideband out
TRIGger:IN:SOURCE:SIDEband



The commands to control monitoring are:

# # Select a signal for live monitoring TRIGger:MONitor[IN|OUT]:[SIGNAL-NAME]:[HOST|DEVice]

Sets a trigger port to activate live monitoring for a given signal. The host/device parameter selects the side of the module to monitor on.

# TRIGger:MONitor[IN?|OUT?]

Returns the selection for live monitoring on the given trigger port. The response will be in the form **PERST:HOST** or similar (**SIGNAL\_NAME:SIDE**)

Note that the triggering mode must also be set before the live monitoring will start.



# Voltage Measurements

The modules are capable of measuring various voltages both for self test and to assist in the testing of a customer's system. The following measurement points are available:

| Measurement Command         | Description                                                         | Resolution /<br>Accuracy |
|-----------------------------|---------------------------------------------------------------------|--------------------------|
| MEASure:VOLTage:SELF 3v3?   | Returns the voltage of the module's internal 3.3v power rail        | 64mV / 5%                |
| MEASure:VOLTage:SELF 5v?    | Returns the voltage of the module's internal 5v internal power rail | 64mV / 5%                |
| MEASure:VOLTage:SELF -5v?   | Returns the voltage of the module's internal -5V power rail         | 64mV / 5%                |
| MEASure:VOLTage 12vin?      | Returns the host side 12V power rail                                | 64mV / 5%                |
| MEASure:VOLTage 12vout?     | Returns the drive side 12V power rail                               | 64mV / 5%                |
| MEASure:VOLTage 3v3_auxin?  | Returns the host side<br>3V3_aux power rail                         | 64mV / 5%                |
| MEASure:VOLTage 3v3_auxout? | Returns the drive side<br>3V3_aux power rail                        | 64mV / 5%                |



# **Default Startup State**

On power up or reset, the control modules enter a default state. On the cable module all signals are connected at startup. The "run:power down" command will immediately disconnect the cable without needing any initial setup.

The default hot-swap scenario will disconnect data pins immediately, followed by the management interface (as the management interface uses longer pins)

| Source<br>Number | Initial<br>Delay | Pin<br>Bounce<br>Mode | Bounce<br>Length | Bounce<br>Period | Bounce Duty<br>Cycle |
|------------------|------------------|-----------------------|------------------|------------------|----------------------|
| 1                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |
| 2                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |
| 3                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |
| 4                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |
| 5                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |
| 6                | 0mS              | Standard              | 0mS              | 0uS              | 50%                  |

| Signal                                    | Assigned Source |
|-------------------------------------------|-----------------|
| REFCLKp0, REFCLKn0, REFCLKp1,<br>REFCLKn1 | Source 1        |
| SMBRST, SMBCLK, SMBDAT                    | Source 1        |
| PWRDIS, DUALPORTEN, MFG                   | Source 1        |
| PRSNT0, PERST0, PERST1                    | Source 1        |
| 12V, 3V3_AUX                              | Source 1        |
| All PCIe Data signals                     | Source 1        |

#### Hot-Swap State:

The cable is in the 'plugged' state, waiting for a **RUN:POWer DOWN** command to disconnect it.



# **Controlling the Module**

The module can be controlled either by:

Serial ASCII terminal (such as HyperTerminal)

This is normally used with scripted commands to automate a series of tests. The commands are normally generated by a script or user code (PERL, TCL, C, C# or similar).

Telnet Terminal (Only when connected to an Array Controller).

This mode uses exactly the same commands as the serial ASCII terminal, but run over a standard Telnet connection.

REST API (Only when connected to an Array Controller).

Controllers provide a basic REST API, allowing multi-user control over Torridon products.

USB

Quarch's TestMonkey application can control a single module via USB, this allows simple graphical control of the module. The Quarch C# API and Python examples allow automation via USB.

# **Terminal Command Set**

These commands are based on the SCPI style control system that is used by many manufacturers of test instruments. The entire SCPI specification has NOT been implemented but the command structure will be very familiar to anyone who has used it before.

- SCPI commands are NOT case sensitive
- SCPI commands are in a hierarchy separated by ':' (LEVel1:LEVel2:LEVel3)
- Most words have a short form (e.g. '**register**' shortens to '**reg**'). This will be documented as **REGister**, where the short form is shown in capitals.
- Some commands take parameters. These are separated by spaces after the main part of the command (e.g. "meas:volt:self 3v3?" obtains the 3v3 self test measurement).
- Query commands that return a value all have a '?' on the end
- Commands with a preceding '\*' are basic control commands, found on all devices.



Commands that do not return a particular value will return "OK" or "FAIL". Unless disabled, the fail response will also append a text description for the failure if it can be determined.

### # [comments]

Any line beginning with a # character is ignored as a comment. This allows commenting of scripts for use with the module.

#### \*RST

Triggers a reset, the module will behave as if it had just been powered on.

#### \*CLR

Clear the terminal window and displays the normal start screen. Also runs the internal self test. The same action can be performed by pressing return on a blank line.

#### \*IDN?

Displays a standard set of information, identifying the device. An example return is shown below:

| Family:     | Torridon System            | [The parent family of the device] |
|-------------|----------------------------|-----------------------------------|
| Name:       | Ethernet Cable Pull Module | [The name of the device]          |
| Part#:      | QTL1271-01                 | [The part number of the hardware] |
| Processor:  | QTL1159-01,3.50            | [Part# and version of firmware]   |
| Bootloader: | QTL1170-01,1.00            | [Part# and version of bootloader] |
| FPGA 1:     | 1.0                        | [Version of FPGA core]            |

#### \*TST?

Runs a set of standard tests to confirm the device is operating correctly, these tests are also performed at start up. Returns 'OK' or 'FAIL' followed by a list of errors that occurred, each on a new line.



#### CONFig:MODE BOOT

Configures the card for boot loader mode (to update the firmware), requires an update utility on the PC.

#### CONFig:MESSages [SHORt|USER]

#### CONFig:MESSages?

Gets or sets the mode for messages that are returned to the user's terminal

**Short**: Only a "FAIL" or "OK" will be returned.

**User**: Full error messages are returned to the user on failure.

#### CONFig:TERMinal USER

Sets the terminal response mode to the default 'User' setting. This is intended for use with HyperTerminal or similar and manually typed commands.

#### CONFig:TERMinal SCRIPT

Sets the terminal response mode for easier parsing. Especially useful from a UNIX/LINUX based system. Characters sent from the PC are not echoed by the device and a <CR><LF> is sent after the cursor to force a flush of the USART buffer.

#### CONFig:TERMinal?

Returns the current terminal mode.

#### CONFig:DEFault STATE

Resets the state of the module. This will set all source/signal/glitch etc logic to its default power-on values. Terminal setting will not be affected. This command allows the module to be brought back to a known state without resetting it.



# SOURce:[1-6|ALL]:SETup [#1] [#2] [#3] [#4]

Sets up the source in a single command. All parameters are positive integer numbers:

#1 = Initial delay (mS)

[Limits: 0 to 127ms in steps of 1ms, 130ms to 1270ms in steps of 10ms]

#2 = Bounce length (mS)

[Limits: 0 to 127ms in steps of 1ms, 130ms to 1270ms in steps of 10ms]

#3 = Bounce Period (uS)

[Limits: 10 to 1270us in steps of 10us, 2000 to 127000us in steps of 1000us]

#4 = Duty Cycle (%)

[Limits: 0 to 100% in steps of 1%]

SOURce:[1-6|ALL]:DELAY [#ms] [#Unit\*]

SOURce:[1-6|ALL]:DELAY?

Sets the initial delay of a source in mS. The delay is entered as a integer number with no units. E.g. "Source:1:delay 300".

#1 = Initial delay (mS)

[Limits: 0 to 127ms in steps of 1ms, 130ms to 1270ms in steps of 10ms]

#2 = Optional unit specifier (High resolution firmware only) [uS, mS, S]. High resolution firmware allows initial delay of 0 to 16,775mS in 1uS resolution. This parameter is optional, to be backcompatible with older firmware

```
SOURce:[1-6|ALL]:BOUNce:SETup [#1] [#2] [#3]
```

Sets up the bounce parameters in a single command. All parameters are positive integer numbers:

#1 = Bounce length (mS)

[Limits: 0 to 127ms in steps of 1ms, 0 to 1270ms in steps of 10ms]

#2 = Bounce Period (uS)

[Limits: 10 to 1270us in steps of 10us, 2000 to 127000us in steps of 1000us]



#3 = Duty Cycle (%)

[Limits: 0 to 100% in steps of 1%]

### SOURce:[1-6|ALL]:BOUNce:LENgth [#ms] [#Unit\*]

### SOURce:[1-6|ALL]:BOUNce:LENgth?

Sets the length of the pin bounce in mS. The delay is entered as a decimal number with no units. E.g. "Sour:2:boun:len 50".

#1 = Bounce length (mS)

[Limits: 0 to 127ms in steps of 1ms, 130ms to 1270ms in steps of 10ms]

#2 = Optional unit specifier (High resolution firmware only) [uS, mS, S]. High resolution firmware allows initial delay of 0 to 16,775mS in 1uS resolution. This parameter is optional, to be back-compatible with older firmware

SOURce:[1-6|ALL]:BOUNce:PERiod [#us] [#Unit<sup>\*</sup>]

SOURce:[1-6|ALL]:BOUNce:PERiod?

Sets the bounce period of the pin bounce in uS. The value is entered as a decimal number with no units. E.g. "Sour:6:boun:period 300".

#1 = Bounce Period (uS)

[Limits: 10 to 1270us in steps of 10us, 2000 to 127000us in steps of 1000us]

#2 = Optional unit specifier (High resolution firmware only) [uS, mS, S]. High resolution firmware allows initial delay of 0 to 1,677mS in 100nS resolution. This parameter is optional, to be back-compatible with older firmware

SOURce:[1-6|ALL]:BOUNce:DUTY [#%]

SOURce:[1-6|ALL]:BOUNce:DUTY?

Sets the duty cycle of the pin bounce as a %. The value is entered as a decimal number with no units. E.g. "source:3:bounce:duty 50".

#1 = Duty Cycle (%)

[Limits: 0 to 100% in steps of 1%]

SOURce:[1-6|ALL]:BOUNce:MODE [SIMPLE|USER]



SOURce:[1-6|ALL]:BOUNce:MODE?

Sets the bounce pattern to **SIMPLE** (Duty cycle driven oscillation) or **USER** (User defined custom pattern).

# SOURce:[1-6|ALL]:BOUNce:PATtern:WRITe [0xAAAA] [0xDDDD]

Writes a word of the custom bounce pattern to the give address within the pattern

0xAAAA is the address (for example 0x0002)

0xDDDD is the pattern data (for example 0x13F2)

SOURce:[1-6|ALL]:BOUNce:PATtern:READ [0xAAAA]

**Reads a word of** the custom bounce pattern

0xAAAA is the address (for example 0x0002)

SOURce:[1-6|ALL]:BOUNce:PATtern:DUMP [0xAAAA] [0xAAAA]

Reads a range of words from the custom bounce pattern

0xAAAA is the start and end address range (for example 0x0002)

#### SOURce:[1-6|ALL]:BOUNce:CLEAR

Removes any pin bounce from the source and sets all bounce settings to default values. See "Default Startup State" for details for the default settings.

SOURce:[1-6|ALL]:STATE [ON|OFF]

SOURce:[1-6|ALL]:STATE?

Sets or returns the enable state of the source. Any signals assigned to a disabled (off) source will immediately be disconnected and vice versa. If a source state is changed, all signals assigned to it will change at exactly the same time (if a change is required).

SOURce:[1-6]:BOUNce:PATtern:LENgth [#bits]

SOURce:[1-6]:BOUNce:PATtern:LENgth?

Sets or returns the number of bits of the custom bounce pattern that are to be used. This defaults to the maximum (112) and can be reduced to create more accurate patterns.

# SOURce:[1-6]:BOUNce:PATtern:REPeat [ON|OFF]

SOURce:[1-6]:BOUNce:PATtern:REPeat?



Sets the custom pattern repeat **flag**. This is used when the current custom bounce pattern is shorter that the specified bounce length. When the flag is set (default) the pattern will wrap. When this flag is off, the last bit of the pattern will be repeated.

# SOURce:[1-6]:BOUNce:PATtern:SETup [#us] [#binarypattern]

Sets a basic custom pattern from a single command. This command will alter the bounce period, bounce length, pattern length and the custom pattern.

[#uS] – Integer value of uS to specify the period. The length of each bit in the pattern will be half of this value. 20uS is the minimum value (10uS per bit)

[#binarypattern] – String parameter containing 1s and 0s, for example "001" is a 2 bit pattern that is low for 2 bits then high for 1. The given pattern will always be padded up to the nearest millisecond. This is because the total glitch length has a 1mS resolution.

# SIGnal:[SIG\_NAME|ALL]:SOURce [#num]

# SIGnal:[SIG\_NAME|ALL]:SOURce?

Assigns a given signal to a numbered timing source (0-8). SIGNAL\_NAME is one of the signals/groups as found in the 'Signal Names' appendix at the end of this manual

# SIGnal:[SIG\_NAME|ALL]:GLITch:ENAble [ON|OFF]

#### SIGnal:[SIG\_NAME|ALL]:GLITch:ENAble?

Enables a signal for glitching. If this in on, the signal will be glitched whenever the glitch logic is in use. Multiple signals may be set to glitch at the same time.

# SIGnal:[SIG\_NAME]:DRIve:OPEn [HIGH|LOW|NONE]

# SIGnal:[SIG\_NAME]:DRIve:OPEn?



Sets the 'drive' mode for a signal when the switch would normally be 'open'. Only the 'driving' capable signals (listed in the appendix) can support this.

# SIGnal:[SIG\_NAME]:DRIve:CLOsed [HIGH|LOW|NONE]

### SIGnal:[SIG\_NAME]:DRIve:CLOsed?

Sets the 'drive' mode for a signal when the switch would normally be 'closed'. Only the 'driving' capable signals (listed in the appendix) can support this.

### SIGnal:[SIG\_NAME]:STATus:HOST?

#### SIGnal:[SIG\_NAME]:STATus:DEVice?

Requests the current state of the sideband signal on the host or device side, from the monitoring system. Only the 'monitoring' capable signals (listed in the appendix) can support this.



# GLITch:SETup [MULTIPLIER\_STEP] [#count]

Sets up the length of the glitch in a single command.

#1 = Multiplier factor for glitch length (mS)

[50ns|500ns|5us|50us|500us|5ms|50ms|500ms]

#2 = Length of the glitch (number of times the multiplication factor will be run)

[Limits: 0 to 255 in steps of 1]

This gives a maximum glitch of 127.5 Seconds.

### GLITch:MULTiplier [MULTIPILER\_STEP]

#### GLITch:MULTiplier?

Sets the multiplier value for the glitch time to one of the specified durations.

This factor is multiplied with the **GLITch:LENgth** value to give the actual glitch time.

#1 = Multiplier factor for glitch length (mS)

[50ns|500ns|5us|50us|500us|5ms|50ms|500ms]

# GLITch:LENgth [#count]

#### GLITch:LENgth?

This value is multiplied by **GLITch:MULTiplier** to give the glitch duration.

#1 = Length of the glitch (number of times the multiplication factor will be run)

[Limits: 0 to 255 in steps of 1]

# GLITch:CYCle:SETup [MULTIPLIER\_STEP] [#count]

Sets up the length of the glitch cycle in a single command.

#1 = Multiplier factor for glitch cycle length (mS)

[50ns|500ns|5us|50us|500us|5ms|50ms|500ms]

#2 = Length of the glitch cycle (number of times the multiplication factor will be run)

[Limits: 0 to 255 in steps of 1]



This gives a maximum glitch cycle time of 127.5 Seconds.

### GLITch:CYCle:MULTiplier [MULTIPILER\_STEP]

#### GLITch:CYCle:MULTiplier?

Sets the multiplier value for the glitch cycle time to one of the specified durations.

This factor is multiplied with the **GLITch:CYCle:LENgth** value to give the actual time between cycled glitches.

#1 = Multiplier factor for glitch length (mS)

[50ns|500ns|5us|50us|500us|5ms|50ms|500ms]

#### GLITch:CYCle:LENgth [#count]

#### GLITch:CYCle:LENgth?

This value is multiplied by **GLITch:CYCle:MULTiplier** to give the actual time between cycled glitches.

#1 = Length of the glitch (number of times the multiplication factor will be run)

[Limits: 0 to 255 in steps of 1]

#### GLITch:PRBS [#1]

Sets the PRBS rate for Pseudo Random repeat glitching, this is a ratio, 2 means 1:2 (approximately 50% of the time the signal will be glitched), 256 means 1:256.

#### #1 = PRBS Ratio

[2|4|8|16|32|64|128|256|512|1024|2048|4096|8192|16384|32768|65536]

#### RUN:POWer [UP|DOWN]

Initiates a plug or pull operation (legacy name used to preserve compatibility between Torridon modules). This is the master control for all switches on the card.

The command will fail if you order a power up when the module is already in the connected state and vice-versa as the action cannot be performed.



The "OK" response will be returned as soon as the hot-swap event has begun. If your timing sequence is very long you may have to poll the BUSY bit in register 0 to check when it has completed.

#### RUN:POWer?

Returns the current plugged/pulled state of the module.

#### RUN:GLITch ONCE

Triggers a single glitch with length:

#### GLITch:MULTiplier x GLITch:LENgth.

#### RUN:GLITch CYCLE

Triggers a sequence of repeated glitches that run until the **RUN:GLITch STOP** command is executed. All signals with **GLITch:ENAble** set to **ON** are glitched for **GLITch:MULTiplier** x **GLITch:LENgth** and then released for a duration of **GLITch:CYCle:MULTiplier** x **GLITch:CYCle:LENgth**. This is repeated until the **RUN:GLITch STOP** command is run.

#### RUN:GLITch PRBS

Triggers a PRBS glitch sequence which runs until the **RUN:GLITch STOP** command is issued.

#### RUN:GLITch STOP

Stops any running glitch sequence.

#### RUN:GLITch?

Returns the state of the current glitch sequence running on the module.

#### TRIGger:IN:TYPE [EDGE|LEVEL]

Sets the trigger type

EDGE = Actions will start on the asserted edge and complete in full

LEVEL = Actions will run for as long as the trigger signal is asserted

#### TRIGger:IN:INVERT [ON|OFF]

Sets the trigger invert mode for input triggers



OFF = Trigger acts as normal

ON = Trigger responds to an inverted input

### TRIGger:OUT:INVERT [ON|OFF]

Sets the trigger invert mode for output trigger

OFF = Trigger acts as normal

ON = Trigger outputs in an inverted form

#### TRIGger:IN:SOURce [EXTernal|???\_host]

Sets the source of the trigger in event

EXTernal = Uses the trigger in connector

???\_host = Uses the output of the host power detect system. ??? is the voltage channel, generally 3v3\_host or 12v\_host, though the channel selection options will vary between modules and is not supported on all devices.

# TRIGger:IN:MODE [OFF|POWER|GLITCH|SIDEband]

Sets the action to perform on a trigger in event

OFF = No action (default mode)

POWER = Power cycle will be performed

GLITCH = Glitch action will be performed

SIDEband= Sideband monitor mode (if 'monitoring' is supported)



# TRIGger:OUT:MODE [OFF|POWER|GLITCH|???\_host|SIDEband]

Sets the action to perform on a trigger out event

OFF = No action (default mode)

POWER = Trigger out shows power state

GLITCH = Trigger out on glitch

???\_host = Trigger out on detect of host power. ??? is the voltage channel, generally 3v3\_host or 12v\_host, though the channel selection options will vary between modules and is not supported on all device.

SIDEband= Sideband monitor mode (if 'monitoring' is supported)

# TRIGger:MONitor:IN [#SignalName] [HOST|DEVice]

#### TRIGger:MONitor:IN?

If monitoring is supported and enabled for trigger IN, this command sets the sideband signal to be output on the trigger IN line.

You MUST ensure that nothing external will try to drive this trigger line when the monitor feature is enabled, as this may cause damage.

The signals available for monitoring are listed in the appendix

# TRIGger:MONitor:OUT [#SignalName] [HOST|DEVice]

#### TRIGger:MONitor:OUT?

If monitoring is supported and enabled for trigger IN, this command sets the sideband signal to be output on the trigger IN line.

You MUST ensure that nothing external will try to drive this trigger line when the monitor feature is enabled, as this may cause damage.

The signals available for monitoring are listed in the appendix



# **Appendix 1 - Signal Names**

The following signal names are used to specify a single signal or a group of signals. These may be used in commands that take a parameter "SIGNAL\_NAME".

These signals names are based on the interface specification.

Note that some commands, such as those returning a value, only accept a parameter that resolves to a single signal. In this case you cannot use the groups

### Signals

| orginalo  |                                                                                    |
|-----------|------------------------------------------------------------------------------------|
| PETpN     | (Data transmitted from the 'input' port on Lane n (+ve side of differential pair)) |
| PETnN     |                                                                                    |
| PERpN     |                                                                                    |
| PERnN     |                                                                                    |
| 12V       |                                                                                    |
| 3V3_AUX   |                                                                                    |
| REFCLKp0  |                                                                                    |
| REFCLKn0  |                                                                                    |
| REFCLKp1  |                                                                                    |
| REFCLKn1  |                                                                                    |
| PRSNT0    |                                                                                    |
| PERST0    |                                                                                    |
| PERST1    |                                                                                    |
| LED       |                                                                                    |
| SMBRST    |                                                                                    |
| SMBCLK    |                                                                                    |
| SMBDAT    |                                                                                    |
| PWRDIS    |                                                                                    |
| MFG       |                                                                                    |
| DUALPORTI | EN                                                                                 |
|           |                                                                                    |



# Signal Groups

| ALL        | (Allows change of all signals at the same time)                      |
|------------|----------------------------------------------------------------------|
| LANE0      | (Affect all signals relating to a specific lane)                     |
| LANE1      |                                                                      |
| LANE2      |                                                                      |
| LANE3      |                                                                      |
| POWER      | (Affects all power signals)                                          |
| DATA       | (Affects all data lanes)                                             |
| SMB_BUS    | (All SM BUS signals)                                                 |
| CLK_A      | (REFCLKp0 and REFCLKn0)                                              |
| CLK_B      | (REFCLKp1 and REFCLKn1)                                              |
| MANAGEMENT | (Controls all signals in the management interface)                   |
| PORT_A     | (Affects all data lanes 0 and 1, with REFCLKp0, REFCLKn0 and PERST0) |
| PORT_B     | (Affects all data lanes 2 and 3, with REFCLKp1, REFCLKn1 and PERST1) |
| DATA_A     | (Affects lanes 0 and 1)                                              |
| DATA_B     | (Affects lanes 2 and 3)                                              |



# Appendix 2 – Signals supporting 'Monitoring'

| Signal name   | Side that can be monitored |  |  |
|---------------|----------------------------|--|--|
| PRSNT0        | Host and Drive             |  |  |
| PERST0        | Host and Drive             |  |  |
| PERST1/CLKREQ | Host and Drive             |  |  |
| SMBRST        | Host and Drive             |  |  |
| SMBDAT        | Host and Drive             |  |  |
| SMBCLK        | Host and Drive             |  |  |
| LED           | Host and Drive             |  |  |
| PWRDIS        | Host and Drive             |  |  |
| DUALPORTEN    | Host and Drive             |  |  |



# Appendix 3 – Signals supporting 'Driving'

| Signal Name       | Signal Type                                  | Host Side Behavior |               | Device Side Behavior |            |
|-------------------|----------------------------------------------|--------------------|---------------|----------------------|------------|
|                   |                                              | High               | Low           | High                 | Low        |
| PRSNT0            | Open Drain output<br>from Device             | Not Driven         | Driven<br>Low | Not<br>Driven        | Not Driven |
| SMBRST            | Driven high by<br>Host                       | Not Driven         | Not<br>Driven | Driven<br>High       | Driven Low |
| DUALPORTEN        | Push/Pull output<br>from Host                | Not Driven         | Not<br>Driven | Driven<br>High       | Driven Low |
| PWRDIS            | Push/Pull output<br>from Host                | Not Driven         | Not<br>Driven | Driven<br>High       | Driven Low |
| PERST0            | Push/Pull output<br>from Host                | Not Driven         | Not<br>Driven | Driven<br>High       | Driven Low |
| PERST1/<br>CLKREQ | Open Drain output<br>from Host and<br>Device | Not Driven         | Not<br>Driven | Not<br>Driven        | Driven Low |
| LED               | Open Drain output<br>from Host               | Not Driven         | Driven<br>Low | Not<br>Driven        | Not Driven |