# **SP02 Backplane Interfaces**

## Petersburg Nuclear Physics Institute / University of Florida September 1, 2003 Version 5.0

## **CCB** Interface

The CCB interface provides the SP02 with timing and trigger control signals distributed by the Clock and Control Board (CCB) over the backplane [i]. The backplane counts as many as 34 signal lines coming in and going out of the SP02. Table 1 groups backplane signals into four Groups. All GTLP lines are active LOW (negative bus logic).

The Clock Group includes a differential clock and clock\_enable lines. For the TF prototype the enable line is expected to be always in a LOW state.

#### Table 1: SP02 CCB Interface Signals.

| Signal                     | Lines | Direction         | Туре           | Logic | Duration        |
|----------------------------|-------|-------------------|----------------|-------|-----------------|
|                            |       | Clock Grou        |                |       |                 |
| CCB_CLK                    | 2     | IN                | Point-to-point | LVDS  | 40MHz           |
| CCB_CLK_EN                 | 1     | IN                | Bussed         | GTLP  | Pulse, n counts |
| Subtotal                   | 3     |                   |                |       |                 |
|                            |       | Fast Control G    | roup           |       |                 |
| CCB_CMD [50]               | 6     | IN                | Bussed         | GTLP  | Level           |
| CCB_ECRES                  | 1     | IN                | Bussed         | GTLP  | 25ns            |
| CCB_BCRES                  | 1     | IN                | Bussed         | GTLP  | 25ns            |
| CCB_CMD_STR                | 1     | IN                | Bussed         | GTLP  | 25ns            |
| CCB_BX0                    | 1     | IN                | Bussed         | GTLP  | 25ns+ECL FP     |
| CCB_L1ACC                  | 1     | IN                | Bussed         | GTLP  | 25ns+ECL FP     |
| CCB_DAT [70]               | 8     | IN                | Bussed         | GTLP  | Level           |
| CCB_DAT_STR                | 1     | IN                | Bussed         | GTLP  | 25ns            |
| CCB_RDY                    | 1     | IN                | Bussed         | GTLP  | Static level    |
| Subtotal                   | 21    |                   |                |       |                 |
|                            |       | <b>Reload Gro</b> | սթ             |       |                 |
| CCB_SP_HRES                | 1     | IN                | Bussed         | GTLP  | 400ns           |
| SP_CFG_DONE                | 1     | OUT               | Point-to-Point | GTLP  | Level           |
| Subtotal                   | 2     |                   |                |       |                 |
|                            |       | Reserved Gr       | oup            |       |                 |
| CCB_RSVD [30] <sup>#</sup> | 4     | IN                | Bussed         | GTLP  | 25ns            |
| SP_RSVD [30]*              | 4     | OUT               | Bussed         | GTLP  | 25ns            |
| Subtotal                   | 8     |                   |                |       |                 |
| Total                      | 34    |                   |                |       |                 |

<sup>&</sup>lt;sup>#</sup> CCB\_RSVD3 is assigned for CCB\_L1RES – L1 Reset signal resets L1 buffers and resynchronizes optical links.

<sup>\*</sup> SP\_RSVD3 is assigned for SP\_L1REQ – L1 request, local trigger generated by the SP\_FPGA logic.

The Fast Control Group includes a ccb\_ready status line, TTCrx command and data busses accompanied with strobes, and a few TTCrx signals, decoded by CCB. The Fast Control Group signals are valid when and only when the ccb\_ready is LOW.

The Reload Group includes a hard\_reset signal for reconfiguration of the SP02 FPGAs. In turn, the SP02 returns a configuration\_done status to the CCB.

The Reserved Group is partially specified at the moment, see footnotes to Table 1.

The VME\_FPGA delivers fast control signals to each SP02 FPGA via a 5-bit Fast Control (FC) bus. Table 2 sets correspondence between the FC and the CCB signals.

Table 2: SP02 Internal Control Bus and configuration control/status lines

| FC/CCB Command<br>Description                                                                                                | CCB Backplane Signal or<br>Command Code | FC/CCB<br>Command                  | Fast Control Bus<br>Command Code |
|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------|----------------------------------|
| Description                                                                                                                  | Command Code                            | Acronym                            | Command Code                     |
| No commands / Idle state                                                                                                     |                                         | FC_NOCMD                           | fc_cmd[4:0]=5'b0_0000            |
| L1 Accept                                                                                                                    | ccb_llacc                               | FC_L1ACC<br>CCB_L1ACC              | <pre>fc_cmd[4:0]=5'h1_XXXX</pre> |
| Store Next Event into Spy FIFO,<br>as determined by the CSR_SFC                                                              | Generated by VME_FPGA                   | FC_SFRUN                           | <pre>fc_cmd[4:0]=5'hX_1XXX</pre> |
| Bunch Counter Reset                                                                                                          | ccb_bcres                               | FC_BCRES<br>CCB_BCRES              | fc_cmd[4:0]=5'hX_X001            |
| Event Counter Reset                                                                                                          | ccb_ecres                               | FC_ECRES<br>CCB_ECRES              | fc_cmd[4:0]=5'hx_X010            |
| Bunch & Event Counter Reset                                                                                                  | ccb_bcres & ccb_ecres                   | FC_BERES<br>CCB_BCRES<br>CCB_ECRES | fc_cmd[4:0]=5'hX_X011            |
| Bunch Crossing Zero Mark                                                                                                     | ccb_cmd[5:0]=0x01                       | FC_BC0<br>CCB_BC0                  | fc_cmd[4:0]=5'hX_X100            |
| L1 Reset – Resets L1 Buffers and<br>Resynchronizes Optical Links                                                             | ccb_cmd[5:0]=0x03                       | FC_L1RES<br>CCB_L1RES              | fc_cmd[4:0]=5'hX_X101            |
| Start Data Taking                                                                                                            | ccb_cmd[5:0]=0x06                       | FC_L1RUN<br>CCB_L1STT              | fc_cmd[4:0]=5'hX_X110            |
| Stop Data Taking                                                                                                             | ccb_cmd[5:0]=0x07                       | CCB_L1STP                          | Handled by VME_FPGA              |
| Inject Test Pattern into SP.<br>See details in CSR_TFC description                                                           | ccb_cmd[5:0]=0x2F                       | FC_TFRUN<br>CCB_TPSP               | fc_cmd[4:0]=5'hX_X111            |
| Inject Test Pattern into MPC                                                                                                 | ccb_cmd[5:0]=0x30                       | CCB_TPMPC                          | Handled by VME_FPGA              |
| Inject Test Pattern into TMB                                                                                                 | ccb_cmd[5:0]=0x24                       | CCB_TPTMB                          | Handled by VME_FPGA              |
| Bunch Counter Reset                                                                                                          | ccb_cmd[5:0]=0x32                       | FC_BCRES<br>CCB_BXRES              | fc_cmd[4:0]=5'hX_X001            |
|                                                                                                                              |                                         |                                    |                                  |
| Hard Reset – reconfigures SP02<br>FPGAs (as determined by a<br>Configuration Mask Register)                                  | ccb_sp_hard_res                         |                                    | cfg_prog_n[7:1]                  |
| Configuration Done – reports on<br>successful completion of FPGA<br>configuration (as determined by a<br>Done Mask Register) | sp_cfg_done                             |                                    | cfg_done[7:1]                    |

The FC bus has two dedicated lines, one for L1 Accepts and another to initiate storing data into Spy FIFOs. Three more lines encode all other fast control commands. Signals on dedicated lines may coincide in time with encoded commands, while encoded commands are mutually exclusive.

Note, that data taking is stopped on power-up, so backplane CCB\_L1ACC signals don't pass to the FC\_L1ACC line. A sequence of CCB\_L1STT and CCB\_BC0 commands should be issued to let L1 Accepts pass to the internal FC bus, see Figure 1 for details on the L1Accept

State Machine (L1A\_FSM). A CCB\_L1STP command returns the L1A\_FSM into the default L1A\_STOP state from the L1A\_RUN state. Besides, CCB\_L1RES or CCB\_BXRES commands return the L1A\_FSM into the L1A\_STOP state unconditionally.



Figure 1 State Machine for L1Accept Control

An FC\_SFRUN internal command requests storing next event into the Spy FIFO. See the CSR\_SFC – Spy FIFO Configuration section for details.

Bunch counter on power-up and/or after CCB\_BCRES, CCB\_BXRES, or CCB\_L1RES commands is preloaded with a 0xFFF=4095 value. It starts counting from 1 and up upon receiving a CCB\_BC0 command. Bunch counter rolls over to zero count, when it reaches its maximum value, which is 923 for the beamtest at SPS and 3563 for LHC operations.

Summary of fast control commands:

- CCB\_BCRES resets Bunch counters to 0xFFF = 4095;
- CCB\_ECRES resets Event counters;
- CCB\_L1RES resets Bunch counters to 0xFFF = 4095, resynchronizes optical links, resets readout buffers, and resets Event counters.
- CCB\_BXRES resets Bunch counters to 0xFFF = 4095, and stops counting of CCB\_L1ACCs.

- CCB\_L1STT counting of CCB\_L1ACCs to be resumed on the next CCB\_BC0 command.
- CCB\_L1STP stops counting of CCB\_L1ACCs.
- CCB\_BC0 if preceded with the CCB\_L1STT command, starts the Bunch counter from its offset value, as determined by the CSR\_BCO register; otherwise serves as a timing mark to verify the Bunch counter synchronization to the control timing.

The current state of the SP02 logic can be monitored with four fast monitoring statuses: busy (FM\_BSY), ready (FM\_RDY), warning-of-overflow (FM\_WOF), and out-of-synch (FM\_OSY). Each SP02 FPGA reports its 4-bit status to the VME\_FPGA. The VME\_FPGA is capable of masking individual statuses when providing the SP02 overall status to the RJ45 connector and front panel indicators (LEDs).

For the summary of fast monitoring statuses see details into CSR\_BSY – Busy Control/Status, CSR\_RDY – Ready Control/Status, CSR\_WOF – Warning-of-OverFlow Control/Status, and CSR\_OSY – Out-of-Synch Control / Status sections below.

| Description           | Left LED<br>Color | Left LED<br>Name | Right LED<br>Name | Right LED<br>Color | Description      |
|-----------------------|-------------------|------------------|-------------------|--------------------|------------------|
| Busy                  | Red               | BSY              | 5.0V_OK           | Green              | 5.0V power is OK |
| Ready                 | Green             | RDY              | 3.3V_OK           | Green              | 3.3V power is OK |
| Warning-of-OverFlow   | Red               | WOF              | 2.5V_OK           | Green              | 2.5V power is OK |
| Out-of-Synch          | Red               | OSY              | 1.5V_OK           | Green              | 1.5V power is OK |
| Local Charged Trigger | Yellow            | LCT              | L1ACC             | Yellow             | L1 Accept        |

Table 3 SP02 LED panel

The LED indicators are located above the F5 link transceivers. The BSY, RDY, WOF, and OSY indicators display status of the corresponding signal lines. Power OK indicators are off, since the power-monitoring chip MAX6338BUB is missing on the board. The L1ACC LED blinks for 25 ms on each CCB\_L1ACC. The LCT currently indicates RDY0\_INT status of the VME\_FPGA.

# **VME** Interface

The SP02 card includes two A24D16 Slave interfaces [ii] implemented in VME\_FPGA and CPLD\_FPGA accordingly. Table 4 shows all address modifiers, the SP02 responds to during the VME Data Transfer Bus (DTB) cycles.

