# DEVELOPMENT OF FPGA-BASED READOUT CONTROLLER IN A CALORIMETER OF AN E-P COLLIDER

## Faridah Mohamad Idris<sup>1,2</sup>, Wan Ahmad Tajuddin Wan Abdullah<sup>2</sup>, Zainol Abidin Ibrahim<sup>2</sup>, Peter Goettlicher<sup>3</sup>

<sup>2</sup>Malaysian Nuclear Agency, Bangi, 43000, Kajang, Selangor, Malaysia.

<sup>2</sup>Physics Department, Faculty of Science, University of Malaya, 50603 Kuala Lumpur, Malaysia.

> <sup>5</sup>Deutsches Electronen Synchrotron (DESY), Hamburg, Germany. e-mail: faridah\_idris@nuclearmalaysia.gov.my

#### ABSTRACT

In complex controlling algorithm, such as in high energy physics experiment, Programmable Gate Array (FPGA) based readout controller may offer the most convenient method for its allows for a trigger improvement and troubleshooting purposes with minimal costing. In case of the readout controller of the calorimeter of the ZEUS detector at Hadron-Electron Ring Accelerator (HERA), the analogue modules i.e. table, pipeline, buffer and format controls, were converted into a single FPGA-based controller, to study trigger sequence between the pipeline and the buffer that have cause unwanted data being carried into the data tables despite the fast clear signal trigger. Hardware descriptive language (HDL) Verilog was used to code the analogue controller into FPGA-based, and later simulated on Quartus II using a single Altera Cyclone configuration. We also include the first version of the hardware interface board with a single FPGA chip in the middle of the board.

### ABSTRAK

Dalam algoritma pengawalan yang kompleks, seperti di eksperimen fizik tenaga tinggi, Programmable Gate Array (FPGA) berpangkalan pengawal baca keluar mungkin menawarkan paling banyak kaedah mudah untuknya membenarkan peningkatan picu dan tujuan-tujuan merumus masalah dengan pengekosan minimum. Jika pengawal baca keluar kalorimeter pengesan ZEUS di Hadron Electron Ring Accelerator, modui-modul analog iaitu meja, saluran paip, penimbal dan kawalan format, telah ditukar ke dalam satu pengawal berasaskan FPGA, untuk belajar jujukan picu antara saluran paip dan penimbal yang mempunyai data tidak dikehendaki punca dibawa ke dalam jadual data walaupun picu isyarat jelas yang cepat. Bahasa deskriptif perkakasan Verilog digunakan untuk kod pengawal analog ke dalam FPGA berpangkalan, dan kemudian dibuat-buat atas Quartus II menggunakan satu tatarajah Altera Cyclone. Kami juga merangkumi versi pertama lembaga antara muka perkakasan dengan satu cip FPGA di tengah-tengah papan litar.

Keywords: readout controller, FPGA-based, single on chip, hardware interface

## INTRODUCTION

In high energy physics data taking, the Programmable Gate Array (FPGA)-based readout controller may offer the best replacement strategy in the detector survival (CMS UG-TP-1, 2010). This is especially pertinent when the readout controller involves a large amount of data-taking at a fast rate, and requires complex controlling algorithm (Altera Corporation, 2011). Single-on-chip FPGA-based controller allows for a trigger improvement and troubleshooting purposes, as well easier for maintenance when design as disposable parts and components.

The analogue readout controller of the former ZEUS detector at HERA (Hadron-Electron Ring Accelerator) was converted into FPGA format to study the trigger sequence between the pipeline and buffer modules that caused the data from physics event which did not belong to the bunch crossing of the pipeline, to be carried into the chain of events - these data should have been aborted when the fast clear signal (FCLR) was triggered, but were still added into the data tables. In case of an active FCLR, this data anomaly could inhibit the efficiency of the data-taking of the readout controller (P. Goettlicher, 2015).

In this paper, we described how the analogue modules of the readout control (ROC) of the calorimeter of the ZEUS detector were converted into the FPGA controller that accommodated more than 140 signals into a single FPGA module. The FPGA-based ROC was later used to demonstrate synchronization sequence between accept (ACT) and abort (ABT) signals between the pipeline and buffer modules that might have caused failure of the aborted data by the buffer, resulting in redundant data being carried into the data chain.



