# Status Report on a MicroTCA Card for HCAL Trigger and Readout at SLHC

Prof. Jeremiah Mans Mr. Erich Frahm\*

University of Minnesota



Upgrade of CMS HCAL:

Increase the ADC channel count by about 4x without an increase in the number of links from the HCAL Front End to the Back End.

HCAL Data Philosophy: Every sample from the ADCs at the Front End goes to the Back End L1 pipelines and trigger primitives.

University of Minnesota R&D is involved in achieving the required speed and stability of communication links in the CMS environment.

Current data rate: 1.6 Gbps Upgraded data rate target: 4.8 Gbps

(Upgraded data format is also slightly more compact.)

#### **R&D** Goals



HCAL Trigger and Readout Board – System Concept

MiniCTR2 is board built at UMN that evaluates the key elements of the uHTR System Concept, but with reduced link counts.

#### **R&D** Goals

**Discussion Topics:** 

- MiniCTR2 Architecture
- Bit Error Rate Tests
- 4.8 Gbps Serial Data Integrity Analysis
- "IPbus" Control Concept
- MiniCTR2b Architecture
- Communication with a Front End Prototype
- Communication with a CMS-MCH

Successful integration of FPGA firmware from the CMS-MCH group (previous speaker). MiniCTR2 received 40 MHz Clock and Fast Controls from a CMS-MCH across a MicroTCA backplane.



MiniCTR2 Features:

• Xilinx XC5VFX70T-1FFG1136C FPGA

16 GTX high-speed serial links (datasheet says max. 4.25 Gbps)

- Two SFP+ Optical Transceivers (6.4 Gbps)
- SNAP12 12-channel Optical Transmitter (4.8 Gbps)
- SNAP12 12-channel Optical Receiver (4.8 Gbps)
- Flexible clock network with 6 clock sources.
- Jitter-attenuating Si5319 any-rate clock multiplier/synthesizer

Internal or external 40 MHz frequency reference clock

Generates 320 MHz GTX reference clocks



MiniCTR2 Printed Circuit Board Stackup

- 10 Copper Layers
- 5 mil lines, 4 mil spaces
- Top and bottom layer (stripline) 6 mil traces support 6.4 Gbps

# Bit Error Rate Test (BERT)

- Board to Board communication via 850nm optics, multimode fiber
- Xilinx IBERT FPGA core

PRBS-31 data pattern (length 2<sup>31</sup>-1)

- 4.8 Gbps on SNAP12 (4 channels)
- 6.4 Gbps on SFP+ (2 channels)
- Two different legs of a realistic (somewhat pessimistic) clock distribution example.





MicroTCA Workbench – Board to Board Communication

## Silicon Laboratories Si5319

Locks on to external reference clock frequency.

Output clock phase is not specified.





Clock Period Histograms for both 40.08 MHz clock distribution branches. Measured using a Wavecrest SIA-4000

(Thanks to Brad Hegge, Gigamax Technologies, www.gigamaxtech.com)



#### Clock Period Difference Histogram (Ch1 to Ch2) Measured using a Wavecrest SIA-4000

(Thanks to Brad Hegge, Gigamax Technologies, www.gigamaxtech.com)

