# **RCU Firmware V2**

# **User Manual**

Started: 15<sup>th</sup> June 2008 Last Update: 25<sup>th</sup> November 2008 DRAFT 0.1



# **Top Level Unit**

# **1.1 Functionality**

The data/configuration transfer between the RCU and front-end cards is performed with the ALTRO protocol as described in the ALTRO Chip User's Manual. From the User's point of view the ALTROs are not directly accessible from the RCU. The link is made through a  $\mu$ controller-like procedure that will execute sequentially a set of pre-loaded instructions. In this way the user can send large portions of front-end configuration in an instruction memory in the RCU and execute the sequence with a single command. These sequences can be composed with ALTRO instructions and RCU-specific instructions.

This manual contains full information on all accessible memories and registers along with the executable commands.



Figure 1.1: Block Diagram of TOP Module of the RCU Firmware

# **1.2 RCU/FEC Instruction Format**

An important difference between v1 and v2 of the RCU firmware regards the Instruction Sequencer (IS). In the new version the IS can execute ALTRO Instructions but not RCU Instructions. In addition the IS recognizes a set of 4 internal instructions that can be used to condition the execution of the ALTRO instructions. The Instruction Memory (IM) of the IS has in RCU v2 a depth of 4096 x 22-bit wide words. The format of the Instructions for the IS is illustrated in tables 1.1, 1.2 and 1.3.

| 21 IS/FEC 20    | 19INSTRUCTION PARAMETERS0                                      |  |  |
|-----------------|----------------------------------------------------------------|--|--|
| 00, FEC_RD      | ALTRO Instruction                                              |  |  |
| 01, FEC_CMD     | ALTRO Instruction                                              |  |  |
| 10, FEC_WR (*)  | ALTRO Instruction (Address)                                    |  |  |
| 10, T LO_WK ( ) | ALTRO Instruction (Data)                                       |  |  |
| 11, IS_CMD      | IS Internal Code (4 bits) IS Internal Code parameter (16 bits) |  |  |

 Table 1.1. IS Instruction Format

| Name   | Access | Inst. Code | Description                                                  |
|--------|--------|------------|--------------------------------------------------------------|
| LOOP   | W      | 0x1        | Execute the instructions in loop for defined number of times |
| WAIT   | W      | 0x2        | Wait for defined number of clock cycles                      |
| ENDSEQ | W      | 0x8        | End of specific sequence (set of instructions)               |
| ENDMEM | W      | 0xF        | End of Instruction Memory                                    |

Table 1.2. IS internal instructions codes.

| IS/FEC | IS CMD | CMD PARAMETER          |                           |
|--------|--------|------------------------|---------------------------|
| 11     | Wait   | Number of wait cycles  |                           |
| 11     | Loop   | No of loops<br>[15:12] | Loop return address[11:0] |
| 11     | ENDSEQ | X                      |                           |
| 11     | ENDMEM | x                      |                           |

Table 1.3. IS internal instruction format.

# **1.3 Register Table**

The register Table 1.4, incorporates various registers that are used for configuration of the RCU. Table 1.5 and table 1.6 describes the status and error register which can be read externally for RCU and trigger module respectively.

| Name            | Address | Width | Access | Description                                                                                                                                                                                   |
|-----------------|---------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACTFECLIST      | 0x5100  | 32    | W/R    | Active FEC List                                                                                                                                                                               |
| ALTROIF         | 0x5101  | 18    | W/R    | Nr. Samples / channel $\equiv$ [9:0];<br>T <sub>sampling</sub> / T <sub>LHC</sub> $\equiv$ [13:10];<br>CSTB programmable delay $\equiv$ [15:14];<br>Instruction error check selection [17:16] |
| TRGCONF         | 0x5102  | 17    | W/R    | Trigger Source $\equiv$ [16:14], Trigger Mode $\equiv$ [13], L2 latency wrt L1 $\equiv$ [12:0].                                                                                               |
| RDOMOD          | 0x 5103 | 4     | W/R    | [3] Mask RDYRX ;Sparse readout enable ≡<br>[2]; execute sequencer on SOE/EOE ≡ [1] ;<br>MEB mode [0].                                                                                         |
| ALTROCFG1       | 0x5104  | 16    | W/R    | Copy of the ALTROCFG1 register of the ALTRO chip (see ALTRO manual pags. 36-37). The content of this register will be copied in one of the words of the event data block trailer.             |
| ALTROCFG2       | 0x5105  | 18    | W/R    | Copy of the ALTROCFG2 register of the ALTRO chip (see ALTRO manual pags. 36-37). The content of this register will be copied in one of the words of the event data block trailer.             |
| RCU_VERSI<br>ON | 0x5106  | 24    | R      | RCU version (ASCII coding of version number).                                                                                                                                                 |
| BP_VERSION      | 0x5107  | 1     | W/R    | Mapping of ACTFECLIST to cardswitch lines. 0 for TPC and FMD, 1 for PHOS.                                                                                                                     |
| RCUID           | 0x5108  | 9     | W/R    | RCU ID Register                                                                                                                                                                               |

Table 1.4 Configuration Registers of RCU



# Active Front End Card List [31:0]

| Address     | 0x5100 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 31     |

# **Description:**

Front end cards are set turned on and off by configuring this register.

FEC – Branch A [15:0]

FEC – Branch B [31:16]



# ALTRO Interface Register [17:0]

| Address     | 0x5101 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 18     |

### **Description:**

#### **Instruction error check selection** $\equiv$ [17:16]

"00":= Contents of Instruction memory are not Checked

"01":= Contents of Instruction memory will be checked against TPC instruction set.

"10":= Contents of Instruction Memory will be checked against PHOS instruction set.

"11":= Contents of Instruction Memory will be checked against FMD instruction set

#### **CSTB programmable delay** $\equiv$ [15:14]

This is the delay between the assertion of "cstb" and altro bus to avoid any possibility of glitch on hand shake

signals due to 40 bit ALTRO bus driving.

#### Sampling Clock Dividing Ratio: $T_{sampling} / T_{LHC} \equiv [13:10]$

"00":= divide by 2; Period of sampling clock = 50nsec

"01":= divide by 4; Period of sampling clock = 100nsec

- "10":= divide by 8; Period of sampling clock = 200nsec
- "11":= divide by 16; Period of sampling clock = 400nsec

**Nr. Samples** / channel  $\equiv$  [9:0]



# Trigger Configuration Register [16:0]

| Address     | 0x5102 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 17     |

### **Description:**

**Trigger Source** [16:14]

"1XX"  $\equiv$  CTP – Triger Enabled "001"  $\equiv$  Software Trigger Enable (0x5306) "010"  $\equiv$  Auxiliary Trigger Enable (0x5306)

#### Trigger Mode [13]

 $0' \equiv$  Trigger mode is TPC {L1 from CTP is mapped to L1 to FEC}  $1' \equiv$  Trigger mode is PHOS {L0 from CTP is delivered as L1 to FEC}

#### L1 – L2 Latency [12:0]

When software trigger is issued this latency is used to set the latency between L1 and L2 to FECs.



# Readout Mode Configuration Register [3:0]

| Address     | 0x5103          |
|-------------|-----------------|
| Access Type | R/W             |
| Bit Width   | 4+2(Debug mode) |

### **Description:**