## THEROC MODULES FUNCTION

The controlling readout modules such as in the former ZEUS detector gave a typical example of how the readout controller in a particle collider operated, and might give an insight on the overall mechanism of the readout controller in a particle collider.

Figure 1 shows the readout analog controlling modules i.e. the table, pipeline, buffer, format and generator in the calorimeter of the ZEUS detector. The data taking during the electron-proton collision in the high energy physics experiments were synchronized by a 96 ns or 10MHz HERA clock, using a 24-bits serial data for online control.

Sub modules functioned as follows: the table module interfaced between the General First Level Trigger (GFLT) and the calorimeter readout electronics and, preset the controlling bits of the readout; the pipeline module selected which particular cell out of 96 samples to trigger (B. Schmidke, 2009) during the data taking; the buffer kept the interim data received from the pipeline; the format controller controlled the timing for the digitization of the output; the pulse generator controlled test pulses during data taking and during various offline operation.

The controlling bits during online operation of the readout system were kept in the RAM unit of the table module. The controlling bits included sample delay, number of sample, event types, output format, event type and online/offline mode. During an offline mode, a 16-bits serial data synchronized by a 10MHz clock was send the RAM unit via a 16-bits shift register to preset the controlling bits. The first bit of the serial data would be pushed up to the  $16^{\text{th}}$  bit in the RAM and, was continued until the  $16^{\text{th}}$  bit of the serial data was in the register, before the system was put in online mode and ready data-taking (A. Caldwell *et al.*, 1992).

## THE INTEGRATION OF THE ROCIN FPGA MODE

By integrating the four sub-modules i.e. table, pipeline, buffer and format of the ROC of the calorimeter of the ZEUS detector, into a single FPGA-based controlling module, we demonstrated that a compact ROC system was possible for use in a particle collider. In the following sections we described how the analogue circuits and the logic block diagram of ROC of calorimeter of the ZEUS detector were converted into an FPGA-based ROC.

The block diagram of the original circuits of the analogue controlling modules was used as basics building blocks to the FPGA-based controller. Each block building in the sub-module was converted into an equivalent FPGA block using Verilog, and later combined into working sub-module. This step was repeated for each of the sub-module in the readout controller; all of the sub-modules were later combined to form an FPGA-based readout controller and functioned as a whole unit. Figure 2 gives the flow of coding of the analogue controlling modules into the FPGA-based module.



Figure 2. The analogue modules of readout control (ROC) of the ZEUS detector were coded into single board, FPGA-based using Verilog, starting with basic blocks, later combined to become the main controlling block before being simulated on Quartus II.

Two instances of FPGA-based block are given in while Figure 4, e.g. 16-bit non-blocking shift register (Figure 4a) and 16-bit RAM unit (Figure 4b) in full Quartus II RTL viewer, while Figure 3 show the FPGA-based ROC that integrated table, pipeline, buffer, format modules in full Quartus II RTL viewer.





## SIMULATION OF THE FPGA-BASED ROC

The FPGA-based ROC in Figure 3 was simulated on Quartus II using the device settings of Altera Cyclone I. In pre-setting the controlling bits, a flag 0 was given to the ROC to isolate the system in offline mode. Each serial data consist of 4 bytes control data given to RAM in table module, with each bit of the serial data is only counted on negative change of the clock edge, where subsequent byte pushes a prior byte up the 16-bit shift register. Figure 5 shows the part of the vector waveform used in Quartus II for the simulation for serial data input into the RAM – each bit was pushed by a prior bit into the next register in the chain (A. Caldwell et al., 1992). Once set, the ROC was put on-line again, where the signals from GFLT (Global First Level Trigger) would determine the controlling sequence of the readout control (F. Mohamad Idris *et al.*, 2009).