| АМ | Description                             | Interface<br>Chip |
|----|-----------------------------------------|-------------------|
|    |                                         |                   |
| 39 | A24 non-privileged data access          |                   |
| 3A | A24 non-privileged program access       | VME_FPGA          |
| 3B | A24 non-privileged block transfer (BLT) |                   |
|    |                                         |                   |
| 3D | A24 supervisory data access             |                   |
| 3E | A24 supervisory program access          | VME_CPLD          |
| 3F | A24 supervisory block transfer (BLT)    |                   |

## **Auxiliary VME Interface**

The auxiliary VME\_CPLD interface is intended for board configuration and provides access solely for the Bus Scan Controller (BSC). The BSC drives three chains of JTAG-compatible devices, see Table 5:

- Chain 0 consists of the MAIN\_FPGA and its EEPROMs;
- Chain 1 includes the VME\_FPGA with EEPROM, the FRONT\_FPGAs with EEPROMs, and the DDU\_FPGA with EEPROM;
- Chain 2 connects 45 SRAMs.

 Table 5: SP02 Configuration Chains.

| Chain | Device | Device       | Device            | Device                                                    | Bypass |
|-------|--------|--------------|-------------------|-----------------------------------------------------------|--------|
| No    | No     | Name         | Туре              | ID Code                                                   | Switch |
|       |        |              |                   |                                                           |        |
| 0     | 1      | SP_EEPROM_1  | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | MC_SW2 |
| 0     | 2      | SP_EEPROM_2  | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | MC_SW3 |
| 0     | 3      | SP_EEPROM_3  | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | MC_SW4 |
| 0     | 4      | SP_EEPROM_4  | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | MC_SW5 |
| 0     | 5      | SP_EEPROM_5  | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | MC_SW6 |
| 0     | 6      | SP_FPGA      | XC2V4000-5FF1152C | VVVV 0001 0000 0101 0000 0000 1001 0011                   | MC_SW1 |
|       |        |              |                   |                                                           |        |
| 1     | 1      | VME_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW4    |
| 1     | 2      | VME_FPGA     | XC2V1000-5FG456C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW5    |
| 1     | 3      | FF5_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW2    |
| 1     | 4      | FRONT_FPGA_5 | XC2V1000-5FF896C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW3    |
| 1     | 5      | FF4_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW14   |
| 1     | 6      | FRONT_FPGA_4 | XC2V1000-5FF896C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW15   |
| 1     | 7      | FF3_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW19   |
| 1     | 8      | FRONT_FPGA_3 | XC2V1000-5FF896C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW20   |
| 1     | 9      | DDU_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW10   |
| 1     | 10     | DDU_FPGA     | XC2V1000-5FG456C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW11   |
| 1     | 11     | FF2_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW12   |
| 1     | 12     | FRONT_FPGA_2 | XC2V1000-5FF896C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW13   |
| 1     | 13     | FF1_EEPROM   | XC18V04VQ44C      | VVVV 0101 0000 0010 0110 0000 1001 0011                   | SW17   |
| 1     | 14     | FRONT FPGA 1 | XC2V1000-5FF896C  | VVVV 0001 0000 0010 1000 0000 1001 0011                   | SW18   |
|       |        |              |                   |                                                           |        |
| 2     | 1      | ME4C LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 2      | ME4C GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | 1      |
| 2     | 3      | ME4C GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 4      | ME4B LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | 1      |
| 2     | 5      | ME4B GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | SW7    |
| 2     | 6      | ME4B GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 7      | ME4A LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | -      |
| 2     | 8      | ME4A GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | -      |
| 2     | 9      | ME4A GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 10     | ME3C LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 11     | ME3C GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   |        |
| 2     | 12     | ME3C GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | 1      |
| 2     | 13     | ME3B LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | 1      |
| 2     | 14     | ME3B GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | SW9    |
| 2     | 15     | ME3B GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011                   | 1      |
| 2     | 16     | ME3A LP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011<br>1VVV 0000 0000 | 4      |
| 2     | 10     | ME3A GE      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011<br>1VVV 0000 0000 | 1      |
| 2     | 18     | ME3A GP      | GS881Z18AT        | 1VVV 0000 0000 0000 1010 0001 1011 0011<br>1VVV 0000 0000 | 4      |

| Chain | Device | Device  | Device      | Device                                  | Bypass |
|-------|--------|---------|-------------|-----------------------------------------|--------|
| No    | No     | Name    | Туре        | ID Code                                 | Switch |
| 2     | 19     | ME2C_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 20     | ME2C_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 21     | ME2C_GP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 22     | ME2B_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 23     | ME2B_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 | SW8    |
| 2     | 24     | ME2B_GP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 25     | ME2A_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 26     | ME2A_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 27     | ME2A_GP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 28     | ME1F_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 29     | ME1F_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 30     | ME1F_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |
| 2     | 31     | ME1E_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 32     | ME1E_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 | SW6    |
| 2     | 33     | ME1E_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |
| 2     | 34     | ME1D_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 35     | ME1D_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 36     | ME1D_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |
| 2     | 37     | ME1C_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 38     | ME1C_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 39     | ME1C_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |
| 2     | 40     | ME1B_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 41     | ME1B_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 | SW16   |
| 2     | 42     | ME1B_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |
| 2     | 43     | ME1A_LP | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 44     | ME1A_GE | GS881Z18AT  | 1VVV 0000 0000 0000 1010 0001 1011 0011 |        |
| 2     | 45     | ME1A_GP | GS8161Z36AT | VVVV 0000 0000 0000 1000 0001 1011 0011 |        |

Alex M. is to determine the VME address mapping for the auxiliary VME interface.

## **Main VME Interface**

The main VME\_FPGA interface utilizes a 5-bit geographical addressing scheme [ii] and provides for the VME Data Transfer Bus (DTB) broadcast *write* cycles by partitioning the address space into fields, Table 6.

### Table 6 SP02 Address Space

| A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|     |     | SA  |     |     |     |     |     | CA  |     |     |     | Х   | M   | A  |    |    |    | RA |    |    |    | Х  | 0  |

Here:

- X Don't care address line;
- SA Slot Address, could be either Slot Geographical Address (GA), or Slot Broadcast Address (30);
- CA Chip Address. Positional coding provides simultaneous write access to any combination of SP02 FPGAs (except VME\_FPGA), see Table 7;
- MA Muon Address. Each FRONT\_FPGA processes data for 3 muons, and SP\_FPGA services 3 PT LUTs. A 2-bit MA field provides write access either to a single muon-related register or to all three such registers simultaneously, see Table 8 for details.
- RA Register Address inside FPGA(s). There are 4 groups of registers in total, see Table 9 for details:
  - Action Register Group. Writing to these write-only registers causes pulses, like reset or test pulse, to be generated and/or operations, like start or stop L1ACC processing, to be performed.
  - Control/Status Register Group. These registers carry 2 groups of bits: readonly status bits to monitor, and read/write bits to control behavior of the SP02 logic.
  - Address Register Group. These registers provide access to LUT and Eta Window address counters.
  - Data Register Group. The group provides access to LUT and FIFO data inputs/outputs.

Full Address (FA) of register is defined as:

FA = (SA << 19) + (CA << 12) + (MA << 9) + (RA << 2).

## Table 7 SP02 Chip Address Field

| Chip | Chip Address   | Description         |
|------|----------------|---------------------|
| VM   | 0b_000_0000_d0 | VME_FPGA Access     |
| F1   | 0b_000_0001    | FRONT_FPGA_1 Access |
| F2   | 0b_000_0010    | FRONT_FPGA_2 Access |
| F3   | 0b_000_0100    | FRONT_FPGA_3 Access |
| F4   | 0b_000_1000    | FRONT_FPGA_4 Access |
| F5   | 0b_001_0000    | FRONT_FPGA_5 Access |
| DD   | 0b_010_0000    | DDU_FPGA Access     |
| SP   | 0b_100_0000    | SP_FPGA Access      |

## Table 8 SP02 Muon Address Field

| Label | Muon<br>in<br>FPGA | Muon Address | Description                                            |
|-------|--------------------|--------------|--------------------------------------------------------|
| MA    | ALL                | 0x0          | Access to all three muon-related registers             |
| M1    | A/D/1              | 0x1          | Access to a First (A or D or 1) muon-related register  |
| M2    | B/F/2              | 0x2          | Access to a Second (B or E or 2) muon-related register |
| М3    | C/E/3              | 0x3          | Access to a Third (C or F or 3) muon-related register  |

Note, that only *write* access is defined to a group of registers, while *read* access may only be executed to a single register at any time.

## Table 9 SP02 Storage Address

|              | Register        |                                |     | Destination | n / Valid MA |     |
|--------------|-----------------|--------------------------------|-----|-------------|--------------|-----|
| Address      | Name            | Description                    | SP  | DD          | Fx           | VM  |
| Action Regis | ter Group       |                                |     | •           |              |     |
| 0x00         | ACT_HR          | Hard Reset                     |     |             |              | MA  |
| 0x01         | ACT_CMR         | Clock Manager Reset            | TBD | MA          | MA           | MA  |
| 0x02         | ACT_LER         | Link Error Counters Reset      |     | MA          | MA/M1/M2/M3  |     |
| 0x03         | ACT_XFR         | FIFO Reset                     | TBD | MA          | MA           |     |
| 0x04         |                 | Fast Controls_3                | TBD | TBD         | TBD          | TBD |
| 0x05         |                 | Fast Controls_4                | TBD | TBD         | TBD          | TBD |
| 0x06         |                 | Fast Controls_5                | TBD | TBD         | TBD          | TBD |
| 0x07         |                 | Address Counters Reset         | TBD | TBD         | TBD          | TBD |
| Control/Stat | us Register Gro | bup                            |     |             |              |     |
| 0x10         | STS_CCB         | Fast Control Status            |     |             |              | MA  |
| 0x11         | STS_ANA         | CCB Logic Analyzer             |     |             |              | MA  |
| 0x12         | STS_VPC         | Valid Pattern bit Counter      |     |             | M1/M2/M3     |     |
| 0x20         | CSR_CID         | Chip ID                        | TBD | MA          | MA           | MA  |
| 0x21         | <br>CSR_CLK     | System CLK Control/Status      |     |             | MA           |     |
| 0x22         | CSR CM1         | Clock Manager_1 Control/Status | TBD | MA          | MA           | MA  |
| 0x23         | CSR_CM2         | Clock Manager_2 Control/Status | TBD | MA          | MA           | MA  |
| 0x24         | CSR_HR          | Hard Reset Mask                |     |             |              | MA  |
| 0x25         | CSR_CFG         | Configuration Done Status      |     |             |              | MA  |
| 0x26         | CSR_INI         | Init Status                    |     |             |              | MA  |
| 0x27         | CSR_CHP         | Chip Presence Mask             |     |             |              | MA  |
| 0x28         | CSR_BSY         | Busy Mask/Status               |     |             |              | MA  |
| 0x29         | CSR_RDY         | Ready Mask/Status              |     |             |              | MA  |
| 0x2A         | CSR_WOF         | WarningOfOverflow Mask/Status  |     |             |              | MA  |
| 0x2B         | CSR_OSY         | OutOfSynch Mask/Status         |     |             | MA/M1/M2/M3  | MA  |
| 0x2C         | CSR_LCT         | LCT Control/Status             | TBD |             | TBD          | MA  |
| 0x2D         | CSR_CCD         | CCB Command Delay - obsolete   |     |             |              | MA  |
| 0x2D         | CSR_BCO         | Bunch Counter Offset           |     |             | MA           |     |
| 0x2E         | CSR_L1D         | Ll Accept Delay                |     |             |              | MA  |
| 0x30         | CSR_LEC         | Link Error Counters            |     | MA          | M1/M2/M3     |     |
| 0x31         | CSR_AF          | Alignment FIFO Status          | TBD | MA          | M1/M2/M3     |     |
| 0x32         | CSR_TF          | Test FIFO Status               | TBD | MA          | M1/M2/M3     |     |
| 0x33         | CSR_SF          | Spy FIFO Status                | TBD | MA          | M1/M2/M3     |     |
| 0x34         | CSR_PF          | Pipeline FIFO Status           | TBD |             | MA           |     |
| 0x35         | CSR_DF          | DAQ FIFO Status                | TBD | MA          | MA           |     |
| 0x36         | CSR_LF          | L1 FIFO Status                 |     |             | MA           |     |
| 0x37         | CSR_RBW         | Ring Buffer Writer Pointer     |     |             | MA           |     |
| 0x38         | CSR_RBR         | Ring Buffer Read Pointer       |     |             | MA           |     |