#### Mask Check of [Channel Address / Block Length] Mismatch [5][4]

 $[5] = "1" \equiv$  check of Channel address mismatch will be masked (not checked)  $[5] = "0" \equiv$  check of Channel address mismatch will not be masked (checked)

 $[4] = "1" \equiv$  check of Block Length mismatch will be masked (not checked)  $[4] = "0" \equiv$  check of Block Length mismatch will not be masked (checked)

#### Mask Read to Receive "RDYEX" [3]

"1" ≡ Ready to receive command is masked, means even if the ready to receive command is not given from DDL still data will be delivered from RCU to SIU. {Used for debugging purposes}

"0"  $\equiv$  Ready to receive command (open link) must be given before data is to be received.

#### **Sparse Readout Mode** [2]

 $0^{\circ} = \text{Read out mode is } \frac{\text{"full readout"}}{\text{"according to readout list memory."}}$ 

'1'  $\equiv$  Read out mode is <u>"sparse readout"</u> according to readout list memory.

#### **SOE/EOE Instruction Memory Execution** [1]

'0' = Sequence in the instruction memory will not be executed on SOE/EOE.

'1' ≡ Sequence in the instruction memory will be executed on SOE/EOE and result from result memory will be sent as payload.

#### MEB (multi event buffer) Mode [0]

 $0' \equiv$  Multi event buffer mode is set to 4  $1' \equiv$  Multi event buffer mode is set to 8



# ALTRO Configuration Register 1 [19:0]

| Address     | 0x5104 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 20     |

## **Description:**

This register is copy of ALTRO configuration register. Parameters in this register are used to record in the RCU trailer word. Refer to ALTRO manual pages 36, 37.

