# The ATLAS Level-1 Central Trigger System

P. Borrego Amaral, N. Ellis, P. Farthouat, P. Gällnö, J. Haller, T. Maeno, T. Pauly, H. Pessoa Lima, Jr., I. Resurreccion Arcas, J. M. de Seixas, G. Schuler, R. Spiwoks, R. Torga Teixeira, and T. Wengler

Abstract—The central part of the ATLAS Level-1 trigger system consists of the central trigger processor (CTP), the local trigger processors (LTPs), the timing, trigger, and control (TTC) system, and the read-out driver busy (ROD\_BUSY) modules. The CTP combines information from calorimeter and muon trigger processors, as well as from other sources, and makes the final Level-1 accept decision (L1A) on the basis of lists of selection criteria, implemented as trigger menus. Timing and trigger signals are fanned out to about 40 LTPs, which inject them into the subdetector TTC partitions. The LTPs also support stand-alone running and can generate all necessary signals from memory. The TTC partitions fan out the timing and trigger signals to the subdetector front-end electronics. The ROD\_BUSY modules receive busy signals from the front-end electronics, and send them to the CTP (via an LTP) to throttle the generation of L1As. An overview of the ATLAS Level-1 central trigger system will be presented, with emphasis on the design and tests of the CTP modules.

Index Terms—Timing, trigger.

#### I. THE CENTRAL TRIGGER SYSTEM

T HE ATLAS Level-1 trigger [1] is a synchronous system operating at the bunch-crossing (BC) frequency (40.08 MHz) of the large hadron collider (LHC) accelerator. It uses information on clusters and global energy in the calorimeters and from tracks found in dedicated muon trigger detectors. An overview of the ATLAS Level-1 trigger is shown in Fig. 1. The central trigger system consists of the central trigger processor (CTP) and the timing, trigger, and control (TTC) partitions.

The CTP itself forms the Level-1 Decision (accept or not) every 25 ns, and distributes it to the TTC partitions. It also receives the timing signals from the LHC and fans them out to the TTC partitions.

The TTC partitions perform the distribution of the TTC signals to all subdetector front-end electronics. In the ATLAS experiment, there are about 40 TTC partitions. Each contains one local trigger processor (LTP) [2], [3], a TTC system proper [4], [5], and a busy tree. The TTC system proper encodes the signals received from the CTP, converts them into optical signals, and fans them out to the detector front-end electronics, where they are recovered by a dedicated ASIC chip. The busy tree is a fast feedback tree for the front-end electronics to throttle the generation of Level-1 accept (L1A) decisions. It is based on the ATLAS read-out driver busy (ROD\_BUSY) module [6].

H. P. Lima, Jr. and J. M. de Seixas are with the Federal University of Rio de Janeiro, Rio de Janeiro RJ 21945-970, Brasil (e-mail: seixas@lps.ufrj.br).

Digital Object Identifier 10.1109/TNS.2005.852648

calorimeter trigger Central Trigger Processor Central Trigger Processor UTP BUSY TTC detector front-end

Fig. 1. Overview of the ATLAS Level-1 trigger.

In October 2004, the system was tested successfully at CERN in a combined test-beam with 25 ns bunch structure. A brief description of these tests is given in Section IV.

### II. OVERVIEW OF THE CENTRAL TRIGGER PROCESSOR

The CTP has many functions that can be divided into three groups: it synchronizes and aligns in time trigger information coming from different sources; it forms the Level-1 trigger decision and distributes it to the TTC partitions; it provides readout data to, and is controlled by, the data acquisition system.

#### A. Trigger Inputs

The CTP receives information from the calorimeter and muon trigger processors. The trigger information consists of multiplicities for electrons/photons, taus/hadrons, jets, and muons, and of threshold flags for total transverse energy, total missing energy, and total jet transverse energy. Other external inputs such as beam-pickup signals, cosmic rays triggers, minimum bias and luminosity triggers, will also be used. A total of 160 external input bits can be taken into account by the CTP at any given time. The CTP first has to synchronize and align all these inputs coming from different sources, so that the subsequent processing stage sees all of the selected data coming from the same BC. Finally, the CTP provides internal triggers from random generators, for BC groups and prescaled clocks.