| Address Register<br>Name |             | Description                   | De          | stinatior | n / Valid MA |    |
|--------------------------|-------------|-------------------------------|-------------|-----------|--------------|----|
| Address                  | Name        | Description                   | SP          | DD        | Fx           | VM |
| 0x40                     | CSR LNK     | Link Control/Status           |             | MA        | MA/M1/M2/M3  |    |
| 0x41                     | CSR_AFD     | Alignment FIFO Read Delay     |             |           | MA           |    |
| 0x42                     | CSR TFC     | Test FIFO Configuration       | TBD         | MA        | MA           |    |
| 0x43                     | CSR_SFC     | Spy FIFO Configuration        | TBD         | MA        | MA           | MA |
| 0x44                     | CSR_PFD     | Pipeline FIFO Read Delay      | TBD         | MA        | MA           |    |
| 0x45                     | CSR_DFC     | DAQ FIFO Configuration        |             |           | MA           |    |
| Address Cou              | nter Group  |                               |             |           |              |    |
| 0x50                     | CNT_LPL     | Local Phi LUT Address Low     |             |           | MA           |    |
| 0x51                     | CNT LPH     | Local Phi Address High        |             |           | MA           |    |
| 0x52                     | CNT GPL     | Global DT phi LUT Address Low |             |           | MA           |    |
| 0x53                     | CNT GPH     | Global_DT Phi Address High    |             |           | MA           |    |
| 0x54                     | CNT GEL     | Global Eta LUT Address Low    |             |           | MA           |    |
| 0x55                     | CNT GEH     | Global Eta Address High       |             |           | MA           |    |
| 0x56                     | CNT PTL     | PT LUT Address Low            | MA          |           |              |    |
| 0x57                     | CNT PTH     | PT LUT Address High           | MA          |           |              |    |
| 0x58                     | CNT_EW      | Eta Window Address            | MA          |           |              |    |
| Data Registe             | r Group     |                               |             |           |              |    |
| 0x60                     | DAT_LP      | Local Phi LUT Data            |             |           | MA/M1/M2/M3  |    |
|                          |             |                               | Data        |           | Address      |    |
| 0x62                     | DAT_GP      | Global Phi LUT Data           | MA/M1/M2/M3 |           | MA/M1/M2/M3  |    |
| 0x63                     | DAT_DT      | DT LUT Data                   |             |           | MA/M1/M2/M3  |    |
| 064                      | 53 <b>.</b> |                               | Data        |           | Address      |    |
| 0x64                     | DAT_GE      | Global Eta LUT Data           | MA/M1/M2/M3 |           | MA/M1/M2/M3  |    |
| 0x66                     | DAT_PT      | PT LUT Data                   | MA/M1/M2/M3 |           |              |    |
| 0x68                     | DAT_EW      | Eta Window Data               | TBD         |           |              |    |
| 0x72                     | DAT TF      | Test FIFO Data                | TBD         | MA        | MA/M1/M2/M3  |    |
| 0x73                     | DAT_SF      | Spy FIFO Data                 | TBD         | MA        | M1/M2/M3     | 1  |
| 0x75                     | DAT_DF      | DAQ FIFO Data                 | TBD         |           | MA           |    |
|                          |             |                               |             |           |              |    |
| 0x78                     | DAT_BLT     | BLT Mapping Data              |             | ļ         |              | MA |
| 0x79                     | DAT_BF1     | BLT Mapping FIFO_1 Data       |             |           |              | MA |
| 0x7A                     | DAT_BF2     | BLT Mapping FIFO_2 Data       |             |           |              | MA |
| 0x7B                     | DAT_BF3     | BLT Mapping FIFO_3 Data       |             |           |              | MA |
| 0117.5                   |             |                               |             |           |              |    |

The main VME\_FPGA interface distributes VME control all over the board via the Internal Data Transfer Bus (IDTB). IDTB is a synchronous parallel bus that is used by the VME\_FPGA to transfer data to or from other SP02 FPGA(s): SP\_FPGA, 5 FRONT\_FPGAs, and DDU\_FPGA.

The IDTB bus lines are grouped into 4 categories:

| _ | Address Lines:   | A[11:2]   | see Table 10                     |
|---|------------------|-----------|----------------------------------|
| _ | Data Lines:      | D[15:0]   | Bi-directional                   |
| _ | Control Lines:   | /CS[7:1]  | Chip Select, active LOW          |
|   |                  | /ACK[7:1] | Acknowledge, active LOW          |
|   |                  | /WR       | Write, active LOW                |
| _ | Auxiliary Lines: | VMB_WR    | Buffer Write                     |
|   |                  | VMB_/OE   | Buffer Output Enable, active LOW |

#### Table 10 SP02 IDTB Address Lines

| A11 | A10 | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 |
|-----|-----|----|----|----|----|----|----|----|----|
| RV  | M   | A  |    |    |    | RA |    |    |    |
| RV  |     |    |    |    | ΤA |    |    |    |    |

- IA Internal DTB Address, defines storage location inside FPGA
- RV Reserved line

To prevent data lines from being too long they are split into two segments: the SP segment and the FRONT/DDU segment, with bi-directional buffers in between. The SP segment connects directly to the VME\_FPGA pins. The FRONT/DDU segment is located behind the buffers. Two auxiliary lines: Buffer Write (data direction) and Buffer Output Enable, - are used to control data flow through the buffers.

The IDTB cycle is a sequence of level states on the signal lines that results in the transfer of an address and two bytes of data between the VME\_FPGA and other SP02 FPGA(s).

Each IDTB cycle is an inherent part of the backplane DTB cycle, when DTB addresses FPGA(s), other than VME\_FPGA. Chip Select (/CS) plays role of the DS\* strobe and Acknowledge (/ACK) plays role of the DTACK\*. The major difference between backplane DTB and IDTB is that IDTB is a synchronous bus, i.e. both /CS and /ACK handshake signals should be asserted on the rising edge of the system clock at source, and sensed with the next rising edge of the system clock at destination.

The VME\_FPGA initiates two types of IDTB cycles:

- IDTB Write cycle transfers data from the VME\_FPGA to one or more destination FPGA(s). The cycle begins when the VME\_FPGA sets address, data, Write and optionally Buffer Write and Buffer Output Enable on the corresponding lines and issues one or more Chip Selects. Selected FPGA(s) captures the address and checks to see if it is to respond to the cycle. If so, sensing Write in a LOW state, it stores the data and acknowledges the transfer. The VME\_FPGA then terminates the cycle.
- IDTB Read cycle transfers data from the source FPGA to the VME\_FPGA. The cycle begins when the VME\_FPGA sets address and optionally a Buffer Output Enable and issues a Chip Select. Selected FPGA captures and the address and checks to see if it is to respond to the cycle. If so, sensing Write in a HIGH state, it retrieves the data from the corresponding storage, places it on the data lines and acknowledges the transfer. The VME\_FPGA then terminates the cycle.

Normally the VME\_FPGA would terminate the DTB cycle with the Data Transfer Acknowledge (DTACK\*) asserted low. If during the DTB cycle the addressable SP02 detects that the VME Master either addresses a non-existed location, or tries to write to a read-only location, the VME\_FPGA terminates the cycle with a Bus Error (BERR\*) asserted low. The VME\_FPGA is not aware of the DTB outcome, when it passed the DTB cycle to the IDTB. If the expected IDTB Acknowledge(s) is (are) not received after a time-out period has expired, the VME\_FPGA terminates the cycle driving BERR\* low. The VME\_FPGA time-out period is set to 8 system clocks.

Any storage location inside the SP02 can also be accessed with a Block Read/Write Cycle (BLT), when AM=0x3B. To initialize BLT to a certain location(s), the user has first to access the VME\_FPGA and either to download the BLT Mapping Register with a BLT

destination address, or to fill in one of the BLT Mapping FIFOs with a list of destination addresses. During the BLT DTB cycle the VME\_FPGA, depending on value in the BA field, uses one of the mapping locations, see Table 11, to substitute the current backplane address with the address stored in the mapping location. Table 13 shows data format for loading the BLT Mapping Register/FIFO, and Table 12 lists 4 128Kbyte windows for BLT transfers.

Table 11 SP02 BLT Address Space, AM=0x3B

| A23 A22 A21 A20 A19 | A18 A17 | A16 A15 A | A14 A13 A12 | A11 A10 | A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
|---------------------|---------|-----------|-------------|---------|----|----|----|----|----|----|----|----|----|----|
| SA                  | BA      |           |             |         | Z  | K  |    |    |    |    |    |    |    | 0  |

Here:

- SA Slot Address, could be either Slot Geographical Address (GA), or Slot Broadcast Address (30);
- BA BLT Address. Defines one out of four BLT Mapping locations inside the VME\_FPGA to substitute the current VMA backplane address with the preloaded one.
- X Don't care address lines;

Table 12 SP02 Broadcast Address Field, AM=0x3B

| BA  | Register Name        | First Address     | Last Address      | Address Space          |
|-----|----------------------|-------------------|-------------------|------------------------|
| 0x0 | BLT Mapping Register | SA<<19    0x00001 | SA<<19    0x1FFFF | 64 Kwords = 128 Kbytes |
| 0x1 | BLT Mapping FIFO_1   | SA<<19    0x20001 | SA<<19    0x3FFFF | 64 Kwords = 128 Kbytes |
| 0x2 | BLT Mapping FIFO_2   | SA<<19    0x40001 | SA<<19    0x5FFFF | 64 Kwords = 128 Kbytes |
| 0x3 | BLT Mapping FIFO_3   | SA<<19    0x60001 | SA<<19    0x7FFFF | 64 Kwords = 128 Kbytes |

 Table 13 SP02 BLT Mapping Register/FIFO Data Format

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|     |     |     | CA  |     |     |    | М  | A  |    |    |    | RA |    |    |    |

## **Register Detail**

## **Action Register Group**

## ACT\_HR – FPGA Hard Reset Register

Addressing this write-only register results in sending a 400 ns Hard Reset pulse to the selected FPGA(s) onboard. Hard Reset is applied to the /PROG\_B pin of the corresponding FPGA. A VME-generated Hard Reset is ORed with a CCB backplane hard reset. Register address is applicable to VME\_FPGA only.