First Baseline Correction Mode  $\equiv$  RDO\_CFG1[3:0] Polarity. When set, the ADC data is inverted (1's C) [4] Nr. Of pre-samples excluded from 2<sup>nd</sup> baseline corr.  $\equiv$  RDO\_CFG1 [6:5] Nr. Of post-samples excluded from 2<sup>nd</sup> baseline corr.  $\equiv$  RDO\_CFG1 [10:7] Enable second baseline correction  $\equiv$  RDO\_CFG1 [11] Glitch filter configuration for zero suppression  $\equiv$  RDO\_CFG1 [13:12] Nr. Of post-samples excluded from suppression  $\equiv$  RDO\_CFG1[16:14] Nr. Of pre-samples excluded from suppression  $\equiv$  RDO\_CFG1[18:17] Enable Zero Suppression  $\equiv$  RDO\_CFG1 [19]



# Altro Configuration Register 2 [24:0]

| Address     | 0x5105 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 25     |

## **Description:**

Nr of ALTRO Buffers (copy of RCU register ALTROCFG2[4]) = RDO\_CFG2[24]

Nr of pre-trigger samples (copy of RCU reg ALTROCFG2[[3:0]) = RDO\_CFG2[23:20]

Nr. Samples / channel (copy of RCU reg ALTROIF[9:0]) = RDO\_CFG2[19:10]

Sparse Readout = RDO\_CFG2[9]

Tsampling / TLHC = RDO\_CFG2[8:5]

Phase of L1 trigger w.r.t. LHC bunch crossing = RDO\_CFG2 [4:0].

The phase is calculated in terms of bunch crossing cycles for example if the Tsampling/TLHC is equal 01 (10MHz sampling rate), only the two least significant bits are meaningful and the phase can take values 0, 1, 2, 3.



# RCU Version Register [23:0]

| Address     | 0x5106 |
|-------------|--------|
| Access Type | R      |
| Bit Width   | 24     |

# **Description:**

This register describes the RCU version along with the revision, format is "MM-YY-AE-VERSION" read as X"07-08-AE-20"

Month Year: = 0708 Version: = 2.0 Identification: = AE



# Back Plane Version Register [0]

| Address     | 0x5107 |
|-------------|--------|
| Access Type | R      |
| Bit Width   | 1      |

# **Description:**

This register set the mapping structure of ACTFECLIST to card switch lines.

'0':= TPC and FMD.

'1':= PHOS.



# **RCU Identification Register [8:0]**

| Address     | 0x5108 |
|-------------|--------|
| Access Type | R/W    |
| Bit Width   | 9      |

# **Description:**

This register identifies the physical location of RCU.

RCUID [8] = 0 for A-side, 1 for C-side RCUID [7:3] = sector number (0:17) RCUID [2:0] = readout partition number (0:5)

| Name    | Address | Width | Access | Description                                                                                          |
|---------|---------|-------|--------|------------------------------------------------------------------------------------------------------|
| FECERRA | 0x 5110 | 20    | R      | Error code, transactions on branch A                                                                 |
| FECEKKA | 0X 3110 | 20    | ĸ      | [0] Altro Error is asserted.                                                                         |
|         |         |       |        | FSM_WR                                                                                               |
|         |         |       |        | [1] Altro assert error before "cstb" assert                                                          |
|         |         |       |        | [2] "ack" assert before "cstb"                                                                       |
|         |         |       |        | [3] Altro assert error during 'waitack'                                                              |
|         |         |       |        | [4] "ack" not asserted & time out                                                                    |
|         |         |       |        | <ul><li>[5] Altro error asserted during 'waitdone'</li><li>[6] "ack" not released by Altro</li></ul> |
|         |         |       |        | [7] Altro Assert the error while waiting for broad cast                                              |
|         |         |       |        | command                                                                                              |
|         |         |       |        | FSM RD                                                                                               |
|         |         |       |        | [8] Altro error is asserted during 'assertbus'                                                       |
|         |         |       |        | [9] Altro error is asserted while waiting for "ack"                                                  |
|         |         |       |        | "chlack"                                                                                             |
|         |         |       |        | [10] Altro assert "ack" before "cstb" assert                                                         |
|         |         |       |        | [11] Altro error is asserted while waiting for "ack"                                                 |
|         |         |       |        | [12] Altro does not assert ack                                                                       |
|         |         |       |        | [13] Altro error is asserted while waiting for release of                                            |
|         |         |       |        | "ack"                                                                                                |
|         |         |       |        | [14] "ack" never released by Altro                                                                   |
|         |         |       |        | FSM_RDO                                                                                              |
|         |         |       |        | [15] Fsm wr error when started by FSM RDO<br>[16] Altro error asserted before transfer asserted.     |
|         |         |       |        | [17] Transfer not asserted                                                                           |
|         |         |       |        | [18] Altro error asserted while data being transferred                                               |
|         |         |       |        | [19] Transfer not released                                                                           |
| FECEDDO | 0 5111  | 20    |        | Error code, transactions on branch A                                                                 |
| FECERRB | 0x 5111 | 20    | R      | [0] Altro Error is asserted.                                                                         |
|         |         |       |        | FSM_WR                                                                                               |
|         |         |       |        | [1] Altro assert error before "cstb" assert                                                          |
|         |         |       |        | [2] "ack" assert before "cstb"                                                                       |
|         |         |       |        | [3] Altro assert error during 'waitack'                                                              |
|         |         |       |        | [4] "ack" not asserted & time out                                                                    |
|         |         |       |        | [5] Altro error asserted during 'waitdone'                                                           |
|         |         |       |        | [6] "ack" not released by Altro<br>[7] Altro Assert the error while waiting for broad cast           |
|         |         |       |        | [ 7] Altro Assert the error while waiting for broad cast command                                     |
|         |         |       |        | FSM RD                                                                                               |
|         |         |       |        | [8] Altro error is asserted during 'assertbus'                                                       |
|         |         |       |        | [9] Altro error is asserted while waiting for "ack"                                                  |
|         |         |       |        | "chlack"                                                                                             |
|         |         |       |        | [10] Altro assert "ack" before "cstb" assert                                                         |
|         |         |       |        | [11] Altro error is asserted while waiting for "ack"                                                 |
|         |         |       |        | [12] Altro does not assert ack                                                                       |
|         |         |       |        | [13] Altro error is asserted while waiting for release of                                            |
|         |         |       |        | "ack"<br>[14] "ack" never released by Altro                                                          |
|         |         |       |        | FSM RDO                                                                                              |
|         |         |       |        | [15] Fsm wr error when started by FSM RDO                                                            |
|         |         |       |        | [16] Altro error asserted before transfer asserted.                                                  |
|         |         |       |        | [17] Transfer not asserted                                                                           |
|         |         |       |        | [18] Altro error asserted while data being transferred                                               |

|                  |        |    |   | [19] Transfer not released                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|--------|----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RDOERR           | 0x5112 | 9  | R | Errors related to Event Read out<br>[0]Error occur during send command<br>[1]Atlro error when wait trsf assert<br>[2]Trsf not assert<br>[3]Altro not give four dstb data<br>[4]Trsf not release<br>[5]Error occur during send scan event length command<br>[6] RD_RX not asserted or de-asserted during event<br>readout<br>[7] Channel Address mismatch<br>[8] Data Block Length mismatch<br>Debug<br>[31:28] FSMWR_ST_B<br>[27:24] FSMWR_ST_A<br>[23:20] FSMEVLEN_ST |
| ALTBUSS<br>TATUS | 0x5114 | 8  | R | ALTRO bus status refreshed every clock cycle:<br>[0] CSTB, branch A<br>[1] ACK, branch A<br>[2] TRSF, branch A<br>[3] CSTB, branch B<br>[4] ACK, branch B<br>[5] TRSF, branch B<br>[6] L1 of ALTRO<br>[7] L2 of ALTRO                                                                                                                                                                                                                                                  |
| ALTBSST<br>_TRSF | 0x5115 | 8  | R | ALTRO bus status(when TRSF_A or TRSF_B is<br>asserted):<br>[0] CSTB, branch A<br>[1] ACK, branch A<br>[2] TRSF, branch A<br>[3] CSTB, branch B<br>[4] ACK, branch B<br>[5] TRSF, branch B<br>[6] L1 of ALTRO<br>[7] L2 of ALTRO                                                                                                                                                                                                                                        |
| BUSBSY           | 0x5116 | 2  | R | RCU bus is busy(running instruction sequencer)<br>[0] instruction sequencer busy<br>[1] Last instruction sequence completed with errors                                                                                                                                                                                                                                                                                                                                |
| MEBST<br>CNT     | 0x511B | 4  | R | <ul> <li>[3:0] MEB status counter</li> <li>Debug</li> <li>[7:4] DATA_READY</li> <li>[9:8] DM_SEL :- it shows which of memory block(out of A0,A1,B0,B1) is being read by the data assembler.</li> </ul>                                                                                                                                                                                                                                                                 |
| SWTTRGC<br>NT    | 0x511C | 20 | R | Software Trigger counter                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| AUXTRG<br>CNT    | 0x511D | 20 | R | Auxiliary Trigger counter                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TTCL2_A<br>CNT   | 0x511E | 20 | R | TTC L2 Accept Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TTCL2_R<br>CNT   | 0x511F | 20 | R | TTC L2 Reject Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DSTB_A<br>CNT    | 0x5120 | 20 | R | Branch A DSTB Assert Counter                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| DSTB_B<br>CNT    | 0x5121 | 20 | R | Branch B DSTB Assert Counter                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|                 |        |    | 1 |                                                                                                                                                                                                                        |
|-----------------|--------|----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRSFA<br>CNT    | 0x5122 | 12 | R | Branch A TRSF Assert Counter                                                                                                                                                                                           |
| TRSFB<br>CNT    | 0x5123 | 12 | R | Branch B TRSF Assert Counter                                                                                                                                                                                           |
| ACKA CNT        | 0x5124 | 12 | R | Branch A ACK Assert Counter                                                                                                                                                                                            |
| ACKB CNT        | 0x5125 | 12 | R | Branch B ACK Assert Counter                                                                                                                                                                                            |
| CSTBA<br>CNT    | 0x5126 | 12 | R | Branch A CSTB Assert Counter                                                                                                                                                                                           |
| CSTBB<br>CNT    | 0x5127 | 12 | R | Branch B CSTB Assert Counter                                                                                                                                                                                           |
| DSTB_NU<br>MA   | 0x5128 | 9  | R | Block length of last data written from Branch A                                                                                                                                                                        |
| DSTB_NU<br>MB   | 0x5129 | 9  | R | Block length of last data written from Branch B                                                                                                                                                                        |
| ADD_MM_<br>CNT  | 0x512A | 12 | R | Number of address mismatches between ALTRO trailer and addressed channel from ROLM.                                                                                                                                    |
| BLTH_MM<br>_CNT | 0x512B | 12 | R | Number of block length mismatches between ALTRO trailer word and the (data strobe counter $-1$ )                                                                                                                       |
| ABDFSMP<br>R_ST | 0x512C | 22 | R | ABD state machines status[21:19]FSM_RDO status of branch B[18:15]FSM_RD status of branch B[14:11]FSM_WR status of branch B[10:8]FSM_RDO status of branch A[7:4]FSM_RD status of branch A[3:0]FSM_WR status of branch A |
| RDOFSMP<br>R_ST | 0x512D | 15 | R | Readout state machines status[14:12]SCEVLEN_FSM status[11:8]EVLEN_FSM status[7:4]FSM_EVRDO_CTRL status[3:2]FSM_SEL_BR status of branch B[1:0]FSM_SEL_BR status of branch A                                             |
| INSSEQ<br>PR_ST | 0x512E | 15 | R | Execute instruction sequencer state machines status<br>[14:10] FSM_INSTSEQ status<br>[9:5] FSM_INSTLOOP status<br>[4:0] FSM_RU status                                                                                  |
| EVMNGPR<br>_ST  | 0x512F | 12 | R | Event manager state machines status[11:10]FSM_TST_TRG status[9:6]FSM_TTC_TRG status[5:3]FSM_EV status[2:0]FSM_INSSEQ status                                                                                            |
| DA_FSM          | 0x5130 |    | R | [29:25] fsmrdrm_st ,<br>[24:20] fsmrdpar_st ,<br>[19:15] fsmrddm_st ,<br>[14:10] fsmrdcdhsoft_st ,<br>[9:5] fsmrdcdh_st ,<br>[0:4] fsmdamain_st                                                                        |

Table 1.5 Status & Error Registers of RCU

| Name                    | Address | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Control[23:0]           | 0x 4000 | RW     | <ul> <li>[0] Serial B channel on/off Default: 1</li> <li>[1] Disable_error_masking 0</li> <li>[2] Enable Rol decoding 0</li> <li>[3] L0 support 1</li> <li>[4:7] (Not Used)</li> <li>[8] L2a FIFO storage mask 1</li> <li>[9] L2r FIFO storage mask 1</li> <li>[10] L2 Timeout FIFO storage mask 1</li> <li>[11] L1a message mask 1</li> <li>[12] Trigger Input Mask Enable 0</li> <li>[13:15] (Not Used)</li> <li>[16] Bunch_counter overflow -</li> <li>[17] Run Active -</li> <li>[18] Busy (receiving sequence) -</li> <li>[19] Not Used</li> <li>[23:20] CDH version 0x2</li> </ul> |
| Module Reset            | 0x4001  | Т      | Reset Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Rol_Config1[17:0]       | 0x4002  | RW     | Definition of what region of interest the RCU is a part of (depends on the sector). Bit 17:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Rol_Config2[17:0]       | 0x4003  | RW     | Definition of what region of interest the RCU is a part of (depends on the sector). Bit 35:18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Reset Counters          | 0x4004  | Т      | Write to this registers will reset the counters in the module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Issue Testmode          | 0x4005  | Т      | Debug: Issues testmode sequence. Note that serialB channel input MUST be disabled when using this feature.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| L1_Latency[15:0]        | 0x4006  | RW     | [15:12] Uncertainty region +- N. default value 0x2 (50 ns)<br>[11:0] Latency from L0 to L1, default value 0x0D4 (5.3 us)                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| L2_Latency[31:0]        | 0x4007  | RW     | [15:0] Max Latency from BC0 to L2, default value 0x4E20<br>(500 us)<br>[31:16] Min Latency from BC0 to L2, default value 0x0C80<br>(80 us)                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Rol_Latency[31:0]       | 0x4009  | RW     | [15:0] Max Latency from BC0 to Rol msg<br>[31:16] Min Latency from BC0 to Rol msg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| L1_msg_latency[31:0]    | 0x400A  | RW     | [15:0] Max Latency from BC0 to L1 msg, default value<br>0x0028 (1 us)<br>[31:16] Min Latency from BC0 to L1 msg, default value<br>0x0F8 (6,2 us)                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Pre_pulse_counter[15:0] | 0x400B  | R      | Number of decoded pre-pulses.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| BCID_Local[11:0]        | 0x400C  | R      | Number of bunchcrossings at arrival of L1 trigger.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| L0_counter[15:0]        | 0x400D  | R      | Number of L0 triggers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| L1_counter[15:0]        | 0x400E  | R      | Number of L1 triggers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| L1_msg_counter[15:0]    | 0x400F  | R      | Number of successfully decoded L1 messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| L2a_counter[15:0]       | 0x4010  | R      | Number of successfully decoded L2a messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| L2r_counter[15:0]       | 0x4011  | R      | Number of successfully decoded L2r messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Rol_counter[15:0]       | 0x4012  | R      | Number of successfully decoded Rol messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bunchcounter[11:0]      | 0x4013  | R      | Debug: Number of bunchcrossings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Name                  | Address | Access | Description                                                                                            |
|-----------------------|---------|--------|--------------------------------------------------------------------------------------------------------|
| hammingErrorCnt[31:0] | 0x4016  | R      | [15:0] Number of single bit hamming errors<br>[31:16]Number of double bit hamming errors               |
| ErrorCnt[31:0]        | 0x4017  | R      | [15:0] Number of message decoding errors [31:16]<br>Number of errors related to sequence and timeouts. |
| Buffered_events[4:0]  | 0x4020  | R      | Number of events stored in the FIFO.                                                                   |
| DAQ Header01[31:0]    | 0x4021  | R      | Latest received DAQ Header 1                                                                           |
| DAQ Header02[31:0]    | 0x4022  | R      | Latest received DAQ Header 2                                                                           |
| DAQ_Header03[31:0]    | 0x4023  | R      | Latest received DAQ Header 3                                                                           |
| DAQ_Header04[31:0]    | 0x4024  | R      | Latest received DAQ Header 4                                                                           |
| DAQ_Header05[31:0]    | 0x4025  | R      | Latest received DAQ Header 5                                                                           |
| DAQ_Header06[31:0]    | 0x4026  | R      | Latest received DAQ Header 6                                                                           |
| DAQ_Header07[31:0]    | 0x4027  | R      | Latest received DAQ Header 7                                                                           |
| Event_info[17:0]      | 0x4028  | R      | Latest Received Event information:<br>[0] Rol enabled                                                  |
|                       |         |        | [1] Region of Interest announced (=ESR)                                                                |
|                       |         |        | [2] Rol received                                                                                       |
|                       |         |        | [3] Within region of interest                                                                          |
|                       |         |        | [4:7] Calibration/SW trigger type (= RoC)                                                              |
|                       |         |        | [8] Software trigger event                                                                             |
|                       |         |        | [9] Calibration trigger event                                                                          |
|                       |         |        | [10] Event has L2 Reject trigger                                                                       |
|                       |         |        | [11] Event has L2 Accept trigger<br>[12] Include payload                                               |
|                       |         |        | [17] Include payload<br>[17:13] SCLK phase when (L0/L1)trigger arrives                                 |
| Event error [24:0]    | 0x4029  | R      | [0] Serial B Stop Bit Error                                                                            |
|                       | 0/11020 |        | [1] Single Bit Hamming Error Individually Addr.                                                        |
|                       |         |        | [2] Double Bit Hamming Error Individually Addr.                                                        |
|                       |         |        | [3] Single Bit Hamming Error Broadcast.                                                                |
|                       |         |        | [4] Double Bit Hamming Error Broadcast.                                                                |
|                       |         |        | [5] Unknown Message Address Received                                                                   |
|                       |         |        | [6] Incomplete L1 Message                                                                              |
|                       |         |        | [7] Incomplete L2a Message                                                                             |
|                       |         |        | [8] Incomplete Rol Message<br>[9] TTCrx Address Error (not X"0003")                                    |
|                       |         |        | [10] Spurious L0                                                                                       |
|                       |         |        | [11] Missing L0                                                                                        |
|                       |         |        | [12] Spurious L1                                                                                       |
|                       |         |        | [13] Boundary L1                                                                                       |
|                       |         |        | [14] Missing L1                                                                                        |
|                       |         |        | [15] L1 message arrives outside legal timeslot                                                         |
|                       |         |        | [16] L1 message missing/timeout                                                                        |
|                       |         |        | [17] L2 message arrives outside legal timeslot<br>[18] L2 message missing/timeout                      |
|                       |         |        | [19] Rol message arrives outside legal timeslot                                                        |
|                       |         |        | [20] Rol message missing/timeout                                                                       |
|                       |         |        | [21] Pre pulse error (=0; possible future use)                                                         |
|                       |         |        | [22] L1 message content error                                                                          |
|                       |         |        | [23] L2 message content error                                                                          |
|                       |         |        | [24] Rol message content error                                                                         |

Table 1.6 Trigger interface module register set

# 1.4 RCU Memories

| Name                   | Address           | Size                             | Access | Description                                                  |
|------------------------|-------------------|----------------------------------|--------|--------------------------------------------------------------|
| INSTRUCTION<br>MEMORY  | 0x 0000 – 0x 0FFF | *SPM<br>22x4K                    | W/R    | Contains instructions to be executed by *IS                  |
| READOUT<br>LIST MEMORY | 0x 1000– 0x 1FFF  | SPM<br>12x4K                     | W/R    | Configured with the channel addresses for event readout      |
| RESULT<br>MEMORY       | 0x 2000 – 0x 37FF | SPM<br>25x 6K                    | W/R    | It contains result of each transaction by IS                 |
| TTCRx<br>REGISTERS     | 0x 4000 – 0x 4FFF | Registers<br>of various<br>sizes | W/R    | These registers are used in TTCRx module                     |
| HIT LIST<br>MEMORY     | 0x 5000 – 0x 507F | *DPM<br>32x128                   | W/R    | Configured by Board Controllers with list of active channels |
| DATA<br>MEMORIES       | 0x 5800 – 0x 5FFF | DPM<br>8*(20x256)                | W/R    | Contains the event data, from FECs                           |

RCU contains a number of memories to execute the block transactions and to perform the event readout. These memories and their description are given in table 1.7

Table 1.7 Addressable Memories of RCU

# **1.5 Instruction Sequencer Commands**

There are four internal instructions for the Instruction Sequencer (IS) which controls the execution of instructions from instruction memory. Result of these internal commands is loaded in the result memory as well. In this section detail structure of these commands in the instruction memory and the respective result in the result memory is described.



### Instruction Sequencer Loop

#### Instruction Coding in Instruction Memory

| 2 | 1 | 20 | 19   | 16 | 15 | 12                 | 11 |                     | 0 |
|---|---|----|------|----|----|--------------------|----|---------------------|---|
|   | 1 | 1  | 0001 |    |    | Number of<br>Loops |    | Loop Return Address |   |

Table 1.8 Structure of LOOP instructions.

#### Description

This command is used as internal instruction of the sequencer to repeat a set of instructions for specific number of times. The iteration is made for the specific number of times till the loop return address. Parametric structure for loop command is shown in table 1.8

#### **Result of "LOOP" in the Result Memory**

Result of this instruction is loaded in the result memory. Status bit [20] shows the success or failure of the execution. 0: success; 1: failure. Table 1.9 and 1.10 shows the result of execution for successful or failed execution respectively.

| 24 | - 2  | 21 | 20 | 19  | 16 | 15          | 12 | 11 |                     | 0 |
|----|------|----|----|-----|----|-------------|----|----|---------------------|---|
|    | 0100 |    | 0  | Zer | os | Numb<br>Loo |    |    | Loop Return Address |   |

Table 1.9: Content of result memory for successful execution of loop.

| 2 | 24   | 21 | 20 | 19   | 14 | 13 | 10 9                      |                  | 0 |
|---|------|----|----|------|----|----|---------------------------|------------------|---|
|   | 0100 |    | 1  | Zero | os |    | <sup>.</sup> Loop<br>nber | Number of Errors |   |

Table 1.10: Content of result memory for failed execution of loop.



### **Instruction Sequencer Wait**

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19 | 16 | 15 |                                  | 0 |
|----|----|----|----|----|----------------------------------|---|
| 1  | 1  | 00 | 10 |    | Number of wait cycles (40MZ CLK) |   |

Table 1.11: Structure of WAIT instruction

#### Description

This command is used as internal instruction of the sequencer to wait for specified number of clock cycles. Parametric structure for WAIT command is shown in table 1.11

#### **Result of "WAIT" in the Result Memory**

Result of this instruction is loaded in the result memory. Table 1.12 shows the result of execution.

| 24   | 21 | 20 | 19 | 16    | 15                               | 0 |
|------|----|----|----|-------|----------------------------------|---|
| 0101 |    | 0  |    | Zeros | Number of wait cycles (40MZ CLK) |   |

Table 1.12: Content of result memory for the execution of Wait



### End OF Sequence

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19 16 | 15 | 0 |
|----|----|-------|----|---|
| 1  | 1  | 1000  | Х  |   |

Table 1.13: Structure of ENDSEQ instruction.

#### Description

This command is used as internal instruction of the sequencer to end a set of instructions. Parametric structure for ENDSEQ command is shown in table 1.13

#### Result of "ENDSEQ" in the Result Memory

Result of this instruction is loaded in the result memory along with the address of last instruction executed. Table 1.14 shows the result of execution for ENDSEQ.

| 24 | 21  | 20 | 19 | 12    | 11                                   | 0 |
|----|-----|----|----|-------|--------------------------------------|---|
| 0  | 111 | 0  |    | Zeros | Address of last executed instruction |   |

Table 1.14: Content of result memory for ENDSEQ.



### Instruction Sequencer End of memory

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19  | 16 | 15 |  |   |  | 0 |
|----|----|-----|----|----|--|---|--|---|
| 1  | 1  | 111 | 1  |    |  | х |  |   |

Table 1.15 Structure of ENDMEM instruction.

#### Description

This command is used to declare that end of memory has reached. Parametric structure for ENDMEM command is shown in table 1.15

#### Result of "ENDMEM" in the Result Memory

Result of this instruction is loaded in the result memory along with the address of last instruction executed. Table 1.16 shows the result of execution for ENDMEM.

| 24 | 21   | 20 | 19    | 12 11                                | 0 |
|----|------|----|-------|--------------------------------------|---|
|    | 0111 | 0  | Zeros | Address of last executed instruction |   |

Table 1.16 Content of result memory for ENDSEQ.

# **1.6 Front End Card Instructions**

There are three instructions which can be executed through the instruction sequencer. These instructions are to perform three different functions in FECs, read, write or command. Results of these instructions are loaded in the result memory regardless of successful or failed execution. In this section detail structure of these instructions for the instruction memory and the respective result in the result memory is described.



### Front End Card Read Instruction

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19 |                          | 0 |
|----|----|----|--------------------------|---|
| 0  | 0  |    | Altro Instruction Format |   |

Table 1.17: Structure of FEC\_RD instruction.

#### Description

This instruction is used to perform the read operation on FEC. Any addressable location of ALTRO or Board controller can be read using this instruction through instruction sequencer. Parametric structure for FEC\_RD instruction is shown in table 1.17





Figure 1.2 FEC- read chronogram.

**pgdly** = The command strobe is asserted after this programmable delay with respect to the ALTRO bus.

**Tout\_ack1** = This is the maximum time for which acknowledge from FEC is awaited to get asserted, 40 readout clock cycles.

**Tout\_ack2** = This is the maximum time for which acknowledge from FEC is awaited to get released, 40 readout clock cycles.

#### Result of "FEC\_RD" in the Result Memory

Result of this instruction is loaded in the result memory. Result of each read instruction comprises of two locations of the result memory. Status bit [20] shows the success or failure of the execution. 0: success; 1: failure. Table 1.18 ad 1.19 shows the result of execution for successful or failed execution respectively.

| 24 21 | 20 | 19 | 0                  |                                                   |
|-------|----|----|--------------------|---------------------------------------------------|
| 0000  |    |    | FEC Address        | s from instruction memory for current instruction |
| 0000  | U  |    | Data Read from FEC |                                                   |

Table 1.18: Content of result memory for successful execution of FEC\_RD.

| 24  | 21    | 20 | 9                                                           | 0 |
|-----|-------|----|-------------------------------------------------------------|---|
| 000 | 000 4 |    | FEC Address from instruction memory for current instruction |   |
| 000 | 00 1  |    | "0000000"; AIM Error Code [10:6] ; Instr error code [5 :0]  |   |

#### Table 1.19: Content of result memory for failed execution of FEC\_RD.

| AIM Error<br>Code [10:6] | Description                                                     |
|--------------------------|-----------------------------------------------------------------|
| 01001                    | Altro Error line is asserted before "cstb" is asserted from RCU |
| 01010                    | Altro Error line is asserted before the "ack" from FEC          |
| 01011                    | Altro asserts the "ack" before "cstb"" is asserted from RCU     |
| 01100                    | Altro asserts error while RCU wait for "ack"                    |
| 01101                    | Altro does not assert "ack" time out 1 occurs.                  |
| 01110                    | Altro error is asserted while waiting the release of "ack"      |
| 01111                    | ALTRO doesn't release the "ack" time out 2 occurs.              |

Table 1.20: Description f the AIM error code in the result memory for read transaction.

| Bit Number | Instr error code [5 :0] Description                                                               |
|------------|---------------------------------------------------------------------------------------------------|
| 0          | This bit is set if there has been an error in loop instruction                                    |
| 1          | This error bit is set if the format of instruction sequencer command is not correct.              |
| 2          | This bit is set if the format of instruction to board controller is not correct.                  |
| 3          | This bit is set if the board controller at "Off FEC" is addressed, checked w.r.t. FEC_ACTIVE LIST |
| 4          | This bit is set if the format of instruction to ALTRO is not correct.                             |
| 5          | This bit is set if ALTRO at "Off FEC" is addressed, checked w.r.t. FEC_ACTIVE LIST                |

Table 1.21: Description of the instruction Analyzer error code in the result memory for read transaction.



### Front End Card Write Instruction

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19                        | 0 |
|----|----|---------------------------|---|
| 4  | 0  | Altro Instruction Format  |   |
|    | U  | Data to be written to FEC |   |

Table 1.22: Structure of FEC\_WR instruction.

#### Description

This instruction is used to perform the write operation on FEC. Any write able location of ALTRO or Board controller can be written using this instruction through instruction sequencer. Each write instruction consists of two locations, first one contains the instruction parameters same as ALTRO, next subsequent location contains the data for the write transaction. Parametric structure for FEC\_WR instruction is shown in table 1.22

#### **Timing Parameters**



Figure 1.2 FEC- write Chronogram.

**pgdly** = The command strobe is asserted after this programmable delay with respect to the ALTRO bus.

**Tout\_ack1** = this is the maximum time for which acknowledge from FEC is awaited to get asserted, 40 readout clock cycles.

**Tout\_ack2** = This is the maximum time for which acknowledge from FEC is awaited to get released, 40 readout clock cycles.

#### Result of "FEC\_WR" in the Result Memory

Result of this instruction is loaded in the result memory. Result of each write instruction comprises of two locations of the result memory. Status bit [20] shows the success or failure of the execution. '0': success; '1': failure. Table 1.23 ad 1.24 shows the result of execution for successful or failed execution respectively.



| 24  | 21 | 20 | 19 |                                                             | 0 |
|-----|----|----|----|-------------------------------------------------------------|---|
| 001 | 10 |    |    | FEC Address from instruction memory for current instruction |   |
| 001 | 10 |    |    | "0000000" ; AIM Error Code[10:6] ; Instr Anlz. code [5 :0]  |   |

Table 1.23: Content of result memory for successful execution of FEC\_WR.

Table 1.24: Content of result memory for failed execution of FEC\_WR.

| AIM Error<br>Code [10:6] | Description                                                           |
|--------------------------|-----------------------------------------------------------------------|
| 00001                    | Altro Error line is asserted before "cstb" is asserted from RCU       |
| 00010                    | Altro "ack" is asserted before the "cstb" from RCU                    |
| 00011                    | Altro asserts error while RCU wait for "ack"                          |
| 00100                    | Altro does not assert "ack" time out 1 occurs.                        |
| 00101                    | Altro error is asserted while waiting the release of "ack"            |
| 00110                    | ALTRO doesn't release the "ack" time out 2 occurs.                    |
| 00111                    | ALTRO asserts the error line while broadcast write is being executed. |

Table 1.25: Description f the AIM error code in the result memory for write transaction.

| Bit Number | Instr error code [5 :0] Description                                                               |  |  |
|------------|---------------------------------------------------------------------------------------------------|--|--|
| 0          | This bit is set if there has been an error in loop instruction                                    |  |  |
| 1          | This error bit is set if the format of instruction sequencer command is not correct.              |  |  |
| 2          | This bit is set if the format of instruction to board controller is not correct.                  |  |  |
| 3          | This bit is set if the board controller at "Off FEC" is addressed, checked w.r.t. FEC ACTIVE LIST |  |  |
| 4          | This bit is set if the format of instruction to ALTRO is not correct.                             |  |  |
| 5          | This bit is set if ALTRO at "Off FEC" is addressed, checked w.r.t. FEC_ACTIVE LIST                |  |  |

Table 1.26: Description f the Instruction Analyzer error code in the result memory for write transaction.



### Front End Card Command Instruction

#### Instruction Coding in Instruction Memory

| 21 | 20 | 19                       | 0 |
|----|----|--------------------------|---|
| 0  | 1  | Altro Instruction Format |   |

Table 1.27: Structure of FEC\_CMD instruction.

#### Description

This instruction is used to execute FEC command operation. Parametric structure for FEC\_CMD instruction is shown in table 1.27.

#### **Timing Parameters**

The timing behaviour for this instruction is same as the FEC write instruction. There is one exception for the "EVLRDO" command which is issued while making the sparse readout. The exception is related to acknowledge signal "ACK" from FEC. For this command ACK is not checked for its assertion.

### Result of "FEC\_CMD" in the Result Memory

Result of this instruction is loaded in the result memory. Result of each command instruction comprises of two locations of the result memory. Status bit [20] shows the success or failure of the execution. 0: success; 1: failure. Table 1.28 and 1.29 shows the result of execution for successful or failed execution respectively.

| 24 21 | 20 | 19 0                                                        |  |
|-------|----|-------------------------------------------------------------|--|
| 0001  | •  | FEC Address from instruction memory for current instruction |  |
| 0001  | U  | 0 XXXXXX                                                    |  |

Table 1.28: Content of result memory for successful execution of FEC\_CMD.

| 24 | 21  | 20 | 19                                                                | 0 |
|----|-----|----|-------------------------------------------------------------------|---|
|    | 0.1 | 1  | FEC Address from instruction memory for current instruction       |   |
| U  | )01 |    | 1 "0000000" ; **AIM Error Code [10:6] ; * Instr Anlz. code [5 :0] |   |

Table 1.29: Content of result memory for failed execution of FEC\_CMD.

Explanation of the error codes is same as the FEC – write transaction please refer to table 1.25 and table 1.26.

# 1.7 RCU Commands

There are eleven commands which can be executed directly on RCU means that its not loaded in the instruction sequencer. These commands are to initialize different functions in RCU. Results of these instructions are not available in the result memory In this section detail structure of these commands is described. Please not that the instruction for the resets is different for DDL and DCS side.

| Name         | Access | Inst. Code | Description                                        |
|--------------|--------|------------|----------------------------------------------------|
| GRESET       | W      | 0x 5300    | Global reset. Resets RCU and FECs                  |
| FECRST       | W      | 0x 5301    | Front end card reset                               |
| RCURST       | W      | 0x 5302    | RCU Reset                                          |
| CONFGFEC     | W      | 0x 5303    | Re-configures the BC of the FEC.                   |
| EXESEQ       | W      | 0x 5304    | Start Execution of Instruction Sequencer           |
| ABRTSEQ      | W      | 0x 5305    | Abort the Execution cycle of Instruction Sequencer |
| SWTTRG       | W      | 0x 5306    | Issue Software Trigger                             |
| CLERRSTREG   | W      | 0x 5307    | Clear Error & Status Registers                     |
| CLEARRDRXREG | W      | 0x 5308    | Clear RD_RX error register                         |
| CLRCNT       | W      | 0x 5309    | Clear Counters                                     |
| ARBITERIRQ   | W      | 0x 5310    | DCS BUS INTERRUPT REQUEST                          |
|              |        |            | Note: In DCS interface                             |

Table 1.30: RCU Commands



## **Global Reset**

| Instruction Code | 0x5300  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will reset the full RCU, including configuration registers, error and status registers and front end cards. The code 0x5300 is specific to be used from DCS only. The coding of this command from DDL is different.



# **FEC Reset**

| Instruction Code | 0x5301  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will reset the RCU for state machines. Configuration registers, error and status registers will not have any effect from this command. The code 0x5301 is specific to be used from DCS only. The coding of this command from DDL is different.



## **RCU** Reset

| Instruction Code | 0x5302  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will reset the RCU for state machines. Configuration registers, error and status registers will not have any effect from this command. The code 0x5302 is specific to be used from DCS only. The coding of this command from DDL is different.



## **Configuration of Front End Card (Board Controller)**

| Instruction Code | 0x5303  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will turn off the front end cards for 4.0uSec. After the 4.0uSec the front end cards will be turned on same as the original configuration of active front end card list as shown in the figure

#### **Timing Parameters**







## **Execute Sequence (Start Sequencer)**

| Instruction Code | 0x5304  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will start the execution of Instruction sequencer. Instruction sequencer will execute the sequence loaded in the instruction memory.



### Abort Sequence (Stop Sequencer)

| Instruction Code | 0x5305  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will abort the execution of current sequence which is being executed by the sequencer. Instruction sequencer will exit from the sequence loaded in the instruction memory to idle state.



### **Software Trigger**

| Instruction Code | 0x5306  |
|------------------|---------|
| Access Type      | Command |

#### Description

This command will issue sequence of L1a and L2a to front end cards. The latency between L1 and L2 is programmable through the Altro interface configuration register (ALTROIF).

#### **Timing Parameters**

Latency between L1 and L2 is programmable with Altro interface register. Total of 13 bits can be assigned to set this latency. L1 is synchronized with respect to sampling clock asserted for two clock cycle. Similar way L2 to FEC is synchronized with read out clock as shown in figure X.X.



Figure 1.4 software trigger chronogram.



# **Clear Error and Status Registers**

| Instruction Code | 0x5308  |  |
|------------------|---------|--|
| Access Type      | Command |  |

### Description

This command clears all the error status registers.



# **Clear Error and Status Registers**

| Instruction Code | 0x5309  |  |
|------------------|---------|--|
| Access Type      | Command |  |

### Description

This command clears all the counters in the RCU.

# 2.0 RCU Data Format

In the RCU, the 40-bit wide ALTRO data packets are formatted into 32-bit wide packet. Structure of event data is described in table 1.26 The 32-bit data packet is completed by a trailer (table 1.1) to form the RCU data block. The trailer consists of 2 fixed words, the first and the last one in the trailer, and N optional words that carry information on the settings and status of the FECs and RCU.

The two fixed trailer words define respectively: 1) the Payload Length, which specifies the number of 40-bit data words; 2) the RCU Address and the Trailer Length in 32-bit words.

