DUNE WIB registers

## A. Madorsky, UF

DRAFT, 2021-03-17

Access to all modules in WIB firmware is provided via standard ZYNQ AXI bus interface.

List of currently implemented and planned modules with AXI registers is shown below. Note that this list may be expanded in the future.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Base address, hex** | **Module type** | **FEMB**  **#** | **COLDATA**  **chip #** | **Description** |
| A0030000 | coldata\_fast\_cmd | All | All | COLDATA FAST command generator for all COLDATA chips |
| A0010000 | coldata\_i2c | 0 | 0 | I2C interface for COLDATA chip |
| A0040000 | coldata\_i2c | 0 | 1 | I2C interface for COLDATA chip |
| A0050000 | coldata\_i2c | 1 | 0 | I2C interface for COLDATA chip |
| A0060000 | coldata\_i2c | 1 | 1 | I2C interface for COLDATA chip |
| A0070000 | coldata\_i2c | 2 | 0 | I2C interface for COLDATA chip |
| A0080000 | coldata\_i2c | 2 | 1 | I2C interface for COLDATA chip |
| A0090000 | coldata\_i2c | 3 | 0 | I2C interface for COLDATA chip |
| A00A0000 | coldata\_i2c | 3 | 1 | I2C interface for COLDATA chip |
| A00B0000 | axi\_iic | n/a | n/a | I2C interface for WIB on-board devices |
| A00C0000 | Register bank | n/a | n/a | Control and status registers |
| n/a | Timing endpoint | n/a | n/a | Timing endpoint, programmed via control register |
| A0100000 | DAQ spy memory | 0,1 | All | 1MB DAQ spy memory for FEMBs 0,1. Capable of recording DAQ output data sent to FELIX. |
| A0200000 | DAQ spy memory | 2,3 | All | 1MB DAQ spy memory for FEMBs 2,3. Capable of recording DAQ output data sent to FELIX. |

Table . WIB firmware modules and their base addresses

All registers are 32 bits wide.

Sections below contain details of the registers of each module.

# COLDATA I2C interface

Register list is shown below. Note that there are 8 such modules, so the register addresses are shown as offsets from the base address of each unit. See base addresses in Table 1.

|  |  |  |
| --- | --- | --- |
| **Offset, hex**  **Relative to base** | **Register name** | **Description** |
| 0 | start\_transfer | Writing 1 into this register starts I2C transfer programmed into addr\_data register. Write 0 immediately after writing 1. |
| 4 | addr\_data | Combined address and data register. See format description below. |

Table . I2C interface registers

Format of addr\_data register is shown below:

|  |  |
| --- | --- |
| **Bits** | **Function** |
| 31:27 | Unused |
| 26:23 | Chip address |
| 22:20 | Register page address |
| 19 | Read = 1, write = 0 |
| 18 | Placeholder for Acknowledge bit (ACK) |
| 17:10 | Register address |
| 9 | Placeholder for Acknowledge bit (ACK) |
| 8:1 | Write operation: data to write to register, Read operation: data read from register |
| 0 | Placeholder for Acknowledge bit (ACK) |

Table . Format of addr\_data register

### How to use I2C interface:

Write operation:

1. Write the parameters into addr\_data register as needed. Leave ACK bit placeholders = 0
2. Set start\_transfer register to 1, then immediately set it to 0
3. Wait for 60 uS or longer before attempting the next transfer

Read operation:

1. Write the parameters into addr\_data register as needed. Leave ACK bit placeholders = 0
2. Set start\_transfer register to 1, then immediately set it to 0
3. Wait for 60 uS or longer
4. Read addr\_data register back. Bits 8:1 in that register contain data that were read from the register. Bits 0, 9, and 18 should contain values of 1 in each. These are recorded states of ACK bits, received after transfer of each of 3 bytes.

Note that two COLDATA I2C interfaces that serve the same FEMB are sharing clock lines. That means that you can use only one of these interfaces at any given time. Example:

* Program I2C interface for FEMB #0 COLDATA #0 to read or write a register
* You can use I2C interfaces for FEMB #1,2,3 at this time, don’t have to wait until transaction in step 1 is finished.
* However, to use any of the I2C interfaces for FEMB #0 for the next transaction, wait for 60 uS or more until the transaction in step 1 is finished

### COLDATA v1 I2C bugs:

**Bug #1** leads to missing ACK bits after first byte in certain conditions. That ACK bit is recorded in bit 18. It should be ignored.

**Bug #2** leads to incorrect latching of the chip ID inside COLDATA. Workaround: When trying to read/write any register in COLDATA or any of the COLDADC chips, first issue **two** read commands to that chip, any register. Then proceed to read/write registers that you actually intended to access. Issuing two read commands is only necessary when switching from one chip to another.

# COLDATA FAST command generator

Register list:

|  |  |  |
| --- | --- | --- |
| **Address, hex** | **Register name** | **Description** |
| A0030000 | fast\_cmd\_code | Writing a command code into this register immediately generates the corresponding FAST command. See the list of valid command codes below. Command codes **cannot** be combined using OR operation; only one command at a time can be issued. Invalid command codes are ignored. |
| A0030004 | edge\_to\_act\_delay | Delay between EDGE and ACT command for correct COLDADC reset procedure. Write a value of 19 into this register. |

Table . FAST command generator registers

FAST command codes:

|  |  |  |
| --- | --- | --- |
| **Command code, bin** | **Command name** | **Description** |
| 000001 | RESET | COLDATA chip reset |
| 000010 | ACT | Performs command stored in ACT command register |
| 000100 | SYNC | Zero time stamp |
| 001000 | EDGE | Move edge of 2 MHz clock to next rising edge of 64 MHz clock |
| 010000 | IDLE | No description for this command in COLDATA datasheet, need to check with COLDATA team |
| 100000 | EDGE\_ACT | COLDADC rev 1 requires the following reset procedure:  First EDGE command, then after a delay, ACT command programmed as COLDADC reset. COLDADC reset must end (rise) between 62.5 and 125 ns after 2M clock rising edge. This command code makes FAST command unit to issue EDGE and ACT commands with precise timing needed for correct reset procedure. Note that before using this command, ACT command must be programmed with FASTACT\_COLDADC\_RESET\_COMMAND code. |

Table . FAST command codes

### How to use FAST command generator:

1. If you are intending to use ACT command, first program the desired ACT command into COLDATA “ACTCOMMANDREG” register via I2C.
2. If you are intending to use EDGE\_ACT command, first program COLDATA “ACTCOMMANDREG” register with FASTACT\_COLDADC\_RESET\_COMMAND code (via I2C), and WIB edge\_to\_act\_delay register with the value of 19.
3. Write command code into fast\_cmd\_code. The command will be immediately executed.

# I2C interface for WIB on-board devices

This is a standard Xilinx IIC module. It’s connected via a multiplexer to all on-board devices that require I2C programming. Please use the driver provided by Xilinx to talk to this module.

Before accessing a particular device, please make sure to select it by using i2c\_select control register. See “Control and status registers” section below for details.

# Control and status registers

WIB firmware implements 32 control registers and 32 status registers. Each register is 32-bit wide. Control registers are readable and writable; status registers are read-only.

Control registers (read/write) are listed below:

|  |  |  |  |
| --- | --- | --- | --- |
| **Address, hex** | **Bits in register** | **Parameter name** | **Description** |
| A00C0000 | 7:0 | ts\_addr | Timing point address |
| A00C0000 | 9:8 | ts\_tgrp | Timing point group code |
| A00C0004 | 3:0 | i2c\_select | On-board I2C bus selector. Devices are selected according to the table below:   |  |  | | --- | --- | | **Value** | **Selected device** | | 0 | SI5344 | | 1 | SI5342 | | 2 | QSFP | | 3 | PL\_FEMB\_PWR | | 4 | PL\_FEMB\_EN | | 5 | SENSOR\_I2C | | 6 | PL\_FEMB\_PWR2 | | 7 | LTC2977 | | 8 | PL\_FEMB\_PWR3 | | 9 | FLASH | | 10 | ADN2814 | |
| A00C0004 | 4 | fp\_sfp\_sel | P15 SFP connection selector 0=CDR 1=GTH (schematic page 14) |
| A00C0004 | 5 | rx\_timing\_sel | U1 input selector 0=backplane 1=SFP (schematic page 15) |
| A00C0004 | 6 | daq\_spy\_reset[0] | DAQ spy FSM reset for FELIX link 0, FEMB 0,1 |
| A00C0004 | 7 | daq\_spy\_reset[1] | DAQ spy FSM reset for FELIX link 1, FEMB 2,3 |
| A00C0004 | 11:8 | PRBS selection | PRBS pattern selection for COLDATA RX links   |  |  | | --- | --- | | **Value** | **Pattern** | | 0 | Normal operation | | 1 | PRBS-7 | |
| A00C0004 | 12 | fb\_reset | Frame builder reset. Write 1 then 0 to reset. |
| A00C0004 | 13 | coldata\_rx\_reset | Reset of the serial receivers. Write 1 then 0 to reset. |
| A00C0008 | 15:0 | link\_mask | There are 16 input serial links, 4 per FEMB. The link\_mask bits, when set to 1, are telling firmware that the corresponding serial link is not working. These bits are also passed in the DAQ data header [1], so the unpacker knows which data to ignore. The bit assignment is shown below:   |  |  |  | | --- | --- | --- | | **Link\_mask bit** | **FEMB** | **Link** | | 0 | 0 | 0 | | 1 | 0 | 1 | | 2 | 0 | 2 | | 3 | 0 | 3 | | 4 | 1 | 0 | | 5 | 1 | 1 | | 6 | 1 | 2 | | 7 | 1 | 3 | | 8 | 2 | 0 | | 9 | 2 | 1 | | 10 | 2 | 2 | | 11 | 2 | 3 | | 12 | 3 | 0 | | 13 | 3 | 1 | | 14 | 3 | 2 | | 15 | 3 | 3 | |
| A00C000C | 0 | ts\_edge\_sel | Timing endpoint clock edge selector |
| A00C000C | 1 | fake\_time\_stamp\_en | Enable fake time stamp. Fake time stamp is generated by a local firmware counter and replaces the timing endpoint time stamp. |
| A00C0010 | 7:0 | cmd\_code\_idle | Timing system command code for IDLE |
| A00C0010 | 15:8 | cmd\_code\_edge | Timing system command code for EDGE |
| A00C0010 | 23:16 | cmd\_code\_sync | Timing system command code for SYNC |
| A00C0010 | 31:24 | cmd\_code\_act | Timing system command code for ACT |
| A00C0014 | 7:0 | cmd\_code\_reset | Timing system command code for RESET |
| A00C0014 | 15:8 | cmd\_code\_adc\_reset | Timing system command code for ADC RESET |
| A00C0014 | 23:16 | cmd\_code\_trigger | Timing system command code for Trigger |
| A00C0018 | 31:0 | fake\_time\_stamp\_init[31:0] | Initial value for fake time stamp, bits 31:0 |
| A00C001C | 31:0 | fake\_time\_stamp\_init[63:32] | Initial value for fake time stamp, bits 63:32 |
| A00C0020 | 0 | fake\_daq\_stream | Enables sending fake data to FELIX even without FEMBs attached. |
| A00C0024 | 17:0 | spy\_rec\_time | Spy ring buffer recording time, in 32-bit words, based on FELIX fabric clock, 240.48MHz |

