# CMS RPC Upgrade Phase-II of new Link System



Behzad Boghrati<sup>1,2</sup>, Roghayeh Ghasemi<sup>1</sup>, Vahid Amoozegar<sup>1</sup>, Mohammad Ebrahimi<sup>1</sup>, Elham Zareiyan<sup>1</sup>, Mojtaba Mohammadi Najaf Abadi<sup>1</sup>

> on behalf of the CMS Muon Group RPC2020, Roma



#### <sup>1</sup>Institute for Research in Fundamental Science, <sup>2</sup>Damghan University

Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020



### Summary

- Link System Upgrade Motivation
- New Link System Overview
- Radiation Consideration
- Data Rates at barrel and Endcap Region
- RPC Layer-1 trigger Architecture and Link system Hits Data Frame Format
- Control, Diagnostic and Synchronization of **New Link System using New Slow Controller**











## Link System Upgrade Motivation





#### **Upgrade Motivation**

- Despite the intrinsic resolution of the RPCs, the CMS trigger system is based in the 25 ns sampling.
- Data transmission speed is about 1.6 Gbps
- Control, diagnostic and monitoring of the Link system has been designed based on CCU ring (combination of copper cable and fiber optic), very susceptible to electromagnetic interference



- CCU ring is not very fast, the bandwidth (40 MHz) share between 12 control boards
- Most radiation hard electronic components are obsoleted
- Electronic aging, presently the Link system at the end of LS2 is already 13 years old Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link
   <sup>3</sup>

Senzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020



## **New Link System Overview**



#### **New Link system Features :**

- 1. FPGAs are KINTEX-7, XC7K160T Industrial Version
- 2. Muon hit time, TDC timing Resolution : 1.56 ns
- 3. Master Link board output data rate : 10.24 Gbps
- 4. Control Board communication with slow controller at 10.24 Gbps
- 5. Embedded internal buffer (DDR3) : 1.28 GByte
- 6. Radiation Mitigation: TMR + Internal Scrubbing
- 7. Scrub Rate of entire FPGA (Real time SEU detection and Correction) : 13ms (31,770 times faster than the rate of SEU at the Balcony)
- SEU at the Balcony : Every 413000 ms





## **New Link Board Hardware Architecture**



# The design is based on the TDR baseline and on following specifications and components:

- 1. FPGAs are KINTEX7, XC7K160T-2FFG676I.
- 2. Fully support 10.3 Gbps data transmission. FPGA Chip is equipped with heat sink.
- 3. High resolution TDCs (at the steps of 1.56 ns) implemented into the Kintex7 FPGA
- 4. <u>Two Redundant optical data transmission line at the data</u> rate of 10.24 Gbps
- 5. Ethernet link for the debugging and onboard JTAG programmer
- 6. <u>256 M x 40 bits</u> of SDRAM-DDR3 for data buffering and debugging
- 7. Data transmission with adjacent slave link boards through the SAMTEC back-plane type connector with bandwidth of <u>16 GHz</u> and special front panel PCB board (Roger type).
- 8. Radiation Mitigation is based on Triple Modular Redundancy (TMR) techniques and Soft Error Mitigation (SEM) IP core from Xilinx.
- 9. Voltage Regulators selected from low dropout linear regulator families which <u>has been tested already under</u> <u>radiation</u>.





Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020



## **New Link System Firmware List**





TDC Calibration test setup



TDC Performance measurement



Fixed Latency GTX @ 10.24 Gbps



## • New Link system Firmware

- 1. Control Software
- 2. TTC Generator
- 3. TX LpGBT Protocol (Xilinx)
- 4. FEB Controller
- 5. TDC (1.56 ns)
- 6. TTC Decoder
- 7. Frame Generator
- 8. TTC Clock Recovery & Phase Shift
- 9. Multi Boot Remote Programming
- 10. Control/Diagnostic/ Histogramming (LB)
- 11. Ethernet LAN
- 12. DDR3 interface Controller
- **13. Jitter Cleaner (State Machine Controller)**
- 14. Fixed Latency data transmission
- 15. Control/Diagnostic (CB)
- 16. Soft Error Mitigation Engine (SEM)
- 17. Triple Modular Redundancy (TMR)

FEB Communication and Control

## Time to Digital Converter Performance TDC 1.56 ns @ 160MHz / 640 MSPS





TDC Calibration test setup



**TDC Performance measurement** 



• TDC Resolution 1.56 ns



## High Speed Data Transmission – Optical Link Fixed Latency GTX @ 10.24 Gbps





Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020

- (Near-End) Maximum
  achievable Opening eye
  for the <u>Ideal Case</u> (Loop
  back inside the FPGA1) is
  55.56%
