## **MROD-In Programmers Manual**

#### Introduction

The MROD-In is the input part of the MDT Precision Chamber Read-Out Driver. It is designed to receive data from two channels of 18 TDCs each. These two data streams are processed in two FPGAs; one per channel. The FPGAs are connected to one SHARC processor (figure 1). The description below will focus on one channel and one FPGA since the processing of each channel is equal.



Figure 1: MROD-In block diagram.

The input data for one channel of the MROD-In will be organised as can be seen in figure 2. Such data will be produced by the Chamber Service Module (CSM) and send over a Gigabit Optical Link (GOL) to the MROD-In.

| Separator | TDC | TDC | <br>TDC | Separator | TDC |  |
|-----------|-----|-----|---------|-----------|-----|--|
|           | 0   | 1   | 17      |           | 0   |  |

Figure 2: Input data format for one MROD-In channel.

A Separator word is used to mark the start of 18 time slots, one for each TDC. When there is no data available from a TDC then a NoData word is put in the data stream in the corresponding time slot.

The MROD-In channel can be programmed to recognise several words in the input data stream. These words are:

- A Separator word
- A TDC-Header word
- A NoData word
- A TDC-Trailer word

To do so, the FPGA on the MROD-In contains comparators that can be programmed with a bit pattern and a bit mask. The pattern and mask bits are organised as two 32-bit words; in the last word, only bit 0 is significant. This single bit signals whether or not the first 32-bit word needs to be a link control word (LCTRL n = '0') or not.

#### Separator:

When a Separator is recognised a time slot counter is started which will count from 0 up until 17. While counting, data from the Input Link is transferred to 18 partitions (each 8K words) of the buffer memory. Partition 0 is corresponding with time slot 0, partition 1 with time slot 1 etc. The only case where no data will be transferred to the buffer memory is when a NoData word is received.

If there are more than 18 words send after a Separator is recognised then the surplus of data will be discarded.

#### TDC-Header:

When a TDC-Header is recognised then bits [28..24] will be replaced by the value of the time slot counter (5 bits). In this way, data of the 18 TDCs can be uniquely identified. Note that the TDC-Header bits [27..24] normally contain the 4-bit TDC-ID as programmed by JTAG into the TDCs.

#### NoData word:

When a NoData word is send by the CSM and recognised by the MROD-In NoData word comparator then this means that there was not yet data available from the TDC to be send by the CSM in the corresponding time-slot. Nothing is stored in the corresponding partition.

#### TDC-Trailer:

When a TDC-Trailer is recognised then the Event-ID of the trailer is checked whether it falls within a 16 wide window of 'Expected' Event-IDs. This can lead to an 'Accept', an 'Early', or a 'Late' condition. The Event-ID in the TDC-Trailer is 12 bits wide, which means that the Event-ID can have 4096 different values. So, for 2048 values further than the Expected Event-ID + 8 (which is halfway the 'Accept' window) there is a roll over from 'Early' to 'Late' (see Table 1). Note that [Expected Event-ID + 7 - 2048] is the same value as [Expected Event-ID + 7 + 2048].

'Early' and 'Late' are error conditions, which can generate an interrupt on the SHARC. When the TDC-Trailer is accepted, a flag bit is set in the 'Tetris register'. This register operates similar to the famous computer game called 'Tetris', hence the name 'Tetris register'.

| Expected Event-ID + 7 – 2048 | Early |
|------------------------------|-------|
|                              |       |

| Expected Event-ID + 8 – 2048 | Late   |
|------------------------------|--------|
| :                            | :      |
| Expected Event-ID – 1        | Late   |
| Expected Event-ID            | Accept |
| ;                            | •      |
| Expected Event-ID + 15       | Accept |
| Expected Event-ID + 16       | Early  |
| ;                            | •      |
| Expected Event-ID + 7 + 2048 | Early  |
| Expected Event-ID + 8 + 2048 | Late   |

Table 1: Expected Event-ID window

The row of the flag bit in the Tetris register is determined by the low order 4 bits of the TDC-Trailer Event-ID. The column of the flag bit in the Tetris register is determined by the TDC time slot (0..17).

When all Trailers with the Expected Event-ID of enabled TDCs are received then a 'Row-Out' condition is send to the output controller. So a row is complete when all enabled TDCs (see the TDC-Mask register) flagged the presence of their TDC-Trailer with the Expected Event-ID in the buffer memory.

A Row-Out condition will also occur when a row which is flagging the first, up to fourteenth following Event-ID is complete (Expected Event-ID + (1..14)). In this case the Row-Out condition for the Expected Event-ID is waiting for one or more TDC-Trailers with an Event-ID which was lost. The status of the flags of the Expected Event-ID row in the Tetris Register tells us, which TDC-Trailer(s) was/were lost.

Furthermore a Row-Out condition immediately occurs whenever a TDC-Trailer is received with its Event-ID equal to Expected Event-ID + 15. This will only occur if the Event-ID difference between TDCs is more than 15, which is a very rare condition. Note that in this case the last row in the Tetris register is indexed so this Row-Out condition is an attempt to free up rows in the Tetris register in order to keep track of incoming TDC data.

A Row-Out condition stores the status from the Expected Event-ID row of the Tetris Register in an 'input to output FIFO' (I2O\_FIFO). The Expected Event-ID is also stored. Note that the Input Link data is not restricted to 18 TDC number slots. It could be less since the TDC number counter is forced to 0 after each received Separator word. However the frequency of the Separator words is limited due to the way the Tetris register is implemented. Separator words should at least be 3 clock cycles apart.