#### B. Trigger Formation

The CTP generates an L1A derived from the trigger inputs according to the Level-1 trigger menu, which describes the Level-1 physics selection. It consists of up to 256 trigger items, each of which is a combination of one or more conditions on any of the trigger inputs. For example, "At least one Muon with transverse momentum greater than 10 GeV AND missing transverse energy greater than 20 GeV AND a filled bunch (as obtained from the beam pickups)". Each trigger item also has

Manuscript received October 27, 2004; revised March 8, 2005.

P. B. Amaral, N. Ellis, P. Farthouat, P. Gällnö, T. Maeno, I. R. Arcas, G. Schuler, R. Spiwoks, R. T. Teixeira and T. Wengler are with CERN, Geneva 23, Switzerland (e-mail: Ralf.Spiwoks@cern.ch).

a mask, a priority for the deadtime generated by the CTP (see Section III-D) and a prescaling factor. The L1A is the logical OR of all (masked and prescaled) trigger items.

The rate of L1A is limited by the CTP itself, by introducing deadtime. This limits the rate of L1A up to a maximum of 75–100 KHz, that the front-end electronics should be able to sustain. The CTP also receives the busy signals from the subdetectors to throttle the L1A generation, so that further L1As are inhibited until the busy condition set by the subdetectors is cleared.

The CTP not only generates the L1A, but also provides with each L1A an 8-bit trigger-type summary word which indicates the type of trigger, and which can be used to steer event data processing in the detector front-end electronics. The CTP provides an event counter reset (ECR) signal.

The formation of the trigger is required to be performed within four BCs from input to the CTP until output of the L1A out of the CTP. This corresponds to a latency of 100 ns, out of a total Level-1 latency of less than 2.5  $\mu$ s. The Level-1 trigger menu used for the trigger formation is likely to change frequently, depending on the physics, beam, and detector conditions. Hence, it must be easy to reload a new trigger menu into the CTP.

## C. Data Acquisition

The CTP sends, at every L1A, Region-of-Interest (RoI) information to the Region-of-Interest builder (RoIB) of the Level-2 trigger system for guidance of the Level-2 trigger algorithms. The CTP further sends, at every L1A, information to the Read-Out System (ROS) of the data acquisition system. The CTP also provides monitoring data, to be read out via VMEbus: snapshots of incoming data, bunch-by-bunch monitoring of inputs, and scalers of trigger inputs and trigger items before and after prescaling integrated over all bunches.

The CTP and the LTPs, as well as the TTC system and ROD\_BUSY modules, are configured, controlled, and monitored by the ATLAS Online System [7], [8]. This is performed via single-board computers that communicate with the modules via VMEbus.

## III. DESIGN AND STATUS OF THE CTP

The block diagram of the CTP is shown in Fig. 2.

The CTP consists of a machine interface module for timing (CTP\_MI), up to three input modules (CTP\_IN), a bunch-by-bunch monitoring module (CTP\_MON), a core module for trigger formation and read-out (CTP\_CORE), up to four output modules connecting to the LTPs (CTP\_OUT), and a module to handle calibration requests from the subdetectors (CTP\_CAL).

The CTP modules are housed in a 9U VME64x crate. In addition to the standard VMEbus, the CTP modules also use dedicated buses for synchronized and aligned trigger inputs (PITbus, PIT = "pattern in time"), for the common timing and trigger signals (COMbus), and for the calibration requests from the subdetectors (CALbus). Technical details on the CTP design that are not described in the following sections can be found in [9].



Fig. 2. Block diagram of the CTP with its modules, backplanes, and signals.

## A. The CTP Backplanes

The CTP uses two dedicated backplanes. One backplane contains both the PITbus and the CALbus, since they do not overlap (see Fig. 2). The PITbus carries the synchronized and aligned trigger inputs from up to three CTP\_IN modules to the CTP\_MON and the CTP\_CORE modules. The PITbus contains 160 signals, and extends over only five VMEbus slots. Hence, it is implemented as a single-ended, multidrop, SSTL-2-like bus. It is terminated at the destination, namely, the (parallel) resistors of the CTP\_MON and CTP\_CORE modules. The CALbus carries the calibration requests from up to four CTP\_OUT modules to the CTP\_CAL module. The CALbus contains 64 signals, extending over five VMEbus slots, and is implemented as point-to-point LVDS. The PIT/CAL backplane is a four-layer, impedance-controlled printed circuit board (PCB), mounted in the position of the J5/J6 connectors.