- (Far-End) Opening eye
  for the <u>Real Case</u> in
  which the data
  transmission will take by
  connecting two FPGAs
  through the <u>120 meters</u>
  optical channel (OM2) is
  50~55%.
- Test Period is 48 hours and number of errors is Zero 9



## **Radiation Consideration**





- The Link system will be installed on the Balcony of CMS (750 cm <R < 800 cm), where the rates are even lower than what we have at the periphery of the detector.
- Total Irradiation Dose is 0.001-10 Gy @ 3000 fb<sup>-1</sup>
- The new Link board components has been chosen from (Commercial-off-theshelf) COTS which are validated for radiation at the level of **300 Gy**
- The FPGA TID KINTEX-7 (XC7K160T) is 3400-4500 Gy
- Neutron Flux at the CMS Balcony is 1x10<sup>4</sup> cm<sup>-2</sup>s<sup>-1</sup> @5 x 10<sup>34</sup> cm<sup>-2</sup>s<sup>-1</sup>
- Neutron Fluence for 10 HL-LHC years is 1x10<sup>12</sup> cm<sup>-2</sup>
- The Single Event upset (SEU) rate on configuration memory is 1 SEU every 413 sec. and 1 SEU every 1695 sec. at Block RAM
- Scrub Time of entire FPGA (SEU detection and Correction) : 13 ms
- <u>TMR</u> and <u>Configuration Scrubbing</u> will mitigate the SEUs

Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February



## **Radiation Consideration Estimation of SEU on the KINTEX-7 XC7K160T Configuration and BRAM Memories**







## Hit Rate wrt Max expected Background Rate at HL-LHC



- Expected Max hit rate in Barrel in HL-LHC , safety factor 3: 600 cm<sup>-2</sup> s<sup>-1</sup>
- Biggest Strip surface area : 120 X 3 cm<sup>2</sup>
- Average cluster size: -
- Number of Strip per chamber : 96
- Max Single hit in one LB per bx : 600 x (120 x 3) x 96 x 25 X 10<sup>-9</sup>= 0.52 hit /LB x bx
- One Master Link Board collects hits of two adjacent Slave Link boards
- Max Single hit in one MLB per bx : 0.52 x 3 = 1.56 hit /LB x bx
- Size of hit information Package : 15 bits (Yellow box)
- MLB Max. Payload: 15 bits x 1.56 hits x 40 MHz = 0.936 Gbps
- We foresee to send 232 bits/BX (for physics, already removed EOD and checksums) between MLB and RPC backend.
- Maximum limit of single hits in one MLB = (one frame overheads) / size of one hit = (256 46) / 15 = 14 hits



| ג | ltems | Header +<br>FEC | Number<br>of Events<br>(1 14) | No. Strip<br>(196) | Sub-bx | LB No.<br>(0 8) | BCN | BCO | Partition | ID |
|---|-------|-----------------|-------------------------------|--------------------|--------|-----------------|-----|-----|-----------|----|
|   | Bit   | 24              | 4                             | 7                  | 4      | 4               | 12  | 1   | 3         | 2  |



## RPC Layer-1 Trigger Architecture and New Link system Hits Data Frame Format



| Item | Header +<br>FEC | Number of Hits<br>(114) | No. Strip<br>(196) | Sub-bx | LB No. | <br>BCN | BC0 | Partition<br>delay | End of<br>Data |
|------|-----------------|-------------------------|--------------------|--------|--------|---------|-----|--------------------|----------------|
| Bit  | 24              | 4                       | 7                  | 4      | 4      | <br>12  | 1   | 3                  | 2              |

- Each Frame has **256 bit** per each BX = 10.24 Gbps
- Data Frame format consists of transceiver overheads, Number of hits, hit information package, timing information, and a flag which shows status of transmission of current bunch cross in the sense that it is finished or not.
- Transceiver overheads : Header + FEC + End of data
- Number of hits shows the number of hit information package which exist inside the current frame information
- **Hit information Package** includes of the detail information of a hit such as **fired strip number** (1 to 96), timing information of a hit (**sub-bx**) which is a four bit number and shows the exact hitting time of fired strip with resolution of 1.56ns, and **the number of link board** as a location of fired strip corresponding to the RPC Chamber
- **Timing information** : using for synchronization and timing alignment of data transmission and contains a bunch cross number (12 bits) and bunch cross zero (BCO).
- **Partition delay:** In the rare physical events, it could be possible the number of hits will not fit inside one frame. In such cases, the reminder of hits information will be send on the consequent frames. The partition delay shows the number of consequent frames. In such frames, the number of bunch cross counter (BNC) is the same as last frame.



Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020