TDCs that are not in use or which have a malfunction can be disabled using the TDC-Mask register. When a TDC is disabled then the Tetris register will not wait for the corresponding trailer, which might never come.

The output controller reads the I2O\_FIFO and gathers the data from the partitions in the buffer memory. This data is placed, either with or without Zero Suppression, in an output FIFO (Outp\_FIFO) that is read by the SHARC under DMA control with a maximum bandwidth of 80 MB/sec. Table 2 lists the format of this data.

Note that the SHARC host bus is used by two FPGAs so the bandwidth of each FPGA is 40 MB/sec when the bandwidth is equally distributed over these two FPGAs.

| Data         | Remark                                                  |
|--------------|---------------------------------------------------------|
| MROD Header  | Bits [3124] MROD Header Pattern (Register 0x14)         |
|              | Bits [170] point out which TDCs are present in the data |
| TDC0 Header  | If TDC0 was present                                     |
| TDC0 Data    | If TDC0 was present and had data                        |
| :            |                                                         |
| TDC0 Trailer | If TDC0 was present                                     |
| TDC1 Header  | If TDC1 was present                                     |
| TDC1 Data    | If TDC1 was present and had data                        |
| :            |                                                         |
| TDC1 Trailer | If TDC1 was present                                     |
| :            |                                                         |
| :            |                                                         |
| MROD Trailer | Bits [3124] MROD Trailer Pattern (Register 0x15)        |
|              | Bits [2312] contain the Event-ID                        |
|              | Bits [110] contain the Event Word Count                 |
| MROD Header  | Next event                                              |

Table 2: Output data format

The number of data words within a single event is send to an Event Length FIFO, which can be read by the SHARC. The empty status of the Event Length FIFO can be inspected by the SHARC by means of one of its flag pins.

Note that the SHARC services two MROD-In channels. The Outp\_FIFO DMA controller of channel A and B are connected to DMAR1\_n and DMAR2\_n of the SHARC respectively. The empty status of the Event Length FIFO of channel A and B are connected to flag 2 and 3 of the SHARC respectively. See also Table 3 and 6.

Each word that is read from the I2O\_FIFO contains the status of the Tetris Register and the Expected Event-ID. If a bit in the Tetris Register was set then the corresponding partition in the buffer memory should be read until a TDC-Trailer is found with an event number equal to the Expected Event-ID in the I2O\_FIFO status word. It is guaranteed that the output controller will find such a TDC-Trailer in the buffer memory since the Tetris Register has the corresponding flag set.

There can be two conditions where the output controller will switch off the read-out for a certain partition. The first condition is when a partition in the buffer memory is full. Since the partitions are in fact circular buffers, the data in the partition will be overwritten. This means there is no unambiguous relation anymore between the content of the Tetris Register and the data in the partition. The output controller could get confused because it is no longer guaranteed that it will find the TDC-Trailer with the Expected Event-ID.

The second condition where the output controller will switch off the read-out is when a single event is longer than a maximum event size. Read-out of the partition is shut down to prevent the data from that partition of blocking the output bandwidth to the SHARC.

Each channel of the MROD-In can be put in "Test Mode". Some Control and Status registers can feed data to the link input. It is also possible for the SHARC to access the buffer Memory although this is only possible offline since the cycle-shared ports of the buffer memory are dedicated to the link input and the output controller of the FPGA during normal operation.

Several interrupt sources signal special conditions or errors.

All the above can be controlled and monitored by means of a set of Control and Status Registers, which reside in the MS0 address space of the SHARC. Table 5 contains a listing these registers.

## **SHARC Memory regions**

SHARC Address line A[20] determines the MROD-In channel, which is being accessed as can be seen in Table 3. This table also lists the SHARC DMA request lines and the Event Length FIFO empty status for each channel.

| MROD-In | A[20]      | Output FIFO DMA | Event Length FIFO               |
|---------|------------|-----------------|---------------------------------|
| Channel |            | Channel         | empty status (see also table 6) |
| A       | '0'        | DMAR1_n         | Flag 2                          |
| В       | <b>'1'</b> | DMAR2_n         | Flag 3                          |

Table 3: Access to the MROD-In input Channel A and B

The memory regions for the FPGAs are organized as can be seen in Table 4. Note that since address line A[20] of the SHARC is used to address the FPGA of channel A or B, memory regions MS0, MS1 and MS2 should be at least 2 MWord long (1 MWord for each channel).

The SHARC uses a 64-bit data bus to interface to external memory. The data bus of each FPGA is connected to bits 63 to 32 of the SHARC data bus. The SHARC should use "32-bit normal word addressing" on *odd* address (see also figure 7-1 and the note on page 7-3 of the "SHARC DSP Hardware Reference").

| Memory | Function             | EBxWS | EBxAM | Remarks |
|--------|----------------------|-------|-------|---------|
| Region |                      |       |       |         |
| MS0    | Internal registers   | 100   | 00    | 1, 2    |
| MS1    | Read Output FIFO     | 001   | 00    | 1, 3    |
| MS2    | Buffer memory access | 011   | 00    | 1, 4    |
|        | when in SHARC        |       |       |         |
|        | Read/Write Mode      |       |       |         |
| MS3    | Not Used             | N.A.  | N.A.  |         |

Table 4: SHARC Memory regions

#### Remarks:

1: EBxWS and EBx=AM are sub-patterns of the Wait register described in table 8-3 and table 8.4 of the "SHARC Technical Specification", or table 5-4 and table 5-5 of the "SHARC DSP Hardware Reference".