The optional words that compose the trailer consist of a parameter *code* (the 6 MSB), and the parameter itself that consists of 26 bits. The parameters to be appended to the Event Trailer will be stored in a dedicated RCU memory (Trailer Memory) that contains a maximum of 64 words. The actual number of parameter that will be included in the Trailer is variable and is defined by the first word in the Trailer Memory. Hereunder, detail of each parameter is described in table 1.32, that will be included in the RCU Firmware V2.0).

| Common I          | Data Header (8 words)        |
|-------------------|------------------------------|
| Payload (Variab   | ole nr. of words, minimum 0) |
| Trailer (Variable | e nr. Of words, minimum 2)   |

Table 1.31 Structure of the Event data block

# 2.1 Common Data Header (CDH)

The various fields of the common data format header are either loaded using the data transmitted by the ALICE Trigger system or created locally by the RCU when running without the ALICE Trigger system (e.g. for standalone tests). The parameters which are set at the RCU level are described here.



 Table 2.1 Common Data Header

Block Length parameter in CDH 0 is set to "FFFFFFF"

In CHD4 status & Error bits are set by RCU. RCU receives total of 25 bits of errors from trigger receiver module and code them into these 15 bits. These errors are described in table 2.2.

| Error Bit<br>No | Name                      | Explanation                                                           |
|-----------------|---------------------------|-----------------------------------------------------------------------|
| 0               | Spurious L0               | High if a L0 trigger comes outside of the legal time window for a L0. |
| 1               | Missing L0                | High if the L0 trigger is missing                                     |
| 2               | 0                         | Data parity error: Not handled in RCU set to '0'                      |
| 3               | 0                         | Control parity error : Not handled in RCU set to '0'                  |
| 4               | Incomplete L1<br>Message  | High when less than 4 L1 data words follows a L1 header               |
|                 | Incomplete L2a<br>Message | High when less than 7 L2a data words follows a L2a header             |
|                 | Incomplete Rol<br>Message | High when less than 3 Rol data words follows a Rol header             |
|                 | L1 message                | High if the L1 message does not start to arrive within the legal      |