The other backplane contains the COMbus. The COMbus carries the timing signals, i.e., BC clock and LHC orbit (ORBIT), the trigger signals, i.e., L1A, the trigger type, and the busy signal. It also carries the control signals, i.e., ECR, synchronization signal (SYN), and calibration prepulse. The COMbus extends over all 11 CTP modules, except for L1A, trigger type, and prepulse, which only go from the CTP\_CORE module to all CTP\_OUT modules and the CTP\_CAL module. For the timing signals (BC, ORBIT, ECR, SYN), a differential LVPECL point-to-point differential fan-out is used from the CTP\_MI to all other modules. The trigger signals (L1A, trigger type, prepulse), are distributed from the CTP CORE using a multidrop differential LVPECL bus, terminated at a single location, at the end of the backplane. Finally, the busy signal is the wired-OR signal of the individual busy signals of all CTP modules. The busy signal is implemented as multipoint-LVDS, terminated on the backplane. The COM backplane is a nine-layer, impedance-controlled PCB, and is mounted at the back of the J0 connector.

Both backplanes were successfully manufactured and tested, after careful pre-layout simulation of the signal's propagation and integrity.



Fig. 3. Block diagram of the CTP\_MI module.

#### B. CTP\_MI Module

The CTP\_MI [10] is the timing module of the CTP; it receives the timing signals (BC, ORBIT) from the LHC via the TTCmi [4] or generates them locally. It also generates the ECR and SYN control signals. Both the timing and control signals are sent to the COMbus, to be distributed to the other modules. The CTP\_MI also receives, monitors, and masks the busy signals that may be received from the subdetectors, other external inputs, or internally generated. The block diagram of the CTP\_MI module is shown in Fig. 3.

The CTP\_MI module is based on FPGAs (ALTERA Cyclone) and the CERN high-performance TDC (HPTDC) [11] for phase measurement.

## C. CTP\_IN Module

The block diagram of the CTP input module (CTP\_IN) is shown in Fig. 4.

The CTP\_IN module [12] receives trigger inputs from the trigger processors, i.e., the calorimeter and muon trigger processors, or other sources. The link between the muon and calorimeter trigger processors and the CTP\_IN is implemented in LVDS. Each module can receive up to  $4 \times 31$  trigger inputs, for a total of 372 trigger inputs, if all three CTP\_IN modules are used. In the pipeline block of each CTP IN, each of the trigger inputs is synchronized with respect to the internal clock, the parity is checked, and the data are aligned with respect to the BC identifier (BCID). The alignment delay of each input is programmable via VMEbus, from 1 to 63 BC clock cycles. The CTP\_IN module then selects and routes 160 trigger inputs to be sent to the PITbus, via a switch matrix. It can store a snapshot of the trigger inputs in a test memory or provide trigger inputs from the test memory. The test memory has a capacity to store or emulate trigger inputs for 18 LHC orbits. Finally, the CTP\_IN module also monitors the trigger inputs using scalers that integrate over all bunches.

The CTP\_IN module is based on ALTERA Stratix FPGAs for the pipeline block, Cypress dual-port memories for the test memories, Lattice XPLD for the switch matrix, and HPTDCs [11] for the phase measurement of the trigger inputs. The monitoring block is implemented with an Altera Cyclone FPGA. A first prototype of the CTP\_IN, shown in Fig. 5, was designed, manufactured, and tested.

#### D. CTP\_CORE Module

The CTP\_CORE module [13] receives and synchronizes the 160 trigger *inputs* from the PITbus, coming from the CTP\_IN modules. It combines these with additional internal triggers in a look-up table (LUT) to form 256 trigger *conditions*. This LUT mapping is necessary to decode the incoming multiplicities and energy flags, while allowing for maximum flexibility in

