Coaxial Data Serialization & Power

The major advantage of ONI-compliant headstages is that they contain onboard logic for controlling and streaming from arbitrary configurations of head-borne devices using a unified, bidirectional data stream. In this way, data can be sent to host hardware (see PCIe Host) using modern serializer/deserialzer (SERDES) chips that vastly reduce the amount of wiring required for communication.

ONIX coaxial headstages use a coaxial serializer for host communication. This chip provides power and bidirectional data transmission to and from from the headstage using a single coaxial cable (one signal wire and an outer shield). The coaxial cable is the only external connection to the headstage. Power (DC), a control “back-channel” (MHz), and a data “forward-channel” (GHz) occupy different portions of the RF spectrum and therefore can be resolved as distinct signal streams. Any high-quality 50-Ohm characteristic impedance cable with low loss in the GHz frequency range can be used to make this connection (e.g. SMA cables). However, the connection to the headstage is usually accomplished using specialized micro-coax cable that is extremely thin and flexible. We generally use cables that are 150-300 μm in diameter.

Note

Have a look at the Making Coaxial Tethers page for more detials on mirco-coax headstage tethers

ONIX headstages use an FPGA to control peripheral devices and combine their data streams prior to serialization. For instance, Headstage-64 and Neuropixels-1.0 Headstage use an Intel MAX10 FPGA. The exact FPGA is not important because every ONI-compliant headstage is uses very similar gateware (FPGA-based firmware) that performs three major functions

  1. Local Hardware Control Provides hardware controllers (SPI, I2C, etc), timing, and control logic for each of the sensors and actuators on the headstage

  2. Data Streaming Provides a standard protocol for arbitrating access of each of the device data streams to the serializer.

  3. Register Programming Provides a standard interface for bi-directional configuration and control of the devices on the headstage.

Power

As mentioned in the previous section, power is DC-coupled into the coaxial link at the host and recovered at the headstage via a second, inductive DC path. This “T-network” provides a low impedance path for the DC portion of the signal (power) and rejects the RF components so that they are preserved for communication between the SERDES pair.

../../_images/rf-t.png

LC-network for combining power and data on the coaxial cable.

Its important to note that this circuit is completely passive. Therefore whatever voltage is supplied at the host side will end up at the input to the headstage. Care must be taken to make sure this voltage is appropriate.

Warning

Do not exceed the maximaum voltage at the coaxial input to the headstage. Make sure you make this measurement at the headstage to account for a potential voltage drop in the tether. Exceeding this voltage can permanently damage some headstages (Headstage-64 in particular because it lacks an overvoltage lockout circuit)

Further, if a long and thin coaxial tether is used, the DC resistivity of the wire can accumulate, resulting in a significant voltage drop across the cable.

Note

Long, thin tethers can have a significant series resistance that results in a voltage drop across the length of the tether. This may have to be compensated for by tuning the host input voltage to account for the drop. ONIX host boards have this ability (e.g. see PCIe Host).

DS90UB933/4 Communication Protocols

The DS90UB933/DS90UB934 are a coaxial SERDES pair used on several ONIX headstages and host modules:

along with the UCLA Miniscope and its derivatives. This section describes how this SERDES pair is used for control of and communication with headstages.

Data Serialization

The DS90UB933 is a 100 MHz parallel to coaxial serializer that is typically used for streaming camera data. ONIX headstages use an intermediate FPGA to translate data from any number of heterogeneous data sources to the serializer input using the following simple protocol


where the signal lines are defined as follows:

plck

The serializer’s pixel clock, repurposed for generic data transmission for ONIX headstages.

hsync

The horizontal synchronization signal, re-purposed on ONIX headstages to indicate the data bus contains a device ID on ONIX headstages

vsync

The vertical synchronization signal, re-purposed to indicate the data bus a CRC value for the preceeding packet on ONIX headstages

data

The 12-bit data bus containing device ID, CRC value, or device data depending on the states of hsync and vsync

The ID is the device index within the host device table, frame is a device’s frame data, and CRC is a CRC-12 of the ID and frame elements. See the ONI Specification for detailed descriptions of these elements meaning.

These signal lines are present on the FPGA-side of both the serializer and deserializer, prior to headstage serialization and after host deserialization, respectively. This means that the serializer link is effectively “invisible” from the host’s perspective, and the headstage can be treated as if it was just a module on the host itself.

During serialization, data are transmitted over the coaxial cable using an RF-encoding scheme called FDP Link III which embeds the clock in the data stream and allows for active equalization to compensate for imperfections in the cable. This link uses and 700 MHz carrier for high speed data and provides a low speed bidirectional link for sending triggers and configuration to the headstage.

Register Configuration

The DS90UB933/DS90UB934 SERDES pair have a I2C-based backchannel for bidirectional communication. This channel is used for two purposes in ONIX hardware.

  1. Device configuration via register writing and reading. e.g. setting and bandwidth of the filters on the Intan chip.

  2. Flashing the headstage FPGA’s non-volatile memory with updated firmware.

The ONI Specification describes a register programming protocol that can be implemented using a 32-bit wishbone bus:


where the signal lines are defined as follows:

cyc

Transaction cycle / chip select

we

Write enable

addr

32-bit register address

wval

32-bit write value

ack

Acknowledge

err

Error

rval

32-bit read value

The cyc line is typically muxed to different devices in an acqustion context using an auxilary 32-bit device index that is also required by the ONI specification. This bus needs to be transmitted over the DS90UB933/4 I2C backchannel to be used to configure headstage devices. We have developed a simple Wishbone over I2C module to accomplish this. This module uses the following 7-bit command words:

Value

Diagram Code

Description

0x00

WE

Write enable

0x01

RR

Read request

0x02

R0

Read enable 0

0x03

R1

Read enable 1

0x04

R2

Read enable 2

0x05

W0

Read enable 3

0x06

W1

Read enable 4

0x07

S0

Status 0

0x08

S1

Status 1

0xFF

NA

Invalid

along with a status register for reporting the validity of read and write operations:

The coarse-grained state machine for this translation is as follows:

digraph { rankdir=LR; size="8,5" "IDLE" -> "WRITE" [label = "cyc,we"] ; "IDLE" -> "RDREQ" [label = "cyc,!we"]; "WRITE" -> "WRITE" [label = "n < 4"]; "WRITE" -> "STAT0"; "RDREQ" -> "STAT0"; "STAT0" -> "WAIT" [label = "we"]; "STAT0" -> "READ" [label = "!we, !err"]; "STAT0" -> "WAIT" [label = "!we, err"]; "READ" -> "READ" [label = "n < 4"]; "READ" -> "STAT1" ; "STAT1" -> "WAIT" ; "WAIT" -> "IDLE" [label = "!cyc"]; }

An example write sequence on this bus is given below. The wishbone bus drives an I2C sequence that is interpreted on the headstage and used to recreate the wishbone signals locally.