|    | missing/timeout                                  | time window for a L1 message.                                                                                                                                                      |
|----|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | L2 message                                       | High if all or part of the L2a/L2r message arrives outside of the                                                                                                                  |
|    | arrives outside<br>legal timeslot                | legal time window for a L2a/L2r message.                                                                                                                                           |
|    | Rol message<br>missing/timeout                   | High if the RoI message does not start to arrive within the legal time window for a RoI message.                                                                                   |
| 5  | 0                                                | Front-end electronics error Not Handled in RCU set to '0'                                                                                                                          |
| 6  | 0                                                | HLT decision flag : Not Handled in RCU set to '0'                                                                                                                                  |
| 7  | 0                                                | HLT payload flag: Not Handled in RCU set to '0'                                                                                                                                    |
| 8  | 0                                                | DDG payload flag: Not Handled in RCU set to '0'                                                                                                                                    |
| 9  | TTCrx Address<br>Error                           | High if the TTCrx address is unequal to 0x8001. The message will not be decoded if this is this case and the message decoder will return to idle.                                  |
| 10 | L2 message<br>arrives outside<br>legal timeslot  | High if all or part of the L2a/L2r message arrives outside of the legal time window for a L2a/L2r message.                                                                         |
|    | L2 message<br>missing/timeout                    | High if the L2a/L2r message does not start to arrive within the<br>legal time window for a L2a/L2r message                                                                         |
| 11 | Prepulse error                                   | Not Used.                                                                                                                                                                          |
| 12 | Serial B Stop Bit<br>Error                       | Serial B stop bit is 0 when it is expected to be 1                                                                                                                                 |
|    | Single Bit<br>Hamming Error<br>Individually Addr | Single bit hamming error found and corrected in individually addressed message.                                                                                                    |
|    | Double Bit<br>Hamming Error<br>Individually Addr | Double bit hamming error found in individually addressed message, not possible to correct. Most likely a lot of other errors will come as a result of this.                        |
|    | Double Bit<br>Hamming Error<br>Broadcast         | Double bit hamming error found in broadcast message, not possible to correct. Most likely a lot of other errors will come as a result of this.                                     |
|    | Unknown Message<br>Address Received              | If an individually addressed message has arrived with a not known address. Known addresses are given in Table 5-7.                                                                 |
|    | TTCrx Address<br>Error                           | High if the TTCrx address is unequal to 0x8001. The message will not be decoded if this is this case and the message decoder will return to idle.                                  |
|    | L1 message<br>arrives outside<br>legal timeslot  | High if all or part of the L1 message arrives outside of the legal time window for a L1 message.                                                                                   |
|    | L2 message<br>arrives outside<br>legal timeslot  | High if all or part of the L2a/L2r message arrives outside of the legal time window for a L2a/L2r message.                                                                         |
|    | Rol message<br>arrives outside<br>legal timeslot | High if all or part of the RoI message arrives outside of the legal time window for a RoI message.                                                                                 |
|    | Rol message<br>missing/timeout                   | High if the Rol message does not start to arrive within the legal time window for a Rol message.                                                                                   |
|    | L1 message<br>content error                      | High if a combination of the following occur:<br>CIT_L1 = 0 after arrival of pre-pulse<br>L1_SwC = 0 when CIT_L1 = 1<br>L1_SwC /= L2_SwC<br>CIT_L1 /= CIT_L2a<br>ESR_L1 /= ESR_L2a |
|    | L2 message<br>content error                      | High if a combination of the following occur:<br>BCID_L2a/L2r > 3563<br>CIT_L2 = 0 after arrival of pre-pulse<br>L2_SwC = 0 when CIT_L2 = 1<br>L1_SwC /= L2_SwC                    |