Table . Control registers

**How to set initial value for fake time stamp (FTS):**

1. Disable FTS by setting **fake\_time\_stamp\_en = 0**
2. Write the new initial value into **fake\_time\_stamp\_init** register
3. Enable FTS by setting **fake\_time\_stamp\_en = 1**

**How to use Timing system command codes:**

Each of the FAST commands, including the 2MHz clock sync command, can be triggered by a timing system command sent from TLU. The exact codes of TLU commands corresponding to each FAST command are programmable using the following registers:

* **cmd\_code\_idle**
* **cmd\_code\_edge**
* **cmd\_code\_sync**
* **cmd\_code\_act**
* **cmd\_code\_reset**
* **cmd\_code\_adc\_reset**
* **cmd\_code\_trigger**

These registers support 8-bit command codes. However, the current timing endpoint has 4-bit commands, so only 4 lower bits are used in each of the registers at this time. Default for all of them is 0, which is considered invalid. Unless reprogrammed to non-zero value, the corresponding command is disabled.

Status registers (read-only):

|  |  |  |  |
| --- | --- | --- | --- |
| **Address, hex** | **Bits in register** | **Parameter name** | **Description** |
| A00C0080 | 0 | daq\_spy\_full[0] | “full” flag for DAQ spy memory, FELIX link 0, FEMB 0,1 |
| A00C0080 | 1 | daq\_spy\_full[1] | “full” flag for DAQ spy memory, FELIX link 1, FEMB 2,3 |
| A00C0084 | 15:0 | rxprbserr | PRBS error detection bits, one for each of the 16 input serial links. |
| A00C0088 | 5:0 | fw\_second | Firmware generation time stamp, second |
| A00C0088 | 11:6 | fw\_minute | Firmware generation time stamp, minute |
| A00C0088 | 16:12 | fw\_hour | Firmware generation time stamp, hour |
| A00C0088 | 22:17 | fw\_year | Firmware generation time stamp, year - 2000 |
| A00C0088 | 26:23 | fw\_month | Firmware generation time stamp, month |
| A00C0088 | 31:27 | fw\_day | Firmware generation time stamp, day |
| A00C008c | 3:0 | bp\_slot\_addr | Slot address read from the crate backplane |
| A00C008c | 7:4 | bp\_crate\_addr | Crate address read from the crate backplane |
| A00C0090 | 3:0 | ts\_stat | ts\_stat signal from timing endpoint |
| A00C0090 | 4 | ts\_rst | ts\_rst signal from timing endpoint |
| A00C0090 | 8 | ts\_rdy | ts\_rdy signal from timing endpoint |
| A00C0090 | 15:12 | ts\_sync | ts\_sync signal from timing endpoint |
| A00C0090 | 16 | ts\_sync\_v | ts\_sync\_v signal from timing endpoint |
| A00C0090 | 17 | adn2814\_lol | LOL signal from CDR |
| A00C0090 | 18 | and2814\_los | LOS signal from CDR |
| A00C0090 | 27:20 | 0xff | fixed pattern |
| A00C0094 | 19:0 | spy\_addr [0] | Current memory address for spy memory 0, in bytes |
| A00C0098 | 19:0 | spy\_addr [1] | Current memory address for spy memory 1, in bytes |
| A00C00A0 | 31:0 | ts\_tstamp[31:0] | Timing point time stamp bits 31:0 |
| A00C00B0 | 63:32 | ts\_tstamp[63:32] | Timing point time stamp bits 63:32 |
| A00C00bc | 31:0 | test\_pattern | Hardwired value = 0xbabeface |