To make sure all FPGA chips are present on the board, CSR\_CFG command should be executed twice: first time when chips are engaged in the configuration process and second time after a 5 sec pause, when the configuration is definitely completed. If there is a missing FPGA chip on board (a mezzanine card not installed, for example) then the corresponding Configuration Done line remains floating, and could be sensed by the VME\_FPGA either as a High ("1") or Low ("0") level. But in any case, the bit for a missing chip would retain its state, while the bit for a successfully configured FPGA would be "0" on the first read and "1" on the second read. See Table 48 for chip coding.

#### Table 14

| D15 | D14  | D13 | D12 | D11 | D10 | D9 | D8 | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0 |
|-----|------|-----|-----|-----|-----|----|----|------|------|------|------|------|------|------|----|
| Х   | Х    | Х   | Х   | Х   | Х   | Х  | Х  | SPHR | DDHR | F5HR | F4HR | F3HR | F2HR | F1HR | Х  |
|     | Hana |     |     |     |     |    |    |      |      |      |      |      |      |      |    |

Here:

- X Don't care bit
- F1HR FRONT\_FPGA\_1 Hard Reset
- F2HR FRONT\_FPGA\_2 Hard Reset
- F3HR FRONT\_FPGA\_3 Hard Reset
- F4HR FRONT\_FPGA\_4 Hard Reset
- F5HR FRONT\_FPGA\_5 Hard Reset
- DDHR DDU\_FPGA Hard Reset
- SPHR SP\_FPGA Hard Reset

#### ACT\_CMR – Clock Manager Reset

Addressing this write-only register results in sending 50 ns reset pulse to selected DCM(s). Reset pulse resets also DCM error counters described under the CSR\_CM1 and CSR\_CM2 headings. Register address is applicable to all FPGAs.

#### Table 15

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2   | D1   | D0 |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|------|------|----|
| Х   | Х   | Х   | Х   | Х   | Х   | Х  | Х  | Х  | Х  | Х  | Х  | Х  | CMR2 | CMR1 | Х  |

Here:

- X Don't care bit
- CMR1 Clock Manager 1 Reset
- CMR2 Clock Manager 2 Reset

#### ACT\_LCR – Link Counters Resets

Addressing this write-only register results in sending 25 ns reset pulse to selected error counters described under the STS\_VPC, CSR\_LNK and CSR\_LEC headings. The ACT\_LCR address is applicable to FRONT\_FPGA and DDU\_FPGA.

#### Table 16