|    |               | CIT_L1 /= CIT_L2a                                       |
|----|---------------|---------------------------------------------------------|
|    |               | ESR_L1 /= ESR_L2a                                       |
|    | Rol message   | High if a combination of the following occur:           |
|    | content error | BCID_Rol > 3563                                         |
| 13 | Missing L1    | High if the L1 trigger is missing                       |
| 14 | 0             | Multi-event buffer error: Not Handled in RCU set to '0' |
| 15 | 0             | Reserved (Not used) '0'                                 |

Table 2.2 Error & Status Bit in CDH 4 [27:12]

| Code [31:26] | Name              | Description [25:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00         | PAYLOAD<br>LENGTH | The payload length is expressed {No. of 40 bit words for DM}<br>{No. of 32 bit words for RM}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x01         | ERR_REG1          | Trailer[25:13] ≡ FECERRA[19:7];         Trailer[12:0] ≡ FECERRB[19:7];         FECERR[19]: transfer not released         FECERR[18]: ALTRO error signal asserted while data being transferred;         FECERR[17]: transfer not asserted;         FECERR[16]: ALTRO error asserted before transfer,         FECERR[15]: Write FSM error when started by RDO FSM;         FECERR[14]: ackn not released by ALTRO;         FECERR[13]: ALTRO error asserted while waiting for ackn to be released;         FECERR[12]: ALTRO does not assert ackn;         FECERR[11]: ALTRO error asserted while waiting for ackn;         FECERR[10]: ALTRO asserts ackn before assertion of cstb;         FECERR[09]: ALTRO error asserted while waiting for ackn;         FECERR[08]: ALTRO error asserted in state "assertbus"         FECERR[07]: ALTRO error asserted in the execution of a broadcast command |
| 0x02         | ERR_REG2          | ERR_REG2[8] : Block Length mismatch<br>ERR_REG2[7]: Channel Address mismatch;<br>ERR_REG2[6]: RDYRX error;<br>ERR_REG2[5]: SCANEVLEN error;<br>ERR_REG2[4:0]:EVLENRDO error;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x03         | ERR_REG3          | ERR_REG3 [11:0] = Number of mismatches in the channels address detected by the data assembler during the readout ERR_REG3[24:12] = Number of mismatches in the channel data block length detected by the data assembler during the readout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x04         | ERR_REG4          | NOT USED "0000000000000000000000000"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0x05         | FEC_RO_A          | It defines the bit map of the "active" FECs of Branch A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0x6          | FEC_RO_B          | It defines the bit map of the "active" FECs of Branch B.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0x7          | RDO_CFG1          | Copy of the RCU Register ALTROCFG1. For the definition of this parameter, see also<br>ALTRO manual pags. 36,37.<br>First Baseline Correction Mode $\equiv$ RDO_CFG1[3:0]<br>Polarity. When set, the ADC data is inverted (1's C) [4]<br>Nr. Of pre-samples excluded from 2 <sup>nd</sup> baseline corr. $\equiv$ RDO_CFG1 [6:5]<br>Nr. Of post-samples excluded from 2 <sup>nd</sup> baseline corr. $\equiv$ RDO_CFG1 [10:7]<br>Enable second baseline correction $\equiv$ RDO_CFG1 [11]<br>Glitch filter configuration for zero suppression $\equiv$ RDO_CFG1 [13:12]<br>Nr. Of post-samples excluded from suppression $\equiv$ RDO_CFG1[16:14]<br>Nr. Of pre-samples excluded from suppression $\equiv$ RDO_CFG1[18:17]<br>Enable Zero Suppression $\equiv$ RDO_CFG1 [19]                                                                                                                        |
| 0x8          | RDO_CFG2          | Nr of ALTRO Buffers (copy of RCU register ALTROCFG2[4]) $\equiv$ RDO_CFG2[24]<br>Nr of pre-trigger samples (copy of RCU reg ALTROCFG2[[3:0]) $\equiv$ RDO_CFG2[23:20]<br>Nr. Samples / channel (copy of RCU reg ALTROIF[9:0]) $\equiv$ RDO_CFG2[19:10]<br>Sparse Readout $\equiv$ RDO_CFG2[9]<br>T <sub>sampling</sub> / T <sub>LHC</sub> $\equiv$ RDO_CFG2[8:5] $\Rightarrow$ 00 = 2 (20MHz), 01 = 4 (10MHz), 10 = 8 (5 MHz)<br>Phase of L1 trigger wrt LHC bunch crossing $\equiv$ RDO_CFG2 [4:0]. The phase is internally<br>calculated in terms of bunch crossing cycles. For example if the Tsampling/TLHC is<br>equal 01 (10MHz sampling rate), only the two least significant bits are meaningful and<br>the phase can take values 0, 1, 2, 3.                                                                                                                                              |
| 0x9          | RCU ID            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Table 1.32: Content of Trailer word