| ChipScope Pro Analyzer [                                                              | IBERT_A]                                                                            |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------|---------------------|------|---------------------|---------------------|---------------------|---------------------|---------------------|--|--|--|--|--|
| <u>File View</u> JTAG Chain                                                           | Device IBERT <u>V</u> 5GTX <u>V</u>                                                 | <u>/indow</u> | <u>H</u> elp        |      |                     |                     |                     |                     |                     |  |  |  |  |  |
| 🗱 🕑   👏 JTAG Scan Ra                                                                  | ite: 500 ms 💌 S!                                                                    |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
| Project: IBERT_A                                                                      | 📓 IBERT Console - DEV:0 MyDevice0 (XC5VFX70T) UNIT:0 MyIBERT_V5_GTX0 (IBERT_V5_GTX) |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
| AG Chain<br>DEV:0 MvDevice0 (XC5)                                                     | Clock Settings MGT/BERT Settings Sweep Test Settings                                |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
| - System Monitor Cor<br>- UNIT:0 MyIBERT_V<br>- IBERT Console<br>- UNIT:1 MyVIO1 (VIC |                                                                                     |               |                     |      | OTY DUN YOULA       |                     |                     |                     |                     |  |  |  |  |  |
|                                                                                       |                                                                                     |               | EXPOIL.             |      | GTX_DUAL_X0Y4_1     | GIX_DUAL_X0Y5_0     |                     |                     | GTX_DUAL_X0Y7_1     |  |  |  |  |  |
|                                                                                       | Edit                                                                                | 1             | Edit                |      | Edit                | Edit                | Edit                | Edit                | Edit                |  |  |  |  |  |
| - VIO Console                                                                         | None                                                                                | ~             | None                | T    | None                | None                | None                | Nohe 👻              | None                |  |  |  |  |  |
| Signals: DEV: 0 UNIT: 0                                                               |                                                                                     |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
| - Data Port                                                                           | LOCKED                                                                              |               | LOCKED              |      | LOCKED              | LOCKED              | LOCKED              | LOCKED              | LOCKED              |  |  |  |  |  |
|                                                                                       |                                                                                     |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
|                                                                                       | Inject                                                                              |               | Inject              |      | Inject              | Inject              | Inject              | Inject              | Inject              |  |  |  |  |  |
|                                                                                       | 600 mV (000)                                                                        | •             | 600 mV (000)        | -    | 600 mV (000)        | 600 mV (000)        | 600 mV (000) 🔹      | 600 mV (000) 🗸 🗸    | 600 mV (000)        |  |  |  |  |  |
|                                                                                       | 0% (0000)                                                                           | -             | 0% (0000)           | -    | 0% (0000) 💌         | 0% (0000) 🗸 🔻       | 0% (0000) 💌         | 0% (0000) 🗸 🗸       | 0% (0000) 💌         |  |  |  |  |  |
|                                                                                       |                                                                                     |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
|                                                                                       | LOCKED                                                                              |               | LOCKED              |      | LOCKED              | LOCKED              | LOCKED              | LOCKED              | LOCKED              |  |  |  |  |  |
|                                                                                       |                                                                                     |               | and a second        |      |                     |                     |                     |                     |                     |  |  |  |  |  |
|                                                                                       | 2                                                                                   |               | V                   |      | <b>V</b>            | V                   |                     |                     | ×                   |  |  |  |  |  |
|                                                                                       | GND                                                                                 | -             | GND                 | -    | GND                 | GND                 | GND                 | GND                 | GND                 |  |  |  |  |  |
|                                                                                       | Large HF Boost (00)                                                                 |               | Large HF Boost (00) | -    | Large HF Boost (00) | Large HF Boost (00) | Larde HF Boost (00) | Larde HF Boost (00) | Large HF Boost (00) |  |  |  |  |  |
|                                                                                       | 0                                                                                   | -             | 0                   | -    | 0                   | 0                   | 0                   | 0                   | 0                   |  |  |  |  |  |
|                                                                                       | 0                                                                                   | -             | 0                   | •    | 0                   | 0                   | 0                   | 0                   | 0                   |  |  |  |  |  |
|                                                                                       |                                                                                     | 417 UI        |                     | 9 UI | 52 0.409 UI         | 0.417 UI            | <u>53</u> 0.417 UI  | <u>53</u> 0.417 UI  | 530.417 UI          |  |  |  |  |  |
|                                                                                       |                                                                                     |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |
|                                                                                       | PRBS 31-bit                                                                         |               | PRBS 31-bit         | -    | PRBS 31-bit         |  |  |  |  |  |
|                                                                                       | 2.353E-015                                                                          |               | 2.353E-015          |      | 2.353E-015          | 2.353E-015          | 2.353E-015          | 1.764E-015          | 1.764E-015          |  |  |  |  |  |
|                                                                                       | 4.807 Gbps                                                                          |               | 4.814 Gbps          |      | 4.806 Gbps          | 4.805 Gbps          | 4.807 Gbps          | 6.407 Gbps          | 6.409 Gbps          |  |  |  |  |  |
|                                                                                       | 4.250E014                                                                           |               | 4.250E014           |      | 4.250E014           | 4.250E014           | 4.250E014           | 5.668E014           | 5.668E014           |  |  |  |  |  |
|                                                                                       | 0.000E000                                                                           |               | 0.000E000           |      | 0.000E000           | 0.000E000           | 0.000E000           | 0.000E000           | 0.000E000           |  |  |  |  |  |
|                                                                                       |                                                                                     |               |                     |      |                     |                     |                     |                     |                     |  |  |  |  |  |

All 4 SNAP12 channels ran for more than 24 hours without a single error at 4.8 Gbps.

| 🕼 ChipScope Pro Analyzer [IBERT_A]                                                                                                  |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------|-----------------------|---------------------|-------------------------|-------------------------|---------------------|--|--|--|--|--|--|--|
| Eile View JTAG Chain Device IBERT V5GTX Window Help                                                                                 |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
| 🟥 🕑   🕥 JTAG Scan R                                                                                                                 | tate: 500 ms 💌 S!                                                                   |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
| Project: IBERT_A                                                                                                                    | 📓 IBERT Console - DEV:0 MyDevice0 (XC5VFX70T) UNIT:0 MyIBERT_V5_GTX0 (IBERT_V5_GTX) |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
| AG Chain<br>DEV:0 MyDevice0 (XC5)<br>System Monitor Cor<br>OUNIT:0 MyIBERT_V<br>IBERT Console<br>OUNIT:1 MyVIO1 (VIC<br>VIO Console | Clock Settings MGT/BERT Settings Sweep Test Settings                                |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     | GTX_DUAL_X0Y0_1                                                                     | GTX_DUAL_X0Y4_0       | GTX_DUAL_X0Y4_1       | GTX_DUAL_X0Y5_0     | GTX_DUAL_X0Y5_1         | GTX_DUAL_X0Y7_0         | GTX_DUAL_X0Y7_1     |  |  |  |  |  |  |  |
|                                                                                                                                     | Edit                                                                                | Edit                  | Edit                  | Edit                | Edit                    | Edit                    | Edit                |  |  |  |  |  |  |  |
|                                                                                                                                     | None                                                                                | None                  | None                  | None                | None                    | None 💌                  | None                |  |  |  |  |  |  |  |
| Signals: DEV: 0 UNIT: 0                                                                                                             |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
| — Data Port                                                                                                                         | LOCKED                                                                              | LOCKED                | LOCKED                | LOCKED              | LOCKED                  | LOCKED                  | LOCKED              |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     | Inject                                                                              | Inject                | Inject                | Inject              | Inject                  | Inject                  | Inject              |  |  |  |  |  |  |  |
|                                                                                                                                     | 600 mV (000)                                                                        | 600 mV (000)          | 600 mV (000) 🗸 🔻      | 600 mV (000) 🔍 💌    | 600 mV (000) 🗸 🗸        | 600 mV (000) 🗸 🗸        | 600 mV (000)        |  |  |  |  |  |  |  |
|                                                                                                                                     | 0% (0000) 💌                                                                         | 0% (0000) 💌           | 0% (0000) 🗸 🔻         | 0% (0000) 🗸 🔻       | 0% (0000) 💌             | 0% (0000) 🗸 🗸           | 0% (0000)           |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     | LOCKED                                                                              | LOCKED                | LOCKED                | LOCKED              | LOCKED                  | LOCKED                  | LOCKED              |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       | V                     | V                   | ×                       |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     | GND                                                                                 | GND 💌                 | GND                   | GND                 | GND                     | GND                     | GND 💌               |  |  |  |  |  |  |  |
|                                                                                                                                     | Large HF Boost (00) 🔍                                                               | Larde HF Boost (00) 🔹 | Large HF Boost (00) 🔹 | Large HF Boost (00) | Larde HF Boost (00) 🗾 💌 | Large HF Boost (00) 🗸 💌 | Large HF Boost (00) |  |  |  |  |  |  |  |
|                                                                                                                                     | 0                                                                                   | 0                     | 0                     | 0                   | 0                       | 0                       | 0                   |  |  |  |  |  |  |  |
|                                                                                                                                     | 0                                                                                   | 0                     | 0                     | 0                   | 0                       | 0                       | 0                   |  |  |  |  |  |  |  |
|                                                                                                                                     | <u>53</u> 0.417 UI                                                                  | <u>52</u> 0.409 UI    | <u>52</u> 0.409 UI    | 0.417 UI            | <u>53</u> 0.417 UI      | 0.417 UI                | 530.417 UI          |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |
|                                                                                                                                     | PRBS 31-bit                                                                         | PRBS 31-bit           | PRBS 31-bit           | PRBS 31-bit         | PRBS 31-bit             | PRBS 31-bit             | PRBS 31-bit         |  |  |  |  |  |  |  |
|                                                                                                                                     | 2.353E-015                                                                          | 2.353E-015            | 2.353E-015            | 2.353E-015          | 2.353E-015              | 1.764E-015              | 1.764E-015          |  |  |  |  |  |  |  |
|                                                                                                                                     | 4.807 Gbps                                                                          | 4.814 Gbps            | 4.806 Gbps            | 4.805 Gbps          | 4.807 Gbps              | 6.407 Gbps              | 6.409 Gbps          |  |  |  |  |  |  |  |
|                                                                                                                                     | 4.250E014                                                                           | 4.250E014             | 4.250E014             | 4.250E014           | 4.250E014               | 5.668E014               | 5.668E014 _         |  |  |  |  |  |  |  |
|                                                                                                                                     | 0.000E000                                                                           | 0.000E000             | 0.000E000             | 0.000E000           | 0.000E000               | 0.000E000               | 0.000E000           |  |  |  |  |  |  |  |
|                                                                                                                                     |                                                                                     |                       |                       |                     |                         |                         |                     |  |  |  |  |  |  |  |

Both SFP+ channels ran for more than 24 hours without a single error at 6.4 Gbps.



The communication from board to board over the short MicroTCA backplane was also error free even at speeds above 6 Gbps. (Note that FPGA is not rated above 4.25 Gbps.)

The signal path includes two Molex RA MicroTCA connectors and about 7 inches of FR4 on the backplane.

University of Minnesota - TWEPP 2010

4.8 Gbps Serial Data Integrity Analysis



#### 4.8 Gbps Serial Data Integrity Analysis Measured using a ScopemaX from Gigamax Technology (Thanks to Brad Hegge, Gigamax Technology, www.gigamaxtech.com)

# Data Integrity Analysis



PRBS-7 Eye Diagram at 4.8 Gbps

# Data Integrity Analysis



PRBS-7 Data Dependent Jitter Diagram, 4.8 Gbps (208ps bit) max error: 17.73ps, min error: -13.31ps, 31.04ps pk-pk Not sensitive to choice of clock distribution branch.

# Data Integrity Analysis



PRBS-7 Time Interval Error Diagram for 3086 bits, 4.8 Gbps (208ps bit) max error: 36.27ps, min error: -31.88ps, 68.15ps pk-pk Not sensitive to choice of clock distribution branch. "IPbus" Control Concept



"IPbus" Control Concept

- "IPbus" is an R&D effort in CMS.
- Use Ethernet to control devices through the MicroTCA MCH Ethernet switch.
- Create a virtual A32/D32 bus in FPGA firmware.
- Perform READ, WRITE, RMW transactions on the bus.
- Package multiple bus transactions into a single Ethernet packet to minimize latency and maximize bandwidth.



"IPbus" Status

- Initial FPGA demonstration using UDP has been completed.
- Performance: Approximately 20 MBytes/s (block transfers)
- Size: Approximately 3% of XC5VFX70T (MiniCTR2)
- User protocol supports TCP but FPGA firmware does not support it yet.
- Successfully tested with the CMS-MCH ("DTC") on a backplane.

**Other Activities** 

#### MiniCTR2b

A modified MiniCTR2 board has been designed but not fabricated (yet).

- Better access to Si5319 clock input and output for jitter analysis.
- Microcontroller (MMC) has been moved to a mezzanine card.
- The mezzanine card can also support an Ethernet switch that will connect two SGMII (Gigabit Ethernet) from FPGAs to MicroTCA PORT0 and MicroTCA PORT1. (See next slide.)



- The mezzanine card can also support an Ethernet switch that will connect two SGMII (Gigabit Ethernet) from FPGAs to MicroTCA PORT0 and MicroTCA PORT1.
- Collaboration with University of Virginia.



Preliminary communication tests with a prototype Front End card are working in our lab at 4.8 Gbps on SNAP12 fiber links.

• Collaboration with Princeton University and Fermilab.



Princeton University / Fermilab Front End Prototype

### **Future Activities**

#### Measure and Optimize System Latency

- Integration with Front End Prototype
- Integration with Trigger

Demonstration in Test Beam

- Integration with Front End Prototype
- Integration with DAQ