Figure 6a shows the output of the ROC simulation - when the pipeline accept data PACT is triggered, the pipeline busy PBSY and the pipeline read PREAD are triggered with PCLK temporarily disabled. Here, the buffer read is flagged 0 and the BCLK is temporarily disabled. Figure 6(b) gives a closer look at the sequence of pipeline and buffer triggers upon abort ABT signal by GFLT. On a negative edge of ABT from GFLT, the pipeline abort PABT triggers and pipeline accept PACT is flagged down to 0. During the abort trigger, the buffer is still flagged 0 and only changes to 1 about 0.07 ms later, resulting in unused data being taken by the buffer instead of rejecting it.

| GFLT_busy  |   |       |     |   |  |
|------------|---|-------|-----|---|--|
| Offline    |   |       |     |   |  |
| STRB       |   |       |     |   |  |
| TYP        |   |       | 000 |   |  |
| TSTEN      |   |       |     |   |  |
| DBSY       |   |       |     |   |  |
| PBSY       | Π |       |     |   |  |
| PACT       |   |       | Π   |   |  |
| PABT       |   |       |     |   |  |
| PCLK       |   |       |     |   |  |
| PREAD      | Π | Π     | Π   | Π |  |
| TEST_PULSE |   |       |     |   |  |
| NIM_TRIG   |   |       |     |   |  |
| NIM BSY    | п |       |     |   |  |
| SYNC       |   |       |     |   |  |
| cellg      |   |       |     |   |  |
| BR         |   | ┓╻┍╾╾ |     |   |  |
| BCLK       |   |       |     |   |  |
| BINCR      |   |       |     |   |  |
| clk50MHz   |   |       |     |   |  |
|            |   |       |     |   |  |
|            |   |       |     |   |  |

Figure 6a. Output signals from the FPGA-based readout control

| GFLT       | 00000000 | 0000bX | 1 | 10000 | 00000 | 0000 |   | ж  |   |      | 0   | 0000 | 0000 | 0000 |   |   |   |   |
|------------|----------|--------|---|-------|-------|------|---|----|---|------|-----|------|------|------|---|---|---|---|
| GFLT[12]   |          | Ē      |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| GFLT[11]   |          |        |   |       |       |      |   | Ĩ. |   |      |     |      |      |      |   |   |   |   |
| GFLT[10]   |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
|            | -        |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
|            |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
|            |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| DBSY       |          |        |   |       |       |      | _ | _  | _ |      | _   |      |      | _    | _ | _ | - | _ |
| PBSY       |          |        |   |       |       |      |   | _  |   |      |     |      |      | _    | _ | _ |   | _ |
| PACT       |          |        |   |       |       |      |   |    |   |      |     |      |      |      | _ | _ |   | _ |
| PABT       |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| PCLK       |          |        |   |       |       |      |   |    |   | பாபா | սոս | ГЛ   |      |      |   |   |   |   |
| PREAD      |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| TEST_PULSE |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| NIM_TRIG   |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| NIM_BSY    |          |        | _ |       |       |      | - |    |   |      |     |      |      |      |   | ٦ |   |   |
| SYNC       |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| cellg      |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| BR         |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |
| BCLK       |          |        |   |       |       |      |   |    |   |      | L   |      | IT   |      |   |   |   |   |
| BINCR      |          |        |   |       |       |      |   |    |   |      |     |      | Π    |      |   |   |   |   |
|            |          |        |   |       |       |      |   |    |   |      |     |      |      |      |   |   |   |   |

Figure 6b. A close-up of the FPGA-based readout control showing the abort ABT signal from the pipeline control. Global first level trigger during on-line operation with GFLT[12]: ACT=1 for Accept data trigger, while GFLT[11]: ABT=1 for Abort data trigger (CP: HERA clock 10MHz).

Table 1 gives some of the output labels used the FPGA-based readout control (ROC) block, with the output waveform as given in Figure 6 (a) and (b).

