OptoHybrid v3 Firmware

Thomas Lenzi ([thomas.lenzi@cern.ch)](mailto:thomas.lenzi@cern.ch))  
Andrew Peck ([andrew.peck@cern.ch)](mailto:andrew.peck@cern.ch))  
Evaldas Juska ([evaldas.juska@cern.ch](mailto:evaldas.juska@cern.ch))

August 21, 2017

This document describes how to interact with the OptoHybrid (OH) modules and how to parameterize and use the various functionalities integrated in the firmware.

# Contents

[Contents 1](#_Toc491090490)

[Introduction 3](#_Toc491090491)

[Hardware Description 4](#_Toc491090492)

[Clocking 5](#_Toc491090493)

[Synchronization 6](#_Toc491090494)

[Trigger Link Frame Sequencing 6](#_Toc491090495)

[TTC Monitoring 6](#_Toc491090496)

[GBT E-Link Deserialization 7](#_Toc491090497)

[In “16 bit” full-bandwidth mode 7](#_Toc491090498)

[In “10 bit” low-bandwidth mode 7](#_Toc491090499)

[GBT Packets (Full Bandwdith Mode) 8](#_Toc491090500)

[Transmit (FPGA to GBT) 8](#_Toc491090501)

[Receive (GBT to FPGA) 10](#_Toc491090502)

[GBT Packets in Low Bandwidth Mode 11](#_Toc491090503)

[Transmit (FPGA to GBT) 11](#_Toc491090504)

[Receive (GBT to FPGA) 12](#_Toc491090505)

[Trigger Algorithm 13](#_Toc491090506)

[Clock 1 13](#_Toc491090507)

[Clock 2 13](#_Toc491090508)

[Clock 3 14](#_Toc491090509)

[Clock 4 14](#_Toc491090510)

[Clock 5 15](#_Toc491090511)

[Clock 6 15](#_Toc491090512)

[Clock 7 15](#_Toc491090513)

[Clock 8 16](#_Toc491090514)

[Clock 9 16](#_Toc491090515)

[Clock 10 16](#_Toc491090516)

[Clock 11 16](#_Toc491090517)

[Clock 12 17](#_Toc491090518)

[Clock 13 17](#_Toc491090519)

[Clock 14 17](#_Toc491090520)

[Clock 16 17](#_Toc491090521)

[Cluster Packer Miscellany 19](#_Toc491090522)

[Synchronization Frame 19](#_Toc491090523)

[Cluster Counter 19](#_Toc491090524)

[LED Indicators 20](#_Toc491090525)

[Registers 21](#_Toc491090526)

[Loopback 22](#_Toc491090527)

[Addressing 22](#_Toc491090528)

[Errors 22](#_Toc491090529)

[Errors to avoid 22](#_Toc491090530)

[Counters 23](#_Toc491090531)

[Addressing 23](#_Toc491090532)

[System Registers 25](#_Toc491090533)

[Addressing 25](#_Toc491090534)

[Status Registers 26](#_Toc491090535)

[Addressing 26](#_Toc491090536)

[ADC 27](#_Toc491090537)

[Addressing 27](#_Toc491090538)

[Errors 27](#_Toc491090539)

[Errors to avoid 27](#_Toc491090540)

[History 28](#_Toc491090541)

# Introduction

# Hardware Description

# Clocking

# Synchronization

The primary purpose of the Optohybrid firmware is its role in the firmware. Integral to this role is the ability to synchronize each Optohybrid to a known phase.

Two provisions are implemented in the Optohybrid firmware to aid this.

### Trigger Link Frame Sequencing

In addition to the 56 bits of trigger data that are sent every bunch crossing, each fiber link also transmits an 8 bit frame delimiter which is used to align the frames into packets.

There are several frame markers which can be chosen, and we exploit this to provide information about the Optohybrid which will aid in synchronization.

During normal operation, the frame will follow a predictable cycle of 0xBC, 0xF7, 0xFB, 0xFD.

In this simplest form we can ensure crude synchronization between links and different chambers as well as monitoring the data integrity, by comparing the sequence to a local state machine in the backend electronics.

Two additional separators are used to mark special conditions:

1. **BC0:** the bunch crossing zero flag received from the GBTx is connected to the trigger link logic. When a BC0 (or equivalently BX0) is received the frame marker will be changed to 0x50.
2. **Overflow:** the trigger links are only capable of transmitting 8 clusters per bunch crossing. Hence there is a possibility for overflows to occur, wherein clusters are found by not transmitted. When this happens, the trigger link will change its frame separator to 0xFC.

### TTC Monitoring

The Optohybrid has a local accumulator which increments bunch crossing number (bxn) and produces a locally generated bx0 flag.

In order for the two flags, (1) locally generated and (2) received from GBTx, to be in sync a programmable parameter (bxn offset) is provided which allows you to set an “offset” which is the value which will be assumed by the bxn counter after ttc resync.

The synchronization of these two flags can be monitored by checking the status of bxn\_sync\_error in the OH status register (*n.b. that bx0\_sync\_error is NOT suitable for this, as it is a 1bx wide pulse useful for internal counters when the bx0 is received, while bxn\_sync\_error will persist for the entire orbit*).

When the Optohybrid is correctly timed in to the TTC system, bxn\_sync\_error should be 0. A software routine in the CTP-7 to find the correct bxn offset should be easily designed.

A counter in the counters module counts the number of bx0 sync errors since the last resync or hard-reset.

# GBT E-Link Deserialization

With the existence of two different communication modes corresponding yielding 16 bits/bx and 10 bits/bx (duplex) there will be two alternative assignments of which bits will be carried on which e-links.

In “16 bit” full-bandwidth mode:

We specify that one eLink (labelled in firmware as eLink0) be run at 320 MHz and carry the 8 least-significant bits of the packet. The other eLink (labelled in firmware as eLink1) will run at 320 MHz and carry the 8 most-significant bits.

i.e.

|  |  |  |
| --- | --- | --- |
|  | **E-link** | **Payload** |
| RX  (GBT to OH) | eLink1 | TTC[3:0],  data[11:8] |
| eLink0 | data[7:0] |
| TX  (OH to GBT) | eLink1 | data[15:8] |
| eLink0 | data[ 7:0] |

In “10 bit” low-bandwidth mode:

We specify that one eLink (labelled in firmware as eLink0) be run at 80 MHz and carry the 2 least-significant bits of the packet. The other eLink (labelled in firmware as eLink1) will run at 320 MHz and carry the 8 most-significant bits.

i.e.

|  |  |  |
| --- | --- | --- |
|  | **E-link** | **Payload** |
| RX  (GBT to OH) | eLink1 | TTC[3:0],  data[5:2] |
| eLink0 | data[1:0] |
| TX  (OH to GBT) | eLink1 | data[9:2] |
| eLink0 | data[1:0] |

Within each e-link, all bits are transmitted and most-significant bit first.

# GBT Packets (Full Bandwdith Mode)

In “Full Bandwidth Mode” the GBT to FPGA link consists of two 320 Mbps duplex links. In version 3a this was not implemented, and a separate functionality of 1x 320 Mbps duplex and 1x 80Mbps duplex was adopted. This alternative, “Low Bandwidth Mode” is covered in the next section.

### Transmit (FPGA to GBT)

Communication with the optohybrid in the direction of FPGA to GBT is accomplished with a simple 16 bit packet format.

A valid packet is three frames long and will consist of the 16 bit frame marker BCBC followed by two 16 bit data frames:

|  |  |
| --- | --- |
| **Frame** | **frame[15:0]** |
| Start | 0xBCBC |
| Data0 | data[31:16] |
| Data1 | data[15: 0] |

For example, this waveform shows the transmission of the 32-bit packet 0x12345678:

![](data:image/png;base64,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)

Consecutive packets will simply repeat this sequence, e.g:

|  |  |
| --- | --- |
| **Frame** | **frame[15:0]** |
| Start | 0xBCBC |
| Data0 | data[31:16] |
| Data1 | data[15: 0] |
| Start | 0xBCBC |
| Data0 | data[31:16] |
| Data1 | data[15: 0] |

When the transmit FIFO is empty and there is no data to send, the state machine will send an idle frame marker, 0xFCFC:

|  |  |
| --- | --- |
| **Frame** | **frame[15:0]** |
| Start | 0xBCBC |
| Data0 | data[31:16] |
| Data1 | data[15: 0] |
| IDLE | 0xFCFC |
| IDLE | 0xFCFC |
| IDLE | 0xFCFC |
| IDLE | 0xFCFC |
| Start | 0xBCBC |
| Data0 | data[31:16] |
| Data1 | data[15: 0] |

For example, this waveform shows the transmission of the 32-bit packet 0x12345678, followed by the idle transmission of the 0xFCFC frame marker.

![](data:image/png;base64,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)

The receiving state machine should monitor for 0xBCBC for alignment and record the next two frames as the 32 bit data packet.

If the following frame is 0xBCBC, then the sequence should repeat and record the following two frames, and so on. If the frame is 0xFCFC then the state machine should wait until it sees a start-of-packet marker (0xBCBC).

### Receive (GBT to FPGA)

Communication in the direction of GBT to FPGA is similarly accomplished with a packet format, whose payload includes 16 bits of address and 32 bits of data. Transmit and receive bandwidths are asymmetric, due to the requirement of transmitting synchronous TTC commands on the GBT to FPGA link, so the format on the receive side is somewhat more complicated.

In this direction, the highest 4 bits of the GBT link are reserved for TTC commands:

* Bit15 = L1A
* Bit14 = VFAT Reset
* Bit13 = TTC Resync
* Bit12 = BC0

The remaining 12 bits are used as the GBT data frame used to construct packets.

|  |  |  |
| --- | --- | --- |
| **Frame** | **Highest 4 bits** | **Lowest 12 bits** |
| Start | L1A + reset + Resync + BC0 | 0xABC |
| Header | L1A + reset + Resync + BC0 | req\_valid + wr\_enable + reserved[5:0] + address[15:12] |
| Address 0 | L1A + reset + Resync + BC0 | address[11:0] |
| Data 0 | L1A + reset + Resync + BC0 | data[31:24] |
| Data 1 | L1A + reset + Resync + BC0 | data[23:12] |
| Data 2 | L1A + reset + Resync + BC0 | data[11: 0] |

For continuous transmission, this sequence should just be repeated cyclically. i.e. the frame after Data 2 should be “Start” (0xABC). E.g. as follows:

**<START> <HEADER> <ADR0><DATA0> <DATA1> <DATA2>, <START> <HEADER> <ADR0> ….**

When idle, there are two possible ways of sending data to the OH:

Either cycle through the 7 frame packet format continuously, making sure to set request\_valid to 0 for any null packets. The Optohybrid will process and discard the packet.

Alternatively (preferably) when can send an idle frame marker, for example 0x5FC. The exact choice does not matter as long as it is not 0xABC. This marker can be sent continuously as long as the transmission is idle and the Optohybrid will remain in an idle SYNC state. The state machine will monitor for 0xABC and if received, will continue to process the rest of the frame normally.

# GBT Packets in Low Bandwidth Mode

In “Low Bandwidth Mode” the GBT to FPGA link consists of 1x 320 Mbps duplex and 1x 80Mbps duplex, leaving 10 bits per bunch crossing in each direction.

### Transmit (FPGA to GBT)

Communication with the optohybrid in the direction of FPGA to GBT is accomplished with a simple 10 bit packet format.

A valid packet is three five long and will consist of the a bit frame marker BC followed by three 10 bit data frames:

|  |  |
| --- | --- |
| **Frame** | **frame[9:0]** |
| Start | 2’b00 & 0xBC |
| Data0 | 2’b00 & data[31:24] |
| Data1 | 2’b01 & data[23:16] |
| Data2 | 2’b10 & data[15: 8] |
| Data3 | 2’b11 & data[ 7: 0] |

For example, this waveform shows the transmission of the 32-bit packet 0x12345678:

![](data:image/png;base64,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)

Note that the highest two bits of the data frames indicate the numbering of the frame in the packet and can be used for error checking.

Consecutive packets will simply repeat this sequence.

When the transmit FIFO is empty and there is no data to send, the state machine will send an idle frame marker, 0xFC. For example, this waveform shows the transmission of the 32-bit packet 0x12345678, followed by the idle transmission of the 0xFC frame marker, followed by the beginning of a new valid packet.

![](data:image/png;base64,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)

The receiving state machine should monitor for 0xBC for alignment and record the next four frames as the 32 bit data packet.

If the frame following the last data frame is 0xBC, then the sequence should repeat and record the following two frames, and so on. If the frame is 0xFC (or anything else) then the state machine should wait until it sees a start-of-packet marker (0xBC).

### Receive (GBT to FPGA)

Communication in the direction of GBT to FPGA is similarly accomplished with a packet format, whose payload includes 32 bits of address and 32 bits of data. Transmit and receive bandwidths are asymmetric, due to the requirement of transmitting synchronous TTC commands on the GBT to FPGA link, so the format on the receive side is somewhat more complicated.

In this direction, the highest 4 bits of the GBT link are reserved for TTC commands:

* Bit10 = L1A
* Bit9 = VFAT Reset
* Bit8 = TTC Resync
* Bit7 = BC0

The remaining 6 bits are used as the GBT data frame used to construct packets.

|  |  |  |
| --- | --- | --- |
| **Frame** | **Highest 4 bits** | **Lowest 6 bits** |
| Start | L1A + reset + Resync + BC0 | 0x2A |
| Header | L1A + reset + Resync + BC0 | request\_valid + wr\_enable + reserved[3:0] |
| Address 0 | L1A + reset + Resync + BC0 | address[15:10] |
| Address 1 | L1A + reset + Resync + BC0 | address[ 9: 4] |
| Address 2 | L1A + reset + Resync + BC0 | address[3:0] + data[31:30] |
| Data 0 | L1A + reset + Resync + BC0 | data[29:24] |
| Data 1 | L1A + reset + Resync + BC0 | data[23:18] |
| Data 2 | L1A + reset + Resync + BC0 | data[17:12] |
| Data 3 | L1A + reset + Resync + BC0 | data[11: 6] |
| Data 4 | L1A + reset + Resync + BC0 | data[ 5: 0] |

For continuous transmission, this sequence should just be repeated cyclically. i.e. the frame after Data 2 should be “Start” (0xABC). E.g. as follows:

**<START><HEADER><ADR0><ADR1><ADR2><DATA0><DATA1><DATA2><DATA3><DATA4>, <START>**

When idle, there are two possible ways of sending data to the OH:

Either cycle through the 7 frame packet format continuously, making sure to set request\_valid to 0 for any null packets. The Optohybrid will process and discard the packet.

Alternatively (preferably) when can send an idle frame marker, for example 0x1C. The exact choice does not matter as long as it is not 0x2A. This marker can be sent continuously as long as the transmission is idle and the Optohybrid will remain in an idle SYNC state. The state machine will monitor for 0x2A and if received, will continue to process the rest of the frame normally.

# Trigger Algorithm

Trigger information in the Optohybrid comes from the VFAT’s S-bits (Sector bits, or Sum bits, depending on who you ask). In the GE1/1 VFAT 3 these take the form of 8 320 MHz trigger links plus a 320 MHz synchronization pulse used to align the S-bits to the 40 MHz clock.

From 24 VFATs, the S-bits links are deserialized into 1536 S-bits divided in 8 physical partitions.

The S-bits are passed into a module called the cluster packer, which uses a priority encoding scheme to find the coordinates of 8 S-bit clusters inside of the GEM chamber.

All of the priority encoding logic operates at 160 MHz, so the number of bx consumed by the algorithm is 1/4 of the number of 160 MHz clocks.

A sequential description of the algorithm follows:

### Clock 1

Oneshots trim the tails of S-bit pulses in order to prevent retriggering on the same S-bit in subsequent clock cycles. The S-bit will become active again for triggering after it goes low for 1 clock cycle. This is especially important if the monostable length of the VFAT is set to anything longer than one.

An optional deadtime parameter can be controlled through the sys module to provide a 4-bit delay (0-15 bunch crossings) during which the S-bit cannot retrigger at all. This may be useful to supress afterpulsing which has been observed in the VFATs.

### Clock 2

The second clock cycle is responsible for the creation of cluster flags and sizes which will be inputs to the priority encoder. A cluster is defined as a continuous sequence of S-bits, which can be encoded together to save bandwidth.

In the chosen data format, the maximum size of a cluster is 7, meaning that the primary S-bit was active along with 7 additional neighbours, for a total cluster size of 7. A cluster size of 0 indicates that only 1 S-bit was active.

Due to limitations of the logic, if a cluster is longer than 8 S-bits, its tail will simply be truncated.

There is an optional, compile-time parameter that can change this behaviour so that the tail of a cluster could be split into a 2nd cluster, with the limitation that after 16 S-bits it would be truncated again. By default this is disabled, due to the resource savings that are achieved.

In the firmware, two processes occur in parallel:

1st is that a “valid primary flag” is created for each of the 1536 S-bits, which identifies the particular S-bit as being the primary (first) S-bit in a cluster. This is done by looking for a preceding 0 (S-bit OFF).

2nd is that a count is derived for all pads, which is a 3-bit number following the scheme above.

For each of the 1536 S-bits, these 4 bits (vpf and count) are registered and passed to the priority encoder.

### Clock 3

This clock is used to register the vpfs and counts of the 1536 trigger pads (vpfs are latched inside the truncator, counts are latched inside the priority encoder), providing a 6.25 ns routing slack which allows the signals to be routed through the FPGA and aligned at the priority encoder.

Nota bene: This clock cycle is critical in the choice of the phase of the frame clock. The frame clock should be adjusted such that the rising edge of the 20 MHz frame clock is coincident with the rising edge of the clock at the end of this cycle.

Each 160 MHz clock cycle represents a 45 degree phase shift of the frame clock. Thus, because this step is in Clock 3, the phase shift applied to the frame clock should be 45 \* 3 = 135 degrees. This needs to be correctly configured in the MMCM

### Clock 4

Multi-bit priority encoding presents a significant challenge for a latency-constrained system. Finding a single cluster can be done efficiently through a multi-stage pipelined priority encoding tree. But finding subsequent clusters is very slow, because the entirety of the process must be pipelined:

e.g. 3 clock cycles to find the first cluster, mask it off, 3 clock cycles to find the second cluster, mask it off, 3 clock cycles to find the 3rd, etc.

It should be apparent that in such a scheme the latency would be very large.

Fortunately a clever scheme was devised which allows for masking and encoding to occur as separate, parallel processes.

This exploits the fact that the twos complement of a number has an interesting relation to its least significant set bit (note that the twos\_complement of a = -a = ~a+1).

At each clock cycle, the least-significant 1 becomes 0, using a simple property of integers: subtracting 1 from a number will always affect the least-significant set 1-bit. Using just arithmetic, with this trick we can take some starting number, and generate a copy of it that has the least-significant 1 changed to a zero.

e.g.

let a = 101100**1**00 // our starting number   
 ~a = 010011**0**11 // bitwise inversion  
 b = ~a+1 = 010011**1**00 // b is the twos complement of a  
 ~b = 101100**0**11 // bitwise inversion  
 a & b = 000000**1**00 // one hot of first one set  
 a &~b = 101100**0**00 // copy of a with the first set bit changed to 0

or as a one line expression in Verilog,

c = a & ~(~a+1), or equivalently  
 c = a & ~( -a), or equivalently  
 c = a & ~({1536{1'b1}}-a), etc., I'm sure there are more.

But alas, the point: we can Zero out bits without knowing the position of the bit, So this so-called cluster-truncator can run independently of a priority encoder that is finding the position of the bit. This allows the cluster truncation to be the timing critical step (running at 160 MHz) while the larger amount of logic in the priority encoder can be pipelined, to run over 2 or 3 clock cycles, which adds an overall latency but still allows the priority encoding to be done quickly without the necessity of a pipelined feedback.

This reduces the overall encoding time for 8 clusters in the example above from 3\*8 = 24 clock cycles to 2+8 = 10 clock cycles (2bx latency + 8 bx of data).

Additionally, operating on such large amounts of data (1536 bits) is a significant processing hurdle. To simplify this, split the chamber into two parts, each of which is finding 8 clusters from that half of the chamber (768). The findings of the two encoders will be merged at the end.

**Having said all this**--- in this clock cycle:

1. The “cluster truncator” applies this twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-1
2. In parallel, the data from the cluster truncator flip-flops is routed to the priority encoder, where it will be registered in order to find the 1st valid cluster.

### Clock 5

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-2
2. In parallel, the data the first 4 pipeline stages of the priority encoder are completed, reducing the search set from 768 to 48 clusters.

### Clock 6

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-3
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster
   1. *1st valid cluster*

### Clock 7

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-4
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster
   1. 2nd valid cluster

### Clock 8

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-5
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #3)
   1. *3rd valid cluster*

### Clock 9

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-6
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #4)
   1. *4th valid cluster*

### Clock 10

1. The “cluster truncator” applies its twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0
   1. Cluster n-7
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #5)
   1. *5th valid cluster*

### Clock 11

1. The truncation process for this set of S-bits has completed and we are only awaiting the latency of the priority encoder. Because the data is a continuous input stream, we have a pipelined logic design which utilizes this logic again for new data before the previous set of S-bits has finished processing.   
     
   So in this clock cycle we load new data into the register from bunch crossing N+2 (where N was the bx of the data which we just completed) and repeat the same process:   
     
   The “cluster truncator” applies this twos-complement math to the S-bit valid-primary flags and registers a modified version of the logic with the least-significant S-bit set to 0 (cluster-1)  
     
   For clarity, in subsequent clock cycles, the descriptions of processing on the data from BX = N+2 is removed.
2. In parallel, the data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #6)
   1. *6th valid cluster*

### Clock 12

In this clock:

1. The data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #7)
   1. *7th valid cluster*

### Clock 13

1. The data the next 4 pipeline stages of the priority encoder are completed, reducing the search set from 48 to a single cluster, and returns the address, cnt, and vpf of that cluster (cluster #8)
   1. *8th valid cluster*
2. The 8 clusters from each of the two priority encoders are collated and aligned for input in into the merge16 module, which uses a merge-sort algorithm to pick out 8 clusters from the 16 inputs.

### Clock 14

1. The merge 16 module completes the first sets of sorting, swapping pairs from different halves of the chamber depending on whether which has the lowest address (invalid patterns are automatically set to the maximum address 0x7FF).   
     
   Stage 0: sort eights (0,8), (1,9), (2,10), (3,11), (4,12), (5,13), (6,14), (7,15)
2. The merge 16 module completes the second set of sorting, swapping pairs of clusters depending on which has the lowest address.   
     
   Stage 1: sort fours (4,8), (5,9), (6,10), (7,11)

### Clock 16

1. The merge 16 module completes the third set of sorting, swapping pairs of clusters depending on which has the lowest address.   
     
   Stage 2: sort twos (2,4), (3,5), (6,8), (7,9)
2. The merge 16 module completes the fourth and last set of sorting, swapping pairs of clusters depending on which has the lowest address.   
     
   Stage 3: swap odd pairs (1,2), (3,4), (5,6), (7,8), (9,10), (11,12), (13,14)
3. The 8 sorted clusters are multiplex into the 40MHz clock domain.   
     
   The 8 sorted clusters have a mask applied to them, so that during reset they are set to 0x7FE and if the Optohybrid trigger control is idle (waiting for bc0) they will be set to 0x7FD.   
     
   The masked clusters are moved onto the fabric 40MHz clock and will be sent out on the optical links.

A total of 16 clocks at 160Mhz means that the entire cluster encoding process is 4bx (100ns), exactly.

Retiming the module to consume an additional BX while adding additional pipeline stages would greatly ease the burden of place-and-route, but at this point does not seem necessary.

# Cluster Packer Miscellany

This section contains various other notes on the configuration, inputs, and outputs of the cluster packer aside from its algorithm.

### Synchronization Frame

Performance of the cluster packer is achieved by splitting the chamber into two time-multiplexed logic blocks. Every bunch crossing, either the “odd” or “even” encoders receives the entire chamber’s worth of data and produces a result.

The results from the odd or even encoders are multiplexed back together and output from the cluster packer module.

Rather than a counter, which I worried would be too fickle and subject to SEU, the synchronization and multiplexing of these two modules is achieved with a MMCM derived 20MHz clock.

The odd and even modules are given either 0 or 180 degree versions of this 20MHz clock and they synchronize their logic and multiplexing to this clock.

This scheme was chosen because on every clock cycle of the slow clock, each of the priority encoder modules will reset itself on the rising edge of this clock, irrespective of any previous state.

### Cluster Counter

A submodule of the cluster packer produces a full 12 bit count of the number of clusters found in the chamber. This is accomplished with a multi-step pipelined adder tree that produces its result faster than the cluster packer. An SRL delay must be correctly programmed to align the adder results with the output of the cluster packer.

In another module of the Optohybrid firmware, the cluster count output is used in a rate counter. This module averages the cluster count over a compile-time programmable time window and produces an output in Hertz.

# LED Indicators

# Registers

A summary table of the wishbone slaves in the Optohybrid v3 is given here. Detailed descriptions of individual registers follow on subsequent pages.

|  |  |  |  |
| --- | --- | --- | --- |
| Slave | Name | Addresss | Function |
| Wishbone Slaves | | | |
| 0 | Loopback | 0x0000 | Loopback register receives data and responds with the same data, for testing communication and error rates. Data in the loopback register has no effects in the FPGA. |
| 1 | Counters | 0x10YY | Counters register allows readback of a number of counters |
| 2 | System | 0x20YY | System register is responsible for controlling various settings in the Optohybrid |
| 3 | Status | 0x30YY | Status register is responsible for readback of various status |
| 4 | ADC | 0x40YY | Controls the System Monitor of the Virtex-6 FPGA |

In an address such as 0x10YY, the lowest 11 bits denoted by YY are used to select between individual end-points in the wishbone bus. Splitting the request is handled by the individual wishbone slaves.

The highest 5 bits are used to select the wishbone slave. Presently only the highest 4-bits are used, so that addresses count as 0x0000, 0x1000, 0x2000, 0x3000… for future expansion the 5th bit is reserved such that if additional addresses are needed we can occupy the 0x0800, 0x1800, 0x2800, 0x3800… up to 0xF800. In total this provides space for 32 wishbone slaves, from 0x0000 to 0xF800, each of which can have 2048 endpoints.

## Loopback

This module is designed for testing GBT communication. It will echo as a response whatever data is written to it as a request.

### Addressing

Module ID 0

Address 0x0000

|  |  |  |
| --- | --- | --- |
| Y register | Mode | Function |
| Loopback Registers | | |
| 0 | Read/write | Echoes back the last written value as a wishbone response |

### Errors

None

### Errors to avoid

* None

## Counters

This module holds all the counters of the OptoHybrid. Writing to a given register will reset its value.

All counters are 32 bit

### Addressing

Module ID 1

Address 0x10YY

|  |  |  |
| --- | --- | --- |
| Y register | Mode | Function |
| Control | | |
| 0 | Read | *Snap Enable*  Write (anything) to this register to take a snapshot of the counters, freezing a shadow copy for synchronous readout. This MUST be flagged before reading out a register or it will not be updated.  The register will readback a counter of the number of snapshots taken since last reset. |
| 1 | Read | *Reset All*  Write anything to this register to reset all of the counters  The register will readback a counter of the number of reset\_alls done. This register is reset by writing to the register. A non-writing request will readback the contents. |
| Wishbone |  |  |
| 2 | Read | *Wishbone master strobes*  Counts the number of strobes received on the wishbone master (GBT) |
| 3 | Read | *Wishbone master acknowledgments*  Counts the number of acknowledgements returned by the wishbone master. |
| 4—8 | Read | *Wishbone slaves strobe*  Order: Loopback, counters, system, status, adc |
| 9—13 | Read | *Wishbone slaves acknowledgments*  Order: Loopback, counters, system, status, adc |
| TTC |  |  |
| 14 | Read | *L1A Counter* |
| 15 | Read | *Resync Counter* |
| 16 | Read | *BC0 Counter* |
| 17 | Read | *BC0 Sync Error Counter* |
| MMCM | | |
| 18 | Read | *GBT Frame Clock MMCM Unlocked Counter* |
| 19 | Read | *Fabric Clock MMCM Unlocked Counter* |
| 20 | Read | *Either MMCM Unlocked Counter* |
| GBT | | |
| 21 | Read | *GBT Link Errors* |
| SEM |  |  |
| 22 | Read | *SEM Corrections* |
| S-Bits |  |  |
| 23 | Read | *SBit Overflows* |
| 24—47 | Read | *Active VFAT Flags count the number of the number of bx with at least one S-bit in a VFAT* |
| Latency Timers | | |
| 48—71 | Read | *Latency timer: Number of BX between the SBits and the L1A, for each VFAT* |

## System Registers

System registers are writable registers used to control programmable settings of the Optohybrid

### Addressing

Module ID 2

Address 0x20YY

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Y register | Mode | Bits | Function | |
| VFAT | | | |
| 1 | Read / write | 4:0 | *SBit magic select for HDMI* | |
| 2 | Write only | 0 | *VFAT reset*  Write any data to this register and it will reset the VFATs (for 1 bx.. is this sufficient??). This register automatically returns to a 0 state | |
|  |  |  |  | |
| 2 | Read / write | 23:0 | *VFAT trigger data mask*  Allows to mask individual VFATs for trigger data | |
| 3 | Read / write | 29:0 | *TDC SBits selects* | |
| 4 | Read / write | 1:0 | *TDC SBits mode*  0 : single VFAT2  1 : Eta row (OR of 3 VFAT2s)  2 : Sector (OR of 4 VFAT2s)  3 : no output | |
| 5 | Read / write | 0 | FMM dont\_wait  If this is asserted, the Optohybrid will not wait for resync 1st BC0 before sending trigger data. This is useful for test-stands and debugging where a reliable TTC startup sequence may not be expected. | |
| 6 | Read / write | 11:0 | TTC BXN Offset  This 12 bit configuration will set the “zero” value of the local BC0 counter which will be assumed after resync. Adjust this to account for different latencies to chambers. When this register is correctly set the BC0 error counters in the status register should be zero.  Note that since the OH does not have a startup configuration this must be programmed by the CTP-7 after every hard reset. | |
| 7 | Read / write | 3:0 | *Trigger Deadtime*  Adds a deadtime, 0-15 bunch crossings, on each S-bit which will prevent retriggering on that same S-bit during the time window specified by the deadtime. This is meant to supress afterpulsing in the trigger data path. | |

## Status Registers

List of status registers

### Addressing

Module ID 3

Address 0x30YY

|  |  |  |  |
| --- | --- | --- | --- |
| Y register | Mode | Bit(s) | Function |
| Version | | | |
| 0 | Read only | 31:0 | *OH firmware date*  *Hex encoded: YYYYMMDD* |
| 1 | Read only | 31:0 | *Firmware version Hex Encoded*  Major 8 bits  Minor 8 bits  Version 8 bits  HW 8 bits = Hardware ID A = v3A, etc. |
| Clocking | | | |
| 2 | Read only | 0  1  2 | *Both MMCMs Locked*  *GBT SerDes Frame Clock MMCM Locked*  *Fabric clock MMCM Locked* |
| Soft Error Mitigation | | | |
| 3 | Read only | 0 | *Critical error induced by SEU detected* |
| GBT |  |  |  |
| 4 | Read only | 0  1  2 | *GBT TX Ready*  *GBT RX Valid*  *GBT RX Ready* |
| Trigger |  |  |  |
| 5 | Read only | 31:0 | *Averaged cluster rate in Hertz* |
| TTC |  |  |  |
| 6 | Read only | 31:0 | *Local BC0 Counts* |
| 7 | Read only | 31:0 | *Received BC0 Counts from GBT* |
| 8 | Read only | 31:0 | *TTC Orbit Counter* |
| 9 | Read only | 11:0 | *TTC BXN Count* |
| 10 | Read only | 0 | *TTC BXN Sync Error* |

## ADC

This module is directly connected to the xADC of the Virtex-6 FPGA. Refer to the following user guide for a full list of register: <http://www.xilinx.com/support/documentation/user_guides/ug370.pdf>

### Addressing

Module ID 4

Address 0x40YY

|  |  |  |
| --- | --- | --- |
| Y register | Mode | Function |
| ADC registers | | |
| 0 - 79 | Read/write | Returns the conversion value of a given channel  0 = Temperature  1 = VCCINT  2 = VCCAUX  3 = VP/VN  16-31 = VAUX[0:15] (not connected)  32 = Temperature max  33 = VCCINT max  34 = VCCAUX max  36 = Temperature min  37 = VCCINT min  38 = VCCAUX max  64-66 = Control registers[0:2]  67-71 = Test registers[0:4]  72-79 = Sequencer registers[0:7] |

### 

### Errors

The module returns an error if the parameters are not in spec.

### Errors to avoid

* The register ID must be in the range 0 to 79.

# History

|  |  |  |
| --- | --- | --- |
| Date | Author | Modification |
| 8/7/2017 | AP | Initial conversion to OHv3 from Thomas’ v2 document |
| 8/10/2017 | AP | Description of GBT link formats |
| 8/14/2017 | AP | Updates register definitions according to latest firmware |
| 8/14/2017 | AP | Add description of synchronization and algorithmic description of the cluster packer |
| 8/17/2017 | AP | Update trigger description to match new firmware (reduced latency) |
| 8/18/2017 | AP | Update register description and GBT decoding for 16 bit addresses |