| 2: | EBxWS = 100 | means 4 Wait, 1 Hold Cycle                      |
|----|-------------|-------------------------------------------------|
|    | EBxAM = 00  | Both Internal and External Acknowledge required |
| 3: | EBxWS = 001 | means 1 Wait, 0 Hold Cycles                     |
|    | EBxAM = 00  | Both Internal and External Acknowledge required |
| 4: | EBxWS = 011 | means 3 Wait, 1 Hold Cycles                     |
|    | EBxAM = 00  | Both Internal and External Acknowledge required |

## SHARC MS0 address space: Control and Status Registers

## Register 0x00 to 0x03 (MS0 offset 0x01 and 0x07): **Separator Pattern & Mask**

Registers 0x00 and 0x01 contain the 33-bit pattern that must match the Separator data on the Input Link. A 33-bit mask (registers 0x02 and 0x03) defines the bits that must match. If a mask bit is set to '1' the corresponding bit in the pattern register must match the Separator data on the Input Link. If all bits match then a Separator is signalled. The Pattern and Mask are 33-bit wide; 32 data bits and one bit to distinguish between a link data or control word (as signalled by LCTRL n, active low). Registers 0x00 and

0x02 are 32-bit wide. Registers 0x01 and 0x03 contain the 1-bit pattern and mask for the link control bit. Reading back registers 0x00 or 0x02 yields the value written into them.

Reading back registers 0x01 or 0x03 yields either 0x00000000 or 0x00000001 depending on the value written into the bit 0 location. Bits 31 to 1 are always read back as '0'.

#### Registers 0x04 to 0x07 (MS0 offset 0x09 to 0x0F): **TDC-Header Pattern & Mask**

The description of these registers is the same as for the Separator Pattern and Mask registers 0x00 to 0x03, except that registers 0x04 to 0x07 control the recognition of a TDC-Header condition.

## Registers 0x08 to 0x0B (MS0 offset 0x11 to 0x17): **TDC-Trailer Pattern & Mask**

The description of these registers is the same as for the Separator Pattern and Mask registers 0x00 to 0x03, except that registers 0x08 to 0x0B control the recognition of a TDC-Trailer condition.

## Registers 0x0C to 0x0F (MS0 offset 0x19 to 0x1F): **NoData Pattern & Mask**

The description of these registers is the same as for the Separator Pattern and Mask registers 0x00 to 0x03, except that registers 0x0C to 0x0F control the recognition of a 'NoData' word condition.

## Registers 0x10 (MS0 offset 0x21): **Error-Code Replace Patterns**

When an error is signalled on the incoming data stream from the CSM then the word-ID bits [31..28] of the data word that contains the error is replaced by an Error-Code. The original word-ID bits are moved to bits [27..24] in order to make debugging easier because the original word type can probably still be traced (there is no guarantee however, since the error could have effected on of the word-ID bits).

When a TDC Parity Error was signalled by the CSM (bit 27 of the data word was set to '1' by the CSM) then bits [31..28] will be replaced with the TDC Parity Error-Code bits [31..28] of the Error-Code Replace Patterns Register.

When an Input Link parity check fails (bit 26 of the data word serves as a parity bit over all other 31-bits in the data word) then bits [31..28] will be replaced with the Input Link Parity Check Failure Error-Code bits [15..12] of the Error-Code Replace Patterns Register.

When both errors (TDC Parity Error and Input Link Parity Check Failure) occur at the same time then the Input Link Parity Check Failure is given priority.

Summarizing register 0x10 bits:

bit [31..28] TDC Parity Error, Error-Code Replace bits

bit [27..16] Not used, writing doesn't care, reading yields 0x000

bit [15..12] Input Link Parity Check Failure Error-Code Replace bits

bit [11..0] Not used, writing doesn't care, reading yields 0x000

# Registers 0x11 to 0x13 (MS0 offset 0x23 to 0x27): Reserved

These registers are reserved. Writing to them doesn't care, reading always yields 0x00000000.

| Registe | MS0    | Function                          | Write     | Read       | Default     |
|---------|--------|-----------------------------------|-----------|------------|-------------|
| r       | offset |                                   |           |            | After Reset |
| 0x00    | 0x01   | Separator Pattern                 | 0xnnnnnnn | 0xnnnnnnn  | 0xD0000000  |
| 0x01    | 0x03   | Separator Control Bit Pattern     | 0хр       | q0000000x0 | 0x00000000  |
| 0x02    | 0x05   | Separator Mask                    | 0xnnnnnnn | 0xnnnnnnn  | 0xF0000000  |
| 0x03    | 0x07   | Separator Control Bit Mask        | 0хр       | q0000000x0 | 0x00000000  |
| 0x04    | 0x09   | TDC-Header Pattern                | 0xnnnnnnn | 0xnnnnnnn  | 0xA0000000  |
| 0x05    | 0x0B   | TDC-Header Control Bit<br>Pattern | 0хр       | 0x0000000p | 0x00000000  |
| 0x06    | 0x0D   | TDC-Header Mask                   | 0xnnnnnnn | 0xnnnnnnn  | 0xF0000000  |
| 0x07    | 0x0F   | TDC-Header Control Bit Mask       | 0хр       | q0000000x0 | 0x00000000  |
| 0x08    | 0x11   | TDC-Trailer Pattern               | 0xnnnnnnn | 0xnnnnnnn  | 0xC0000000  |
| 0x09    | 0x13   | TDC-Trailer Control Bit Pattern   | 0хр       | q0000000x0 | 0x00000000  |
| 0x0A    | 0x15   | TDC-Trailer Mask                  | 0xnnnnnnn | 0xnnnnnnn  | 0xF0000000  |
| 0x0B    | 0x17   | TDC-Trailer Control Bit Mask      | 0хр       | q0000000x0 | 0x00000000  |
| 0x0C    | 0x19   | No Data Pattern                   | 0xnnnnnnn | 0xnnnnnnn  | 0x00000000  |
| 0x0D    | 0x1B   | No Data Control Bit Pattern       | 0хр       | q0000000x0 | 0x00000000  |
| 0x0E    | 0x1D   | No Data Mask                      | 0xnnnnnnn | 0xnnnnnnn  | 0xF0000000  |
| 0x0F    | 0x1F   | No Data Control Bit Mask          | 0хр       | 0x000000p  | 0x00000000  |
| 0x10    | 0x21   | Error-Code Replace Patterns       | 0xnn      | 0xn000n000 | 0x5000D000  |
| 0x11    | 0x23   | Reserved                          | 0x        | 0x00000000 | 0x00000000  |
| 0x12    | 0x25   | Reserved                          | 0x        | 0x00000000 | 0x0000000   |