## Control, Diagnostic and Synchronization of New Link System using New Slow Controller

IMS







## **New Slow Controller Functions**



#### Downlink, data direction from <u>new Slow</u> <u>Controller</u> to <u>Control boards</u>:

- Number Links : 216 Downlinks (96 links Endcap CBs + 120 links Barrel CBs)
- Link Protocol: LpGBT Protocol
- Data Rate: 10.24/5.12/2.56 Gbps (All of this speeds are acceptable)
- Fast trigger, Broadcast commands :
  - BC0, EC0, L1A, Hard Reset
- TTC clocks (40.078 MHz)
- Slow control Commands
  - 1. FEB Threshold setting (received from RPC online software)
  - 2. TTC fine skew adjustment (received from RPC online software)
  - 3. Open/Closed windows setting (received from RPC online software)
  - 4. FPGA configuration file (Remote Programming) (received from RPC online software)

- Uplink, data direction from <u>Control</u> <u>boards</u> to the <u>new Slow Controller</u>:
  - RPC strip hit Histogram
    - Counting Hits on every RPC strip
  - Timing Histograms
    - Counting Hits on all RPC strips in each Bunch Cross
  - Link System Status
    - Voltages, current, Temperature
    - Faults, SEU
    - Firmware Version Control





- Present Link system has been working well for more than 14 years (since 2006-2007)
- New Link system improves the muon hit time to 1.56 ns and using the high bandwidth of data transmission (10.24 Gbps) will increase the speed of data taking of RPC chambers
- In new link system, radiation mitigation is achieved by using the firmware TMR and internal scrubbing (SEM)
- The data transmission bandwidth of the new link system will cover the HL-LHC muon rates (with safety factor of 3)
- Muon hit date will send from link system through high speed data transmission optical link to the RPC Endcap back-end electronic and Barrel backend layer-1.
- Synchronization, control and diagnostic of the New link system will be done by using the new Slow Controller





# •Thank you!

### ι παιπ γου:

Behzad Boghrati, CMS RPC Upgrade Phase-II of New Link System, RPC2020 Conference, 10-14th February 2020

## High speed data transmission Performance @ 10.24 Gbps

- Conceptually, we want the eye to be as "open" as possible, as a larger eye opening implies that we have more margin to the voltage and timing requirements. The eye must be wide enough to provide adequate time to satisfy the setup and hold requirement of the receiver, and have sufficient height to ensure that the voltage levels meet v<sub>ih</sub> and v<sub>il</sub> requirements in a system that may possess multiple sources of noise. This allows the receiver to resolve the input signals successfully into digital values.
- Maximum achievable Opening eye for the <u>Ideal Case</u> (Loop back inside the FPGA1) is 55.56% and the Opening eye for the <u>Real Case</u> in which the data transmission will take by connecting two FPGAs through the 120 meters optical channel is 50~55%.
- The Test Period is 48 hours and number of errors is Zero





## The RPC Architecture and L1T







## Example-1



- Let assume that at BX = 23, <u>three</u> strips are fired as follow:
  - Hit-1 : Stripe No. 40, sub-bx = 1 , LB No. = 2
  - Hit-2 : Stripe No. 63, sub-bx = 16 , LB No. = 5
  - Hit-3 : Stripe No. 90, sub-bx = 7 , LB No. = 8







- Let assume that at BX = 23, <u>twenty</u> strips are fired as follow:
  - Hit-1 : <u>Stripe No. 40</u>, <u>sub-bx = 1</u> , <u>LB No. = 2</u>
  - ....
  - Hit-20 : <u>Stripe No. 90</u>, <u>sub-bx = 7</u> , <u>LB No. = 8</u>

| ltem | Header<br>+ FEC<br>24 bits | Number<br>of Hits<br>(114)<br><mark>4 bits</mark> | Strip<br>No.(19<br>6)<br>7 bits | Sub-bx<br>4 bits | LB No.<br>4 bits | •••• | No.<br>Strip<br>(196)<br>7 bits | Sub-bx<br>4 bits | LB No.<br>4 bits | BCN<br>12 bits | BC0<br>1 bit | Partition<br>delay<br>3 bits | End<br>of<br>Data<br>2bits |
|------|----------------------------|---------------------------------------------------|---------------------------------|------------------|------------------|------|---------------------------------|------------------|------------------|----------------|--------------|------------------------------|----------------------------|
| data | х                          | 14                                                | 40                              | 1                | 2                |      | х                               | х                | х                | 23             | 0            | 0                            | х                          |