the mapping. The trigger conditions are then mapped onto 256 trigger *items* (i.e., the trigger menu) using a ternary content-addressable-memory (CAM). With the CAM implementation, each trigger item can be a combination of any of the 256 trigger conditions, while respecting the latency budget. Moreover, the trigger menu can be changed easily, by downloading the LUT and CAM memories via VMEbus access to the CTP\_CORE module. The LUT and CAM are implemented with a Xilinx Virtex-II FPGA. The architecture is shown in Fig. 6.

Each of the 256 trigger items is individually masked, prescaled, and assigned a priority level, using an ALTERA Stratix FPGA. The CTP\_CORE module adds deadtime in order to prevent the detector front-end buffers from over-running. Two sets of leaky-bucket algorithms [13] are used to count and limit the number of L1As generated over a given period of time. The two deadtimes are associated with two different priorities of trigger items. The final L1A is the OR of the masked and prescaled trigger items, where items might be vetoed by the deadtime logic (depending on the priority level) or by the busy signal received by the CTP\_CORE. A trigger-type word is also formed, depending on which trigger items caused the L1A. Both the L1A and the trigger type are sent to the COMbus to be distributed to the subdetectors via the CTP\_OUT and LTPs.

Upon an L1A, the module sends RoI information to the RoIB of the Level-2 trigger system, indicated in Fig. 2 as "L2\_Link." Also, trigger summary information is sent to the ROS, shown in Fig. 2 as "RO\_Link." This information is a superset of the RoI information, and can contain several bunches before and after the triggering bunch for debugging and monitoring purposes. For each bunch, it contains the 160 trigger inputs, and the 256 trigger items both before and after masking and prescaling. This readout block is implemented in two ALTERA Stratix FPGAs. Within these FPGAs, monitoring scalers of the trigger items are also implemented, to be read via VMEbus.

As for the physics capabilities of the current implementation of the trigger menu, it is worth noting that the total number of trigger inputs (160), as well as of (individually masked and prescaled) trigger items (256) is substantially larger than in the trigger tables currently foreseen for the LHC startup [1].

The CTP\_CORE module was designed and built (see Fig. 7). The critical functionality, namely, the part necessary for the trigger formation, was successfully tested.

## E. CTP\_MON Module

The block diagram of the CTP monitoring module (CTP\_MON), see also [14] and [15], is shown in Fig. 8.

The CTP\_MON module receives and synchronizes the trigger inputs from the PITbus. It decodes and selects the trigger inputs to be monitored. The CTP\_MON module monitors trigger information on a bunch-by-bunch basis. Specifically, for each selected trigger input, the histogram occupancy versus BCID is updated every 25 ns.

The CTP\_MON module uses numerous segmented memories in four Altera Stratix FPGAs for the counters. A total of 2 MBytes are required, i.e., 160 trigger inputs times 3564 BCs times 30 bits per counter. Using 30-bit counters, the CTP\_MON can perform the histogramming for 26 hours, without overflow, even for an input always active (counter increments once per



Fig. 4. Block diagram of the CTP\_IN module.



Fig. 5. Photograph of the CTP\_IN module.



Fig. 6. LUT and CAM of the CTP\_CORE module.

LHC turn, i.e., every 89  $\mu$ s). To read the histograms stored in memory, external IDT FIFOS and an ALTERA Apex FPGA are used. The CTP\_MON, shown in Fig. 9, was tested successfully. Note that only one out of the four Stratix devices was mounted, which is enough for validation of the design in the October 2004 test-beam.



Fig. 7. Photograph of the CTP\_CORE module.



Fig. 8. Block diagram of the CTP\_MON module.

## F. CTP\_OUT Module

The CTP\_OUT [16] is the fan-in/fan-out module of the CTP providing the connection to the LTPs. It receives timing and trigger signals (13 bits) from the COMbus, and fans them out to five LTPs. In turn, it receives 4 bits (busy signal and calibration requests) from the LTPs. In the same way as the ROD\_BUSY module, the CTP\_OUT combines, masks, and monitors the busy signal, and provides the busy-OR to the COMbus. The calibration requests are sent to the CALbus.

The busy logic and interface to the VMEbus are implemented with an ALTERA Cyclone FPGA. The CTP\_OUT link to the



Fig. 9. Photograph of the CTP\_MON module.

LTPs is done in LVDS with low-skew cables. The first prototype of the CTP\_OUT module was designed and tested.