| 0x13 | 0x27 | Reserved                                        | 0x        | 0x00000000 | 0x0000000                |
|------|------|-------------------------------------------------|-----------|------------|--------------------------|
| 0x14 | 0x29 | MROD Header Pattern                             | 0xnn      | 0xnn000000 | 0x89000000               |
| 0x15 | 0x2B | MROD Trailer Pattern                            | 0xnn      | 0xnn000000 | 0x8A000000               |
| 0x16 | 0x2D | Event Length FIFO                               | 0x        | 0x0nnn0nnn |                          |
| 0x17 | 0x2F | Interrupt Control IRQ0                          | 0xnn      | 0x0snnnnn  | 0x00000000               |
| 0x18 | 0x31 | TDC (Parity) Error Individual<br>Interrupt Mask | 0xqnnnn   | 0x000qnnnn | 0x0003FFFF               |
| 0x19 | 0x33 | Input Link Interrupt; IRQ1                      | 0xqp      | 0x000000qs | 0x00000000 1)            |
| 0x1A | 0x35 | Early and Late Event-ID; IRQ2                   | 0x        | 0x000nnnnn | 0x00000000               |
| 0x1B | 0x37 | Test & Input Link Control<br>Status Register    | 0xnvsn    | 0x0000nnnn | 0x00000800 <sup>2)</sup> |
| 0x1C | 0x39 | Test Link Data Register                         | 0xnnnnnnn | 0xnnnnnnn  | 0x00000000               |
| 0x1D | 0x3B | Test Link Control Register                      | 0xq       | p0000000x0 | 0x00000003               |
| 0x1E | 0x3D | Maximum Event Size                              | 0xnnn     | 0x00000nnn | 0x00000400               |
| 0x1F | 0x3F | Expected Event-ID                               | 0xnnn     | 0x00000nnn | 0x00000001               |
| 0x20 | 0x41 | TDC Mask Register                               | 0xqnnnn   | 0x000qnnnn | 0x0003FFFF               |
| 0x21 | 0x43 | Partition Read-out Enable                       | 0xqnnnn   | 0x000qnnnn | 0x0003FFFF               |
| 0x22 | 0x45 | Serial Register                                 | 0x        | 0xnnnnnnn  | 0x00000000               |

#### Remarks:

'n' is any hexadecimal number 's' is one out of 0x00 to 0x07

'-' is don't care 't' is 0x00 or 0x08 'p' is either 0x00 or 0x01 'u' is 0x00 or 0x02

'q' is 0x00, 0x01, 0x02 or 0x03 'v' is 0x00, 0x02, 0x04, 0x06, 0x08, 0x0A, 0x0C, 0x0E

'r' is 0x00, 0x04, 0x08 or 0x0C

Notes: 1) Default value read depends on the status of LDOWN n (bit 2)

Notes: 2) Default value read depends on the status of TDO (bit 7) and LDOWN n (bit 8)

Table 5: Registers in the MS0 address space

# Register 0x14 (MS0 offset 0x29): MROD Header Pattern

Register 0x14 contains an 8 bits MROD Header Pattern in the bit positions 31 down to 24. For each read-out (one event), initiated by a Tetris register status word in the I2O\_FIFO, a special first word is send to the output FIFO, which contains these 8 bits in the positions 31 down to 24 (see table 2). The lower 18 bits of this word give information about which TDCs have data (in sequence). This is actually the AND of the status from the Tetris Register and the Partition Read-out Enable register (register 0x21).

Rule: If one of the lower 18 bits is '1' then data of the corresponding TDC should be in the output stream.

Note: The following situation is an exception to this rule! If a partition full condition is met *after* the MROD header is send to the Output FIFO but *before* the corresponding partition is actually read-out then no data is found in the output stream since the corresponding partition was shut down before it was read-out. However, this will lead to a "Partition Full Interrupt" (see register 0x17). This should be very rare!

Note: A Maximum Event Size overflow (see register 0x1E) will shut down the read-out as well but there should at least be some data of the corresponding TDC in the output stream.

# Register 0x15 (MS0 offset 0x2B): MROD Trailer Pattern

Register 0x15 contains an 8 bits MROD Trailer Pattern in the bit positions 31 down to 24. For each read-out (one event), initiated by a Tetris register status word in the I2O\_FIFO, a sequence of TDC data read from the partitions in the buffer memory is send to the output FIFO. A MROD Trailer word is send to the output FIFO when all TDC data of the event is send to the output FIFO. Bits 31 down to 24 of the MROD Trailer word contain the 8 bits in the positions 31 down to 24 of register 0x15 (see table 2).