Table . Status registers

# Timing Endpoint

This is a timing endpoint module. The only parameters that need programming are Address and Group codes. These parameters are programmed via control registers. See **ts\_addr** and **ts\_tgrp** registers in Control and Status registers section above for details.

# DAQ spy memory

There are two independent DAQ spy memory modules, one for FELIX link 0 (FEMBs 0,1), another for FELIX link 1 (FEMBs 2,3). Each memory unit is 1MB in size. They operate in 32-bit words, so the size is 256K 32-bit words. The spy memory controllers implement a “ring” buffer functionality. How to operate:

Preliminary steps:

* Program **cmd\_code\_trigger** register with the TLU command for external trigger
* Program **spy\_rec\_time** parameter with the number of 32-bit words to record after trigger. That number should be less or equal to **256K – trigger\_latency**. Trigger latency time here is represented in terms of FELIX fabric clock cycles, which is  
  **1 / 240.48 MHz = ~ 4.158 ns.**

Operation:

1. Disable external triggers
2. Reset the spy memory, by using **daq\_spy\_reset** bit. At the time of reset, the spy memory starts continuously recording data transmitted via FELIX links. The memory address overwraps at maximum address back to 0.
3. Wait for at least the trigger latency time or longer to let the memory record the data before trigger.
4. Enable or issue a trigger command. At the time of the trigger command, the spy memory will start counting words stored in it. It will store **spy\_rec\_time** 32-bit words, then stop recording, and set **daq\_spy\_full** bit to 1.
5. Wait until **daq\_spy\_full** bit from that module is set to 1.
6. Read out and store the entire memory array. The size of the array is 1 MB = 256K 32-bit words.
7. Read out the current spy memory address, from this register: **spy\_addr[N],** where **N = 0,1** is the spy memory/FELIX link number. This is the address where the recording stopped.
8. Calculate the address where you need to start decoding memory data:   
     
   **decoding\_start\_addr = spy\_addr[19:2]–spy\_rec\_time–trigger\_latency**  
     
   All arithmetic here is 18-bit, unsigned. The **decoding\_start\_addr** result overwraps to maximum value of **0x3ffff** if it goes below 0. The result represents the 32-bit word index.  
   Note that the resulting address may not necessarily point at the first word of a FELIX data block. Start searching from that address until you detect the SOF symbol.
9. Unpack the following number of 32-bit words:  
   **spy\_rec\_time + trigger\_latency**  
   rounded down to the FELIX frame size.
10. Go to step 1.

The data in the memory array are stored in the same DAQ format [1] as transmitted to FELIX. Each frame is 120 32-bit words in length. The K bits are not stored, so the format decoder should be using specific 32-bit data patterns at the beginning and end of each frame to decode the data (words 0, 118, 119 in [1]).

# WIB configuration sequence

This section has been removed since the actual sequence is now coded in wib\_server software. Will have to provide a description for it eventually.

# References

1. File “WIB-DAQ\_Format\_2021-02-18.xlsx” in git repository, doc directory.

# Revision table

|  |  |
| --- | --- |
| **Date** | **Changes** |
| 2020-07-23 | First draft. Will add more modules and registers as the design is progressing. |
| 2020-08-05 | Reworked table of implemented modules. Only one FAST command module is needed, since FAST command output is fanned out to all FEMBs in hardware |
| 2020-08-10 | Added more modules |
| 2020-10-10 | Added WIB configuration sequence, DAQ spy memory modules, DAQ spy memory control and status bits, control bits for clock selection. |
| 2020-10-19 | Added PRBS pattern selection and error detection, Frame Bulder reset bit. Moved coldata\_rx\_reset bit since it was conflicting with daq\_spy\_reset bits. Added description of DAQ spy memory modules. |
| 2020-10-30 | Added link\_mask register |
| 2021-02-05 | Added a lot of missing registers, removed configuration section |
| 2021-03-17 | Reworked the spy memory into ring buffer. Added corresponding control and status registers, and reworked instructions.  Added TLU time stamp reclocking FIFO, but this did not require changes in this document.  Replaced reference [1] with the updated document. |