## G. CTP\_CAL Module

Some ATLAS subdetectors expressed the need for calibration triggers during the orbit gap of a physics run. The CTP\_CAL module tries to address this requirement, by time-multiplexing the calibration requests on the CALbus per LHC ORBIT, and sending them to the CTP\_IN. The CTP\_CAL can also serve as a patch-panel to receive other external trigger inputs from beam pick-up monitors and test triggers, which are then provided to the CTP\_IN module. The CTP\_CAL module needs to be designed, and was not needed for the test of the CTP system during the October 2004 test-beam.

#### H. Local Trigger Processor (LTP)

The LTP, see also [3], is a programmable input/output switch for TTC signals. One LTP will be used per TTC partition in ATLAS, for a total of about 40 modules. The input can be chosen among the signals from the CTP (from the CTP\_OUT module), or from the LTP daisy chain, from local input, or from the LTP's pattern generator.

Outputs are available to the LTP daisy chain and to the TTC system local to the same TTC partition. In addition, test outputs are provided. The LTP also receives the busy signals from the ROD\_BUSY modules and sends them to a CTP\_OUT or another LTP. Hence, the LTP allows each TTC partition to run in one of the following modes.

- In *common* mode, the CTP drives the TTC partition. The LTP is then an interface between the CTP and the TTC system. This is the normal mode for physics running.
- In *stand-alone* mode, the LTP drives the TTC partition from local inputs or its pattern generator. This is the mode for calibration or debugging of a single TTC partition.
- Two or more TTC partitions can be used in *combined mode* by programming one LTP as the master and by programming the other LTPs as slaves. This mode allows one to run several TTC partitions together for calibration

runs with more than one subdetector, e.g., calorimeter detector and calorimeter trigger.

The LTP was designed as a 6U VMEbus double-width module using CPLDs and external RAMs for the pattern generator. Six prototypes were built, and one was used at the test-beam.

#### I. ROD\_BUSY Module

The ROD\_BUSY module [6] receives 16 input busy signals from the detector's read-out drivers (RODs) or from other ROD\_BUSYs. Each individual input (TTL open collector) can be masked, and the overall OR of the masked inputs is formed. The ROD\_BUSYs can be daisy chained, until the last one feeds an LTP, from which the busy signal will arrive at the CTP\_OUT to throttle the L1A generation. The busy inputs are monitored, so that the history of the first (or last) 3.3 seconds of all the 16 inputs is stored in FIFOs. An interrupt request might be asserted if the overall BUSY\_OR is active for longer than a preset time limit.

The ROD\_BUSY is a 6U single-width module, implemented using ALTERA CPLDs and discrete FIFOs. A total of 60 modules will be used in ATLAS, and 12 were produced and tested. The ROD\_BUSY module was used at the test-beam.

#### IV. THE CTP IN THE ATLAS COMBINED TEST-BEAM

In October 2004, the CTP was tested during the ATLAS combined test-beam, using particle beams with 25 ns bunch structure. A complete  $\varphi$  slice of the central part of the ATLAS detector was tested with protons, muons, electrons, and pions of different energies.

The electromagnetic and hadronic barrel calorimeters provided data to the calorimeter trigger processor, that in turn fed the CTP. Similarly, both the barrel and end-cap muon trigger detectors fed the muon trigger processor, which then sent muon candidates multiplicities to the CTP. In addition, scintillator triggers from the beam instrumentation were also connected to the CTP\_IN. In total, the CTP\_IN received 46 bits of trigger information that were used to form 18 trigger items on the CTP\_CORE. They could be prescaled and masked correctly.

The CTP was used with one CTP\_MI, one CTP\_IN (of up to three), one CTP\_CORE, one CTP\_OUT (of up to four), and one CTP\_MON. The CTP\_OUT was connected to one LTP, from which the L1A and other timing signals were fanned out. All the trigger inputs were timed in, and a first combined muon and calorimeter trigger was achieved, with the resulting L1A being distributed to all the subdetector front-end electronics via an LTP and the TTC system. A ROD\_BUSY module was used to throttle the generation of this L1A.