Bits [23..12] of the MROD Trailer which is send to the output FIFO contain the Event-ID of the data which was just send. Bits [11..0] of contain the word count of the data in the event which was just send. The word count includes the MROD Header and MROD Trailer words.

## Register 0x16 (MS0 offset 0x2D): Event Length FIFO

Register 0x16 is a read only register. When the register is read, one word is read from the Event Length FIFO.

SHARC flags 2 and 3 (for Channel A and B, see table 6) signals whether the Event Length FIFO contains any data.

The event length is send to the Event Length FIFO during the transfer of the last word of the event (MROD-Trailer) to the Output FIFO. When the Output FIFO fills up, the data transfer from the buffer memory partitions is halted. In this case the event cannot be completed by sending the MROD-Trailer to the output FIFO (event length > 128) and thus the event length is not yet send to the Event Length FIFO. Although a part of the event is waiting to be read out of the Output FIFO, the Event Length FIFO may look empty. Normally this situation will not occur since the Output FIFO is continuously read with a DMA transfer.

Warning, reading an empty Event Length FIFO returns the last value read from the FIFO although this should be handled as garbage data.

Bits [27..16] contain the Event-ID

Bits [11..00] contain the word count of the event. The MROD-Header and –Trailer are included in the word count.

## Register 0x17 (MS0 offset 0x2F): Interrupt Control IRQ0

This register controls the interrupt output IRQ0\_n to the SHARC. The IRQ0\_n lines from both MROD-In channels are wired OR-ed.

There are four interrupt sources for IRQ0. If register 0x17 is read back then bits 0 to 3 determine which of the four interrupt sources generated the interrupt.

Bit 0: I2O FIFO Full Interrupt.

Bit 1: Buffer Memory Partition Full Interrupt.

Bit 2: Read-out Maximum Interrupt.

Bit 3: TDC (Parity) Error Interrupt.

Writing a '1' to one of these bits in register 0x17 clears the interrupt.

- Bits 4-7: Mask bits for the interrupt bits (bits 0 to 3). An interrupt bit can only be set when the corresponding mask bit is a '1'.
- Bit 4: I2O\_FIFO Full Interrupt Mask. If '1' then an I2O\_FIFO Full condition generates an interrupt.
- Bit 5: Buffer Memory Partition Full Interrupt Mask. If '1' then a Buffer Memory Partition Full condition generates an interrupt. Note that the Partition Read-out Enable Register (Register 0x21) can give more detailed information about which partition caused the interrupt.
- Bit 6: Read-out Maximum Interrupt Mask. If '1' then an interrupt is generated if an Event is read from a partition but the event contains more data words than is programmed in the "Maximum Event Size" register 0x1E. Note that the Partition Read-out Enable Register (Register 0x21) can give more detailed information about which partition caused the interrupt.
- Bit 7: TDC (Parity) Error General Interrupt Mask. If '1' then an interrupt is generated if a TDC (Parity) Error was signalled (bit 27 = '1') in the data from the Input Link and the TDC (Parity) Error Individual Interrupt Mask bit for the corresponding TDC is set (see register 0x18).
- Bits 25-8: Reflect the 18 (Parity) Error bits, one for each TDC.
- Bit 26: Overrun bit. If this bit is '1' then this means that there were one or more TDC (Parity) Error Interrupts that weren't read-out in time. Note that during an overrun condition, bits 25 down to 8 of the register represent the status of the first error that occurred.

#### Register 0x18 (MS0 offset 0x31):

## TDC (Parity) Error Individual Interrupt Mask

With this register, (Parity) Errors in the data stream from individual TDCs can be masked out for the generation of a TDC (Parity) Error Interrupt.

Bit 0 to 17 corresponds to TDC0 to TDC17 respectively. When a bit is set '1' then an interrupt is generated when a TDC (Parity) Error was signalled (bit 27 = '1') in the data stream from the corresponding TDC.

Note that the TDC (Parity) Error General Interrupt Mask (see register 0x17 bit 7) should also be enabled in order to generate an interrupt.

## Register 0x19 (MS0 offset 0x33): Input Link Interrupt IRQ1

This register controls the interrupt output IRQ1\_n to the SHARC. The IRQ1\_n lines from both MROD-In channels are wired OR-ed.

IRQ1\_n occurs whenever an error is detected on the Input Link. There are two sources that can generate this interrupt, a Input Link Parity Check Failure and LDOWN\_n. Both of these can be masked out by bit 4 and 5 respectively.

The link is tested by inserting parity in bit position 26. By default 'odd' parity is chosen, so when the parity is put into bit 26 then all 32 data bits should have odd parity. 'Even' parity can be chosen if bit 9 of the Test & Input Link Control Status Register is set to '1'. When the cause of the interrupt is an Input Link Parity Check Failure condition then bit 0 of this register is set to '1'.

If bit 1 of this register is a '1' then there was an overrun condition. This means that there were one or more errors that weren't read-out in time.

The Input Link Parity Check Failure interrupt can be cleared by writing a value which has bit 0 set to '1' to this register.

An LDOWN\_n condition can lead to an interrupt as well. The (unmasked) status of the LDOWN\_n line of the Input Link is read back in bit 2 (Note that '0' read back means link is down).

- Bit 0: Input Link Parity Check Failure. If this bit is '1' then this means that a Input Link Parity Check Failure condition generated the interrupt.
- Bit 1: Input Link Parity Check Failure Overrun bit. If this bit is '1' then this means that there were one or more Input Link Parity Check Failure conditions that weren't read-out in time.
- Bit 2: When read, gives the status of the LDOWN\_n line of the Input Link (Note that '0' read back means link is down). This same bit can be found in register 0x1B bit 8.
- Bit 3: Reserved, read back as '0'.
- Bit 4: Input Link Parity Check Failure Mask Bit. When set to '1' an Input Link Parity Check Failure condition leads to IRQ1 n to be asserted.
- Bit 5: LDOWN\_n Mask Bit. When set to '1' an LDOWN\_n condition leads to IRQ1 n to be asserted.