| ltem | Header<br>+ FEC<br>24 bits | Number<br>of Hits<br>(114)<br>4 bits | Strip<br>No.(1<br>96)<br><b>7 bits</b> | Sub-bx<br>4 bits | LB No.<br>4 bits | <br>No.<br>Strip<br>(196)<br>7 bits | Sub-bx<br>4 bits | LB No.<br>4 bits | BCN<br>12 bits | BC0<br>1 bit | Partition<br>delay<br>3 bits | End<br>of<br>Data<br>2bits |
|------|----------------------------|--------------------------------------|----------------------------------------|------------------|------------------|-------------------------------------|------------------|------------------|----------------|--------------|------------------------------|----------------------------|
| data | х                          | 6                                    | х                                      | х                | х                | <br>90                              | 7                | 8                | 23             | 0            | 1                            | х                          |

# Slow Control, Downlink (BEE to CB)



## • Downlink, data direction from Back-end Electronics to Control boards:

- 216 Advanced links (96 links Endcap CBs + 120 links Barrel CBs)
- LpGBT Protocol @ 10.24 Gbps

| ltem | Header<br>+ FEC<br>[023] | L1A<br>[24] | BC0<br>[25] | EC0<br>[26] | Hard<br>Reset<br>[27] | Command<br>Type<br>[2830] | Command<br>Value A<br>[3138] | Command<br>Value B<br>[3954] | Command<br>Value C<br>[55253] | End of<br>Data<br>[254, 255] |
|------|--------------------------|-------------|-------------|-------------|-----------------------|---------------------------|------------------------------|------------------------------|-------------------------------|------------------------------|
| Bit  | 24                       | 1           | 1           | 1           | 1                     | 3                         | 8                            | 16                           | 199                           | 2                            |

#### Command Types:

- 1. <u>TYPE0</u> : Operating Mode (Calibration, Link Board Setting, Control Board setting, Physics RUN, Standby )
- 2. <u>TYPE1</u> : FEB Parameter Setting / Verification
- 3. <u>TYPE2</u> : TTC fine skew adjustment
- 4. **<u>TYPE3</u>** : Coarse/Fine windows setting
- 5. <u>TYPE4</u> : FPGA Remote Programming
- 6. TYPE5..TYPE7: Reserved





## • Downlink, data direction from Back-end Electronics to Control boards:

| ltem | Header<br>+ FEC<br>[023] | L1A<br>[24] | BC0<br>[25] | EC0<br>[26] | Hard<br>Reset<br>[27] | Command<br>Type<br>[2830] | Command<br>Value A<br>[3138] | Command<br>Value B<br>[3954] | Command<br>Value C<br>[55253] | End of<br>Data<br>[254, 255] |
|------|--------------------------|-------------|-------------|-------------|-----------------------|---------------------------|------------------------------|------------------------------|-------------------------------|------------------------------|
| Bit  | 24                       | 1           | 1           | 1           | 1                     | 3                         | 8                            | 16                           | 199                           | 2                            |

**Command Types: TYPE0** : Operating Mode

```
Command Value A_L [31..34] (Target board)
```

```
Value A_L [31..34] = 0; CB
Value A_L [31..34] = 1; LB1
Value A_L [31..34] = 2; LB2
```

•••

```
Value A_L [31..34] = 9; LB9
```

#### Command Value A\_H [35..38] Command Value:

- 1. Value A\_H [35..38] = 0; Calibration mode
- 2. Value A\_H [35..38] = 1; Link Board Parameter Setting
- 3. Value A\_H [35..38] = 2; Control Board Parameter setting
- 4. Value A\_H [35..38] = 3; Physics RUN
- 5. Value A\_H [35..38] = 4; Standby
- 6. Value A\_H [35..38] = 5; Histogram
- 7. Value A\_H [35..38] = 6; Diagnostic
- 8. Value A\_H [35..38] = 7; Loopback
- 9. Value A\_H [35..38] = 8; FEB Test

Behzad Boghrati, CMS RPC Upgra**10** h**Value** A<u>w</u> H<sub>n</sub>[35..38] = 9..16 ; Are Reserved System, RPC2020 Conference, 10-14th February 2020

# Slow Control, Uplink (CB to BEE)



- Uplink, data direction from Control boards to Back-end Electronics :
  - 216 Uplinks (96 links Endcap CBs + 120 links Barrel CBs)
  - LpGBT Protocol
  - Downlink Speed: 10.24/5.12/2.56 Gbps (All of this speeds are acceptable)
  - FEC5
  - At any moment, a copy of received command from BEE and corresponding data or acknowledge from CB will send back to the BEE