| Input label           | Input Status      | Flag     | Output label | Output          | Flag    |
|-----------------------|-------------------|----------|--------------|-----------------|---------|
| HERA clock<br>(CP)    | 96ns              | clock    | GFLT_busy    | GFLT busy       | 1       |
| Global First          | GFLT[12]          | 1        | Offline      | System is off-  | 1       |
| Level Trigger         | Accept $(ACT)$    |          |              | line            |         |
| (GFLT)                |                   |          |              |                 |         |
|                       | GFLT[11] Abort    | 1        | STRB         | Strobe signal   | 0       |
|                       | (ABT)             |          |              |                 |         |
| Serial [7:0]          |                   |          | TYP          | Type of event   | 000     |
| Serial [1]            | Table             | 16  bits | TSTEN        | Test mode       | 0       |
|                       |                   |          |              | enable          |         |
| Serial [3]            | Pipeline          | 16  bits | DBSY         | Data busy       | 0       |
| Serial [5]            | Format            | 16  bits | PBSY         | Pipeline busy   | 1       |
| Serial [6]            | Generator         | 16  bits | PACT         | Pipeline accept | 1       |
|                       |                   |          |              | data            |         |
| Serial [1],[2],[4][6] | $10 \mathrm{MHz}$ | clock    | PABT         | Pipeline abort  | 1       |
|                       |                   |          |              | data            |         |
| Offline               | System offline    | 1        | PCLK         | Pipeline clock  | counter |
|                       | System online     | 0        | PREAD        | Pipeline read   | 1       |
| TYP[2:0]              | Type of user      |          | cellg        | Number of       | 1       |
|                       | request           |          |              | bunch crossing  |         |
| TESTEN                | Test enabled      | 1        | BR           | Buffer read     | 1       |
|                       | Test disabled     | 0        | BCLK         | Buffer clock    | counter |

Table 1. Some of the input/output label from FPGA-based readout control (ROC) and their status

## FPGA-BASED ROC POWER CONSUMPTION

With the designed FPGA-based readout control (ROC), simulation on Quartus II resulted in a total number of 123 input/output pins and 7,010 of logic elements used. In Table 2, the dissipated power calculated for the FPGA-based ROC is given, with a total of 189.61 mW of dissipated power expected for the design ROC. Of the three components, the core static power dissipation contributed the highest at 71% of the total power loss (F. Mohamad Idris, 2011).

| Component                       | Power dissipated | percentage |
|---------------------------------|------------------|------------|
| Core dynamic power dissipation  | 35.73 mW         | 19%        |
| Core static power dissipation   | 134.79 mW        | 71%        |
| I/O power dissipation           | 19.09 mW         | 10%        |
| Total thermal power dissipation | 189.61 mW        | 100%       |

Table 2. Thermal dissipation of readout control block

## HARDWARE DEVELOPMENT

In hardware implementation of the FPGA-based ROC, Proteus software was used to design the PCB layout with an Altera Cylone I FPGA chip mounted in the centre of the board, and with a total of 37 chips i.e. 12 of the ECL-to-TTL type, 16 of the TTL-to-ECL type, 7 of the bus driver type and 2 of the for OR gate type, allocated for ECL-TTL inputs and TTL-ECL outputs of the Altera Cylone I FPGA chip.

In Figure 7, the fabricated printed circuit board (PCB) designed using Proteus software is shown. In the figure, the FPGA kit with Altera Cylone I chip is mounted in the middle of the PCB. The board was tested in laboratory using a -5.2V for  $V_{EE}$  and initial current  $I_{EE}$  supply of 0.5A and, a 5.0V for  $V_{CC}$  and initial current  $I_{CC}$  of supply 0.63A.



Figure 7. A 7inch by 11inch (17.5cm by 27.5cm) PCB designed using Proteus software, with the FPGA Altera Cyclone mounted in the middle and TTL-ECL, ECL-TTL and Quad Bus Driver chips mounted fully. The PCB was tested in laboratory using frequency generator and high current voltage supply

During laboratory test, the chips were mounted one by one on the PCB. Each time the voltage supply  $V_{EE}$  and  $V_{CC}$  dropped with mounted chips, the currents  $I_{CC}$  and  $I_{EE}$  were adjusted again until the initial voltages  $V_{EE}$ =-5.2V and  $V_{CC}$ =5.0V were regained.