## Register 0x1A (MS0 offset 0x35): Early and Late Event-ID; IRQ2

This register controls the interrupt output IRQ2\_n to the SHARC. The IRQ2\_n lines from both MROD-In channels are wired OR-ed.

IRQ2\_n occurs whenever a TDC-Trailer is received with an Event-ID, which is out of the Expected Event-ID window. Such an Event-ID is either 'Early' or 'Late' (see table 1).

Bits 11-0: Represent the Event-ID, which caused the interrupt.

Bits 16-12: Represent the TDC slot number, which caused the interrupt.

Bit 17: If this bit is '1' then the Event-ID is 'Early'. For example, when the Expected Event-Id is 51 and the received Event-ID for a TDC is 102, which is 'in the future' with respect to the Expected Event-ID.

- Bit 18: If this bit is '1' then the Event-ID is 'Late'. For example, when the Expected Event-Id is 51 and the received Event-ID for a TDC is 50, which is 'in the past' with respect to the Expected Event-ID.
- Bit 19: Overrun bit. If this bit is '1' then this means that there were one or more errors that weren't read-out in time. Note that during an overrun condition, bits 18 down to 0 of the register represent the status of the first error that occurred.

Writing any value to this register clears IRQ2\_n.

Take care in enabling IRQ2 on the SHARC. When the MROD-In is being synchronised with respect to the Event-IDs, the Expected Event-ID register (register 0x1F) is programmed with an Event-ID, which will be valid in the near future. 'Late' interrupts will be generated until the Event-IDs from the TDC-Trailers are within the Expected Event-ID window. Therefore it is advisable to enable IRQ2, only when the MROD-In is in synchronisation and Event-IDs should fall within the Expected Event-ID window.

## Registers 0x1B to 0x1D (MS0 offset 0x37 to 0x3B): Test & Input Link Control Status Registers

Register 0x1B is a general purpose Control Status register. It controls:

- Test mode (bit 0, 1 and 2)
- Zero Suppress Mode (bit 3)
- JTAG signals send to the RJ45 connector on the MROD Out (bit 4..7)
- LDOWN n status (bit 8)
- Input Link Odd/Even Parity Check (bit 9)
- Input Link reset (bit 10)
- Freeze mode for the data pipeline (bit 11)
- Four general-purpose bits for LEDs (bit 12..15)

#### Register 0x1B contains the following bits:

- Bit 0: If in test mode, taking this bit from '0' to '1' writes test data from register 0x1C and 0x1D to the MROD-In Input Link (edge sensitive).
- Bit 1: '0' Normal operation (Input Link); default on power up.
  - '1' test mode operation.
- Bit 2: '0' Normal operation. FPGA read mode; default on power up.
  - '1' test mode operation. SHARC has Read/Write access to buffer memory.
- Bit 3: Zero Suppress. Output data to the SHARC is zero suppressed if this bit is '1'. This means that Headers and Trailers of TDCs that do not have data are flushed from the data-stream. Note that the MROD Header word still contains a flag bit which signals that the zero suppressed TDC was in the data-stream.
- Bit 4: TCK, JTAG signal output to the RJ45 connector on the MROD\_Out. The bit in the register can be written and read back.
- Bit 5: TDI, JTAG signal output to the RJ45 connector on the MROD\_Out. The bit in the register can be written and read back.
- Bit 6: TMS, JTAG signal output to the RJ45 connector on the MROD\_Out. The bit in the register can be written and read back.

Bit 7: TDO, JTAG signal input from the RJ45 connector on the MROD\_Out. The

bit in the register read only, writing to it is don't care.

Bit 8: When read gives the status of the LDOWN\_n line of the Input Link (Note that '0' read back means link is down). This same bit can be found in

register 0x19 bit 2.

Bit 9: '0' (default) 'Odd' Parity Check on the Input Link, '1' for 'Even' Parity Check on the Input Link. Note that bit 26 of the Input Link data is defined as the parity bit.

Bit 10: Taking this bit from '0' to '1' resets the Input Link (edge sensitive).

Bit 11: When this bit is '1' the data pipeline in the FPGA is in 'Freeze' mode. Note that the default mode (after a Rst n) is Freeze ON.

Bit [15..12]: Four LEDs can be connected to these bits. Writing a '1' puts on the light. These bits can be read back. Only LEDs[1..0] are fed to FPGA pins since there are no more pins left on the FPGA package to accommodate LEDs[3..2].

In test mode (bit 1 = '1'), the Input Link is disabled and taken over by the SHARC. The SHARC can now write data as if it came from the Input Link.

Register 0x1B controls access to the buffer memory as well. The buffer memory has two cycle-share ports.

The first port is always dedicated to the Input Link.

During normal operation, the second port is connected to the FPGA in such a way that the FPGA can read data from the buffer memory. For test purposes the SHARC may read or write the buffer memory as well. When bit 2 of the Test Control Register is set then the second port is switched from 'FPGA Read mode' to SHARC 'Read/Write mode'.

Note that bit 2 distorts the operation of the output controller of the FPGA. Therefore bit 2 should only be set for debugging purposes.

For a detailed description of the Freeze and Input Link Reset bits (bit 10 and 11), see also the chapter "Reset Facilities".

Register 0x1C is used in test mode and contains the 32 data bits, which would normally come from the Input Link LD[31..0] bus.