| ltem | Header<br>+ FEC<br>[023] | L1A<br>[24] | ВС0<br>[25] | EC0<br>[26] | Hard<br>Reset<br>[27] | Command<br>Type<br>[2830] | Command<br>Value A<br>[3138] | Command<br>Value B<br>[3954] | Command<br>Value C<br>[55253] | End of<br>Data<br>[254, 255] |
|------|--------------------------|-------------|-------------|-------------|-----------------------|---------------------------|------------------------------|------------------------------|-------------------------------|------------------------------|
| Bit  | 24                       | 1           | 1           | 1           | 1                     | 3                         | 8                            | 16                           | 199                           | 2                            |



# **RPC strip hit Histogram**

- Counting Hits on every RPC strip
  - On each LBs two multichannel counters have been implemented
  - Adjustable window and Full window
  - The buffer size of each Multichannel counter is 96 x 32 bits
  - In total at each CB more than 9 (LBs)x 2 (MCC) X 96 X 32 bits
    - Total Buffer Size = 178176 bits ~ 180 kbits
  - Reading from these buffers are not time critical







## **Timing Histograms**



### • Counting Hits on all RPC strips in each Bunch Cross

- On each LBs one 32 bit counter has been implemented
- At each BX, the content of last BX will store at the FIFO
- The size of FIFO is 128 x 32 bits
- In total at each CB timing histogram buffer
- 9 (LBs)x 1 (Timing Histogram) X 128 X 32 bits
  - Total Buffer Size = 10368 bits ~ 10.4 kbits
- Reading from these buffers are not time critical





## MLB Single Hit Rate wrt Max expected Background Rate at HL-LHC in Barrel



- Expected Max hit rate in Barrel in HL-LHC , safety factor 3: 600 cm<sup>-2</sup> s<sup>-1</sup>
- Biggest Strip surface area : 120 X 3 cm<sup>2</sup>
- Average cluster size: -
- Number of Strip per chamber : 96
- Max Single hit in one LB per bx : 600 x (120 x 3) x 96 x 25 X 10<sup>-9</sup>= 0.52 hit /LB x bx
- One Master Link Board collects hits of two adjacent Slave Link boards
- Max Single hit in one MLB per bx : 0.52 x 3 = 1.56 hit /LB x bx
- Size of hit information Package : 15 bits (Yellow box)
- MLB Max. Payload: 15 bits x 1.56 hits x 40 MHz = 0.936 Gbps
- We foresee to send 232 bits/BX (for physics, already removed EOD and checksums) between MLB and RPC backend.
- Maximum limit of single hits in one MLB = (one frame overheads) / size of one hit = (256 46) / 15 = 14 hits



| 7 | ltems | Header +<br>FEC | Number<br>of Events<br>(1 14) | No. Strip<br>(196) | Sub-bx | LB No.<br>(0 8) | BCN | BCO | Partition | ID |
|---|-------|-----------------|-------------------------------|--------------------|--------|-----------------|-----|-----|-----------|----|
|   | Bit   | 24              | 4                             | 7                  | 4      | 4               | 12  | 1   | 3         | 2  |



## MLB Single Hit Rate wrt Max Expected Background Rate at HL-LHC in Endcap



- Expected Max hit rate in Endcap in HL-LHC , safety factor 3: 700 cm<sup>-2</sup> s<sup>-1</sup>
- Biggest Strip surface area : 66 X 3.125 cm<sup>2</sup>
- Average cluster size: -
- Number of Strip per chamber : 96
- Max Single hit in one LB per bx : 700 x (66 x 3.125) x 96 x 25 X 10<sup>-9</sup> = 0.35 hit /LB x bx
- One Master Link Board collects hits of two adjacent Slave Link boards
- Max Single hit in one MLB per bx : 0.35 x 3 = 1.05 hit /LB x bx
- Size of event : 15 bits (Yellow box)
- MLB Max. Payload: 15 bits x 1.05 hits x 40 MHz = 0.63 Gbps
- We foresee to send 232 bits/BX (for physics, already removed EOD and checksums) between CB and RPC backend.
- Maximum limit of single hits in one CB = (one frame overheads ) / size of one hit = (256 – 46) / 15 = 14 hits



| Items | Header +<br>FEC | Number<br>of Events<br>(1 14) | No. Strip<br>(196) | Sub-bx | LB No.<br>(0 8) | BCN | BCO | Partition | ID |
|-------|-----------------|-------------------------------|--------------------|--------|-----------------|-----|-----|-----------|----|
| Bit   | 24              | 4                             | 7                  | 4      | 4               | 12  | 1   | 3         | 2  |