Abstract| The Fanout system is part of the Silicon Vertex Tracker, a new trigger processor designed to reconstruct charged particle trajectories at Level 2 of the CDF trigger, with a latency of 10 s and an event rate up to 100 kHz. The core of SVT is organized as 12 identical slices, which process in parallel the data from the 12 independent azimuthal wedges of the Silicon Vertex Detector SVXII. Each SVT slice links the digitized pulse heights found within one SVXII wedge to the tracks reconstructed by the Level 1 fast track nder XFT in the corresponding 30 angular region of the Central Outer Tracker. Since the XFT tracks are transmitted to SVT as a single data stream, their distribution to the proper SVT slices requires dedicated fanout logic. The Fanout system has been implement e d a s a m ultiboard project running on a common 20 MHz clock. Track fanout is performed in two steps by one Fanout A" and two F anout B" boards. The architecture, design, and implementation of this system are described.
I. Introduction
The main functional blocks of each Silicon Vertex Tracker slice are the Hit Finders, the Associative Memory system, the Hit Bu er and the Track Fitter 1 2 . Every time an event is accepted by the Level 1 trigger, the digitized pulse heights in the Silicon Vertex Detector 3 are sent t o t h e H i t F i n d e r s w h i c h calculate hit positions. The hits found by the Hit Finders and the raw t r a c ks found in the Central Outer tracker by the Level 1 Fast Track n d e r 4 are then fed to both the Associative Memory system and to the Hit Bu er 5 . The Associative Memory system performs pattern recognition by selecting for further processing the combinations of XFT tracks and SVXII hits that represent g o o d t r a c k candidates. This is done by c o mparing the input data with a stored set of patterns in a completely parallel way, using a dedicated custom VLSI chip AM chip 6 . The AM system outputs a list of Roads. Each R o a d i s de ned as a combination of SuperStrips on ve di erent detector layers that can be traversed by a single track. The SuperStrips used to de ne the Roads correspond to the hit positions on four silicon layers, while the fth SuperStrip is a function of the track parameters reconstructed by the XFT track c u r v ature and azimuthal angle measured at the sixth superlayer of the COT at 106 cm from the beamline. To reduce the amount of required memory this pattern recognition process is carried out at a coarser resolution than the full available resolution. The Roads found by the AM system are sent to the Hit Bu er, that retrieves the original full-resolution silicon hit coordinates and the XFT track associated to each Road and delivers them to the Track Fitter system for full-precision computation of track parameters.
The Fanout system has two main functions: performing the distribution of the XFT tracks to the proper SVT slices and mapping the two XFT track parameters to a single coordinate which is binned in SuperStrips and is used by the AM system. Simulation studies have s h o wn that the most e cient use of the Associative Memory is obtained by using as SuperStrip the azimuthal angle of the XFT track extrapolated to a distance of about 10 cm from the beamline and a SuperStrip size of 25 mrad. For each X F T track received in input, the Fanout outputs a two word packet: the rst word contains the SuperStrip numberused by the AM system, while the second word is a copy o f t h e input word and is used by the Track Fitter for the fullprecision reconstruction of the track. For each event the Fanout receives also from the Global Level 1 trigger the information of which among the 64 CDF Level 1 triggers were red. This information is summarized and output from the Fanout as two bits in the special word used within the SVT system to mark the end of each e v ent and to record diagnostic information End Event w ord.
II. Architecture and data format
The Fanout system is organized as a set of three one of type A" and two o f type B" 9U400 VME boards. Communication between the Fanout A and the two F anout B boards takes place through a customized P3 backplane, with data owing from A to B. All the input streams to the Fanout system are received by the A board through three connectors placed on its front panel. One stream carries the XFT tracks and two carry the L1 trigger decisions. Data to the rest of the SVT are output only from the Fanout B boards. Each F anout B has 6 output connectors on the front panel and feeds 6 SVT slices.
Both the XFT data and the data output from the B boards conform to the standard SVT data format while L1 trigger data have a di erent format. S V T a n d X F T d a t a occupy 2 5 b i t words. In each w ord there are 21 data bits the 21 least signi cant b i t s , a n E n d P acket EP, an End Event EE, a Data Strobe DS and a Hold HD signal Table I . The EP bit speci es if the same data packet occupies only one or more words. Its value is set to 1 for the XFT tracks since each packet track occupies one single word. The EE bit marks the end of data corresponding to one event. The Hold and Data Strobe are used for the communication protocol among boards. The DS signal is driven by the source board and indicates when the data become valid and can be latched by the destination board. The Hold signal is driven by the destination board. When the destination board does not keep up with the incoming data rate, the Hold signal is set active and the source responds by suspending the data ow, which is resumed as soon as the Hold goes out. This protocol is uniform among all the SVT boards. The word with the EE bit set to 1 is called End Event word EE word, its data eld contains no information related to tracks but it is used to keep track of possible errors occurred during data transmission or processing and to record global information on the event. The data eld of the XFT word contains 12 bits specifying the azimuthal angle, 6 the curvature and 1 respectively the charge, the isolation and the pseudorapidity o f the track. The data eld in the End Event w ord contains the Event T ag 8 bits, the Parity P A of the event 1 b i t , the Error Flags 8 bits, the L1 Trigger information L1T generated by the Fanout system 2 bits and the Level 2 Bu er number L2B assigned to the event by the Trigger Supervisor 2 bits 8 . The format of the End Event word data eld is reported in Table II , where the additional EP, EE both set to 1, DS and HD signals are omitted. The meaning of the information recorded in the End Event word relevant t o t h e F anout system will be discussed in Sec. II-A.1. Two streams from the Global Level 1 trigger carry the 64 Level 1 trigger decisions to the Fanout A board. This information is transmitted using one word per stream per event. The format of data is the same in both streams and uses a 33 bit data eld with a DS signal to indicate when data become valid. No End Packet, End Event a n d Hold signal are present. The data eld contains 32 trigger decisions the 32 least signi cant bits and 1 bit of the Level 2 Bu er number Table 3 . The combination of the two L2B bits from the two streams must match the L2B number recorded in the EE word of the XFT data. For each XFT track received in input, the Fanout system outputs a two word packet through the B boards to the proper SVT slices, depending on the azimuthal angle of the track. The rst word of the packet is used by the AM system while the second one by the Track Fitter. The format of the two output words is the standard SVT data format. In the word used by the AM system only 15 out of the available 21 bits of the data eld are actually used: 12 bits contain the SuperStrip number, 3 bits the Layer number set to 5 associated to the XFT tracks. The remaining 6 bits of the data eld are spare. The word used by the Track Fitter is a copy of the XFT input word. Since in this case one data packet is logically made of two w ords, the EP bit is set to 0 in the rst word and to 1 in the second one. The end of the output event is marked by the EE word, which i s s e n t simultaneously to all the SVT slices. All the 12 End Event w ords are identical except for the Parity bit which can change from stream to stream because di erent streams transmit di erent data sets Sec. II-B.
A. Fanout A board
The Fanout A board performs the entire data handling within the Fanout system. It receives and processes all the input streams and constructs the output data packets as well as the output End Event w ord Sec. II-A.1. The B boards perform simply the fanout function.
XFT tracks and L1 trigger bits are received asynchronously and are stored on three sets 1 for the XFT tracks and 2 for the L1 Trigger bits of two 4 K 18 bit FiFos each.
The set of FiFos receiving XFT tracks provides an Almost Full signal that is sent back t o the source meaning Hold. If the Fanout A does not keep up with the incoming data rate, the FiFos become Almost Full and the Hold signal is asserted. The signal is active while the amount of unread data in the FiFos remains above the Almost Full threshold. Although this communication protocol is uniform among all the SVT modules, no handshake i s implemented with the Global Level 1 trigger. This is allowed by the fact that the Level 1 trigger information is received at a much l o wer rate one word per stream per event than the XFT tracks.
The Fanout A board transmits data to the B board through a customized P3 backplane. The data stream contains one standard SVT format word 21 bit data eld plus EP, EE, DS and HD bits, 12 enable" bits, used by the B boards to select which SVT slices one or more must receive t h e w ord, and 2 clock lines routed on the backplane to have e a c h B board receiving one line Sec. IV. When the Data Strobe bit is active, the B boards receive one word for each clock cycle, validated at the positive edge. The Hold line is driven and is common to both the B boards. It is implemented as a wired-or chain. When the Hold line is active, the Fanout A stops reading new data from the FiFos.
The SuperStrip number 12 bits inserted in the word used by the AM system and the list of 12 enable bits associated to each XFT track are determined using a L o o k Up Table. The Look Up Table is 
A.1 Error handling and data ow monitoring
There is a number of error conditions that can be detected by SVT while processing data, for example something can go wrong in the data transfer and the input FiFo on one board can become full, or some of the data received in input by one board are outside the valid range. The system can both set error ags in the VME register of the single board and propagate error ags in the data stream setting appropriate error bits on the End Event w ord 7 . Table. When the A board detects one of these conditions, it sets the corresponding error ag in the output End Event w ord. If one error bit is already asserted in the input EE word, it is propagated in the output EE word.
The SVT boards have also a system for data ow monitoring. The input and the output data streams from the boards are continuously copied to circular memories called Spy Bu ers. In the Fanout A board these memories are 128K static RAMs for the XFT data and 64K both for the L1 Trigger data and for the output Spy Bu er, which spies data owing to the P3 connector. These bu ers act as built-in logic state analizers and help system monitoring and diagnostics. As a consequence of error conditions these bu ers can be frozen and read from VME with no interruption of the normal data ow.
B. Fanout B board
There are two identical Fanout B boards whose identity is set by a n o n boardswitch. Their function is to receive t h e data from the Fanout A board through the P3 backplane and to distribute the 23 data bits to the proper SVT wedges according to the list of enable bits. They have also the IC99   IC100   IC98   IC103   IC104   IC102   IC105   IC101   IC92   IC93   IC94   IC2   IC3   IC4   IC43   IC42   IC41   IC40   IC46   IC45   IC44   IC5   IC6   IC7   IC8   IC1   IC9   IC14   IC13   IC12   IC11   IC10   IC16   IC15   IC17   IC18   IC56  IC57   IC59  IC67   IC53   IC22   IC23   IC27   IC28   IC50   IC51   IC29   IC80   IC30   IC52   IC35   IC82   IC20   IC32  IC33  IC34   IC84   IC85   IC86   IC37   IC38  IC39   IC72   IC73   IC74   IC75   IC76   IC77   IC78   IC79   J10   J11   RS43   RS41   RS44   RS42   RS45   RS46   RS3   RS4   RS2   RS5   RS6   RS7   RS8   RS1   RS9   RS11   RS12   RS13   RS14   RS15   RS16   RS17   RS10   RS18   IC19   IC95   IC24   IC47   IC36   IC69   IC58   IC60   IC68   IC201   IC31   IC83   IC54 C93   C99   C98   C97   C96   C95   C94   C205   C203   C206   C207   C208   C209   C211   C212   C216   C217   C218   C219   C220   C221  C222  C223  C224   C225  C226  C227  C228   C229   C230  C231   C232   C233   C234   C235   C236   C237   C238   C242   C243   C244   C245  C246   C247   C248   C249   C297   C298   C1   C2   C250   C251   C252   C253   C210   C204   C254   C255   C256   C260   C262   C263   C264   C265   C266   C257   C258   C259   C261   C267   C268   C269   J8   R128   R129   R108   R109   R110   R111   R84   R85   R86   R133   R134   R136  R137   R138   R139   R140   R25   R193   R178  R179  R180  R181   R182  R183  R184  R185   R186  R187  R188  R189   R190  R191  R192   R201   R200   R199   R198   R197   R196   R202   R195   R203  R204  R205  R206   R209   R207   R53  R65   R63   R3  R4   R55   R64   R54   R56   R67   R66   R57   R58   R1  R2   R5   R6   R8   R7   R9  R10   R11  R12   R13   R14   R15   R16   R17  R18   R19  R20   R21   R22   R23   R24   R26   R27   R28  R29   R210  R211  R212  R213  R214   R215   R76   R77   R39   R38   R37  R36   R35   R34   R33   R32   R31   R243   R244   R216   R217   R218   R219   R220   R221   R222   R223   R224   R225   R226   R227   R228   R229 function to set the Parity bit in the End Event w ords sent to the 12 outputs. The Parity o f e a c h stream is computed by the A board and is transmitted to the B boards: when t h e E E w ord is sent from A to B, the 12 enable bits have a special meaning, each of them is the parity bit of the corresponding output stream. The B boards insert each PA bit in the EE word sent to the corresponding output stream.
In addition the B boards control the Hold and Data Strobe bits of each output stream. Data ow out of each Fanout B board through the 6 connectors on the front panel. If the Hold signal is received from any output, the line on the P3 backplane meaning Hold is set active and the Fanout A stops reading new data. Each F anout B receives the clock from the Fanout A board through the P3 backplane and its logical functions are implemented on one 240 pin FLEX10K20 FPGA from Altera. For simplicity this board has no Spy Bu ers and no VME interface.
III. Operation modes
The Fanout system has two di erent operation modes: running mode and VME mode. In running mode it processes the data received through the input connectors and outputs the proper data to each SVT wedge. The VME mode is used to write the content of the Look Up Table used to map the XFT tracks into SuperStrips and for testing purposes. In particular in VME mode the content of any S p y Bu er can be written from the VME interface and the board can be forced to process these data as if they were the actual input streams. In this operating mode data contained in the input FiFos are disregarded. This can be done for both the input streams simultaneously as well as for only one. This allows an almost complete test of the system in absence of one or both the real input data sources.
IV. Clock distribution
Clock signals are generated on the Fanout A board and are distributed to the two Fanout B boards through two dedicated lines of the P3 backplane. Each F anout B board receives one clock line. Clock generation on the Fanout A is accomplished by using one quartz oscillator connected to one PLL based clock bu er from Quicklogic Roboclock". The Roboclock produces eight outputs with 4 adjustable phase shifts with respect to the input clock, also allowing zero or negative delays. The timing of each phase is adjusted by controlling the individual programmable delays of the Roboclock, in steps of about 1 ns. Each o f t h e three Spy Bu ers uses one Roboclock output to generate the write enable signals to the RAMs. Two Roboclock outputs are sent to the Fanout B boards and one is sent t o a set of two PLL logic fanout chips which provide clock s i gnals to the input FiFos and to the Altera FPGAs on the Fanout A.
Each F anout B board is equipped with a system of two Roboclocks which receive in parallel the clock line from the Fanout A board. OneRoboclock output is used by t h e Altera programmable chip. Each of the six output channels from the board uses one Roboblock output to generate the Data Strobe signal on the cable. This allows adjusting the Data Strobe timing with respect to the data bits.
V. PCB design
The Fanout A and B boards have been implemented as a six layers Eurocard 9U PCB. Critical lines have c o n trolled impedance. The placement of components and routing have been optimized for the maximum symmetry among similar functional blocks.