| D15 | D14 | D13   | D12   | D11    | D10      | D9      | D8      | D7      | D6     | D5      | D4    | D3   | D2    | D1    | D0    |
|-----|-----|-------|-------|--------|----------|---------|---------|---------|--------|---------|-------|------|-------|-------|-------|
| Х   | Х   | Х     | Х     | Х      | Х        | Х       | Х       | Х       | Х      | Х       | VPR   | TER  | SLR   | CER   | EWR   |
|     |     | EWR - |       |        | Error V  |         |         | `       |        |         | ,     |      |       |       |       |
|     | - ( | CER – | TLK2  | 2501 C | Carrier  | Exten   | d Cou   | nter (F | RXDV   | = L     | OW, F | XER  | == HI | GH) F | Reset |
|     | - 5 | SLR – | FINIS | AR of  | ptical 1 | receive | er Sigi | nal Lo  | ss Cou | inter ( | RXSD  | goes | LOW)  | Rese  | t     |

- TER PRBS Test Error Counter Reset
- VPR Valid Pattern Counter Reset

## ACT\_XFR – FIFOs Reset

Addressing this write-only register results in sending 25 ns reset pulse to selected entities as described below. Register address is applicable to FRONT\_FPGA, DDU\_FPGA, and SP\_FPGA.

#### Table 17

|                                               |   |     |     | D3  | D4  | D5 | D6 | D7 | D8 | D9 | D10 | D11 | D12 | D13 | D14 | D15 |
|-----------------------------------------------|---|-----|-----|-----|-----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|
| A A A A A A A A A A A A A A A DFK FFK SFK IFK | Х | TFR | SFR | PFR | DFR | x  |    | X  | Х  | v  | X   | X   | Х   | X   | Х   | Y   |

#### Here:

- TFR Test FIFO Reset (Init)
- SFR Spy FIFO Reset (Init)
- PFR Pipeline FIFO Reset (Init)
- DFR DAQ FIFO Reset (Init). It also resets L1 Accept FIFO, ring buffer read/write pointers, and event builder.

## **Control/Status Register Group**

#### STS\_CCB – Status of the Backplane CCB command bus.

This read-only register remembers previous and displays current state of the CCB command bus. The register address is valid for the VME\_FPGA only.

#### Table 18

| D15 | D14 | D13  | D12  | D11   | D10       | D9   | D8   | D7 | D6 | D5   | D4   | D3    | D2       | D1   | D0   |
|-----|-----|------|------|-------|-----------|------|------|----|----|------|------|-------|----------|------|------|
|     |     | CMD5 | CMD4 | CMD3  | CMD2      | CMD1 | CMD0 |    |    | CML5 | CML4 | CML3  | CML2     | CML1 | CML0 |
|     |     |      | CC   | B CMD | Current S | tate |      |    |    |      | CCB  | CMD L | ast Comr | nand |      |

Here:

- CMD [5:0] current state of the backplane CCB command bus (positive logic)
- CML [5:0] latched state of the previous CCB command (positive logic)

#### STS\_ANA – CCB Analyzer

This register stores a sequence of up to 64 CCB commands. The analyzer content is reset on power-up and on any write cycle addressed to this register.

#### Table 19

| D15   | D14 | D13  | D12  | D11       | D10      | D9   | D8   | D7   | D6   | D5   | D4     | D3    | D2   | D1    | D0    |
|-------|-----|------|------|-----------|----------|------|------|------|------|------|--------|-------|------|-------|-------|
| L1ACC | BC0 | ANA5 | ANA4 | ANA3      | ANA2     | ANA1 | ANA0 | CMD5 | CMD4 | CMD3 | CMD2   | CMD1  | CMD0 | ECRES | BCRES |
|       |     |      | A    | nalyzer V | Vord Cou | nt   |      |      |      |      | CCB Co | mmand |      |       |       |

- L1ACC L1 Accept
- BC0 Decoded by CC B the BC0 command
- CMD [5:0] -CCB command code
- ECRES Event Counter Reset
- BCRES Bunch Counter Reset
- ANA [5:0] Analyzer Word Count after the current word has been read out.

### STS\_VPC – Valid Pattern Counter

This read-only register is intended to monitor incoming muon rate for each link by counting the number of Valid Pattern bits at the Alignment FIFO output. The counter control follows that of the event counter: it is reset on the CCB\_L1RES, and CCB\_ECRES commands and enabled, when data taking state machine is in an L1A\_RUN state, see Figure 1 for details on L1Accept control. The STS\_VPC address is applicable to FRONT\_FPGAs.

#### Table 20

| D15  | D14  | D13  | D12  | D11  | D10  | D9  | D8         | D7       | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|------|------|------|------|------|------|-----|------------|----------|-----|-----|-----|-----|-----|-----|-----|
| VP15 | VP14 | VP13 | VP12 | VP11 | VP10 | VP9 | VP8        | VP7      | VP6 | VP5 | VP4 | VP3 | VP2 | VP1 | VP0 |
|      |      |      |      |      |      | V   | alid Patte | rn Count | er  |     |     |     |     |     |     |

#### CSR\_CID VP0 Chip ID Register

This read-only register keeps a firmware release date in the format shown in the table below. Register address is applicable to all FPGAs.

#### Table 21

| D15 D14 | D13 | D12 | D11 | D10   | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|---------|-----|-----|-----|-------|----|----|----|----|----|----|----|----|----|----|
| Y       | Y   |     |     | MM NN |    |    |    |    |    | DD |    |    |    |    |

Here:

- DD Day Code (01...31)
- NN FPGA Number (0...7), which corresponds to 8 FPGA chips, numbered in the following order: VM, F1, F2, F3, F4, F5, DD, SP.
- MM Month Code (01...12)
- YY Year Code (00...15)

#### CSR\_CLK – System Clock Control/Status

This read/write register controls the source of the TLK2501 80.1574 MHz reference clock, which could be either external VCXO clock (default) or FRONT\_FPGA DCM2 clock. The CSR\_CLK address is applicable to FRONT\_FPGAs.

#### Table 22

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0  | Acc |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|-----|-----|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | RCS | R   |
| Х   | Х   | Х   | Х   | Х   | Х   | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | RCS | W   |

Here:

- X Don't care bit
- RCS TLK2501 Reference Clock Select bit.
  - "0" selects the DCM2 clock
  - "1" selects the VCXO clock (default value).

#### CSR\_CM1 – System Clock Manager 1 Status

This read-only register keeps history of Digital Clock Manager 1 behavior after the last ACT\_CMR command. Its default value is 0x0004, which means that all enabled DCM1 features locked and there were no errors since last reset. For all FPGAs DCM1 is a DCM with internal

feedback, distributing system clock all over the chip, including link clocking for FRONT\_FPGA and DDU\_FPGA.

#### Table 23

| D15 | D14    | D13     | D12 | D11 | D10    | D9      | D8 | D7 | D6 | D5 | D4 | D3 | D2   | D1   | D0   |
|-----|--------|---------|-----|-----|--------|---------|----|----|----|----|----|----|------|------|------|
|     | LCK1 ( | Counter |     |     | CST1 C | Counter |    | 0  | 0  | 0  | 0  | 0  | LCK1 | CST1 | PSO1 |
|     |        |         |     |     |        |         |    |    |    |    |    |    | •    |      |      |

#### Here:

- PSO1 Phase Shift Overflow, should be LOW for normal operation
- CST1 Input Clock Stopped Toggling
- CST1 Counter "loss of input clock" counter. It counts number of "CST2 go HIGH" after last DCM1 reset. Counter stops when reaches its maximum value of 15.
- LCK1 All enabled DCM features locked
- LCK1 Counter "loss of lock" counter. It counts number of "LCK2 go LOW" after last DCM1 reset. Counter stops when reaches its maximum value of 15.

## CSR\_CM2 – System Clock Manager 2 Status

This read-only register keeps history of Digital Clock Manager 2 behavior after the last ACT\_CMR command. Its default value is 0x0004, which means that all enabled DCM2 features locked and there were no errors since last reset. For VME\_FPGA DCM2 is a DCM with external feedback, distributing system clock all over the board. In FRONT\_FPGA(s) DCM2 multiplies by 2 system clock.

#### Table 24

| D15 | D14  | D13     | D12 | D11 | D10    | D9      | D8 | D7 | D6 | D5 | D4 | D3 | D2   | D1   | D0   |
|-----|------|---------|-----|-----|--------|---------|----|----|----|----|----|----|------|------|------|
|     | LCK2 | Counter |     |     | CST2 C | Counter |    | 0  | 0  | 0  | 0  | 0  | LCK2 | CST2 | PSO2 |
|     |      |         |     |     |        |         |    |    |    |    |    |    |      |      |      |

Here:

- PSO2 Phase Shift Overflow, should be LOW for normal operation
- CST2 Input Clock Stopped Toggling
- CST2 Counter "loss of input clock" counter. It counts number of "CST2 go HIGH" after last DCM2 reset. Counter stops when reaches its maximum value of 15.
- LCK2 All enabled DCM features locked
- LCK2 Counter "lost of lock" counter. It counts number of "LCK2 go LOW" after last DCM2 reset. Counter stops when reaches its maximum value of 15.

## CSR\_BSY – Busy Control/Status

In the VME\_FPGA the CSR\_BSY register displays status of seven input and one output BSY lines. Besides, it carries eight mask bits, so each input or/and VME\_FPGA output can be either disabled or enabled:

 $BSY0 = (BSY1*BSC1 + BSY2*BSC2 + BSY3*BSC3 + BSY4*BSC4 + BSY5*BSC5 + BSY6*BSC6 + BSY7*BSC7 + BSY0_INT)*BSC0 + BSY6*BSC6 + BSY7*BSC7 + BSY0_INT)$ 

Indexes 0...7 stand for chip numbers; see Table 7 and/or Table 21 for chip numbering scheme, and BSY0\_INT is an internal busy status o the VME\_FPGA, which is "1" when counting of CCB\_L1ACCs is stopped (disabled).

The FRONT\_FPGA sets BSY to "1", when either the Bunch counter carries 0xFFF=4095 value, or link resynch on CCB\_L1RES failed (the AF word count remains zero).

#### Table 25

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|
| BSC7 | BSC6 | BSC5 | BSC4 | BSC3 | BSC2 | BSC1 | BSC0 | BSY7 | BSY6 | BSY5 | BSY4 | BSY3 | BSY2 | BSY1 | BSY0 | R   |
| BSC7 | BSC6 | BSC5 | BSC4 | BSC3 | BSC2 | BSC1 | BSC0 | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | W   |

Here:

- X Don't care bit
- BSC [7:0] Busy Chip mask for SP, DD, F5...F1, and VM chips
- BSY [7:0] Busy status for SP, DD, F5...F1, and VM chips

#### CSR\_RDY – Ready Control/Status

In the VME\_FPGA the CSR\_RDY register displays status of seven input and one output RDY lines. Besides, it carries eight mask bits, so each input or/and VME\_FPGA output can be either disabled or enabled:

RDY0 = (RDY1\*RDC1 + RDY2\*RDC2 + RDY3\*RDC3 + RDY4\*RDC4 + RDY5\*RDC5 + RDY6\*RDC6 + RDY7 \*RDC7) \* RDY0\_INT \*RDC0

Indexes 0...7 stand for chip numbers; see Table 7 and/or Table 21 for chip numbering scheme, and RDY0\_INT is an internal ready status of the VME\_FPGA, which is "1" when passing of CCB\_L1ACCs to the FC bus is enabled.

The FRONT\_FPGA sets RDY to "1", when link resynchronization initiated by CCB\_L1RES completed a success (the Alignment FIFO is neither empty, nor full). Only links with enabled TLK2501 receivers contribute to the chip's RDY status; see CSR\_LNK – Link Control/Status register for a DVEN bit description.

#### Table 26

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|
| RDC7 | RDC6 | RDC5 | RDC4 | RDC3 | RDC2 | RDC1 | RDC0 | RDY7 | RDY6 | RDY5 | RDY4 | RDY3 | RDY2 | RDY1 | RDY0 | R   |
| RDC7 | RDC6 | RDC5 | RDC4 | RDC3 | RDC2 | RDC1 | RDC0 | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | W   |

Here:

- X Don't care bit
- RDC [7:0] Ready Chip mask for SP, DD, F5...F1, and VM chips
- RDY [7:0] Ready status for SP, DD, F5...F1, and VM chips

#### CSR\_WOF – Warning-of-OverFlow Control/Status

In the VME\_FPGA the CSR\_WOF register displays status of seven input and one output WOF lines. Besides, it carries eight mask bits, so each input or/and VME\_FPGA output can be either disabled or enabled:

WOF0 = (WOF1\*WOC1 + WOF2\*WOC2 + WOF3\*WOC3 + WOF4\*WOC4 + WOF5\*WOC5 + WOF6\*WOC6 + WOF7 \*WOC7) \* WOC0

Indexes 0...7 stand for chip numbers; see Table 7 and/or Table 21 for chip numbering scheme.

The FRONT\_FPGA sets WOF to "1", when either the DAQ FIFO or the Ring Buffer are full. It drops WOF to "0" when both buffers become empty.

#### Table 27

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|
| WOC7 | WOC6 | WOC5 | WOC4 | WOC3 | WOC2 | WOC1 | WOC0 | WOF7 | WOF6 | WOF5 | WOF4 | WOF3 | WOF2 | WOF1 | WOF0 | R   |
| WOC7 | WOC6 | WOC5 | WOC4 | WOC3 | WOC2 | WOC1 | WOC0 | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | W   |

Here:

- X Don't care bit
- WOC [7:0] Warning-of-OverFlow Chip mask for SP, DD, F5...F1, and VM chips
- WOF [7:0] Warning-of-OverFlow status for SP, DD, F5...F1, and VM chips

## CSR\_OSY - Out-of-Synch Control / Status

In the FRONT\_FPGA this register shows a timing offset between BC0 marks, sent by the MPC and coming out of the Alignment FIFO, and the local bunch crossing counter (BXN) value. The BC0 mark strobes the BXN value into the offset register.

If the offset register content is not equal to zero for a given link, an Out-of-Synch status is generated. Bit D12 of the Out-of-Synch register allows masking the out-of-synch status individually for each link before the combined fast monitoring OSY signal is sent over to the VME\_FPGA. Besides, link OSY status is reported only if the corresponding TLK2501 device is enabled, i.e. bit DVEN=1, see the CSR\_LNK – Link Control/Status register description.

See the CSR\_BCO register description on how to adjust the BXN offset value to bring the control and data timing to synch.

In the VME\_FPGA the CSR\_OSY register displays status of seven input and one output OSY lines. Besides, it carries eight mask bits, so each input or/and output can be either disabled or enabled:

OSY0 = (OSY1\*OSC1 + OSY2\*OSC2 + OSY3\*OSC3 + OSY4\*OSC4 + OSY5\*OSC5 + OSY6\*OSC6 + OSY7 \*OSC7) \* OSC0

Indexes 0...7 stand for chip numbers; see Table 7 and/or Table 21 for chip numbering scheme.

| Table 28 FRONT | _FPGA CS | R_OSY registe | r bit assignment, o | one register per muon. |
|----------------|----------|---------------|---------------------|------------------------|
|----------------|----------|---------------|---------------------|------------------------|

| D15 | D14 | D13 | D12 | D11   | D10   | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|-----|-----|-----|-----|-------|-------|------|------|------|------|------|------|------|------|------|------|-----|
| OSM | 0   | 0   | 0   | OFF11 | OFF10 | OFF9 | OFF8 | OFF7 | OFF6 | OFF5 | OFF4 | OFF3 | OFF2 | OFF1 | OFF0 | R   |
| OSM | Х   | Х   | Х   | Х     | Х     | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | W   |

Here:

- X Don't care bit
- OFF [10:0] = offset register, default value on power-up is 0x7FF.
- OSM Out-of-Synch link Mask, default value is "1" The Out-of-Synch condition, if exists, is sent to the chip output.

#### Table 29 VME\_FPGA CSR\_OSY register bit assignment

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|
| OSC7 | OSC6 | OSC5 | OSC4 | OSC3 | OSC2 | OSC1 | OSC0 | OSY7 | OSY6 | OSY5 | OSY4 | OSY3 | OSY2 | OSY1 | OSY0 | R   |
| OSC7 | OSC6 | OSC5 | OSC4 | OSC3 | OSC2 | OSC1 | OSC0 | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | W   |

- X Don't care bit
- OSC [7:0] Out-of-Synch Chip mask for SP, DD, F5...F1, and VM chips
- OSY [7:0] Out-of-Synch status for SP, DD, F5...F1, and VM chips

### CSR\_CCD – CCB Command Delay – obsolete for Firmware Versions after 25-Aug-2003

This read/write register controls the CCB command timing inside the SP02. Writing nonzero values into this register introduces additional delay for all CCB commands, so that the entire SP02 timing gets shifted. Using this register is the only way to adjust the SP02 timing to the input link timing.

#### Table 30

| D15 | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7 | D6 | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|-----|------|------|------|------|------|------|------|----|----|------|------|------|------|------|------|-----|
| 0   | CDS6 | CDS5 | CDS4 | CDS3 | CDS2 | CDS1 | CDS0 | 0  | 0  | CCD5 | CCD4 | CCD3 | CCD2 | CCD1 | CCD0 | R   |
| Х   | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х  | Х  | CCD5 | CCD4 | CCD3 | CCD2 | CCD1 | CCD0 | W   |

Here:

- X Don't care bit
- CCD [5:0] = 0...63 delays CCB commands by 1...64 bunch crossings before passing them to the internal Fast Control bus.
- CDS [6:0] = 1...64 Command Delay Status, reports an actual delay setting.

#### CSR\_BCO – Bunch Counter Offset

This read/write register controls the Bunch Counter Offset value. The whole idea of loading the bunch counter with an offset value is due to having two timings in the FRONT\_FPGA: the CCB control timing and the optical data-link timing. The bunch counter starts counting on the first CCB\_BCO after the CCB\_L1STT command, i.e. on the control timing. But its job is to monitor BC0 marks in the data path, i.e. the data timing. The requirement is that the bunch counter be adjusted to the data timing, since the bunch counter value is an intrinsic part of the event format. An offset between the two timings may be either positive or negative. If the CCB\_BC0 command comes later than BC0 marks, we will consider such an offset to be positive. We would need to download small positive values in the CSR\_BC0 register to compensate for such an offset. If the CCB\_BC0 command comes earlier than BC0 marks, we will consider such an offset to be negative. We would need to download large values in the CSR\_BC0 register to compensate for such an offset. Maximum BXN is equal to 923 for the test beam at SPS and to 3563 for LHC operations. On the contrary, in the CSR\_OSY register uncompensated positive offsets would be seen as large values, while uncompensated negative offsets would be seen as small values.

The CSR\_BCO adjustment makes sense to perform only after the Alignment FIFO has been adjusted. Use the following procedure to make an adjustment:

- $\Rightarrow$  Set the CSR\_BCO = 0 (default value);
- $\Rightarrow$  Start data taking;
- ⇒ Read the CSR\_OSY registers for each active link. If timing in the Peripheral Crate has been set correctly and link alignment procedure has been performed correctly, the CSR\_OSY values for all active links should be the same; If this value is not zero, the red OSY LED should be ON.
- $\Rightarrow$  Find a complement to the CSR\_OSY value (with respect to a maximum bx number);
- $\Rightarrow$  Stop data taking;
- $\Rightarrow$  Load the found value in the CSR\_BCO register;
- $\Rightarrow$  Start data taking;

 $\Rightarrow$  Read the CSR\_OSY registers for each active link. All links should show zero offset, and the red OSY LED should go OFF.

#### Table 31

| D15 | D14 | D13 | D12 | D11   | D10   | D9   | D8    | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|-----|-----|-----|-----|-------|-------|------|-------|------|------|------|------|------|------|------|------|-----|
| BCM | 0   | 0   | 0   | BCO11 | BCO10 | BCO9 | BCO08 | BCO7 | BCO6 | BCO5 | BCO4 | BCO3 | BCO2 | BCO1 | BCO0 | R   |
| BCM | Х   | Х   | Х   | BCO11 | BCO10 | BCO9 | BCO08 | BCO7 | BCO6 | BCO5 | BCO4 | BCO3 | BCO2 | BCO1 | BCO0 | W   |

Here:

- X Don't care bit
- BCO [11:0] = 0...4095 Bunch Counter Offset value. Valid values are 0...923 for the test beam at SPS and 0...3563 for LHC operations.
- BCM = 1/0 SPS beam/LHC beam or 923/3563 bunch crossings per turn.

#### CSR\_L1D – L1 Accept Delay

This read/write register controls the L1 Accept timing inside the SP02. Writing non-zero values into this register introduces an additional delay for L1 Accepts. Using this register is the only way to adjust for a "negative" timing, when L1 Accept trigger arrives earlier than data.

#### Table 32

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7 | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|----|------|------|------|------|------|------|------|-----|
| L1S7 | L1S6 | L1S5 | L1S4 | L1S3 | L1S2 | L1S1 | L1S0 | 0  | L1D6 | L1D5 | L1D4 | L1D3 | L1D2 | L1D1 | L1D0 | R   |
| Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х  | L1D6 | L1D5 | L1D4 | L1D3 | L1D2 | L1D1 | L1D0 | W   |

Here:

- X Don't care bit
- L1D [6:0] = 0...127 delays L1 Accept by 1...128 bunch crossings before passing it to the internal logic.
- L1S [7:0] = 1...128 L1 Accept Delay Status, reports an actual delay setting.

#### CSR\_LEC – Link Error Counters

This read-only register monitors all possible link errors. The TLK2501 synchronization procedure, when the MPC switches TLK2501 transmitters into idle mode for 128 bunch crossings, always precedes the normal operation. Normal receiving operation assumes RXSD and RXDV to be High and RXER to be Low. To facilitate monitoring of error conditions, any combination of RXSD, RXDV and RXER other than normal is detected and countered. Error conditions are accumulated over time, starting from the previous synchronization procedure. Counter stops when it reaches its maximum value. The counters are reset on L1\_Reset and begin count errors after Alignment FIFO has been enabled for writing. Addressing the ACT\_LER register provides an alternative reset option.

#### Table 33

| D15  | D14                                        | D13  | D12  | D11  | D10  | D9   | D8   | D7   | D6   | D5   | D4        | D3       | D2   | D1   | D0   |
|------|--------------------------------------------|------|------|------|------|------|------|------|------|------|-----------|----------|------|------|------|
| SLC3 | SLC2                                       | SLC1 | SLC0 | CEC3 | CEC2 | CEC1 | CEC0 | EWC7 | EWC6 | EWC5 | EWC4      | EWC3     | EWC2 | EWC1 | EWC0 |
| S    | Signal Loss Counter Carrier Extend Counter |      |      |      |      |      | ter  |      |      | E    | Error Wor | d Counte | r    |      |      |
|      | Hana                                       |      |      |      |      |      |      |      |      |      |           |          |      |      |      |

- EWC [7:0] TLK2501 Error Word Counter (RXDV == High, RXER == High)
- CEC [3:0] TLK2501 Carrier Extend Counter (RXDV == Low, RXER == High)

- SLC [3:0] – FINISAR optical receiver Signal Loss Counter (RXSD goes Low)

#### CSR\_AF – Alignment FIFO Status

This read-only register shows the number of words currently sitting in the Alignment FIFO (AF). After a link synchronization procedure has been performed, Alignment FIFOs for different links may show different word counts. Dispersion of word count values corresponds to the dispersion of link latencies. Adjusting the CCB clock in the Track-Finder crate, so that a minimum word count would be equal to 1, minimizes the overall time required to align all muon links. Register address is applicable to FRONT\_FPGA (3 each) and to SP\_FPGA (2 each – MA = 0|1|2). The maximum available value is 31.

#### Table 34

| D15  | D14  | D13 | D12 | D11 | D10 | D9 | D8                                                                       | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   |
|------|------|-----|-----|-----|-----|----|--------------------------------------------------------------------------|------|------|------|------|------|------|------|------|
| AFFF | AFEF | 0   | 0   | 0   | 0   | 0  | AFC8                                                                     | AFC7 | AFC6 | AFC5 | AFC4 | AFC3 | AFC2 | AFC1 | AFC0 |
| Fla  | ags  |     |     |     |     |    | AFC8 AFC7 AFC6 AFC5 AFC4 AFC5 AFC2 AFC1 AFC<br>Alignment FIFO Word Count |      |      |      |      |      |      |      |      |

Here:

- AFC [8:0] Alignment FIFO Read Word Count
- AFFF Alignment FIFO Full Flag
- AFEF Alignment FIFO Empty Flag

#### CSR\_TF - Test FIFO Status

This read-only register shows the number of words currently loaded to the Test FIFO (TF) and FIFO Flags. The maximum available TF capacity is 1024 16-bit words. Register address is applicable to FRONT\_FPGA (3 each), DDU\_FPGA (1 each) and SP\_FPGA (3 each).

#### Table 35

| D15  | D14  | D13 | D12 | D11 | D10   | D9   | D8   | D7   | D6      | D5      | D4      | D3   | D2   | D1   | D0   |
|------|------|-----|-----|-----|-------|------|------|------|---------|---------|---------|------|------|------|------|
| TFFF | TFEF | 0   | 0   | 0   | TFC10 | TFC9 | TFC8 | TFC7 | TFC6    | TFC5    | TFC4    | TFC3 | TFC2 | TFC1 | TFC0 |
| Fla  | ags  |     |     |     |       |      |      |      | Test FI | FO Word | l Count |      |      |      |      |

Here:

- TFC [10:0] Test FIFO Word Count
- TFFF Test FIFO Full Flag
- TFEF Test FIFO Empty Flag

## CSR\_SF – Spy FIFO Status

This read-only register shows the number of words currently sitting in the Spy FIFO (SF). One would probably want to know this value before setting up the BLT read cycle to read out the SF content. Maximum available SF capacity is 1024 16-bit words. Register address is applicable to FRONT\_FPGA (3 each), DDU\_FPGA (1 each) and SP\_FPGA (3 each).

#### Table 36

| D15  | D14  | D13  | D12    | D11 | D10   | D9   | D8   | D7   | D6     | D5      | D4    | D3   | D2   | D1   | D0   |
|------|------|------|--------|-----|-------|------|------|------|--------|---------|-------|------|------|------|------|
| SFFF | SFEF | RXDV | RXER   | 0   | SFC10 | SFC9 | SFC8 | SFC7 | SFC6   | SFC5    | SFC4  | SFC3 | SFC2 | SFC1 | SFC0 |
| Fla  | ags  | RX S | Status |     |       |      |      |      | Spy FI | FO Word | Count |      |      |      |      |

Here:

- SFC [10:0] – Spy FIFO Word Count

- SFFF Spy FIFO Full Flag
- SFEF Spy FIFO Empty Flag
- RXDV, RXER TLK2501 Receiver Status for the last data read out from the Spy FIFO

## CSR\_PF – Pipeline FIFO Status

This read-only register shows the number of words currently loaded to the Pipeline FIFO (PF) and FIFO Flags. The maximum available PF capacity is 1024 18-bit words. Register address is applicable to FRONT\_FPGA.

#### Table 37

| D15  | D14  | D13 | D12 | D11 | D10                                                                                 | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | DO   |
|------|------|-----|-----|-----|-------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------|------|------|
| PFFF | PFEF | 0   | 0   | 0   | PFC10                                                                               | PFC9 | PFC8 | PFC7 | PFC6 | PFC5 | PFC4 | PFC3 | PFC2 | PFC1 | PFC0 |
| Fla  | ags  |     |     |     | PFC10 PFC9 PFC8 PFC7 PFC6 PFC5 PFC4 PFC3 PFC2 PFC1 PFC0<br>Pipeline FIFO Word Count |      |      |      |      |      |      |      |      |      |      |

Here:

- PFC [10:0] Pipeline FIFO Word Count
- PFFF Pipeline FIFO Full Flag
- PFEF Pipeline FIFO Empty Flag

## CSR\_DF – DAQ FIFO Status

This read-only register shows the number of words currently loaded to the DAQ FIFO (DF) and link error status for muon data words. The maximum available DF capacity is 4096 18bit words. Register address is applicable to FRONT\_FPGA. In the readout event format, see Table 51, the Synchronization Error (SE) bit resides in the second data frame. To provide for error analysis, the CSR\_DF register retrieves Receive Error flags for both data frames, making them available after the second frame has been read out.

#### Table 38

| D15  | D14    | D13 | D12   | D11                 | D10   | D9   | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   |
|------|--------|-----|-------|---------------------|-------|------|------|------|------|------|------|------|------|------|------|
| PFRE | CFRE   | 0   | DFC12 | DFC11               | DFC10 | DFC9 | DFC8 | DFC7 | DFC6 | DFC5 | DFC4 | DFC3 | DFC2 | DFC1 | DFC0 |
| Link | Errors |     |       | DAQ FIFO Word Count |       |      |      |      |      |      |      |      |      |      |      |

Here:

- DFC [12:0] DAQ FIFO Word Count
- CFRE Current Frame Receive Error Flag
- PFRE Previous Frame Receive Error Flag

## CSR\_LF – L1 Accept FIFO Status

This read-only register shows the number of words currently loaded to the L1 Accept FIFO (LF) and FIFO Flags. The maximum available LF capacity is 1024 54-bit words. Register address is applicable to FRONT\_FPGA.

#### Table 39

| D15  | D14  | D13 | D12 | D11 | D10   | D9   | D8   | D7   | D6        | D5     | D4       | D3   | D2   | D1   | D0   |
|------|------|-----|-----|-----|-------|------|------|------|-----------|--------|----------|------|------|------|------|
| LFFF | LFEF | 0   | 0   | 0   | LFC10 | LFC9 | LFC8 | LFC7 | LFC6      | LFC5   | LFC4     | LFC3 | LFC2 | LFC1 | LFC0 |
| Flag | gs   |     |     |     |       |      |      | Ι    | .1 Accept | FIFO W | ord Cour | ıt   |      |      |      |

- LFC [10:0] L1 Accept FIFO Word Count
- LFFF L1 Accept FIFO Full Flag
- LFEF L1 Accept FIFO Empty Flag

## CSR\_RBW – Ring Buffer Write Pointer

This read-only register shows the current position of the Ring Buffer Write Pointer. Ring Buffer is a 54 bit x 1024 word temporary storage for muon data, before they are get reformatted and put in the DAQ FIFO for readout. The register is used for firmware debugging.

#### Table 40

| D15 | D14 | D13 | D12 | D11 | D10 | D9   | D8   | D7   | D6   | D5         | D4        | D3   | D2   | D1   | D0   |
|-----|-----|-----|-----|-----|-----|------|------|------|------|------------|-----------|------|------|------|------|
| 0   | 0   | 0   | 0   | 0   | 0   | RBW9 | RBW8 | RBW7 | RBW6 | RBW5       | RBW4      | RBW3 | RBW2 | RBW1 | RBW0 |
|     |     |     |     |     |     |      |      |      | Ring | g Buffer ' | Write Poi | nter |      |      |      |

Here:

- RBW [9:0] – Ring Buffer Write Pointer

## CSR\_RBR – Ring Buffer Read Pointer

This read-only register shows the current position of the Ring Buffer Read Pointer. Ring Buffer is a 54 bit x 1024 word temporary storage for muon data, before they are get reformatted and put in the DAQ FIFO for readout. The register is used for firmware debugging.

#### Table 41

| D15 | D14 | D13 | D12 | D11 | D10 | D9                       | D8   | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   |
|-----|-----|-----|-----|-----|-----|--------------------------|------|------|------|------|------|------|------|------|------|
| 0   | 0   | 0   | 0   | 0   | 0   | RBR9                     | RBR8 | RBR7 | RBR6 | RBR5 | RBR4 | RBR3 | RBR2 | RBR1 | RBR0 |
|     |     |     |     |     |     | Ring Buffer Read Pointer |      |      |      |      |      |      |      |      |      |

Here:

- RBR [9:0] – Ring Buffer Read Pointer

## CSR\_LNK – Link Control/Status

This register provides static link control and status directly to and from both Finisar and TLK2501 transceivers' pins. Read-only upper byte shows receiver status, while lower byte provides access to control pins. Under the normal operational conditions register value equals to 0x0511 for a receiving link and equals to 0x0014 for a transmitting link. When TSEN is asserted High, results of pseudorandom bit stream tests can be monitored on the RXER output. A High on this terminal indicates that valid PRBS is being received. The PRBS test counter counts (RXER goes Low) events, when TSEN is High. It stops, when reaches its maximum value of 31. Counter reset is provided through addressing to the ACT\_LER register.

When the TLK2501 device is disabled (DVEN is set to "0") the corresponding ready/busy link status is masked off and does not contribute to the overall FRONT\_FPGA fast monitoring status.

#### Table 42

| D15  | D14  | D13  | D12  | D11  | D10  | D9   | D8   | D7 | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |
|------|------|------|------|------|------|------|------|----|------|------|------|------|------|------|------|-----|
| TEC4 | TEC3 | TEC2 | TEC1 | TEC0 | RXDV | RXER | RXSD | 0  | TSEN | LPEN | DVEN | RFDI | TXEN | TXER | TXDI | R   |
| Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х    | Х  | TSEN | LPEN | DVEN | RFDI | TXEN | TXER | TXDI | W   |

- X Don't care bit;
- TXDI = 1/0 Disable/Enable the FINISAR optical Transmitter;
- {TXEN, TXER} = {Transmit Enable, Error Coding} Transmit Data Control:
  - ${TXEN, TXER} = {0,0} Transmit Idle Character (0xC5BC or 0x50BC);$ 
    - $\{TXEN, TXER\} = \{0,1\}$  Transmit Carrier Extend (0xF7F7);
    - $\{TXEN, TXER\} = \{1, 0\}$  Transmit Normal Data Character;
    - {TXEN,TXER} = {1,1} Transmit Error Propagation (0xFEFE);
- RFDI =1/0 Disable/Enable the TLK2501 Reference clock;
- DVEN = 1/0 Enable/Disable the TLK2501 Device;
- LPEN = 1/0 Enable/Disable the TLK2501 Loop mode;
- TSEN = 1/0 Enable/Disable the TLK2501 Pseudorandom Bit Stream (PRBS) Test;
- RXSD = 1/0 Signal Detect/No Signal from FINISAR optical receiver;
- { RXDV, RXER} = { Receive Data Valid, Receive Error} Receive Status Signals
  - $\{RXDV, RXER\} = \{0,0\}$  Receive Idle Character (0xC5BC or 0x50BC);
  - $\circ$  {RXDV, RXER} = {0,1} Receive Carrier Extend (0xF7F7);
  - $\circ$  {RXDV, RXER} = {1,0} Receive Normal Data Character;
  - $\circ$  {RXDV, RXER} = {1,1} Receive Error Propagation (0xFEFE);
- TEC [4:0] PRBS Test Error Counter;

## CSR\_AFD - Alignment FIFO Read Delay

This read/write register controls delaying of AF reads after an L1 Reset occurred. It can be used to optimize a muon alignment budget. The register resides in the FRONT\_FPGA.

#### Table 43

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7   | D6   | D5    | D4       | D3       | D2    | D1   | D0   | Acc |
|-----|-----|-----|-----|-----|-----|----|----|------|------|-------|----------|----------|-------|------|------|-----|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | AFD7 | AFD6 | AFD5  | AFD4     | AFD3     | AFD2  | AFD1 | AFD0 | R   |
| Х   | Х   | Х   | Х   | Х   | Х   | Х  | Х  | AFD7 | AFD6 | AFD5  | AFD4     | AFD3     | AFD2  | AFD1 | AFD0 | W   |
|     |     |     |     |     |     |    |    |      |      | Align | ment FIF | O Read I | Delay |      |      |     |

Here:

- AFD = 0...255 - AF resumes reads on the 1<sup>st</sup>... 256<sup>th</sup> clock after L1 Reset has been received. Default value on power-up is 176.

## CSR\_SFC – Spy FIFO Configuration

In the VME\_FPGA this register defines the delay inserted between the CCB test commands and the FC\_SFRUN command on the internal FC bus, see Table 2. The delay is intended to compensate for the time required for the corresponding test data to reach the Spy FIFO input. The delay is not applicable to the CCB\_L1ACC command. The register also determines if request for data is one-time or persistent. Power-up default state for this register is 0x0000.

#### Table 44 VME\_FPGA

| D15  | D14      | D13  | D12  | D11  | D10 | D9   | D8   | D7   | D6   | D5       | D4       | D3   | D2   | D1   | D0   | Acc |
|------|----------|------|------|------|-----|------|------|------|------|----------|----------|------|------|------|------|-----|
| SFM  | SFRL     | SFRS | SFRM | SFRT | 0   | SFD9 | SFD8 | SFD7 | SFD6 | SFD5     | SFD4     | SFD3 | SFD2 | SFD1 | SFD0 | R   |
| SFM  | SFRL     | SFRS | SFRM | SFRT | Х   | SFD9 | SFD8 | SFD7 | SFD6 | SFD5     | SFD4     | SFD3 | SFD2 | SFD1 | SFD0 | W   |
| Mode | Requests |      |      |      |     |      |      |      | Spy  | / FIFO D | elay Set | ting |      |      |      |     |

Here:

- SFD [9:0] = 0...1023 Spy FIFO starts writing data, when 1...1024 bunch crossings have passed after the requested event.
- SFRT = 1/0 store/don't store data on the next CCB\_TPTMB command
- SFRM = 1/0 store/don't store data on the next CCB\_TPMPC command
- SFRS = 1/0 store/don't store data on the next CCB\_TPSP command
- SFRL = 1/0 store/don't store data on the next CCB\_L1ACC command
- SFM = 1/0 persistent/one-time request. Persistent request stores data on all events that followed. One-time request stores data on the next event only and self-resets after that.

In the FRONT\_FPGA this register defines the data source for the Spy FIFO input and the number of beam crossings to be stored upon receiving the FC\_SFRUN command. Note, that the actual number of 16-bit words, saved in the Spy FIFO is twice as big, since each beam crossing data consists of two frames. Moreover, each event stored upon L1 Accept command has a two-word header: an L1 Accept counter value and a Beam Crossing Counter value, which are added to the number of bunch crossings specified by the register.

#### Table 45 FRONT\_FPGA

| D15    | D14 | D13 | D12 | D11 | D10 | D9 | D8                            | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |  |
|--------|-----|-----|-----|-----|-----|----|-------------------------------|------|------|------|------|------|------|------|------|-----|--|
| SFS    | 0   | 0   | 0   | 0   | 0   | 0  | SFB8                          | SFB7 | SFB6 | SFB5 | SFB4 | SFB3 | SFB2 | SFB1 | SFB0 | R   |  |
| SFS    | Х   | Х   | Х   | Х   | Х   | Х  | SFB8                          | SFB7 | SFB6 | SFB5 | SFB4 | SFB3 | SFB2 | SFB1 | SFB0 | W   |  |
| Source |     |     |     |     |     |    | Spy FIFO Bunch Crossing Count |      |      |      |      |      |      |      |      |     |  |

Here:

- SFB [8:0] = 0...511 FRONT\_FPGA Spy FIFO grabs data from 1...512 bunch crossings
- SFS FRONT\_FPGA Spy FIFO data source:
  - "1" Pipeline FIFO output
  - "0" Alignment FIFO output

Control bits for DDU\_FPGA and SP\_FPGA TBD later.

#### CSR\_PFD – Pipeline FIFO Data Delay

This read/write register controls data delay in the Pipeline FIFO to compensate for L1 Accept latency. Default value on power-up is 128.

#### Table 46

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7                       | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Acc |  |
|-----|-----|-----|-----|-----|-----|----|----|--------------------------|------|------|------|------|------|------|------|-----|--|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | PFD7                     | PFD6 | PFD5 | PFD4 | PFD3 | PFD2 | PFD1 | PFD0 | R   |  |
| Х   | Х   | Х   | Х   | Х   | Х   | Х  | Х  | PFD7                     | PFD6 | PFD5 | PFD4 | PFD3 | PFD2 | PFD1 | PFD0 | W   |  |
|     |     |     |     |     |     |    |    | Pipeline FIFO Data Delay |      |      |      |      |      |      |      |     |  |

- PFD = 0...255 - PF delays data for 1... 256 bunch crossings or up to 6.4 µsec.

#### CSR\_DFC – DAQ FIFO Configuration

This read/write register controls event size or the number of bunch crossing to be saved into the DAQ FIFO upon receiving an L1 Accept. When a zero DFB value is loaded, no muon data is saved on L1 Accept, and each event consists only of a Header block, see Table 51 for details. Default event size on power-up is 2.

#### Table 47

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4   | D3   | D2   | D1   | D0   | Acc |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|------|------|------|------|------|-----|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | DFB4 | DFB3 | DFB2 | DFB1 | DFB0 | R   |
| Х   | Х   | Х   | Х   | Х   | Х   | Х  | Х  | Х  | Х  | Х  | DFB4 | DFB3 | DFB2 | DFB1 | DFB0 | W   |
|     |     |     |     |     |     |    |    |    |    |    | DA   | ount |      |      |      |     |

Here:

- DFB [4:0] = 0...31 - DAQ FIFO stores data from 0...31 bunch crossings.

#### CSR\_CFG – FPGA Configuration Done Status

Addressing to this read-only register allows verifying Configuration Done status of FRONT\_FPGAs, DDU\_FPGA, and SP\_FPGA after hard resets. Register address is applicable to VME\_FPGA only. Register's default value is 0xFE, when all, including mezzanine card's, chips are in place. Being Low during configuration, Configuration Done High indicates completion of the configuration.

To make sure all FPGA chips are present on board, the CSR\_CFG command should be executed twice: first, when chips are engaged in the configuration process, i.e. immediately after the ACT\_HR command, and second, after a 5 sec pause, when the configuration is definitely completed. If there is a missing FPGA chip on board (a mezzanine card not installed, for example), then the corresponding Configuration Done line remains floating, and could be sensed by the VME\_FPGA either as a High ("1") or Low ("0") level. But in any case, the bit for a missing chip would retain its state, while the bit for a successfully configured FPGA would be "0" on the first read and "1" on the second read.

#### Table 48

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7                        | D6   | D5   | D4   | D3   | D2   | D1   | D0 |  |
|-----|-----|-----|-----|-----|-----|----|----|---------------------------|------|------|------|------|------|------|----|--|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | SPCD                      | DDCD | F5CD | F4CD | F3CD | F2CD | F1CD | 0  |  |
|     |     |     |     |     |     |    |    | Configuration Done Status |      |      |      |      |      |      |    |  |

- F1CD FRONT\_FPGA\_1 Configuration Done
- F2CD FRONT\_FPGA\_2 Configuration Done
- F3CD FRONT\_FPGA\_3 Configuration Done
- F4CD FRONT\_FPGA\_4 Configuration Done
- F5CD FRONT\_FPGA\_5 Configuration Done
- DDCD DDU\_FPGA Configuration Done
- SPCD SP\_FPGA Configuration Done

## CSR\_INI – FPGA Init Status

Addressing to this read-only register allows verifying the INIT\_B pin status of FRONT\_FPGAs, DDU\_FPGA, and SP\_FPGA after hard resets. Register address is applicable to VME\_FPGA only. Default register value is 0xF7. INIT\_B Low indicates memory is being cleared. The INIT\_B pin transitions High when the clearing of configuration memory is complete. INIT\_B Low during configuration indicates an error.

#### Table 49

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7                            | D6   | D5   | D4   | D3   | D2   | D1   | D0 |  |
|-----|-----|-----|-----|-----|-----|----|----|-------------------------------|------|------|------|------|------|------|----|--|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | SPIN                          | DDIN | F5IN | F4IN | F3IN | F2IN | F1IN | 0  |  |
|     |     |     |     |     |     |    |    | Init_B or Config Error Status |      |      |      |      |      |      |    |  |

Here:

- F1IN FRONT\_FPGA\_1 Configuration error if Low
- F2IN FRONT\_FPGA\_2 Configuration error if Low
- F3IN FRONT\_FPGA\_3 Configuration error if Low
- F4IN FRONT\_FPGA\_4 Configuration error if Low
- F5IN FRONT\_FPGA\_5 Configuration error if Low
- DDIN DDU FPGA Configuration error if Low
- SPIN SP\_FPGA Configuration error if Low

## **Data Register Group**

## DAT\_TF – Test FIFO Data

VME cycles addressed to this write-only register load data in the Test FIFO (TF). Preferred method for loading TF with data is setting up a BLT write cycle. Address is valid for FRONT\_FPGA (3 each), DDU\_FPGA (1 each), and SP\_FPGA (3 each).

The output of the FRONT\_FPGA TF is normally connected to the TLK2501 transmitter to provide a source of data patterns for link tests. Alternatively, during data taking phase TF data may be injected in the data steam, substituting the Alignment FIFO output for one or more bunch crossings. TF destination is defined by the CSR\_TFC register. CCB fast control signals (TBD) are responsible for test pattern injection. Table 50 shows the TF data format, which, in fact, exactly follows the MPC – SP two-frame data format.

Data loaded into the TF cannot be verified by reading it back, since FIFO reads are destructive. Addressing to the CSR\_TF register provides an indirect verification method of the current TF word count.

#### Table 50

| D15 | D14          | D13    | D12     | D11 | D10 D9 D8 D7 |          |           |    | D6 | D5 | D4       | D3        | D2      | D1 | D0 |     |
|-----|--------------|--------|---------|-----|--------------|----------|-----------|----|----|----|----------|-----------|---------|----|----|-----|
| VP  |              | Qualit | y [3:0] |     | Cl           | LCT Patt | ern # [3: | 0] |    |    | Wire     | Group II  | D [6:0] |    |    | FR1 |
|     | CSC ID [3:0] |        |         |     | BX0          | SE       | L/R       |    |    | CL | .CT Patt | ern ID [7 | [0:]    |    |    | FR2 |

Here:

- VP – Valid Pattern flag

- Quality - the more hits the higher track Quality

- CLCT Pattern # the 4-bit pattern number encodes the number of layers and whether the pattern consists of half-strips or di-strips. Higher pattern numbers are assigned to straighter high-momentum tracks with more layers hit.
- Wire Group ID the 7-bit Wire Group ID indicates the position of the pattern within the chamber and runs from 0 to 111.
- CSC ID the 4-bit CSC ID indicates the chamber # and runs from 1 to 9.
- BC0 the Bunch Crossing Zero flag marks bunch zero data
- BX0 the least significant bit of Bunch Crossing Number (BXN ranges from 0 to 3563).
- SE Synchronization Error bit
- L/R the Left/Right bend bit indicates whether the track is heading towards lower or higher strip number
- CLCT Pattern ID For high pT patterns, the 8-bit half-strip ID is between 0 and 159.
   For low pT patterns, the 8-bit di-strip ID is between 0 and 39. This number corresponds to the position of the pattern selected at the third or "key" layer of the chamber.

DDU\_FPGA and SP\_FPGA data formats TBD later.

## DAT\_SF – Spy FIFO Data

VME cycles addressed to this read-only register return data from the Spy FIFO (SF). Preferred method of reading the SF content is setting up BLT read cycles. Addressing to the CSR\_SF register returns the current SF word count. Address is valid for FRONT\_FPGA (3 each), DDU\_FPGA (1 each), and SP\_FPGA (3 each).

The FRONT\_FPGA SF input could be connected to one of two signal sources: the Alignment FIFO output, and the Pipeline FIFO output, as defined by the CSR\_TSC register. Data format of each source is identical to the one shown in Table 50. The process of collecting data into the SF is regulated by fast control commands.

## DAT\_DF – DAQ FIFO Data

VME cycles addressed to this read-only register retrieve event data from the DAQ FIFO (DF). The data format has a header followed by a specified number of data blocks. Each block is composed of 3 muons, 2 frames per muon, see Table 51 for details. The SP header structure follows the DMB header structure and starts with the number of data blocks or, in other words, the number of bunch crossings for which the muon data is presented. Two next words carry the L1 Accept or event number, and, finally, the fourth word is the bunch crossing counter reading for the first data block in the event. The header carries a specific signature of hexadecimal 0xF values to facilitate the separation of events. The data block format exactly follows the MPC-SP link format.

#### **Table 51 Event Data Format**

| D15 | D14 D13     | D1        | 2 D11 | D10 | D9      | D8       | D7      | D6       | D5       | D4       | D3        | D2      | D1   | D0 | Word  | Block        |
|-----|-------------|-----------|-------|-----|---------|----------|---------|----------|----------|----------|-----------|---------|------|----|-------|--------------|
|     | 0xF         |           |       | 02  | κF      |          |         | BC       | # – # of | Bunch    | Crossin   | gs in E | vent |    | HD1   |              |
|     | 0xF         |           |       |     | EC      | C [11:0] | - Event | Counte   | r 12 Les | s Signi  | ficant B  | its     |      |    | HD2   | Header       |
|     | 0xF         |           |       |     | EC      | [23:12]  | - Even  | t Counte | er 12 Mo | ost Sign | ificant H | Bits    |      |    | HD3   | neauer       |
|     | 0xF         |           |       |     | BC [1]  | l:0] – B | unch Cr | ossing ( | Counter  | value fo | or data b | lock 1  |      |    | HD4   |              |
|     |             |           |       |     |         |          |         |          |          |          |           |         |      |    |       |              |
| VP  | Qua         | lity [3:0 | )]    | CI  | CT Patt | ern # [3 | :0]     |          |          | Wire (   | Group II  | D [6:0] |      |    | M1FR1 |              |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M1FR2 | Data         |
| VP  | Qua         | lity [3:0 | )]    | CL  | CT Patt | ern # [3 | :0]     |          |          | Wire C   | Group II  | D [6:0] |      |    | M2FR1 | Block        |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M2FR2 | 1 BIOCK      |
| VP  | Qua         | lity [3:0 | )]    | CL  | CT Patt | ern # [3 | :0]     |          |          | Wire C   | Group II  | D [6:0] |      |    | M3FR1 | 1            |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M3FR2 |              |
|     |             |           |       |     |         |          |         |          |          |          |           |         |      |    |       |              |
| VP  | Qua         | lity [3:0 | )]    | CI  | CT Patt | ern # [3 | :0]     |          |          | Wire (   | Group II  | D [6:0] |      |    | M1FR1 |              |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M1FR2 | Data         |
| VP  | Qua         | lity [3:0 | )]    | CL  | CT Patt | ern # [3 | :0]     |          |          | Wire C   | Group II  | D [6:0] |      |    | M2FR1 | Block        |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M2FR2 | BIOCK<br>BC# |
| VP  | Qua         | lity [3:0 | )]    | CI  | CT Patt | ern # [3 | :0]     |          |          | Wire (   | Group II  | D [6:0] |      |    | M3FR1 | DC#          |
|     | CSC ID [3:0 | ]         | BC0   | BX0 | SE      | L/R      |         |          | CLO      | CT Patte | ern ID [  | 7:0]    |      |    | M3FR2 |              |

Here:

- VP Valid Pattern flag
- Quality the more hits the higher track Quality
- CLCT Pattern # the 4-bit pattern number encodes the number of layers and whether the pattern consists of half-strips or di-strips. Higher pattern numbers are assigned to straighter high-momentum tracks with more layers hit.
- Wire Group ID the 7-bit Wire Group ID indicates the position of the pattern within the chamber and runs from 0 to 111.
- CSC ID the 4-bit CSC ID indicates the chamber # and runs from 1 to 9.
- BC0 the Bunch Crossing Zero flag marks bunch zero data
- BX0 the least significant bit of Bunch Crossing Number (BXN ranges from 0 to 3563 in LHC mode and from 0 to 923 in SPS mode).
- SE Synchronization Error bit
- L/R the Left/Right bend bit indicates whether the track is heading towards lower or higher strip number
- CLCT Pattern ID For high pT patterns, the 8-bit half-strip ID is between 0 and 159.
   For low pT patterns, the 8-bit di-strip ID is between 0 and 39. This number corresponds to the position of the pattern selected at the third or "key" layer of the chamber.

## DAT\_RW – Data Transfer Bus Read/Write Register

This register is used for backplane and internal data bus validation. It allows write/read cycles to be performed to/from each FPGA chip without affecting SP02 functionality in any way.

#### Table 52

| D15 | D14                  | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-----|----------------------|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|     | Validation Data Word |     |     |     |     |    |    |    |    |    |    |    |    |    |    |

# History

## Version 5.0.

- 1. Clock routing changed due to patches:
  - Eliminated the osc\_clk input in the VME\_FPGA;
  - Eliminated the clk\_sel input in the VME\_FPGA;
  - Returned two DCMs: internal and external to the VME\_FPGA;
  - Eliminated the CSR\_CLK register in the VME\_FPGA;
  - Changed default value of the CSR\_CLK register in the FRONT\_FPGA from DCM to VCXO clock;
- 2. Changed the CCB\_BC0 to DATA\_BC0 adjustment scheme:
  - Eliminated the CSR\_CCB register in the VME\_FPGA;
  - Added the CSR\_BCO register in the FRONT\_FPGA (with the same access address);
  - Changed format of the CSR\_OSY registers in the FRONT\_FPGA, now it displays the latched bunch counter value without calculating positive/negative offsets;
- 3. Added data taking state diagrams in the interface description;
- 4. Added the STS\_VPC (Valid Pattern Counter) register for each link in the FRONT\_FPGA;
- 5. Renamed ACT\_LER Link Error Counters Resets to ACT\_LCR Link Counter Resets, added the VPR bit to reset the STS\_VPC counter;
- 6. Fake L1Accept generated by CCB\_TPxxx commands is ORed with the CCB\_L1A line BEFORE the L1Accept delay, not AFTER;
- 7. Added intercept of the CCB\_TPTMB(0x24) command;
- 8. Changed the CSR\_SFC format in the VME\_FPGA;

<sup>[</sup>i] CSC Track Finder Crate Specification, created by Mike Matveev and updated by Alex Madorsky, December 12, 2002; <u>http://www.phys.ufl.edu/~madorsky/TrackFinder/TF backplane v4.doc</u>
[ii] ANSI/VITA 1.1-1997, American National Standard for VME64 Extensions.