Register 0x1D is used in test mode and contains the following bits:

Bit 0: Status of the LCTRL n bit, which would normally come from the Input Link.

Bit 1: Status of the LDERR n bit which would normally come from the Input Link.

After power-up, the MROD operates normal (that is, no test mode and the FPGA has read access to the buffer memory, Freeze on).

To run a test, write the following data in the corresponding registers:

0x1B: 0x00000002 (Enter the test mode, Freeze off)

0x1C: Input Link Data word 1 (Mind 'even'/'odd' parity in bit 26)

0x1D: Input Link Corresponding status LCTRL and LDERR

0x1B: 0x00000003 (Write Data Word 1 by taking bit 0 from 0 to 1)

0x1B: 0x00000002

0x1C: Input Link Data word 2 (Mind 'even'/'odd' parity in bit 26)

```
0x1D: Input Link Corresponding status LCTRL and LDERR
```

0x1B: 0x00000003 (Write Data Word 2 by taking bit 0 from 0 to 1)

0x1B: 0x00000002

:

0x1C: Input Link Data word N (Mind 'even'/'odd' parity in bit 26)

0x1D: Input Link Corresponding status LCTRL and LDERR

0x1B: 0x00000003 (Write Data Word N by taking bit 0 from 0 to 1)

0x1B: 0x00000000 (Go to normal operation, exit test mode)

#### Registers 0x1E (MS0 offset 0x3D): Maximum Event Size

The 12-bit value in this register determines the maximum allowable event size for a TDC. If the number of words in an event, which is being read-out from a partition in the buffer memory, is more than the value in this register then the event is truncated. Read-out for the partition is stopped by clearing the corresponding partition read-out enable bit in register 0x21. A "Read-out Maximum" interrupt will be generated, to signal the SHARC that something went wrong (see Register 0x17).

Register 0x1E will power up to a default value of 0x400 (1K Words).

Note that the value 0 for this register will give unpredictable results and should be avoided.

Note also that due to pipelining, one extra word *could* be transferred to the output FIFO. This depends on the full status of the output FIFO.

## Register 0x1F (MS0 offset 0x3F): Expected Event-ID

Register 0x1F contains 12 bits, which represents the event-ID that is to be expected as the next event-ID to receive from the TDCs. Normally this register is only written during initialisation of the MROD-In. The hardware of the MROD-In increments the Expected Event-ID when a complete event is gathered from its TDC inputs. The register can be inspected at any time.

It should be possible to synchronize the MROD-In during a run. Via the TTC system it is know which Event-ID is currently used. This value, plus an added margin due to events which can already be in the pipeline of the Data Acquisition System, can be programmed in the Expected Event-ID register. The MROD-In then catches up as soon as this Event-ID comes along. Note that there will be 'Late' conditions so probably IRQ2 (register 0x1A) should be disabled until the MROD-In is in synchronisation.

# Register 0x20 (MS0 offset 0x41): TDC Mask Register

Register 0x20 contains an 18 bits TDC-Mask. Writing a '1' to a bit enables the corresponding TDC. If the bit is written '0' then the corresponding TDC is disabled and the Tetris Register will not wait for the corresponding TDC-Trailer to arrive in order to generate a Row-Out condition.

# Register 0x21 (MS0 offset 0x43): Partition Read-out Enable

Register 0x21 contains 18 partition read-out enable bits. When a bit is '1' then the corresponding buffer memory partition is enabled for read-out, if it is '0' then the partition is skipped during read-out. Bit 0 corresponds with TDC0; bit 1 with TDC1 and so on.

There are two conditions where read-out for a TDC is disabled by the hardware. The first condition is when the corresponding TDC partition in the buffer memory is full. Since the partitions are organized as circular buffers, there is a danger of overwriting data, which was not readout yet, so it is no longer possible to have a consistent image of the TDC event data in the buffer memory with respect to the content of the Tetris Register. Therefore read-out may not be able to find the TDC-Trailers anymore for which it is looking in the buffer memory. To avoid read-out problems the read-out is disabled. This condition should never occur since data should be read from the Output FIFO and the Event Length FIFO fast enough.

Note that the Partition Full condition is met when a partition contains 5 to 6K words instead of the maximum possible 8K words. This is due to the fact that the FPGA contains a pipeline to the buffer memory and only the upper 3 bits of the read- and write pointers of the partitions are used (to save hardware resources in the FPGA) to determine a full condition. The full condition is met when:

WritePointer[12..10] = ReadPointer[12..10] - 2

Note the following example: when the read pointer is 0x0423 a partition full condition is met when the write pointer increases to 0x1C00, a difference less then 6K words. The second condition where read-out for a TDC is disabled is when during read-out of a single event a maximum event size is exceeded. In such a case it is likely that a TDC is out of order. Such a condition forces the read-out for that particular TDC to be disabled. This prevents lots of wrong data from blocking the output bandwidth to the SHARC In either case IRQ0 is asserted (if enabled, see register 0x17 Interrupt Control IRQ0) The SHARC can read the Partition Read-out enable register (register 0x21). This gives the SHARC information about which condition and TDC caused the interrupt. The SHARC can write to the register as well, but enabling read-out should only be done during initialisation of the MROD-In. If the read-out is enabled during runtime then the behaviour depends on the values of the read- and write-pointers of the buffer memory partition. Therefore this could result in an immediate assertion of the partition full interrupt, which shuts down the output again. It could also result in a maximum event length interrupt since the relation between the buffer memory partition data and the Tetris

register is lost so the hardware may keep searching for a TDC-Trailer which was overwritten.