A preliminary analysis of the data taken shows correlation between the calorimeters and the calorimeter trigger processors, as well as the muon trigger detectors and the muon trigger processors. In particular, the system was able to trigger on a muon contamination of a pion beam, using the muon trigger processors and the CTP. The basic functionality of the complete ATLAS Level-1 trigger electronics and, in particular, of the central trigger system, was thus achieved, and the design validated. Finally, a preliminary measurement of the latency of the CTP was done. A value of about 130 ns was measured. This is already close to the target value of 100 ns, taking into account that cable delays and other settings of the CTP were not fully optimized.

A more detailed description of the operation of the CTP and results of the test-beam will be given elsewhere.

#### V. CONCLUSION

The Level-1 central trigger system of ATLAS is now designed, and the full chain was tested successfully in a realistic environment in October 2004, in a combined test-beam with 25 ns bunch structure, along with other ATLAS subdetectors and trigger processors.

Substantial progress has been achieved on the CTP over the last year; all the modules and backplanes implementing full functionality have been designed, with the exception of the CTP\_CAL, which is a comparatively simple interface module. A prototype of the system has been built, with each type of module already having the final functionality. The test and integration with the trigger processors at the test-beam was successful.

Regarding the TTC partitions, the hardware is now available with the complete functionality. Besides the TTC system itself, which is by now in a mature state, 12 final prototypes of the ROD\_BUSY modules have been tested. The first six prototypes of the LTP have been produced, and one was used at the testbeam.

The October 2004 test-beam allowed a final validation of the central trigger system design. After incorporating any final changes to the design, construction, installation, and commissioning of the full system in the experimental area can proceed.

## ACKNOWLEDGMENT

The authors would like to thank their colleagues from the all the ATLAS subdetectors, in particular, the calorimeter and muon trigger and data acquisition groups for their collaboration during the October 2004 test-beam.

#### REFERENCES

- "First-Level Trigger Technical Design Report," ATLAS Collaboration, Rep. CERN/LHCC/98-14, 1998.
- [2] The ATLAS LTP Module [Online]. Available: https://edms.cern.ch/ item/EDA-00508
- [3] P. B. Amaral *et al.*, "The local trigger processor (LTP) of ATLAS," *IEEE Trans. Nucl. Sci.*, submitted for publication.
- [4] The TTC System [Online]. Available: http://ttc.web.cern.ch/TTC /intro.html
- [5] B. G. Taylor, "Timing distribution at the LHC," in Proc. 8th Workshop Electron. LHC, Future Exper., Colmar, France, Sep. 2002, pp. 63–74.
- [6] The ATLAS ROD\_BUSY Module MkII [Online]. Available: https://edms.cern.ch/item/EDA-00501
- [7] The ATLAS Online System [Online]. Available: http://atlasonlsw.web.cern.ch/Atlas-onlsw
- [8] "High-Level Trigger Data Acquisition and Controls Technical Design Report," ATLAS Collaboration, Rep. CERN/LHCC/2003-022, 2003.
- [9] Intermediate Design Review of the CTP [Online]. Available: http://atlas.web.cern.ch/Atlas/GROUPS/DAQTRIG/LEVEL1/ctpttc/ L1CTP\_FDR.html, http://agenda.cern.ch/fullAgenda.php?ida=a036454
- [10] The CTP\_MI Module [Online]. Available: https://edms.cern.ch/ item/EDA-00392
- [11] The CERN High-Performance Time-to-Digital Converter [Online]. Available: http://micdigital.web.cern.ch/micdigital/hptdc.html
- [12] The CTP\_IN Module [Online]. Available: https://edms.cern.ch/ item/EDA-00622
- [13] The CTP\_CORE Module [Online]. Available: https://edms.cern.ch/ item/EDA-00624
- [14] H. P. Lima, Jr. et al., "The central trigger processor monitoring module (CTPMON) in the ATLAS level-1 trigger system," in Addendum to Proc. 9th Workshop Electron. LHC, Future Exper., Amsterdam, The Netherlands, Sep. 2003, pp. 1–5.
- [15] The CTP\_MON Module [Online]. Available: https://edms.cern.ch/ item/EDA-00216
- [16] The CTP\_OUT Module [Online]. Available: https://edms.cern.ch/ item/EDA-00623