

# MEA2100 User Guide

---

## Introduction

### System Overview

The MEA2100 system consists of an interface board and one or two headstages.

The interface board consists of:

- Two USB connectors for PC connection
- Two ports for one or two headstages
- 16 digital input and 16 output ports for triggering
- Eight additional analog inputs for monitoring
- DSP debug port
- Audio out
- A DSP
  - Who has access to the measured data stream for additional prompt data calculation
  - Optional Stimulation control

The DSP can be programmed by the user, for example to do real-time signal analyses and program feedback via the stimulation channels. A debug port is provided at the same connector as the analog inputs.



The headstage consists of:

- Adapters for different MEAs (see options below)
  - Electronic for measurement
  - Stimulation of up to 120 electrodes

The headstages connect to an interface board.

The overview about HS options:



## Getting Started

To write code for the DSP, the following tools are needed:

- Code Composer Studio IDE V8 from Texas Instruments [http://processors.wiki.ti.com/index.php/Download\\_CCS](http://processors.wiki.ti.com/index.php/Download_CCS)
  - You need to install the version 7.4.x of the C6000 compiler: Menu -> Help -> Install Code Generation Compiler Tools...; TI Compiler Updates
  - C6000 compiler 7.4.x; Documentation: <http://www.ti.com/lit/ug/spru187u/spru187u.pdf>
  - compiler 8.2.x does not support the TMS320C6454
- Driver\_Bh560v2: v1.0.0.7 might be needed for Windows 10 due to signature problems
- ActivePython V2.7.x <http://www.activestate.com/activepython/downloads>
- Visual Studio 2017, there is a Community Edition available from Microsoft <https://www.visualstudio.com/de/free-developer-offers>
- A System Trace Emulator is of great help to debug DSP code
  - BH-XDS-560v2 <https://www.blackhawk-dsp.com/store/12161.html>
  - BH-USB-100v2D <https://www.blackhawk-dsp.com/store/12139b.html>

## DSP

The default setup of the system routes the data without DSP interaction from HS 1 to USB A and from HS2 to USB B Port. In this case the DSP is only able to monitor the sweep data.



The DSP can be programmed with user code to access the data stream from the headstages and the onboard ADCs of the interface board. The data stream can be sent to the USB ports towards the PC. The DSP can also configure all parts of the MEA2100-System, including stimulation and trigger, except the USB data stream configuration to the PC. By this a realtime feedback with low latency can be build.



The DSP used in the MEA2100 system is a TMS320C6454<sup>[1]</sup> from Texas Instruments running at 819.2 MHz. He has access to the MEA2100 system via its external memory interface (EMIF). Access to the system is via three parts.

- The Configuration of the MEA2100 is done with the register based interface. Therefore the DSP has the MEA addresses mapped into the range from 0xA0000000 to 0xFFFFFFFF. The different components of the MEA2100 use each a subrange of this address region. #Register Map In the FB\_Example Project, MEA21\_init.h defines Macros which can be used to access these registers:

```
#define READ_REGISTER(reg)          MEA21_REGISTER(reg)
#define WRITE_REGISTER(reg, value)    MEA21_REGISTER(reg) = value
```

- Sweep and Digital data is transferred via a fifo-type interface, mapped into the DSP address range starting from 0xB0000000.
- One of two options of controlling the stimulation is the direct streaming mode. This can be done via the streaming port using address 0xC0000000.

## Data Aquisition

### General Overview

The MEA2100 System can measure analog signals from 120 electrodes per Headstage at 50kHz with 24bit resolution.

On the interface board are 8 additional analog inputs for monitoring purposes(also 50kHz and 24bit resolution).

Additional to the analog signals are several digital signals(configurable DSP in data).

### DSP Reception of Sweep and Digital data

Sweep and Digital Data is available to the DSP through a FIFO type interface mapped to the address 0xB0000000 in the DSP memory map.

Each time (once every 20 us), when the MEA2100 has a new sweep of data available from the Datasources, the signal line (GPIO4) to the DSP will be toggled (enabled in Interconnection Logic). After the DSP has received this signal, it can read the new sweep data either by multiple reads from address 0xB0000000, or the more convenient way is to set up a DMA transfer which automatically transfers all data from the sweep into DSP memory. After the transfer is complete, a DMA completion interrupt can be called.

The example code in the FB\_Example project initializes and enables such a DMA transfer. In the example, each time after a new sweep of MEA2100 is avaiable in DSP memory, the function `interrupt6()` is called. The new data is available to the user in the array `MeaData[]`. The data in this `MeaData[]` array automatically updates every 20 us when the DMA is running.

The setup and initialisation of the DMA is done in the `init_dma()` function in `MEA21_init.c`. Once it is up and running, it does the transfers automatic without CPU intervention, so no loose of CPU time in this mode.

One important Register for the readout of data is Register 0x400. This register controls which kind of data is transferred into the FIFO from MEA2100 to the DSP. It can enable data from Headstage 1, Headstage 2, or from the ADCs on the Interface board and some other helpfull data.

The line 94 of `main.c`

```
WRITE_REGISTER(DspIndataCtrl, DSPINDATACTRL_VALUE); // Enable Irq and HS1 Data
```

enables the data transfer from the FPGA to the FIFO towards the DSP.

The ADC Data blocks have the format

|                   |                                           |
|-------------------|-------------------------------------------|
| HS1               | 122 datawords (Header, 120 Data, Counter) |
| HS2               | 122 datawords (Header, 120 Data, Counter) |
| IF                | 9 datawords (Header, 8 Data)              |
| HS1 Filtered Data | 122 datawords (Header, 120 Data, Counter) |
| HS2 Filtered Data | 122 datawords (Header, 120 Data, Counter) |

which means, when you have enabled data from Headstage 1 (HS1), you will get 122 32-bit Datawords per sweep, where the first dataword is a header word, followed by 120 32-bit datawords of ADC data (Format is signed, the ADCs have 24 bit resolution), followed by a 32-bit counter which enumerates the sweep.

So, when data from Headstage 1 is enabled there will be at `MeaData[0]` the header, at `MeaData[1]` the data from the first ADC (MEA Hardware Channel Nr. 1) and so on.

The pointers in the `irq.c` example are intended to help to access the ADC data, `HS1_DATA_OFFSET` is defined to 1, because this is the location of the data from the first data channel.

```
Int32* restrict HS1_Data_p = (Int32 *) &MeaData[HS1_DATA_OFFSET];
```

`HS1_Data_p` is a pointer to the location within `MeaData` where the ADC data is located. When the code in the DSP needs to do some calculation on the sweep data, the data of interest should be copied to a memory location under its control. You always need to remember that `MeaData` will be changed as soon as new sweep data is transferred by the DMA.

The Digital Data blocks have the format

```
Digital Data 28 datawords (Header, 27 Data)
Timestamp      3 datawords (Header, 2 Data)
```

## Stimulation



## General Overview

Each headstage, which can measure from and stimulate up to 120 electrodes has two separate modules (STG 1 and STG 2) for the stimulation. The first module is in control of electrode channels 1 to 60, the second module for electrode channels 61 to 120. Each of the two modules has access to three DAC pairs and three sideband channels.

There are two options of controlling the stimulation in the modules:

- Configure Stimulus-Generator modules
- Direct streaming mode from DSP via streaming port

Within each module, the three DAC pairs and three sideband channels can be arbitrary controlled by three trigger statemachines.

These statemachines handle the stimulus pattern read out units (DAC/SBS) to whom they are assigned to (reg:0x104-0x108). The stimulus pattern is stored in onboard memory on the MEA2100 headstage where each module has its own independent memory. For the stimulation (DAC/SBS) the memory is organized in segments and blocks to support the stimulus with different stimulus pattern lists, to enable quick switching between lists of

prepared patterns. The DACs update their output value every 20 us, resulting in an output rate of 50 kHz. Corresponding for the analog patterns, additional information is stored in memory regions called sidebands. These sideband data contain digital information for controlling the switches and muxes to enable stimulation. The update of this data is also every 20 us.

- The electrical parameters are:

- Voltage Mode: Range: +- 12 V, Resolution: 0.571 mV / digit (571 uV/digit)
- Current Mode: Range: +- 1.5 mA, Resolution: 0.05 uA / digit (50 nA/digit)

The configuration of the Stimulus Generator consists of three parts:

- The stimulus pattern upload
- The electrode configuration
- The trigger setup

The configuration of the Direct Streaming mode can be done in two ways:

- When controlled by Computer SW via DSP
- When fully controlled by DSP

### **Stimulus Pattern Upload**

There are eight stimulus pattern read out units to read the stimulus pattern from the assigned memory block and support the data to the stimulation logic. In the default configuration, only six units are in use, where three support the data for the DAC pairs and three for the sideband signals.

**Setup:** Before the patterns can be uploaded into memory, the available 256 MByte of memory need to be divided in blocks and segments. These blocks and segments need to be assigned to the eight units. One option is to divide all available memory into eight blocks and ONE segment. A more advanced option is to subdivide the total memory into 256 segments, and then subdivide the memory within each of these segments into the eight blocks. This mode, called the segmented mode, allows to predefine and upload up to 256 independent stimulation patterns and quickly select among them within microseconds. The mode will be selected by a write to Memory Control Register (0x200) on each of the STG subsystems. Setting bit 28 one segment will be set up automatically. Setting bit 29 the memory is subdivided into 256 segments with internal logic.

Alternatively the size of each block and each segment can be subdivided individually with the needed amount of memory. This is controlled by the registers 0x200 to 0x2f0 and need to be done manually. There the start pointer for each of the memory blocks need to be inserted. For example the memory block for DAC A and B (default setting of Register 0x1D0) is controlled by the registers 0x200 to 0x210. Register 0x200 is used to select a segment, and then the start address for this block in the selected segment is set via register 0x204. In default Segment 0 is used. When segmented mode is chosen another segment is selected via register 0x200. Again the start address of the selected block is set via register 0x204. So register 0x200 selects the segment to be defined/modified and then the other registers reflect the corresponding block start pointer of the segment.



After the intended memory layout is set up, each of the DAC and sideband memory blocks can be filled with data. Data is written to the blocks in a FIFO type mode via the Write DAC and Write SBS Data Registers (0xF20-0xF3C). Each write to one of these registers appends one 32bit data word to the corresponding block in the selected segment. When a data word is written to the Data Registers at address from 0xF40 to 0xF54, the pointer of the corresponding block is first set to Start. The segment will be changed as well in Register 0x200 (0x220,0x240,...,0x2E0). If the number of vectors for a stimulus pattern is more than the memory space allocated for one block, no hardware will limit the write to the memory (overlapping pattern memory). So the data of an other block will be overwritten! This will lead to unpredictable behavior during operation!

The 32 bit data word is described in Data Vector decoding.

The data vector (000) is either a value with a 16 bit amplitude for DACs or 16 bit Sideband Signal value for Sideband Channels. Bit 26 defines the timebase of this vector. A '0' defines that the value will be valid for one 20 us frame until the number of repeats (bits 25-16) will be decreased by one. If bit 26 is '1' the value will be valid for 1000 times 20 us until the decrement will be done.

Two kind of loops can be used. A single vector loop (001) and a long loop vector (010 in combination with 011) with two vectors keeping the information. For both types of loops the "number of repeats" are one based. Whereby a 0x1 will lead to ignore the vector and a 0x2 will repeat once. A value of 0x0 means to loop forever! The address offset is also one based. A 0x1 will jump backward one vector before the loop vectors. So nested loops for repetition of (sub-)blocks of data can be created. This avoids to store one stimulus multiple times.

## DAC Units

The stimulation module for the 60 electrode channels is subdivided in two halves of 30 electrodes, where each half has its own set of three DACs. In default configuration these six DACs are combined into three DAC pairs, so that it looks like that there are three DACs available for each of the 60 electrodes.

For advanced applications, these DAC pairs can be broken up, allowing stimulation with three DACs available for each block of 30 electrodes. The DACs which are available to the lower 30 electrodes in a module are named DAC A, C and E, the DACs which are available to the upper 30 electrodes in a module are named DAC B, D and F.

In default configuration, DAC A and B form the DAC AB pair, likewise DAC C and D form the DAC CD pair, and DAC E and F form the DAC EF pair, making it look like there are three DACs named AB, CD and EF. Both DACs out of a DAC pair take their data out of the same memory block, thus always have the same analog output.

The DAC pairs are broken up by assigning each DAC to its own stimulus pattern read out unit of the available eighth stimulus pattern supporting units. When all six DACS are to be used individually there are two units left to be shared among the three sidebands. The register which controls the DAC to stimulus pattern read out units is 0x1D0. For Sideband configuration it is register 0x1D4.

## Sideband Data

A Sideband has two functions:

- These Sideband Signals (SBS) control the switches which connect the Stimulation DACs to the electrode and it controls the Amplifier Protection("Blanking") of ADC data while a Stimulus pulse is active. Each function is assigned to a bit in the 16 bit wide data stream:
  - Bit 0: Amplifier Protection Switch on Headstage/Blanking
  - Bit 3: Stimulation Switch Close
  - Bit 4: Stimulus Selector Enable
  - Bit 8: List Mode config ID increment on/to the Interface Board or Bit 15-8 List Mode config ID when source of ID is switched to SB bits
- It can be used to send data to the USB, to the DSP or to the digital outputs on the Interfaceboard which are synchronous to the running stimulation.



The diagram shows an example stimulus pattern together with the sideband datastream. As shown in the drawing, the Stimulation Switch can open with the end of the Stimulus. The Blanking signal should stay active for some additional time  $t_e$ , recommendations are 20 us for Voltage Stimulation and 20 us for Current Stimulation. Likewise, the Stimulation Selector should be kept for some additional time  $t_e$ , here the recommendation is 20 us for Voltage Stimulation and 20 us for Current Stimulation.

### Electrode Configuration

To configure an electrode for stimulation, each of the 120 electrodes has to be either assigned to one of the three DACs within its STG subsystem, or it can be in an "inactive" configuration. This is controlled by register 0x160-0x16C, the Electrode DAC Multiplexer assignment Register. These registers sets the Stimulus selectors to one of the four inputs. Two bits for each electrode either configure the electrode to be stimulated to DAC A/B, C/D or E/F. The bit pattern "00" configures the selector into an "inactive" mode, in which it is configured to fixed ground. Behind the multiplexer, the Stimulation Enable switch connects the DAC selector output with the electrode. This will be configured in register 0x158-0x15C.

For Testing or for Measurement electrodes, each electrode can be set in "manual" mode. With this the DAC Multiplexer and the Stimulation Enable switch are set imidiately in the state which is defined by register 0x160-0x16C for the DAC settings and 0x158-0x15C for the Stimulation Enable. During stimulation, when the system should be controled by the sidband signals, the corresponding stimulation electrode needs to be set into dynamic (automatic) mode (register 0x120-0x12C).

In default setup the sideband 1 is assigned to DAC A/B, sideband 2 is assigned to DAC C/D and sideband 3 is assigned to DAC E/F. For advanced setup these defaults can be changed in register 0x154. For example all DACs can have assigned sideband 1 to it.

When an electrode is in automatic mode assigned to one of the three DACs, the DAC Select and Stimulation Enable register do not directly configure the state of the switches. Only when the Sideband datastream is running, the corresponding SBS vector to the current DAC vector determine the state of the switches. The default state, which is used when the sideband is not running or when the corresponding bit in the sideband datastream is zero, is for the Multiplexer to use its ground connected pin to be selected and the Elektrode Enable Switch is open. The default state of the switches, which is used when the signal from the electrodes is measured, is shown in blue in the schematic overview above. The sideband is a 16 bit wide data stream. Bit 0 of this data stream controls the Amplifier Protection Switch and the Blanking, Bit 3 controls the Stimulation Switch and Bit 4 is in control of the Stimulus Selector.

### Electrode setup advice

- Decide whether your electrode is used as stimulation or measurement electrode (set corresponding bit in register 0x120-0x12C and 0x158-0x15C)
- Assign your stimulation electrode to a stimulation channel (DAC A to F) (set corresponding bits in register 0x160-0x16C)

### Stimulus channel setup advice

- Assign a sideband Channel to a stimulation channel (set in register 0x154)





### List mode for advanced stimulation

There is the possibility to predefine and quickly switch the electrodes between up to 256 different stimulation configurations. The DAC select and Stimulation Enable registers are actually an array of 256 independent configurations. During setup the register 0x150, the Electrode configuration ID CTRL register controls which configuration is to be defined. Here bits 0-7 define which one of the 256 possible configurations is selected for setup editing.

Bit 28 in the Electrode configuration ID CTRL register control how the configuration is selected during stimulation. This bit can either be "0" for taking configuration ID from the Interface Board. When this bit is set to "1" the "internal" configuration ID is active. Then bits 8 to 15 in the sideband datastream define the active electrode configuration. In "external mode" the List Mode configuration ID is generated in the Trigger Block of the Interface Board.

### Standard Trigger

#### Standard Trigger Setup

For controlling the stimulation three trigger statemachines are implemented. In the default configuration, each trigger has control of two stimulus pattern read out units. These units support data for one DAC pair and one sideband. So this controls one stimulus pattern and its corresponding digital information 0x104-0x108.

An example where more than one DAC is assigned to one trigger is, when multiple electrodes are to be stimulated, grouped into two blocks, where each of the two blocks has a different stimulation signal amplitude. To accomplish this, two DACs can be assigned to one trigger. As long as the timing of the two stimulation patterns for two stimulus groups are the same, they can share one sideband resulting in a setup where one trigger controls two DACS and one sideband.

When the two stimulation groups have differences in timing it is useful to use a separate sidebands for each of these groups, thus resulting in a setup where one trigger controls two DACs and two sidebands.

The assignment of the three DAC pairs and three sidebands to the three triggers within each block is controlled by registers 0x104 for the DACs and by register 0x108 for the sideband channels. With this setup the controlling trigger for each DAC and sideband has to be chosen.

Start and Stop of the stimulation is always controlled at the level of the triggers, so that all DAC and sidebands which are grouped together to a specific trigger are started and kept running in sync.

## Start Trigger

For the trigger to work, the first bit(0) in the Trigger Control Register 1 (0x200) **on the Interface board** has to be set to 1. This enables the trigger event packet to propagate from the interface board to the stimulus generators.

The Trigger ID registers (0x218 to 0x244) define for each trigger, which Stimulus-Pattern Memory-Segment to use when the corresponding trigger is startet. For single segment mode leave this register at the default value of 0.

To actually start a trigger manually, write a "1" to the bit which corresponds the trigger number in the Trigger Event Status register 0x214. For example to manually start trigger 1, write a value of 0x00000001 to register 0x214.

To start a trigger with external signals or other sources a Digital Multiplexer for source select is implemented (0x280-0x2AC).



## Direct Streaming Mode triggered by SW

A further advanced mode for Stimulation is the DSP generated stimulus pattern direct streaming mode, which can be standard triggered and monitored by the computer SW. In this mode the trigger statemachine and memory on an STG will be bypassed and the DAC and SBS data will be send direct from the DSP to the stimulus logic. The setup for stimulus switch and selector still needs to be done as in standard mode.

## Direct Steaming Trigger Setup

To detect a trigger event on the DSP the digital data stream to the DSP needs to be enabled reg 0x400 bit 12. In this digital data stream the 8th and 18th vector reflect the trigger event information

## Direct Streaming Data path Setup

For controlling the stimulation by direct streaming data to an STG, the data source for the DAC and SBS Data need to be switched to DSP. This needs to be done in register 0x100.

To start the distribution of the streaming data from the FIFO configure the register 0x430. After this the stimulus data can be send via the streaming FIFO of the DSP. For this write 36 DWords to the address 0xC0000000 from the DSP.

- 24 DWords for DAC Data
  - 6 DWords to HS1 STG1 (DAC: A, C, E, B, D, F)
  - 6 DWords to HS1 STG2 (DAC: A, C, E, B, D, F)
  - 6 DWords to HS2 STG1 (DAC: A, C, E, B, D, F)
  - 6 DWords to HS2 STG2 (DAC: A, C, E, B, D, F)
- 12 DWords for SBS Data
  - 3 DWords to HS1 STG1 (SBS: 1, 2, 3)
  - 3 DWords to HS1 STG2 (SBS: 1, 2, 3)
  - 3 DWords to HS2 STG1 (SBS: 1, 2, 3)
  - 3 DWords to HS2 STG2 (SBS: 1, 2, 3)

Always write 36 DWords, even when you switch only one STG to direct streaming mode, because the FIFO read logic expects 36 Data in the predefined order.



## Digital Multiplexer

There are multiple digital signals within the MEA2100 system, which represent internal states of the systems. These digital signals can be mapped

- To the digital outputs of the Interface board
- Into the digital datastream via the USB connection to the PC
- Used by the DSP
- With some restrictions used as triggers conditions for Stimulation
- With some restrictions used as list mode ID increment
- Trigger gated data start mode

The following digital signals are available for Digital Output and Digital Datastream to the computer and DSP

- Digital In bit 0 to 31; these are 32 bit taken from the rear side Digital Connector
- Digital Pulse Register bit 0 to 31; taken from Digital Pulse Register 0x700, valid for the duration defined in Register 0x704-0x710, started by a write to Register 0x700.
- Feedback Register bit 0 to 31; taken from Feedback Register 0x780
- Aux In bit 0 and 1; taken from the two lemo connectors on the Interface board.
- A fixed value of "0"
- A fixed value of "1"
- Trigger Status of the Stimulation Boards
- Any bit from all the Sideband Channels

There is a multiplexer for each bit of the digital datastream at register 0x880-0x8BC for USB connector A and register 0x8C0-0x8FC for USB connector B. For the digital output there is for each bit a register at 0x840-0x87C.

There you can select its source from all selectable sources as described in the table above.

The multiplexer for the following digital signals are available to trigger the Stimulators

- A fixed value of "0"
- Digital In bit 0 to 31; these are 32 bit taken from the rear side Digital Connector
- Feedback Register bit 0 to 31; taken from Feedback Register 0x780
- Aux In bit 0 and 1; taken from the two lemo connectors on the Interface board.

The multiplexer for each trigger are located in register 0x280 to 0x2AC.

## Using McsUsbUpdate to review configuration

For reviewing the setup done with the DSP there is a program called McsUsbUpdate. With this program all relevant registers are reflected and according to the use case RO, RW, WO.







## Data Format for > 16 bit

### 24 bit Format, Little endian byteorder

|        |    |    |    |    |        |   |   |   |   |        |   |   |   |   |        |    |    |    |    |        |    |   |   |   |        |   |   |   |   |   |   |
|--------|----|----|----|----|--------|---|---|---|---|--------|---|---|---|---|--------|----|----|----|----|--------|----|---|---|---|--------|---|---|---|---|---|---|
| 15     | 14 | 13 | 12 | 11 | 10     | 9 | 8 | 7 | 6 | 5      | 4 | 3 | 2 | 1 | 0      | 15 | 14 | 13 | 12 | 11     | 10 | 9 | 8 | 7 | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
| Byte 1 |    |    |    |    | Byte 2 |   |   |   |   | Byte 3 |   |   |   |   | Byte 4 |    |    |    |    | Byte 5 |    |   |   |   | Byte 6 |   |   |   |   |   |   |
| LSB 0  |    |    |    |    | MSB 0  |   |   |   |   | HSB 0  |   |   |   |   | LSB 1  |    |    |    |    | MSB 1  |    |   |   |   | HSB 1  |   |   |   |   |   |   |

### 24 bit Format, MC\_Rack freundlich, eventuell alle LSBs als Block nach allen 16 bit Kanälen

|        |    |    |    |    |        |   |   |   |   |        |   |   |   |   |        |    |    |    |    |        |    |   |   |   |        |   |   |   |   |   |   |
|--------|----|----|----|----|--------|---|---|---|---|--------|---|---|---|---|--------|----|----|----|----|--------|----|---|---|---|--------|---|---|---|---|---|---|
| 15     | 14 | 13 | 12 | 11 | 10     | 9 | 8 | 7 | 6 | 5      | 4 | 3 | 2 | 1 | 0      | 15 | 14 | 13 | 12 | 11     | 10 | 9 | 8 | 7 | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
| Byte 1 |    |    |    |    | Byte 2 |   |   |   |   | Byte 3 |   |   |   |   | Byte 4 |    |    |    |    | Byte 5 |    |   |   |   | Byte 6 |   |   |   |   |   |   |
| MSB 0  |    |    |    |    | HSB 0  |   |   |   |   | MSB 1  |   |   |   |   | HSB 1  |    |    |    |    | LSB 0  |    |   |   |   | LSB 1  |   |   |   |   |   |   |

### 32 bit Format, Little endian byteorder

|        |    |    |    |    |    |   |        |   |   |   |   |   |   |        |   |    |    |    |    |    |                |   |   |   |   |   |   |        |   |   |   |
|--------|----|----|----|----|----|---|--------|---|---|---|---|---|---|--------|---|----|----|----|----|----|----------------|---|---|---|---|---|---|--------|---|---|---|
| 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 | 15 | 14 | 13 | 12 | 11 | 10             | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| Byte 1 |    |    |    |    |    |   | Byte 2 |   |   |   |   |   |   | Byte 3 |   |    |    |    |    |    | Byte 4         |   |   |   |   |   |   | Byte 5 |   |   |   |
| LSB 0  |    |    |    |    |    |   | MSB 0  |   |   |   |   |   |   | HSB 0  |   |    |    |    |    |    | sign extension |   |   |   |   |   |   | LSB 1  |   |   |   |

## Register Interface

### Address Map (Address bits 15-12 determine the subcomponent)

When accessed from the DSP, all FPGA Registers are memory mapped to the address region from 0xA0000000 to 0xA000FFFF.

```

0x0000 to 0x0FFF: Interfaceboard
0x1000 to 0x1FFF: Mailbox Registers on Interfaceboard
0x2000 to 0x2FFF: RAM Registers on Interfaceboard
0x8000 to 0x8FFF: Headstage 0
0x9000 to 0x9FFF: STG1 on HS 0
0xA000 to 0xAF00: STG2 on HS 0
0xC000 to 0xCFFF: Headstage 1
0xD000 to 0xDFFF: STG1 on HS 1
0xE000 to 0xEFFF: STG2 on HS 1

```

### Interface Board Address Map (Address bits 11-0), Base Address: 0x0000:

Access time is 0,85 us for writes and 0,85 us for reads.

| Register                                 | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8         | 7        | 6                                                                | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------------------------------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|----|---|-----------|----------|------------------------------------------------------------------|---|---|---|---|---|---|
| 0x000:<br>Device ID<br>Register          | 0x00000001 = MEA 21 Interface FPGA |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |   |           |          |                                                                  |   |   |   |   |   |   |
| 0x004:<br>HW/FPGA<br>Version<br>Register | HW/Board Version                   |    |    |    |    |    |    |    |    |    |    |    |    |    | FPGA Version: 0x0101 = Initial Version |    |    |    |    |    |    |    |   |           |          |                                                                  |   |   |   |   |   |   |
| 0x008 :<br>Configuration<br>Register     | Reserved                           |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |   | Cy2notCy1 | Reserved | Additional<br>Boards<br>attached, What<br>kind of board?,<br>... |   |   |   |   |   |   |

| Register                                          | 31                            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                      | 7                      | 6        | 5                     | 4                     | 3 | 2 | 1 | 0 |
|---------------------------------------------------|-------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|---|------------------------|------------------------|----------|-----------------------|-----------------------|---|---|---|---|
| 0x010:<br>GTP<br>CTRL<br>Register                 | Reserved                      |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |   | HS 1<br>Link<br>enable | HS 0<br>Link<br>enable | Reserved | HS<br>1<br>Link<br>up | HS<br>0<br>Link<br>up |   |   |   |   |
| 0x014:<br>(RO)GTP<br>Error<br>counter<br>Register | HS 1                          |    |    |    |    |    |    |    |    |    |    |    |    |    | HS 0 |    |    |    |    |    |    |    |   |                        |                        |          |                       |                       |   |   |   |   |
| 0x014:<br>(WO)GTP<br>Error<br>counter<br>Reset    | Any Value Resets the counters |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |   |                        |                        |          |                       |                       |   |   |   |   |

| Register                            | 31       | 30 | 29 | 28 | 27 | 26 | 25        | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17                                                    | 16 | 15 | 14 | 13       | 12       | 11 | 10 | 9                                    | 8                    | 7                    | 6           | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------------------|----------|----|----|----|----|----|-----------|----|----|----|----|----|-----------|----|-------------------------------------------------------|----|----|----|----------|----------|----|----|--------------------------------------|----------------------|----------------------|-------------|---|---|---|---|---|---|
| 0x020:<br>FPGA<br>Reset             | Reserved |    |    |    |    |    |           |    |    |    |    |    |           |    |                                                       |    |    |    |          |          |    |    |                                      | FPGA<br>Reset        |                      |             |   |   |   |   |   |   |
| 0x024:<br>Power<br>Enable           | Reserved |    |    |    |    |    |           |    |    |    |    |    |           |    |                                                       |    |    |    |          |          |    |    |                                      | HS2<br>PWR<br>Enable | HS1<br>PWR<br>Enable | IF<br>Trafo |   |   |   |   |   |   |
| 0x028:<br>Trafo<br>startup<br>delay | Reserved |    |    |    |    |    | HS2 Delay |    |    |    |    |    | HS1 Delay |    |                                                       |    |    |    | IF Delay |          |    |    |                                      |                      |                      |             |   |   |   |   |   |   |
| 0x02C:<br>LED<br>config<br>Register | Reserved |    |    |    |    |    |           |    |    |    |    |    |           |    | LED<br>HS 1/2<br>and IF<br>register<br>mode<br>enable |    |    |    |          | Reserved |    |    | LED HS 1/2 and IF<br>output register |                      |                      |             |   |   |   |   |   |   |

| Register                                   | 31                                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11         | 10               | 9                 | 8                     | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------------------|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|------------------|-------------------|-----------------------|---|---|---|---|---|---|---|---|
| 0x030: (WO)Flash Instruction Code Register | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | Stop instruction | Fifo Reset        | Instruction Code      |   |   |   |   |   |   |   |   |
| 0x030: (RO)Flash Status Register           | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FIFO_empty | FIFO_full        | Statemachine busy | Flash Status Register |   |   |   |   |   |   |   |   |
| 0x034 : Flash Memory Address Register      | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                  |                   |                       |   |   |   |   |   |   |   |   |
| 0x038 : Flash Data FIFO Register           | 256 Data Bytes in 64 DWords to/from Flash |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                  |                   |                       |   |   |   |   |   |   |   |   |
| 0x03C : Flash Clock Divider Register       | Multiples of 2 divide 38,4 MHz            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                  |                   |                       |   |   |   |   |   |   |   |   |

| Register                                  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11        | 10              | 9                 | 8                 | 7         | 6         | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------------|-------------------|-------------------|-----------|-----------|---|---|---|---|---|---|
| 0x040: FIFO Interface CTRL Dev0           | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           | incl. EOF       | incl. Timestamp   | incl. Packet cnt. | Reserved  | incl. SOF |   |   |   |   |   |   |
| 0x042: FIFO Interface CTRL Dev2           | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | incl. EOF | incl. Timestamp | incl. Packet cnt. | Reserved          | incl. SOF |           |   |   |   |   |   |   |
| 0x044: (W1Set) FIFO Interface CTRL Dev0   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | incl. EOF | incl. Timestamp | incl. Packet cnt. | Reserved          | incl. SOF |           |   |   |   |   |   |   |
| 0x046: (W1Set) FIFO Interface CTRL Dev2   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | incl. EOF | incl. Timestamp | incl. Packet cnt. | Reserved          | incl. SOF |           |   |   |   |   |   |   |
| 0x048: (W1Clear) FIFO Interface CTRL Dev0 | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | incl. EOF | incl. Timestamp | incl. Packet cnt. | Reserved          | incl. SOF |           |   |   |   |   |   |   |
| 0x04A: (W1Clear) FIFO Interface CTRL Dev2 | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | incl. EOF | incl. Timestamp | incl. Packet cnt. | Reserved          | incl. SOF |           |   |   |   |   |   |   |

|                                                      |          |               |          |               |     |     |
|------------------------------------------------------|----------|---------------|----------|---------------|-----|-----|
| 0x04C:<br>(RO)Enabled<br>Analog<br>Channels<br>Dev0  | Reserved |               |          | IF            | HS2 | HS1 |
| 0x04E:<br>(RO)Enabled<br>Analog<br>Channels<br>Dev2  | Reserved |               |          | IF            | HS2 | HS1 |
| 0x050:<br>(RO)Enabled<br>Digital<br>Channels<br>Dev0 | Reserved |               |          | IF            | HS2 | HS1 |
| 0x052:<br>(RO)Enabled<br>Digital<br>Channels<br>Dev2 | Reserved |               |          | IF            | HS2 | HS1 |
| 0x054:<br>Channel<br>config. HS1<br>Dev0             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x056:<br>Channel<br>config. HS1<br>Dev2             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x058:<br>Channel<br>config. HS2<br>Dev0             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x05A:<br>Channel<br>config. HS2<br>Dev2             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x05C:<br>Channel<br>config. DSP<br>Dev0             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x05E:<br>Channel<br>config. DSP<br>Dev2             | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x060:<br>Channel<br>config. IF<br>Dev0              | Reserved | Channeloffset | Reserved | # of Channels |     |     |
| 0x062:<br>Channel<br>config. IF<br>Dev2              | Reserved | Channeloffset | Reserved | # of Channels |     |     |



|                                                   |                                                                              |                                           |
|---------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------|
| 0x090: Gate Mask Dev0                             | Gate Mask of Triggered Mode                                                  |                                           |
| 0x092: Gate Mask Dev2                             | Gate Mask of Triggered Mode                                                  |                                           |
| 0x094:<br>Compare Value of Gate Mask Dev0         | Compare this Value against the Multiplexed Data configured in Register 0x900 |                                           |
| 0x096:<br>Compare Value of Gate Mask Dev2         | Compare this Value against the Multiplexed Data configured in Register 0x900 |                                           |
| 0x098:<br>Amount of sweeps in Triggered Mode Dev0 | Count Start Value                                                            |                                           |
| 0x09A:<br>Amount of sweeps in Triggered Mode Dev2 | Count Start Value                                                            |                                           |
| 0x09C:<br>Current Count Value Dev0                | Current remaining sweeps until Stop                                          |                                           |
| 0x0B0:<br>Endpoint FIFO Reset                     | Reserved                                                                     | 0x2: Reset Fifo EP2, 0x6: Reset Fifo EP 6 |
| 0x0F0: I2C Blocking for other Cypress             | Reserved                                                                     | Block other Cypress                       |

#### \*Decoding Table:

| Register                    | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-----------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| 0x100: ADC Control Register | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Start Stop |   |
| 0x104: Enable ADCs          | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | ADC 1      |   |
| 0x108 - 0x1FC:              | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |            |   |

| Register                             | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                                    | 0 |
|--------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------------------------------|---|
| 0x200: Trigger CTRL Register 1       | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Enable Trigger                       |   |
| 0x214: Trigger Event Status Register | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Trigger Event                        |   |
| 0x218: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 1, to HS1 STG 1 Trigger 1 |   |
| 0x21C: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 2, to HS1 STG 1 Trigger 2 |   |
| 0x220: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 3, to HS1 STG 1 Trigger 3 |   |
| 0x224: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 4, to HS1 STG 2 Trigger 1 |   |
| 0x228: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 5, to HS1 STG 2 Trigger 2 |   |
| 0x22C: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 6, to HS1 STG 2 Trigger 3 |   |
| 0x230: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 7, to HS2 STG 1 Trigger 1 |   |
| 0x234: Trigger Segment ID Register   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Segment ID 8, to HS2 STG 1 Trigger 2 |   |

|                                                                       |                                                               |                                          |          |                 |
|-----------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------|----------|-----------------|
| 0x238:<br>Trigger<br>Segment ID<br>Register                           | Reserved                                                      | Segment ID 9, to HS2 STG 1<br>Trigger 3  |          |                 |
| 0x23C:<br>Trigger<br>Segment ID<br>Register                           | Reserved                                                      | Segment ID 10, to HS2 STG 2<br>Trigger 1 |          |                 |
| 0x240:<br>Trigger<br>Segment ID<br>Register                           | Reserved                                                      | Segment ID 11, to HS2 STG 2<br>Trigger 2 |          |                 |
| 0x244:<br>Trigger<br>Segment ID<br>Register                           | Reserved                                                      | Segment ID 12, to HS2 STG 2<br>Trigger 3 |          |                 |
| 0x260:<br>Trigger<br>status<br>feedback<br>HS1<br>Register<br>(RO/RW) | Reserved                                                      | Armed 6 ... 1                            | Reserved | Running 6 ... 1 |
| 0x264:<br>Trigger<br>status<br>feedback<br>HS2<br>Register<br>(RO/RW) | Reserved                                                      | Armed 6 ... 1                            | Reserved | Running 6 ... 1 |
| 0x280 -<br>0x294:<br>External<br>trigger<br>source                    | Data value from 0 to 99 for Trigger 1 to 6 (Headstage 1) ***  |                                          |          |                 |
| 0x298 -<br>0x2AC:<br>External<br>trigger<br>source                    | Data value from 0 to 99 for Trigger 7 to 12 (Headstage 2) *** |                                          |          |                 |

| Register                     | 31                                                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2             | 1                      | 0 |
|------------------------------|-----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------|------------------------|---|
| 0x300: Digital Out Register  | Data (RO)                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |               |                        |   |
| 0x304: Digital In Register   | Data (RO)                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |               |                        |   |
| 0x308: Direction Register    | '1': Input, '0' Output                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |               |                        |   |
| 0x30C: Interrupt Enable      | '1': Interrupt enabled, only for Inputs, '0' Interrupt disabled |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |               |                        |   |
| 0x310: Aux Data Out Register | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Aux Data      |                        |   |
| 0x314: Aux Data In Register  | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Aux Data (RO) |                        |   |
| 0x318: Aux Data Dir Register | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |               | '0': Input, '1' Output |   |

| Register                              | 31       | 30 | 29 | 28           | 27 | 26 | 25 | 24       | 23 | 22 | 21 | 20            | 19 | 18                   | 17                   | 16                | 15              | 14         | 13          | 12          | 11                 | 10       | 9          | 8 | 7 | 6 | 5 | 4 | 3        | 2          | 1 | 0 |
|---------------------------------------|----------|----|----|--------------|----|----|----|----------|----|----|----|---------------|----|----------------------|----------------------|-------------------|-----------------|------------|-------------|-------------|--------------------|----------|------------|---|---|---|---|---|----------|------------|---|---|
| 0x400: DSP Indata CTRL Register       | Reserved |    |    |              |    |    |    |          |    |    |    |               |    | Filtered HS2 Data en | Filtered HS1 Data en | Timestamp Data en | Digital Data en | IF Data en | HS2 Data en | HS1 Data en | Int en             | Reserved |            |   |   |   |   |   | Clr Fifo | Reset Fifo |   |   |
| 0x404: DSP Outdata CTRL Register      | Reserved |    |    |              |    |    |    |          |    |    |    |               |    | Int en               | Reserved             |                   |                 |            |             |             |                    | Clr Fifo | Reset Fifo |   |   |   |   |   |          |            |   |   |
| 0x408: DSP In Fifo Status Flags (RO)  | Reserved |    |    |              |    |    |    |          |    |    |    |               |    | overflow occurred    | overflow             | full              | prog full       | prog empty | empty       | underflow   | underflow occurred |          |            |   |   |   |   |   |          |            |   |   |
| 0x40C: DSP Out Fifo Status Flags (RO) | Reserved |    |    |              |    |    |    |          |    |    |    |               |    | overflow occurred    | overflow             | full              | prog full       | prog empty | empty       | underflow   | underflow occurred |          |            |   |   |   |   |   |          |            |   |   |
| 0x410: DSP Indata Threshold Register  | Reserved |    |    | Fifo full TH |    |    |    | Reserved |    |    |    | Fifo empty TH |    |                      |                      |                   |                 |            |             |             |                    |          |            |   |   |   |   |   |          |            |   |   |



|                                           |                                        |                          |                          |
|-------------------------------------------|----------------------------------------|--------------------------|--------------------------|
| 0x61C:<br>Filter 1<br>CTRL                | Reserved                               | Filter<br>Enable<br>HS 2 | Filter<br>Enable<br>HS 1 |
| 0x620:<br>Filter 2<br>coefficient<br>b[0] | Filter coefficient b[0] as Q1.30 value |                          |                          |
| 0x628:<br>Filter 2<br>coefficient<br>b[1] | Filter coefficient b[1] as Q1.30 value |                          |                          |
| 0x62C:<br>Filter 2<br>coefficient<br>a[1] | Filter coefficient a[1] as Q1.30 value |                          |                          |
| 0x630:<br>Filter 2<br>coefficient<br>b[2] | Filter coefficient b[2] as Q1.30 value |                          |                          |
| 0x634:<br>Filter 2<br>coefficient<br>a[2] | Filter coefficient a[2] as Q1.30 value |                          |                          |
| 0x63C:<br>Filter 2<br>CTRL                | Reserved                               | Filter<br>Enable<br>HS 2 | Filter<br>Enable<br>HS 1 |
| 0x640:<br>Filter 3<br>coefficient<br>b[0] | Filter coefficient b[0] as Q1.30 value |                          |                          |
| 0x648:<br>Filter 3<br>coefficient<br>b[1] | Filter coefficient b[1] as Q1.30 value |                          |                          |
| 0x64C:<br>Filter 3<br>coefficient<br>a[1] | Filter coefficient a[1] as Q1.30 value |                          |                          |
| 0x650:<br>Filter 3<br>coefficient<br>b[2] | Filter coefficient b[2] as Q1.30 value |                          |                          |
| 0x654:<br>Filter 3<br>coefficient<br>a[2] | Filter coefficient a[2] as Q1.30 value |                          |                          |
| 0x65C:<br>Filter 3<br>CTRL                | Reserved                               | Filter<br>Enable<br>HS 2 | Filter<br>Enable<br>HS 1 |

|                                           |                                        |                          |                          |
|-------------------------------------------|----------------------------------------|--------------------------|--------------------------|
| 0x660:<br>Filter 4<br>coefficient<br>b[0] | Filter coefficient b[0] as Q1.30 value |                          |                          |
| 0x668:<br>Filter 4<br>coefficient<br>b[1] | Filter coefficient b[1] as Q1.30 value |                          |                          |
| 0x66C:<br>Filter 4<br>coefficient<br>a[1] | Filter coefficient a[1] as Q1.30 value |                          |                          |
| 0x670:<br>Filter 4<br>coefficient<br>b[2] | Filter coefficient b[2] as Q1.30 value |                          |                          |
| 0x674:<br>Filter 4<br>coefficient<br>a[2] | Filter coefficient a[2] as Q1.30 value |                          |                          |
| 0x67C:<br>Filter 4<br>CTRL                | Reserved                               | Filter<br>Enable<br>HS 2 | Filter<br>Enable<br>HS 1 |

### Configurable DSP in Data overview:

```

HS1           122 Datawords (Header, 120 Data, Counter)
HS2           122 Datawords (Header, 120 Data, Counter)
IF            9 Datawords (Header, 8 Data)
Filtered HS1 122 Datawords (Header, 120 Data, Counter)
Filtered HS2 122 Datawords (Header, 120 Data, Counter)
Digital       32 Datawords (Header, 31x Digital Data)
  - Header          (32 bit)
  - Digital Mux Data for USB-A      (32 bit)
  - Digital Mux Data for USB-B      (32 bit)
  - Digital In Data          (32 bit)
  - Digital Out Data         (32 bit)
  - Digital Register Data (0x800)   (32 bit)
  - Feedback             (32 bit)
  - Aux In:
    Bit 0: Input Level of Aux 1
    Bit 1: Input Level of Aux 2
  - Trigger Status from HS1:
    Bits 0 - 11 Trigger Statemachine status (2 bit per trigger: 00: not Armed, 01: Armed, 10: Triggered (running), 11: Reserved)
    Bits 16 - 21 Trigger Event (1: Trigger event occurred)
    Bits 24 - 29 Trigger Event Type (1: begin of Trigger event, 0: end of Trigger event)
  - SBS1 from HS1:
    Bits 0 - 15: Headstage 1: Sideband 1 from STG 1
    Bits 16 - 31: Headstage 1: Sideband 1 from STG 2
  - SBS2 from HS1:

```

```

Bits 0 - 15: Headstage 1: Sideband 2 from STG 1
Bits 16 - 31: Headstage 1: Sideband 2 from STG 2

- SBS3 from HS1:
  Bits 0 - 15: Headstage 1: Sideband 3 from STG 1
  Bits 16 - 31: Headstage 1: Sideband 3 from STG 2

- DAC A+B from HS1 of STG1:
  Bits 0 - 15: Headstage 1: DAC A from STG 1
  Bits 16 - 31: Headstage 1: DAC B from STG 1

- DAC C+D from HS1 of STG1:
  Bits 0 - 15: Headstage 1: DAC C from STG 1
  Bits 16 - 31: Headstage 1: DAC D from STG 1

- DAC E+F from HS1 of STG1:
  Bits 0 - 15: Headstage 1: DAC E from STG 1
  Bits 16 - 31: Headstage 1: DAC F from STG 1

- DAC A+B from HS1 of STG2:
  Bits 0 - 15: Headstage 1: DAC A from STG 2
  Bits 16 - 31: Headstage 1: DAC B from STG 2

- DAC C+D from HS1 of STG2:
  Bits 0 - 15: Headstage 1: DAC C from STG 2
  Bits 16 - 31: Headstage 1: DAC D from STG 2

- DAC E+F from HS1 of STG2:
  Bits 0 - 15: Headstage 1: DAC E from STG 2
  Bits 16 - 31: Headstage 1: DAC F from STG 2

- Seg. & Elec. ID from HS1 of STG1:
  Bits 0 - 7: current Segment ID
  Bits 16 - 23: Electrode Config ID

- Seg. & Elec. ID from HS1 of STG2:
  Bits 0 - 7: current Segment ID
  Bits 16 - 23: Electrode Config ID

- Trigger Status from HS2:
  Bits 0 - 11 Trigger Statemachine status (2 bit per trigger: 00: not Armed, 01: Armed, 10: Triggered (running), 11: Reserved)
  Bits 16 - 21 Trigger Event (1: Trigger event occurred)
  Bits 24 - 29 Trigger Event Type (1: begin of Trigger event, 0: end of Trigger event)

- SBS1 from HS2:
  Bits 0 - 15: Headstage 2: Sideband 1 from STG 1
  Bits 16 - 31: Headstage 2: Sideband 1 from STG 2

- SBS2 from HS2:
  Bits 0 - 15: Headstage 2: Sideband 2 from STG 1
  Bits 16 - 31: Headstage 2: Sideband 2 from STG 2

- SBS3 from HS2:
  Bits 0 - 15: Headstage 2: Sideband 3 from STG 1
  Bits 16 - 31: Headstage 2: Sideband 3 from STG 2

- DAC A+B from HS2 of STG1:
  Bits 0 - 15: Headstage 2: DAC A from STG 1
  Bits 16 - 31: Headstage 2: DAC B from STG 1

- DAC C+D from HS2 of STG1:
  Bits 0 - 15: Headstage 2: DAC C from STG 1

```

Bits 16 - 31: Headstage 2: DAC D from STG 1

- DAC E+F from HS2 of STG1:

    Bits 0 - 15: Headstage 2: DAC E from STG 1

    Bits 16 - 31: Headstage 2: DAC F from STG 1

- DAC A+B from HS2 of STG2:

    Bits 0 - 15: Headstage 2: DAC A from STG 2

    Bits 16 - 31: Headstage 2: DAC B from STG 2

- DAC C+D from HS2 of STG2:

    Bits 0 - 15: Headstage 2: DAC C from STG 2

    Bits 16 - 31: Headstage 2: DAC D from STG 2

- DAC E+F from HS2 of STG2:

    Bits 0 - 15: Headstage 2: DAC E from STG 2

    Bits 16 - 31: Headstage 2: DAC F from STG 2

- Seg. & Elec. ID from HS2 of STG1:

    Bits 0 - 7: current Segment ID

    Bits 16 - 23: Electrode Config ID

- Seg. & Elec. ID from HS2 of STG2:

    Bits 0 - 7: current Segment ID

    Bits 16 - 23: Electrode Config ID

The header has the format

Bit 31 : 1, when data from a headstage is enabled and the HS is not connected, otherwise 0  
Bit 24 to 30 : Data Source enumeration (see below)  
Bit 9 to 23 : Reserved (Always Zero)  
Bit 0 to 7 : The number of datapoints + counter values following this header, 0x79 for Headstage data (120 + 1)

## Data Source enumeration:

- 1: Headstage 1
  - 2: Headstage 2
  - 3: Analog Data from Interfaceboard
  - 4: Headstage 1 filtered Data
  - 5: Headstage 2 filtered Data
  - 6: Digital Data
  - 7: Timestamp counter

| Register                       | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                         | 18 | 17 | 16 | 15       | 14 | 13 | 12 | 11      | 10 | 9 | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |
|--------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----------|----|----|----|---------|----|---|---|---|-------------|---|---|---|---|---|---|--|--|--|--|--|
| 0x500: Right Audio Channel     | Reserved |    |    |    |    |    |    |    |    |    |    |    | Source (DSP, IF, HS2, HS1) |    |    |    | Reserved |    |    |    | Channel |    |   |   |   |             |   |   |   |   |   |   |  |  |  |  |  |
| 0x504: Left Audio Channel      | Reserved |    |    |    |    |    |    |    |    |    |    |    | Source (DSP, IF, HS2, HS1) |    |    |    | Reserved |    |    |    | Channel |    |   |   |   |             |   |   |   |   |   |   |  |  |  |  |  |
| 0x510: Right Audio Attenuation | Reserved |    |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |          |    |    |    |         |    |   |   |   | Attenuation |   |   |   |   |   |   |  |  |  |  |  |
| 0x514: Left Audio Attenuation  | Reserved |    |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |          |    |    |    |         |    |   |   |   | Attenuation |   |   |   |   |   |   |  |  |  |  |  |

## Source decoding:

- 0: No source
- 1: HS1
- 2: HS2
- 3: IF
- 4: DSP (bits 23 - 0)

| Register                                                   | 31                                                                                          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                                                               | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                                          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------------------------------------------|----|----|----|----|----|----|----|---|---|---|--------------------------------------------|---|---|---|---|---|---|--|--|
| 0x700: Digital Pulse Register                              | bits can only be set here, and will be cleared after the time defined in reg 0x704 to 0x710 |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x704: Digital Pulse Duration 1                            | Duration of Digital Data in multiple of 20 us for Pulse Register bits 0 to 7                |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x708: Digital Pulse Duration 2                            | Duration of Digital Data in multiple of 20 us for Pulse Register bits 8 to 15               |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x70c: Digital Pulse Duration 3                            | Duration of Digital Data in multiple of 20 us for Pulse Register bits 16 to 23              |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x710: Digital Pulse Duration 4                            | Duration of Digital Data in multiple of 20 us for Pulse Register bits 24 to 31              |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x780: Feedback Data                                       | Data                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x800: Data to Data Stream                                 | 'Digital Data-Stream' face in data                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x804: Dig. Data Delay                                     | Reserved                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   | Number of sweeps to delay the digital data |   |   |   |   |   |   |  |  |
| 0x808: delay configuration                                 | Switch of datawords if delayed or direct*                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                  |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x840 - 0x87C: Select mux for Dig out                      | Data value from 0 to 315 **** for Digital out: 2 to 32(even bits)                           |    |    |    |    |    |    |    |    |    |    |    |    |    | Data value from 0 to 315 **** for Digital out: 1 to 31(odd bits)                 |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x880 - 0x8BC: Select mux for Dig Data to USB-A            | Data value from 0 to 315 **** for Digital Data stream to Host: 2 to 32(even bits)           |    |    |    |    |    |    |    |    |    |    |    |    |    | Data value from 0 to 315 **** for Digital Data stream to Host: 1 to 31(odd bits) |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x8C0 - 0x8FC: Select mux for Dig Data to USB-B            | Data value from 0 to 315 **** for Digital Data stream to Host: 2 to 32(even bits)           |    |    |    |    |    |    |    |    |    |    |    |    |    | Data value from 0 to 315 **** for Digital Data stream to Host: 1 to 31(odd bits) |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |
| 0x900 - 0x93C: Select mux for Trigger of Gated Mode to USB | Data value from 0 to 315 **** for Trigger of Gate to Host: 2 to 32(even bits)               |    |    |    |    |    |    |    |    |    |    |    |    |    | Data value from 0 to 315 **** for Trigger of Gate to Host: 1 to 31(odd bits)     |    |    |    |    |    |    |    |   |   |   |                                            |   |   |   |   |   |   |  |  |

\*Decoding Table:

|                  |         |
|------------------|---------|
| Digital In Data  | (bit 1) |
| Digital Out Data | (bit 2) |
| Feedback         | (bit 4) |
| Aux In           | (bit 5) |

|                      |                        |          |
|----------------------|------------------------|----------|
| Trigger Statemashine | Status from HS1        | (bit 8)  |
| SBS from HS1         | Channel 1 of X1 and X2 | (bit 9)  |
| SBS from HS1         | Channel 2 of X1 and X2 | (bit 10) |
| SBS from HS1         | Channel 3 of X1 and X2 | (bit 11) |
| DAC A+B              | from HS1 of X1         | (bit 12) |
| DAC C+D              | from HS1 of X1         | (bit 13) |
| DAC E+F              | from HS1 of X1         | (bit 14) |
| DAC A+B              | from HS1 of X2         | (bit 15) |
| DAC C+D              | from HS1 of X2         | (bit 16) |
| DAC E+F              | from HS1 of X2         | (bit 17) |
| Trigger Statemashine | Status from HS2        | (bit 20) |
| SBS from HS2         | Channel 1 of X1 and X2 | (bit 21) |
| SBS from HS2         | Channel 2 of X1 and X2 | (bit 22) |
| SBS from HS2         | Channel 3 of X1 and X2 | (bit 23) |
| DAC A+B              | from HS2 of X1         | (bit 24) |
| DAC C+D              | from HS2 of X1         | (bit 25) |
| DAC E+F              | from HS2 of X1         | (bit 26) |
| DAC A+B              | from HS2 of X2         | (bit 27) |
| DAC C+D              | from HS2 of X2         | (bit 28) |
| DAC E+F              | from HS2 of X2         | (bit 29) |

| Register                                      | 31                         | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20              | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11                                          | 10       | 9 | 8 | 7 | 6 | 5 | 4 | 3             | 2 | 1 | 0 |
|-----------------------------------------------|----------------------------|----------|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|----|---------------------------------------------|----------|---|---|---|---|---|---|---------------|---|---|---|
| 0xA00 - 0xA2C: Config ID boundaries           | set first config ID to end | Reserved |    |    |    |    |    |    |    |    |    | Config Start ID |    |    |    |    |    |    |    |    |                                             | Reserved |   |   |   |   |   |   | Config End ID |   |   |   |
| 0xA40: Config ID<br>Manual/current for SBS 1  | Reserved                   |          |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |    | Electrode Config ID 0x00 to 0xFF            |          |   |   |   |   |   |   |               |   |   |   |
| 0xA4C: Config ID<br>Manual/current for SBS 4  | Reserved                   |          |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |    | Electrode Config ID 0x00 to 0xFF            |          |   |   |   |   |   |   |               |   |   |   |
| 0xA58: Config ID<br>Manual/current for SBS 7  | Reserved                   |          |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |    | Electrode Config ID 0x00 to 0xFF            |          |   |   |   |   |   |   |               |   |   |   |
| 0xA64: Config ID<br>Manual/current for SBS 10 | Reserved                   |          |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |    | Electrode Config ID 0x00 to 0xFF            |          |   |   |   |   |   |   |               |   |   |   |
| 0xA80: Config ID trigger source               | Reserved                   |          |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |    | Data value from 0 to 100 for Config ID 1*** |          |   |   |   |   |   |   |               |   |   |   |

|                                       |          |                                               |
|---------------------------------------|----------|-----------------------------------------------|
| 0xA8C: Config ID trigger source       | Reserved | Data value from 0 to 100 for Config ID 4 ***  |
| 0xA98: Config ID trigger source       | Reserved | Data value from 0 to 100 for Config ID 7 ***  |
| 0xAA4: Config ID trigger source       | Reserved | Data value from 0 to 100 for Config ID 10 *** |
| 0xAC0: (Re-)Start List mode increment | Reserved | 1 bit per Sideband                            |
| 0xAC4: Stop List mode increment       | Reserved | 1 bit per Sideband                            |

|                                          |                                                    |                                                         |
|------------------------------------------|----------------------------------------------------|---------------------------------------------------------|
| 0xF0C : EEPROM HW configuration Register | Address length (1,2,3 Bytes)                       | Clock Divider Register (Multiples of 2 divide 38,4 MHz) |
| 0xF10 : EEPROM Offset Register           | Offset for reads and writes to the EEeprom         |                                                         |
| 0xF14 : EEPROM Size Register             | Size of the EEeprom Block available for this Image |                                                         |

| Register                             | from            | to              | in Revision | USB Rev |
|--------------------------------------|-----------------|-----------------|-------------|---------|
| Electrode config/segment ID register | 0x0208 - 0x0234 | 0x0218 - 0x0244 | 0.05        | 0.27    |
| Event Status Register                | 0x0238          | 0x0214          | 0.05        | 0.27    |
| ADC Filter                           | 0x0120 - 0x0138 | 0x0600 - 0x0674 | 0.05        |         |
| FIFO/Channel Mode CTRL DevX          | 0x0068 - 0x006B | 0x006C - 0x006F | 0.05        |         |
| Sampling Freq. DevX                  | 0x006C - 0x006F | 0x0070 - 0x0073 | 0.05        |         |
| DIGITAL_CHANNELS_L                   | 0x0064 - 0x0067 | 0x0080 - 0x0083 | 0.07        | 0.42    |
| DIGITAL_CHANNELS_H                   | 0x0068 - 0x006B | 0x0084 - 0x0087 | 0.07        | 0.42    |
| FIFO/Channel Mode CTRL DevX          | 0x006C - 0x006F | 0x0088 - 0x008B | 0.07        | 0.42    |
| Sampling Freq. DevX                  | 0x0070 - 0x0073 | 0x008C - 0x008F | 0.07        | 0.42    |
| Select mux for Dig Data              | 0x0340 - 0x03FC | 0x0840 - 0x08FC | 0.09        | 0.51    |

\*\*\* Decoding Table:

| Value   | Source                                                       |
|---------|--------------------------------------------------------------|
| 0       | : '0' (default for all bits)                                 |
| 32 - 1  | : Digital In bit 31 downto 0                                 |
| 64 - 33 | : Feedback bit 31 downto 0                                   |
| 66 - 65 | : Aux In bit 1 downto 0                                      |
| 98 - 67 | : Digital Pulse Register bit 31 downto 0                     |
| 99      | : '1'                                                        |
| 100     | : SBS bit 8 of each Trigger is all STGs (only for Config ID) |
| 101     | : DACQ Cypress 1 Virtual Device 1 is started                 |
| 102     | : DACQ Cypress 1 Virtual Device 2 is started                 |
| 103     | : DACQ Cypress 2 Virtual Device 1 is started                 |
| 104     | : DACQ Cypress 2 Virtual Device 2 is started                 |

\*\*\*\* Decoding Table:

| Value     | Source                                  |
|-----------|-----------------------------------------|
| 31 - 0    | : Digital In bit 31 downto 0            |
| 63 - 32   | : Digital Pulse bit 31 downto 0         |
| 95 - 64   | : Feedback bit 31 downto 0              |
| 97 - 96   | : Aux In bit 1 downto 0                 |
| 99 - 98   | : "10" fix Values                       |
| 101 - 100 | : Trigger Status HS1 STG X1 Trigger 1   |
| 103 - 102 | : Trigger Status HS1 STG X1 Trigger 2   |
| 105 - 104 | : Trigger Status HS1 STG X1 Trigger 3   |
| 107 - 106 | : Trigger Status HS1 STG X2 Trigger 1   |
| 109 - 108 | : Trigger Status HS1 STG X2 Trigger 2   |
| 111 - 110 | : Trigger Status HS1 STG X2 Trigger 3   |
| 127 - 112 | : Sideband signals HS1 STG X1 Trigger 1 |
| 143 - 128 | : Sideband signals HS1 STG X1 Trigger 2 |
| 159 - 144 | : Sideband signals HS1 STG X1 Trigger 3 |
| 175 - 160 | : Sideband signals HS1 STG X2 Trigger 1 |
| 191 - 176 | : Sideband signals HS1 STG X2 Trigger 2 |
| 207 - 192 | : Sideband signals HS1 STG X2 Trigger 3 |

```
209 - 208 : Trigger Status HS2 STG X1 Trigger 1
211 - 210 : Trigger Status HS2 STG X1 Trigger 2
213 - 212 : Trigger Status HS2 STG X1 Trigger 3
215 - 214 : Trigger Status HS2 STG X2 Trigger 1
217 - 216 : Trigger Status HS2 STG X2 Trigger 2
219 - 218 : Trigger Status HS2 STG X2 Trigger 3
235 - 220 : Sideband signals HS2 STG X1 Trigger 1
251 - 236 : Sideband signals HS2 STG X1 Trigger 2
267 - 252 : Sideband signals HS2 STG X1 Trigger 3
283 - 268 : Sideband signals HS2 STG X2 Trigger 1
299 - 284 : Sideband signals HS2 STG X2 Trigger 2
315 - 300 : Sideband signals HS2 STG X2 Trigger 3
```

## Mailbox Register Address Map (Address bits 11-0) Base Address: 0x1000:

## **RAM Register Address Map (Address bits 11-0) Base Address: 0x2000:**

## **Headstage Board Address Map (Address bits 11-0) Base Address: HS1: 0x8000 HS2: 0xC000:**

Access time is 2.2 us for writes and 2.4 us for reads.

| Register                                 | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6              | 5        | 4                                                                     | 3 | 2 | 1 | 0 |
|------------------------------------------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|----|---|---|---|----------------|----------|-----------------------------------------------------------------------|---|---|---|---|
| 0x000:<br>Device ID<br>Register          | 0x00000002 = MEA 21 Headstage FPGA |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |   |   |   |                |          |                                                                       |   |   |   |   |
| 0x004:<br>HW/FPGA<br>Version<br>Register | HW/Board Version                   |    |    |    |    |    |    |    |    |    |    |    |    |    | FPGA Version: 0x0101 = Initial Version |    |    |    |    |    |    |    |   |   |   |                |          |                                                                       |   |   |   |   |
| 0x008 :<br>Configuration<br>Register     | Reserved                           |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |   |   |   | STG<br>Presend | Reserved | Additional<br>Boards<br>attached, What<br>kind of board?,<br>*<br>... |   |   |   |   |

|                             |          |                                        |
|-----------------------------|----------|----------------------------------------|
| 0x00c :<br>Channel<br>Limit | Reserved | Number of supported<br>analog channels |
|-----------------------------|----------|----------------------------------------|

### \*Decoding Table:

0: 2 x 60 MEA  
1: 1 x 60 MEA  
2: 1 x 120 MEA  
3: special

|                                                  |                                       |                                                         |
|--------------------------------------------------|---------------------------------------|---------------------------------------------------------|
| 0x03C :<br>Flash HW<br>configuration<br>register | Address<br>length<br>(1,2,3<br>Bytes) | Clock Divider Register (Multiples of 2 divide 38,4 MHz) |
|--------------------------------------------------|---------------------------------------|---------------------------------------------------------|

|                                                                    |          |                                                                               |          |                                    |
|--------------------------------------------------------------------|----------|-------------------------------------------------------------------------------|----------|------------------------------------|
| 0x14C: Open<br>Amplifier<br>Protection<br>Switch while<br>Blanking | Reserved | Electrode 119 - 91                                                            |          |                                    |
| 0x150:<br>Enable<br>Blanking                                       | Reserved | Electrode 30 - 1                                                              |          |                                    |
| 0x154:<br>Enable<br>Blanking                                       | Reserved | Electrode 60 - 31                                                             |          |                                    |
| 0x158:<br>Enable<br>Blanking                                       | Reserved | Electrode 90 - 61                                                             |          |                                    |
| 0x15C:<br>Enable<br>Blanking                                       | Reserved | Electrode 119 - 91                                                            |          |                                    |
| 0x160:<br>Stimulus<br>Data keep<br>pre filter                      | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x164:<br>Stimulus<br>Data keep<br>mid filter                      | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x168:<br>Stimulus<br>Data keep<br>post filter                     | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x170:<br>Non-Stimulus<br>Data keep<br>pre filter                  | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x174:<br>Non-Stimulus<br>Data keep<br>mid filter                  | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x178:<br>Non-Stimulus<br>Data keep<br>post filter                 | Reserved | onset delay                                                                   | Reserved | offset delay                       |
| 0x180:<br>Channel<br>Index                                         | Reserved |                                                                               |          | Index used for Reg.: 0x184 - 0x188 |
| 0x184:<br>Current ADC<br>Value                                     | Reserved | Reflects the ADC Value of the channel selected in Reg. 0x180                  |          |                                    |
| 0x188:<br>Current DC<br>Channel<br>offset                          | Reserved | Reflects the DC offset correction Value of the channel selected in Reg. 0x180 |          |                                    |

|                                                            |                                           |                                                                                                   |                                                 |                |                  |
|------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------|------------------|
| 0x1F0:<br>Stimulation<br>Channel<br>copy                   | Reserved                                  | Electrode 30 - 1 Reflects the STG Register 0x158 and 0x15C for monitoring if information is on HS |                                                 |                |                  |
| 0x1F4:<br>Stimulation<br>Channel<br>copy                   | Reserved                                  | Electrode 60 - 31                                                                                 |                                                 |                |                  |
| 0x1F8:<br>Stimulation<br>Channel<br>copy                   | Reserved                                  | Electrode 90 - 61                                                                                 |                                                 |                |                  |
| 0x1FC:<br>Stimulation<br>Channel<br>copy                   | Reserved                                  | Electrode 119 - 91                                                                                |                                                 |                |                  |
| 0x600: Filter<br>1 coefficient<br>b[0]                     | Filter coefficient b[0] as Q1.16 value    |                                                                                                   | "00000000000000" to extend coefficient to Q1.30 |                |                  |
| 0x604:<br>Reserved<br>(DC)                                 | Reserved                                  |                                                                                                   |                                                 |                |                  |
| 0x608: Filter<br>1 coefficient<br>b[1]                     | Filter coefficient b[1] as Q1.16 value    |                                                                                                   | "00000000000000" to extend coefficient to Q1.30 |                |                  |
| 0x60C: Filter<br>1 coefficient<br>a[1]                     | Filter coefficient a[1] as Q1.30 value    |                                                                                                   |                                                 |                |                  |
| 0x610: Filter<br>1 coefficient<br>b[2]                     | Filter coefficient b[2] as Q1.16 value    |                                                                                                   | "00000000000000" to extend coefficient to Q1.30 |                |                  |
| 0x614: Filter<br>1 coefficient<br>a[2]                     | Filter coefficient a[2] as Q1.30 value    |                                                                                                   |                                                 |                |                  |
| 0x618: Filter<br>1 coefficient<br>a[1]ext. and<br>a[2]ext. | Filter Coef. A2 lower bits -31 downto -46 |                                                                                                   | Filter Coef. A1 lower bits -31 downto -46       |                |                  |
| 0x61C: Filter<br>1 CTRL                                    | Reserved                                  |                                                                                                   | Reserved                                        | Filter<br>Mode | Filter<br>Enable |
| 0x620: Filter<br>2 coefficient<br>b[0]                     | Filter coefficient b[0] as Q1.16 value    |                                                                                                   | "00000000000000" to extend coefficient to Q1.30 |                |                  |
| 0x624:<br>Reserved<br>(DC)                                 | Reserved                                  |                                                                                                   |                                                 |                |                  |
| 0x628: Filter<br>2 coefficient<br>b[1]                     | Filter coefficient b[1] as Q1.16 value    |                                                                                                   | "00000000000000" to extend coefficient to Q1.30 |                |                  |

|                                                   |                                           |                                                 |  |               |                     |
|---------------------------------------------------|-------------------------------------------|-------------------------------------------------|--|---------------|---------------------|
| 0x62C: Filter 2 coefficient a[1]                  | Filter coefficient a[1] as Q1.30 value    |                                                 |  |               |                     |
| 0x630: Filter 2 coefficient b[2]                  | Filter coefficient b[2] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |
| 0x634: Filter 2 coefficient a[2]                  | Filter coefficient a[2] as Q1.30 value    |                                                 |  |               |                     |
| 0x638: Filter 2 coefficient a[1]ext. and a[2]ext. | Filter Coef. A2 lower bits -31 downto -46 | Filter Coef. A1 lower bits -31 downto -46       |  |               |                     |
| 0x63C: Filter 2 CTRL                              | Reserved                                  |                                                 |  | Reserved Mode | Filter Blank Enable |
| 0x640: Filter 3 coefficient b[0]                  | Filter coefficient b[0] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |
| 0x644: Reserved (DC)                              | Reserved                                  |                                                 |  |               |                     |
| 0x648: Filter 3 coefficient b[1]                  | Filter coefficient b[1] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |
| 0x64C: Filter 3 coefficient a[1]                  | Filter coefficient a[1] as Q1.30 value    |                                                 |  |               |                     |
| 0x650: Filter 3 coefficient b[2]                  | Filter coefficient b[2] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |
| 0x654: Filter 3 coefficient a[2]                  | Filter coefficient a[2] as Q1.30 value    |                                                 |  |               |                     |
| 0x658: Filter 3 coefficient a[1]ext. and a[2]ext. | Filter Coef. A2 lower bits -31 downto -46 | Filter Coef. A1 lower bits -31 downto -46       |  |               |                     |
| 0x65C: Filter 3 CTRL                              | Reserved                                  |                                                 |  | Reserved Mode | Filter Blank Enable |
| 0x660: Filter 4 coefficient b[0]                  | Filter coefficient b[0] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |
| 0x664: Reserved (DC)                              | Reserved                                  |                                                 |  |               |                     |
| 0x668: Filter 4 coefficient b[1]                  | Filter coefficient b[1] as Q1.16 value    | "00000000000000" to extend coefficient to Q1.30 |  |               |                     |

|                                                   |                                                                   |                |                            |          |                                                 |                     |  |  |
|---------------------------------------------------|-------------------------------------------------------------------|----------------|----------------------------|----------|-------------------------------------------------|---------------------|--|--|
| 0x66C: Filter 4 coefficient a[1]                  | Filter coefficient a[1] as Q1.30 value                            |                |                            |          |                                                 |                     |  |  |
| 0x670: Filter 4 coefficient b[2]                  | Filter coefficient b[2] as Q1.16 value                            |                |                            |          | "00000000000000" to extend coefficient to Q1.30 |                     |  |  |
| 0x674: Filter 4 coefficient a[2]                  | Filter coefficient a[2] as Q1.30 value                            |                |                            |          |                                                 |                     |  |  |
| 0x678: Filter 4 coefficient a[1]ext. and a[2]ext. | Filter Coef. A2 lower bits -31 downto -46                         |                |                            |          | Filter Coef. A1 lower bits -31 downto -46       |                     |  |  |
| 0x67C: Filter 4 CTRL                              | Reserved                                                          |                |                            |          | Reserved Mode                                   | Filter Blank Enable |  |  |
| 0x6A0: Filter 2 coefficient b2[0]                 | Filter coefficient b2[0] as Q1.16 value for one clock after blank |                |                            |          | "00000000000000" to extend coefficient to Q1.30 |                     |  |  |
| 0x6A8: Filter 2 coefficient b2[1]                 | Filter coefficient b2[1] as Q1.16 value for one clock after blank |                |                            |          | "00000000000000" to extend coefficient to Q1.30 |                     |  |  |
| 0x6AC: Filter 2 coefficient a2[1]                 | Filter coefficient a2[1] as Q1.30 value for one clock after blank |                |                            |          |                                                 |                     |  |  |
| 0x6B0: Filter 2 coefficient b2[2]                 | Filter coefficient b2[2] as Q1.16 value for one clock after blank |                |                            |          | "00000000000000" to extend coefficient to Q1.30 |                     |  |  |
| 0x6B4: Filter 2 coefficient a2[2]                 | Filter coefficient a2[2] as Q1.30 value for one clock after blank |                |                            |          |                                                 |                     |  |  |
| 0x6c0: Filter Info                                | Corner frequency of Hardware Filter in mHz                        |                |                            |          |                                                 |                     |  |  |
| 0x6c4: Filter Info                                | Hardware Filter order                                             | Band: Lowpass  | Family: Butterworth/Bessel | Reserved | 0 = Hardware Filter                             | Filter Active       |  |  |
| 0x6d0: Filter Info                                | Corner frequency of Highpass Filter in mHz                        |                |                            |          |                                                 |                     |  |  |
| 0x6d4: Filter Info                                | Highpass Filter order                                             | Band: Highpass | Family: Butterworth/Bessel | Reserved | 1 = Software Filter                             | Filter Active       |  |  |
| 0x6e0: Filter Info                                | Corner frequency of Lowpass Filter in mHz                         |                |                            |          |                                                 |                     |  |  |
| 0x6e4: Filter Info                                | Lowpass Filter order                                              | Band: Lowpass  | Family: Butterworth/Bessel | Reserved | 1 = Software Filter                             | Filter Active       |  |  |

| <b>Command</b> | <b>Bit 31 to 24</b> | <b>Bit 23 to 0</b> | <b>Description</b>                  |
|----------------|---------------------|--------------------|-------------------------------------|
| STP            | 0xFF                | 0xFFFFFFFF         | Stop DMA                            |
| SDTA           | 0x01                | 0x008RegAddr.      | Store Next Data to Register Address |
| DATA           | 0xData              | 0xData             | Data expected after SDTA command    |

| <b>Register</b>   | <b>from</b>     | <b>to</b>                             | <b>in Revision</b> |
|-------------------|-----------------|---------------------------------------|--------------------|
| ADC Filter        | 0x0120 - 0x0138 | 0x0600 - 0x0674                       | 0.04               |
| ADC Filter enable | 0x100 bits 4:1  | 0x61C, 0x63C, 0x65C, 0x67C each bit 0 | 1.15               |

**Stimulus Board Address Map (Address bits 11-0) Base Address: HS1: 0x9000 and 0xA000 HS2: 0xD000 and 0xE000:**

Access time is 4,3 us for writes and 6,4 us for reads.

| Register                                  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                             | 2                  | 1               | 0 |
|-------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-------------------------------|--------------------|-----------------|---|
| 0x020:<br>FPGA<br>Reset<br>(WO)           | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DDR<br>Block<br>Reset         | DDR clk<br>Reset   | FPGA<br>Reset   |   |
| 0x024:<br>FPGA<br>Reset<br>Status<br>(RO) | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | DDR<br>Block<br>PLL<br>Locked | PLL<br>Locked      | System<br>Reset |   |
| 0x028:<br>System<br>Pll<br>CTRL<br>(WO)   | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | Decrement<br>Phase            | Increment<br>Phase |                 |   |

| Register                                               | 31                                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11         | 10                  | 9                    | 8                     | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------------------------------|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|---------------------|----------------------|-----------------------|---|---|---|---|---|---|---|---|
| 0x030:<br>(WO)Flash<br>Instruction<br>Code<br>Register | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | Stop<br>instruction | Fifo Reset           | Instruction Code      |   |   |   |   |   |   |   |   |
| 0x030:<br>(RO)Flash<br>Status<br>Register              | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FIFO_empty | FIFO_full           | Statemachine<br>busy | Flash Status Register |   |   |   |   |   |   |   |   |
| 0x034 :<br>Flash<br>Memory<br>Address<br>Register      | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                     |                      |                       |   |   |   |   |   |   |   |   |
| 0x038 :<br>Flash<br>Data<br>FIFO<br>Register           | 256 Data Bytes in 64 DWords to/from Flash |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                     |                      |                       |   |   |   |   |   |   |   |   |
| 0x03C :<br>Flash<br>Clock<br>Divider<br>Register       | Multiples of 2 divide 38,4 MHz            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |                     |                      |                       |   |   |   |   |   |   |   |   |

| Register                                            | 31       | 30 | 29 | 28 | 27  | 26       | 25       | 24 | 23  | 22       | 21       | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6        | 5   | 4        | 3                                                          | 2                  | 1 | 0 |
|-----------------------------------------------------|----------|----|----|----|-----|----------|----------|----|-----|----------|----------|----|----|----|----|----|----|----|------------|------------|------------|------------|------------|------------|------------|----------|-----|----------|------------------------------------------------------------|--------------------|---|---|
| 0x100:<br>DAC<br>Control<br>Register                | Reserved |    |    |    |     |          |          |    |     |          |          |    |    |    |    |    |    |    | 0: Current | Reserved | DAC | Reserved | DAC<br>data<br>source<br>(0<br>intern,<br>1 DSP<br>stream) | Start<br>Stop      |   |   |
| 0x104:<br>Trigger<br>select* for<br>Stim MEM<br>FSM | Reserved |    |    |    |     | Mem      | Reserved |    |     | Mem      | Reserved |    |    |    |    |    |    |    |            |            |            | Mem 3      | Reserved   | Reserved   | Mem 1      |          |     |          |                                                            |                    |   |   |
| 0x108:<br>Trigger<br>select* for<br>Stim MEM<br>FSM | Reserved |    |    |    | Mem | Reserved |          |    | Mem | Reserved |          |    |    |    |    |    |    |    |            |            | Mem 4      | Reserved   | Reserved   | Mem 2      |            |          |     |          |                                                            |                    |   |   |
| 0x10C:<br>Stop<br>Trigger<br>Register               | Reserved |    |    |    |     |          |          |    |     |          |          |    |    |    |    |    |    |    |            |            |            |            |            |            |            |          |     |          |                                                            | Stop Trigger 3-2-1 |   |   |

|                                                  |          |                                                                                                |          |                     |
|--------------------------------------------------|----------|------------------------------------------------------------------------------------------------|----------|---------------------|
| 0x110:<br>Trigger<br>conf.<br>Register**         | Reserved |                                                                                                |          | Trigger 1           |
| 0x114:<br>Trigger<br>conf.<br>Register**         | Reserved |                                                                                                |          | Trigger 2           |
| 0x118:<br>Trigger<br>conf.<br>Register**         | Reserved |                                                                                                |          | Trigger 3           |
| 0x11C:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x120:<br>Electrode<br>Mode                      | Reserved | Electrode 15 - 1 (Manual mode: 11 / Automatic mode: 00 , other bit combinations are reserved ) |          |                     |
| 0x124:<br>Electrode<br>Mode                      | Reserved | Electrode 30 - 16                                                                              |          |                     |
| 0x128:<br>Electrode<br>Mode                      | Reserved | Electrode 45 - 31                                                                              |          |                     |
| 0x12C:<br>Electrode<br>Mode                      | Reserved | Electrode 60 - 46                                                                              |          |                     |
| 0x130:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x134:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x138:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x13C:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x140:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x144:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x148:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x14C:<br>Reserved                               | Reserved |                                                                                                |          |                     |
| 0x150:<br>Electr.<br>conf. ID<br>CTRL f.<br>Auto | Reserved | Electrode<br>configuration<br>source<br>0:int/1:ext                                            | Reserved | Electrode Config ID |



|                                        |           |
|----------------------------------------|-----------|
| 0x190:<br>Repeat<br>Trigger #<br>times | Trigger 1 |
| 0x194:<br>Repeat<br>Trigger #<br>times | Trigger 2 |
| 0x198:<br>Repeat<br>Trigger #<br>times | Trigger 3 |
| 0x19C:<br>Reserved                     | Reserved  |
| 0x1A0:<br>Repeat<br>times<br>counter   | Trigger 1 |
| 0x1A4:<br>Repeat<br>times<br>counter   | Trigger 2 |
| 0x1A8:<br>Repeat<br>times<br>counter   | Trigger 3 |
| 0x1AC:<br>Reserved                     | Reserved  |
| 0x1B0:<br>Read Ptr.<br>Cur. pos.       | Stim 1    |
| 0x1B4:<br>Read Ptr.<br>Cur. pos.       | Stim 2    |
| 0x1B8:<br>Read Ptr.<br>Cur. pos.       | Stim 3    |
| 0x1BC:<br>Read Ptr.<br>Cur. pos.       | Stim 4    |
| 0x1C0:<br>Read Ptr.<br>Cur. pos.       | Stim 5    |
| 0x1C4:<br>Read Ptr.<br>Cur. pos.       | Stim 6    |
| 0x1C8:<br>Read Ptr.<br>Cur. pos.       | Stim 7    |

|                                             |          |       |       |       |          |       |       |       |
|---------------------------------------------|----------|-------|-------|-------|----------|-------|-------|-------|
| 0x1CC:<br>Read Ptr.<br>Cur. pos.            | Stim 8   |       |       |       |          |       |       |       |
| 0x1D0:<br>DAC Data<br>Source<br>select***** | Reserved | DAC F | DAC D | DAC B | Reserved | DAC E | DAC C | DAC A |
| 0x1D4:<br>SBS Data<br>Source<br>select***** | Reserved |       |       |       |          | SBS 3 | SBS 2 | SBS 1 |
| 0x1E0:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC A |          |       |       |       |
| 0x1E4:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC C |          |       |       |       |
| 0x1E8:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC E |          |       |       |       |
| 0x1F0:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC B |          |       |       |       |
| 0x1F4:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC D |          |       |       |       |
| 0x1F8:<br>DAC<br>Weighting<br>Factor        | Reserved |       |       | DAC F |          |       |       |       |

SBS: Side Band Signal \*Decoding Table:

```

00: Trigger 1
01: Trigger 2
10: Trigger 3
11: Reserved

```

\*\*Decoding Table:

```

Bit 0: Enable Trigger: not Armed -> Armed
Bit 3:1:
    0: Stop stimulus sequence at recurring of same trigger event
    1: Restart stimulus sequence at recurring of same trigger event
    2: Ignore same trigger and continue processing
    3: Gate stimulus sequence at trigger event
Bit 5:4:
    0: Stop stimulus sequence at occurring of other trigger event

```

1: Restart stimulus sequence at occurring of other trigger event  
2: Ignore other trigger and continue processing  
bit 7-6: Status of Trigger statemachine (00: not Armed, 01: Armed, 10: Triggered (running), 11: Reserved)

### \*\*\* Decoding Table:

00: SBS 1  
01: SBS 2  
10: SBS 3  
11: Reserved, not Valid

\*\*\*\* Decoding Table:

00: GND  
01: DAC A/B  
10: DAC C/D  
11: DAC E/F

\*\*\*\*\* Decoding Table:

```
0000: Stimmulus 1 Data Stream  
0001: Stimmulus 2 Data Stream  
0010: Stimmulus 3 Data Stream  
0011: Stimmulus 4 Data Stream  
0100: Stimmulus 5 Data Stream  
0101: Stimmulus 6 Data Stream  
0110: Stimmulus 7 Data Stream  
0111: Stimmulus 8 Data Stream
```

|                                      |                                                                               |                   |
|--------------------------------------|-------------------------------------------------------------------------------|-------------------|
| 0x220:<br>MEM<br>Control<br>Stim 2   | Reserved                                                                      | Segment Selector* |
| 0x224:<br>Start<br>Pointer<br>Stim 2 | Memory Pointer (SBS 1 select this Data source in reg. 0x1D4 by default)       |                   |
| 0x228:<br>End<br>Pointer<br>Stim 2   | Memory Pointer                                                                |                   |
| 0x22C:<br>Write<br>Pointer<br>Stim 2 | Memory Pointer, write will clear Channel                                      |                   |
| 0x230:<br>Read<br>Pointer<br>Stim 2  | Memory Pointer                                                                |                   |
| 0x240:<br>MEM<br>Control<br>Stim 3   | Reserved                                                                      | Segment Selector* |
| 0x244:<br>Start<br>Pointer<br>Stim 3 | Memory Pointer (DAC C and D select this Data source in reg. 0x1D0 by default) |                   |
| 0x248:<br>End<br>Pointer<br>Stim 3   | Memory Pointer                                                                |                   |
| 0x24C:<br>Write<br>Pointer<br>Stim 3 | Memory Pointer, write will clear Channel                                      |                   |
| 0x250:<br>Read<br>Pointer<br>Stim 3  | Memory Pointer                                                                |                   |
| 0x260:<br>MEM<br>Control<br>Stim 4   | Reserved                                                                      | Segment Selector* |
| 0x264:<br>Start<br>Pointer<br>Stim 4 | Memory Pointer (SBS 2 select this Data source in reg. 0x1D4 by default)       |                   |
| 0x268:<br>End<br>Pointer<br>Stim 4   | Memory Pointer                                                                |                   |

|                                      |                                                                               |                   |
|--------------------------------------|-------------------------------------------------------------------------------|-------------------|
| 0x26C:<br>Write<br>Pointer<br>Stim 4 | Memory Pointer, write will clear Channel                                      |                   |
| 0x270:<br>Read<br>Pointer<br>Stim 4  | Memory Pointer                                                                |                   |
| 0x280:<br>MEM<br>Control<br>Stim 5   | Reserved                                                                      | Segment Selector* |
| 0x284:<br>Start<br>Pointer<br>Stim 5 | Memory Pointer (DAC E and F select this Data source in reg. 0x1D0 by default) |                   |
| 0x288:<br>End<br>Pointer<br>Stim 5   | Memory Pointer                                                                |                   |
| 0x28C:<br>Write<br>Pointer<br>Stim 5 | Memory Pointer, write will clear Channel                                      |                   |
| 0x290:<br>Read<br>Pointer<br>Stim 5  | Memory Pointer                                                                |                   |
| 0x2A0:<br>MEM<br>Control<br>Stim 6   | Reserved                                                                      | Segment Selector* |
| 0x2A4:<br>Start<br>Pointer<br>Stim 6 | Memory Pointer (SBS 3 select this Data source in reg. 0x1D4 by default)       |                   |
| 0x2A8:<br>End<br>Pointer<br>Stim 6   | Memory Pointer                                                                |                   |
| 0x2AC:<br>Write<br>Pointer<br>Stim 6 | Memory Pointer, write will clear Channel                                      |                   |
| 0x2B0:<br>Read<br>Pointer<br>Stim 6  | Memory Pointer                                                                |                   |
| 0x2C0:<br>MEM<br>Control<br>Stim 7   | Reserved                                                                      | Segment Selector* |

|                                      |                                          |                   |
|--------------------------------------|------------------------------------------|-------------------|
| 0x2C4:<br>Start<br>Pointer<br>Stim 7 | Memory Pointer (unused by default)       |                   |
| 0x2C8:<br>End<br>Pointer<br>Stim 7   | Memory Pointer                           |                   |
| 0x2CC:<br>Write<br>Pointer<br>Stim 7 | Memory Pointer, write will clear Channel |                   |
| 0x2D0:<br>Read<br>Pointer<br>Stim 7  | Memory Pointer                           |                   |
| 0x2E0:<br>MEM<br>Control<br>Stim 8   | Reserved                                 | Segment Selector* |
| 0x2E4:<br>Start<br>Pointer<br>Stim 8 | Memory Pointer (unused by default)       |                   |
| 0x2E8:<br>End<br>Pointer<br>Stim 8   | Memory Pointer                           |                   |
| 0x2EC:<br>Write<br>Pointer<br>Stim 8 | Memory Pointer, write will clear Channel |                   |
| 0x2F0:<br>Read<br>Pointer<br>Stim 8  | Memory Pointer                           |                   |

\*Segments:

Segment 0 to 255 reflect the Segment ID 0 to 255 of Trigger

\*\*Initialisation:

Poll Bit after writing a '1' until it is '0' to wait on end of request!



|                                                        |          |                                                                      |                            |                          |          |                   |
|--------------------------------------------------------|----------|----------------------------------------------------------------------|----------------------------|--------------------------|----------|-------------------|
| 0x414:<br>First<br>Fail<br>Address<br>Ptr.<br>Register | Reserved | Reflects the address Pointer of the first failed address of mem test |                            |                          |          |                   |
| 0x420:<br>MEM<br>Status<br>Register                    | Reserved |                                                                      | MEM<br>cal<br>done<br>(RO) | selfref.<br>mode<br>(RO) | Reserved | selfref.<br>enter |

\* Pattermode options:

- 0: Counter
- 1: Pattern
- 2: Shift Pattern right
- 3: Shift Pattern left
- 4: Toggle Pattern after every write

| Register                                    | Byte 4                         | Byte 3 | Byte 2 | Byte 1 |
|---------------------------------------------|--------------------------------|--------|--------|--------|
| 0xF00: MEM Write Address Register           | MEM Address(RW)                |        |        |        |
| 0xF04: MEM Data Register                    | Write Data (WO), Read Data(RO) |        |        |        |
| 0xF08 - 0xF1C: Reserved                     | Reserved                       |        |        |        |
| 0xF20: Write Stim 1 Data Register           | Channel 0 Data Vector*         |        |        |        |
| 0xF24: Write Stim 2 Data Register           | Channel 1 Data Vector*         |        |        |        |
| 0xF28: Write Stim 3 Data Register           | Channel 2 Data Vector*         |        |        |        |
| 0xF2C: Write Stim 4 Data Register           | Channel 3 Data Vector*         |        |        |        |
| 0xF30: Write Stim 5 Data Register           | Channel 4 Data Vector*         |        |        |        |
| 0xF34: Write Stim 6 Data Register           | Channel 5 Data Vector*         |        |        |        |
| 0xF38: Write Stim 7 Data Register           | Channel 6 Data Vector*         |        |        |        |
| 0xF3C: Write Stim 8 Data Register           | Channel 7 Data Vector*         |        |        |        |
| 0xF40: Clear and Write Stim 1 Data Register | Channel 0 Data Vector*         |        |        |        |
| 0xF44: Clear and Write Stim 2 Data Register | Channel 1 Data Vector*         |        |        |        |
| 0xF48: Clear and Write Stim 3 Data Register | Channel 2 Data Vector*         |        |        |        |
| 0xF4C: Clear and Write Stim 4 Data Register | Channel 3 Data Vector*         |        |        |        |
| 0xF50: Clear and Write Stim 5 Data Register | Channel 4 Data Vector*         |        |        |        |
| 0xF54: Clear and Write Stim 6 Data Register | Channel 5 Data Vector*         |        |        |        |
| 0xF58: Clear and Write Stim 7 Data Register | Channel 6 Data Vector*         |        |        |        |
| 0xF5C: Clear and Write Stim 8 Data Register | Channel 7 Data Vector*         |        |        |        |

**Sideband Data:**

Bit 0: Amplifier Protection Switch on Headstage/Blanking  
 Bit 3: Stimulation Switch  
 Bit 4: Stimulus Selector

**\*Data Vector decoding:**

Bit 31: Reserved  
 Bit 30 – 28:  
   000: DAC/SBS Data Vector  
   001: Loopptr. Vector  
   010: Long Loop Ptr. Vector  
   011: Long Loop Ctr. Vector  
   100: Reserved  
   ...  
   110: Reserved  
   111: END Command

**DAC/SBS Data Vector(000):**

Bit 27: Reserved  
 Bit 26: Repeat Timebase (0: 20 us, 1: 1000\*20us)  
 Bit 25 – 16: Number of Repeats (0: Pattern is used 1x Timebase; 1: Pattern is used for 2x Timebase; ...)  
 Bit 15 – 0 : DAC data value (unsigned 16 bit value, 0x8000 is zero level) / SBS data value

|              |   |                                      |
|--------------|---|--------------------------------------|
| SBS Bit 0    | : | Amplifier Protection Switch/Blanking |
| SBS Bit 3    | : | Stimulation Switch                   |
| SBS Bit 4    | : | Stimulus Select                      |
| SBS Bit 8-15 | : | Electrode Config ID                  |

Loop Ptr. Vector(001):

Bit 27 - 26: Loop Level

Bit 25 - 16: Number of Repeats (2: Vectors are repeated once, thus used twice)

Bit 15 - 0 : Address Offset (Number of Vectors to jump backward, 1: One Vector before the LoopPtr is repeated)

Long Loop Ptr. Vector(010):

Bit 27 - 0 : Address Offset (Number of Vectors to jump backward)

Long Loop Ctr. Vector(011):

Bit 27 - 0 : Number of Repeats

End Command(111):

Bit 27 - 0 : Reserved

## HS <-> STG interconnection (bits 32-0)

| Pin | Name  | Bit | HS FPGA Pin | Function             | to FPGA: STG FPGA Pin |
|-----|-------|-----|-------------|----------------------|-----------------------|
| 3   | STG01 | 0   | V1          | Reset                | X2                    |
| 4   | STG02 | 1   | V2          | Suspend              | X2                    |
| 5   | STG03 | 2   | T3          | Reserved             | X2                    |
| 6   | STG04 | 3   | U1          | Reserved             | X2                    |
| 7   | STG05 | 4   | T1          | Reserved             | X2                    |
| 8   | STG06 | 5   | V3          | Reserved             | X2                    |
| 9   | STG07 | 6   | P3          | Reserved             | X2                    |
| 10  | STG08 | 7   | R1          | Blanking             | X2                    |
| 11  | STG09 | 8   | V3          | 50 kHz Impulse       | X2                    |
| 12  | STG10 | 9   | W1          | SPI: read data ready | X2                    |
| 13  | STG11 | 10  | Y1          | SPI: SCLK            | X2                    |
| 14  | STG12 | 11  | Y2          | SPI: CS              | X2                    |
| 15  | STG13 | 12  | W3          | SPI: MOSI            | X2                    |
| 16  | STG14 | 13  | AA1         | SPI: MISO            | X2                    |
| 17  | STG15 | 14  | AA2         | 25.6 MHz clock       | X1,X2                 |
| 18  | STG16 | 15  | Y3          | 400 kHz Power sync.  | X1,X2                 |
| 19  | STG17 | 16  | H6          | 400 kHz Power sync.  | X1,X2                 |
| 20  | STG18 | 17  | H4          | 38.4 MHz clock       | X1,X2                 |
| 21  | STG19 | 18  | G3          | Reset                | X1                    |
| 22  | STG20 | 19  | H8          | Suspend              | X1                    |
| 23  | STG21 | 20  | G6          | Reserved             | X1                    |

|    |       |    |    |                      |    |
|----|-------|----|----|----------------------|----|
| 24 | STG22 | 21 | G4 | Reserved             | X1 |
| 25 | STG23 | 22 | F5 | Reserved             | X1 |
| 26 | STG24 | 23 | G7 | Reserved             | X1 |
| 27 | STG25 | 24 | H5 | Reserved             | X1 |
| 28 | STG26 | 25 | J7 | Blanking             | X1 |
| 29 | STG27 | 26 | J3 | 50 kHz               | X1 |
| 30 | STG28 | 27 | J4 | SPI: read data ready | X1 |
| 31 | STG29 | 28 | J6 | SPI: SCLK            | X1 |
| 32 | STG30 | 29 | K4 | SPI: CS              | X1 |
| 33 | STG31 | 30 | K5 | SPI: MOSI            | X1 |
| 34 | STG32 | 31 | K6 | SPI: MISO            | X1 |

## Quellen nachweise

[1] <http://www.ti.com/product/tms320c6454>

# Quelle(n) und Bearbeiter des/der Artikel(s)

MEA2100 User Guide *Quelle:* <http://wiki.mcs.de.com/index.php?oldid=24618> *Bearbeiter:* Jesinger, Kurnoth, 412 anonyme Bearbeitungen

## Quelle(n), Lizenz(en) und Autor(en) des Bildes

**Image:MEA2100\_Overview.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_Overview.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_Overview.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MEA2100\_OverviewDetail.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_OverviewDetail.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_OverviewDetail.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MEA2100\_DataStream\_noDSP.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_DataStream\\_noDSP.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_DataStream_noDSP.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger

**Image:MEA2100\_DataStream\_withDSP.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_DataStream\\_withDSP.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_DataStream_withDSP.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger

**Image:MEA2100\_StimulationBlanking.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_StimulationBlanking.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_StimulationBlanking.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:Memmory Layout.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:Memmory\\_Layout.png](http://wiki.mcs.de.com/index.php?title=Datei:Memmory_Layout.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MEA2100\_Blanking.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_Blanking.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_Blanking.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:STG\_Mux\_Stimswtich\_control.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:STG\\_Mux\\_Stimswtich\\_control.png](http://wiki.mcs.de.com/index.php?title=Datei:STG_Mux_Stimswtich_control.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:STG\_Config\_Overview.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:STG\\_Config\\_Overview.png](http://wiki.mcs.de.com/index.php?title=Datei:STG_Config_Overview.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MEA2100\_Interface Board HS1\_1.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_Interface\\_Board\\_HS1\\_1.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_Interface_Board_HS1_1.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MEA2100\_Interface Board direct streaming mode.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MEA2100\\_Interface\\_Board\\_direct\\_streaming\\_mode.png](http://wiki.mcs.de.com/index.php?title=Datei:MEA2100_Interface_Board_direct_streaming_mode.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_Digital\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_Digital\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_Digital_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_Filter\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_Filter\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_Filter_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_initial\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_initial\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_initial_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_Interfaceboard\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_Interfaceboard\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_Interfaceboard_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_Headstage\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_Headstage\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_Headstage_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_STG\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_STG\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_STG_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth

**Image:MCS\_USB\_Update\_MEA2100\_STGMEM\_screen.png** *Quelle:* [http://wiki.mcs.de.com/index.php?title=Datei:MCS\\_USB\\_Update\\_MEA2100\\_STGMEM\\_screen.png](http://wiki.mcs.de.com/index.php?title=Datei:MCS_USB_Update_MEA2100_STGMEM_screen.png) *Lizenz:* unbekannt *Bearbeiter:* Jesinger, Kurnoth