Figure 8 shows the plot of current  $I_{CC}$  (A) and  $I_{EE}$  (A) versus number of chips of TTL-ECL quad translator type, while Figure 9shows the same plot for quad bus driver type. In both figures, the currents  $I_{CC}$  and  $I_{EE}$  increased with the number of chips mounted on the PCB, after an initial plateau. For TTL-ECL quad translator type both  $I_{CC}$  and  $I_{EE}$  show the same trend, but in quad bus driver type chip the currents is higher with  $I_{CC}$  dropped lower before increasing.

In quad bus driver type chip, the power dissipation was 575 mW or a total of 6.9 Watt power dissipation produced by 12 chips, thus higher bias current was needed than the TTL-ECL quad translator type.

In Figure 10, the plots of power (watt) from bias drain and emitter currents and their total power versus number of chips for quad TTL-ECL quad translator driver are given, while Figure 11 gives the

same plot for quad bus driver. In both plots, the same trend as in Figure 8 and Figure — observed. In these figures, the linear increase in bias currents and power after a certain number of chips mounted on the PCB indicates that improvisation of the PCB to remove excess heat dissipation is needed.









## DISCUSSION

In the FPGA-based readout control (ROC) that has been developed for the calorimeter of the ZEUS detector, four controlling modules i.e. pipeline, table, buffer and format, were integrated into a single module on a single FPGA chip, and interfaced on a single PCB piece. In a complex control system that

uses high speed synchronization such as an accelerator, this type of control system designed on a single chip may offer an alternative as it is compact, could be modify for diagnostic and upgrading purposes, and could be use as disposable component in maintenance. In this paper, we demonstrated such diagnostic characteristic of FPGA control could be used to diagnose that the delay between pipeline and buffer abort signals that caused unwanted data being carried into the data chain.

The implementation of the FPGA-based ROC on a single module shows that most of the energy lost through core static power dissipation. The interfacing of the FPGA-based ROC on a single PCB board together with the translator chips would cause excess heat dissipation from the chips. Heat sinkers and fans could be of use to remove the heat dissipation excess.

The use fully FPGA-based ROC in its entirety would pose challenges. One would be to design the FPGA-controller to last as long as the interfacing electronic components of the controller, as the former may face obsolescence.

#### CONCLUSION

In this paper, we have shown that integrating the four sub-modules of the ROC of a calorimeter of a particle detector into a single module FPGA-based readout controller is feasible, as it is compact and easier to modify in future, than the conventional system. We have also shown that the FPGA-based ROC could be used to analyze the synchronization of accept and abort signals between the pipeline and buffer modules in the ROC.

The design of a single module FPGA-based ROC on a single chip and mounted on 17.5cm by 27.5cmPCB and surrounded by quad translators and quad bus drivers, while novel for maintenance purposes, needs further improvement to increase its performance and reduce its power consumption and heat dissipation.

#### ACKNOWLEDGEMENT

The authors would like to acknowledge and extend our gratitude the ZEUS Collaboration DESY, Physics Department University of Malaya and Malaysian Nuclear Agency MOSTI in making this project a success.

#### REFERENCES

- A. Caldwell and S. Ritz (1992), User Interface to the CAL Electronics Readout, ZEUS-Note 92-046.
- Altera Corporation, User-Customizable ARM-based SoC FPGAs for Next-Generation Embedded Systems, White paper, Altera Corporation, October 2011.
- B. Schmidke, (2009), The CAL Readout; Columbia University/ZEUS Collaboration.
- F. Mohamad Idris, Long-lived neutral hadrons in the calorimeter of the ZEUS detector, PhD thesis, University of Malaya 2011.

- F. Mohamad Idris, W.A.T. Wan Abdullah, Z.A. Ibrahim, B. Kamaluddin (2009); Design and Simulation of FPGA-Based Readout Control A High-Energy Electron-Proton Collision Calorimeter, AIP Conference Proceeding Neutron and X-ray Scattering in Advancing Materials Research 2009; AIP ISBN 978-0-7354-0739-8.
- P. Goettlicher, Changes in the Pipeline Controller to solve the loss of FCLR, DESY/FEB May, 22<sup>nd</sup> 2005.
- The CMS Collaboration, Technical Proposal for the Upgrade of the CMS Detector Through 2020, CMS UG-TP-1.