## Registers 0x22 (MS0 offset 0x45): Serial Register

Register 0x22 is a read only register. The register is updated with the bits of the Separator word, each time it is recognised in the input data stream (see registers 0x00 to 0x03). Bits that are not used for Separator recognition (see Separator Mask registers 0x01 and 0x03) can be used to transfer data from the CSM to the MROD-In.

Note that the SHARC must poll the content of the Serial Register so this is not a high-speed data channel. The Separator word could typically be used to transfer for example a front-end ID.

## SHARC MS1 address space: Output FIFO

A value from the output FIFO is read when a read cycle on any address in MS1 occurs. Address line A[20] of the SHARC determines the channel to be read (see table 3). Note that reading from an empty output FIFO will return the value of the last word, which was read before the FIFO went empty. Normally this will never occur since the Output FIFO will be readout using DMA, in such a mode that a DMA request is send by the FPGA for each word in the Output FIFO.

## SHARC MS2 address space: Buffer memory Access

For test purposes the SHARC may read or write the buffer memory. When bit 2 of the Test Control Register (Register 0x1B) is '1' then the SHARC gets Read/Write access to the buffer memory. Be careful, this distorts the operation of the output controller of the FPGA; this mode should only be used for debugging purposes!

The SHARC should use "32-bit normal word addressing" on *odd* address (see also figure 7-1 and the note on page 7-3 of the "SHARC DSP Hardware Reference").

It is important to note the difference between the Buffer memory address lines and the SHARC address lines:

Buffer Memory Address = SHARC MS2 Offset \* 2 + 1

The SHARC address lines A[19..1] are re-routed to Buffer Memory address lines A[18..0] while buffer memory address line A[19] is always '0' during an access by the SHARC. The SHARC can only address up to 2 MB of memory instead of the full 4 MB. Note that SHARC address line A[20] is being used to select either Channel A or Channel B.

#### SHARC MS3 address space: Not Used

MS3 address space is not used on the MROD-In board.

## **SHARC Flags:**

Table 6 gives an overview of the SHARC flags.

Flag 0 and Flag 1 must be configured as outputs. These flags control the reset pins of the FPGA of Channel A and B. Note that the reset signal is low active. See also 'Reset Facilities' below.

Note that the core frequency operates at twice the frequency of CLKIN. If a flag output should be active for one external clock cycle then the core should execute a NOP instruction. See also page 11-20 "Flag Outputs" of the ADSP-21160 Hardware Reference.

Flag 2 and 3 must be configured as inputs and are connected to the Empty output of the Event Length FIFOs of the MROD-In Channel A and B respectively.

| Flag Number | Direction | Description                                    |
|-------------|-----------|------------------------------------------------|
| 0           | Output    | FPGA Reset Channel A                           |
| 1           | Output    | FPGA Reset Channel B                           |
| 2           | Input     | Empty status of Event Length FIFO of Channel A |
| 3           | Input     | Empty status of Event Length FIFO of Channel B |

Table 6: SHARC Flags

## **SHARC Interrupt Lines**

The three interrupt lines of the SHARC are shared (wire-or-ed) by the FPGAs of Channel A and Channel B.

IRQ0 is asserted when the I2O\_FIFO is full, a buffer memory partition is full, an event was read-out, which was longer than a pre-programmed maximum, or a TDC (Parity) Error was received (see register 0x17 and 0x18).

IRQ1 is asserted when a Input Link Parity Check Failure occurs or when the Input Link goes down (LDOWN\_n), see register 0x19.

IRQ2 is asserted whenever a TDC-Trailer is received with an Event-ID, which is out of the Expected Event-ID window ('Early' or 'Late', see register 0x1A and table 1).

#### **Reset Facilities**

There are three reset signals: "POR" (Power-On Reset), "SYSRESET\_n" and "Rst\_n". A Power-On Reset or an asserted "SYSRESET\_n" signal resets the SHARC, starts a reconfiguration of the FPGAs and resets the FPGAs (including the Registers, Pipeline, Address Generators, Tetris Register, I2O\_FIFO, Output FIFO. Event Length FIFO etc.). Asserting "Rst\_n" resets the FPGAs (including the Registers, Pipeline, Address Generators, Tetris Register, I2O\_FIFO, Output FIFO. Event Length FIFO etc.) but not the Input Link and the Input Link FIFO (which resides in the FPGA). The "Rst\_n" signals of the two FPGAs can be controlled by the SHARC using flag 0 and 1 respectively.

Note that in all cases, the FPGA enters Freeze mode (See Register 0x1B bit 11). This means that data in the Input Link FIFO is not read into the data pipeline in the FPGA. An Input Link Reset can be generated by taking bit 10 of register 0x1B from '0' to '1'. This resets the Input Link and the Input Link FIFO. The Input Link will force LDOWN\_n low until the initialisation phase of the Input Link is complete. LDOWN\_n will then go high again. The Input Link is now up and running again.

The following sequence should give a proper initialisation. First there will be a Power-Up Reset or a "SYSRESET\_n". After that, the SHARC is booted through link 4. In the mean time garbage data had a chance to enter the Input Link FIFO in the FPGAs. Therefore the SHARC activates flags 0 and/or 1 (Rst\_n for Channel A and/or B). The FPGA(s) are now reset and the data pipeline wakes up in Freeze mode so no data is read from the Input Link FIFO, which might contain garbage. The SHARC resets the Input Link(s) by taking bit 10 of register 0x1B from '0' to '1'. The Input Link is reset and the Input Link FIFO in the FPGA is cleared. The Freeze condition can now be taken away (clear bit 11 of register 0x1B).