## Using the FADC V2 Module

## **<u>1.1</u>** Controlling the Module

Communication with the module is by standard VME bus protocols. All registers and memory locations are defined to be 4-byte entities. The VME slave module has three distinct address ranges.

 $\underline{A24}$  – The base address of this range is set by a 12-element DIP switch on the board. It occupies 4 Kbytes of VME address space, organized in 1 K 32-bit words. Relative to the base address, this space is divided as follows:

000-0FF – Register space to control and monitor the module (64 long words)
100-1FF – ADC processing registers (64 long words)
200-2FF – HITSUM processing registers (64 long words)
300-3FF – SCALER registers (64 long words)

- 400-4FF SYSTEM TEST registers (64 long words)
- 500-FFF Reserved (704 long words)

In addition to registers that are directly mapped to a VME address (Primary Address), the module supports Secondary Addressing in the A24 address space. These registers are accessed through an address mapping register (Secondary Address Register). Each secondary address is associated with a primary address. A Primary Address may have up to 64 K secondary addresses associated with it. A VME cycle loads the mapping register with data which is the internal (secondary) address of the target register. A VME cycle with the associated primary address accesses (read/write) the chosen internal register. Important registers are assigned primary addresses, allowing them to be directly accessible in a single VME cycle. Setup tables are assigned secondary addresses. This allows for a large internal address space, while maintaining a small VME footprint.

<u>A32</u> - The base address of this range is programmed into register ADR32. It occupies 8 Mbytes of VME address space, organized in 2 M 32-bit words. <u>A read of any address in this range will yield the next FADC data word from the module</u>. Even though the module is logically a FIFO, the expanded address range allows the VME master to increment the address during block transfers. This address range can participate in single cycle, 32-bit block, and 64-bit block reads. The only valid write to this address range is the data value 0x8000000 which re-enables the module to generate interrupts (after one has occurred). The address range must be enabled by setting ADR32[0] = 1.

<u>A32</u> - The lower and upper limits of this address range are programmed into register ADR\_MB. This common address range for a set of FADC modules in the crate is used to implement the Multiblock protocol. By means of token passing FADC data may be read out from multiple FADC modules using a single logical block read. <u>The board possessing the token will respond to a read cycle in this address range with the next FADC data word from that module.</u> The token is passed along a private daisy chain line to the next module when it has transferred all data from a programmed number of events (register BLOCK SIZE). The address range must be enabled by setting ADR\_MB[0] = 1.

## **<u>1.3 Module Registers</u>**

VERSION - board/firmware revision (0x0)

[7...0] - (R) -firmware revision

[15...8] - (R) - board revision

[31...16] - (R) - board type ("FADC")

## <u>CSR – Control/Status</u> (0x4)

- 0 (R) Event Accepted
- 1-(R)-Block of Events Accepted
- 2-(R) Block of Events ready for readout
- 3 (R) BERR Status (1 = BERR asserted)
- 4 (R) Token Status (1 = module has token)
- 5 (R) PLL 1 Locked (bits 5-10 not currently implemented)
- 6 (R) PLL 2 Locked
- 7 (R) PLL 3 Locked
- 8 (R) PLL 1 Loss of Lock Occurred
- 9 (R) PLL 2 Loss of Lock Occurred
- 10 (R) PLL 3 Loss of Lock Occurred

- 11 (R) Data FIFO 1 (channels 1 16) Empty Flag Asserted
- 12 (R) Data FIFO 1 (channels 1 16) Almost Empty Flag Asserted
- 13 (R) Data FIFO 1 (channels 1 16) Half Full Flag Asserted
- 14 (R) Data FIFO 1 (channels 1 16) Almost Full Flag Asserted
- 15 (R) Data FIFO 1 (channels 1 16) Full Flag Asserted

#### (bits 16-25 not implemented)

16 - (R) - Data FIFO 2 (channels 9 - 16) Empty Flag Asserted

- 17 (R) Data FIFO 2 (channels 9 16) Almost Empty Flag Asserted
- 18 (R) Data FIFO 2 (channels 9 16) Half Full Flag Asserted
- 19 (R) Data FIFO 2 (channels 9 16) Almost Full Flag Asserted
- 20 (R) Data FIFO 2 (channels 9 16) Full Flag Asserted
- 21 (R) HITSUM FIFO Empty Flag Asserted
- 22 (R) HITSUM FIFO Almost Empty Flag Asserted
- 23 (R) HITSUM FIFO Half Full Flag Asserted
- 24 (R) HITSUM FIFO Almost Full Flag Asserted
- 25 (R) HITSUM FIFO Full Flag Asserted
- 26 (R) Local Bus Time Out target AK or DK timed out (5 us);
- 27 (R/W) Local Bus Error target protocol violation; (write '1' clears latched bits 26, 27)
- 28 (W) Pulse Soft Sync Reset (if CTRL[11] = 1)
- 29 (W) Pulse Soft Trigger ( if CTRL[7] = 1 )
- 30 (W) Pulse Soft Reset
- 31 (W) Pulse Hard Reset

CTRL1 – Control 1 (0x8)

[1...0] - (R/W) - Sampling Clock Source Select

- 0 = Internal Clock
- 1 = Front Panel connector
- 2 = P0 connector (VXS)
- 3 = P0 connector (VXS)

2 - (not used)

3 – (R/W) – Enable Internal Clock

[6...4] - (R/W) - Trigger Source Select

- 0 = Front Panel Connector
  - 1 = Front Panel Connector (synchronized internally)
- 2 = P0 Connector (VXS)
- 3 = P0 Connector (VXS) (synchronized internally)
- 4 (not used)
- 5 (not used)
- 6 = VME (software generated)
- 7 = Module Internal Logic (synchronized internally)
- 7 (R/W) Enable Soft Trigger
- [10...8] (R/W) Sync Reset Source Select
  - 0 = Front Panel Connector
  - 1 = Front Panel Connector (synchronized internally)
  - 2 = P0 Connector (VXS)
  - 3 = P0 Connector (VXS) (synchronized internally)
  - 4 (not used)
  - 5 (not used)
  - 6 = VME (software generated)
  - 7 = no source
- 11 (R/W) Enable Soft Sync Reset
- 12 (R/W) Select Live Internal Trigger to Output
- 13 (R/W) Enable Front Panel Trigger Output
- 14 (R/W) Enable P0 (VXS) Trigger Output

## (bits 15-17 not implemented)

15 – (R/W) – Enable P2 Trigger Output

- 16 (R/W) Enable Readout of ADC channels 1 8
- 17 (R/W) Enable Readout of ADC channels 9 16
- 18 (R/W) Enable Event Level Interrupt
- 19 (R/W) Enable Error Interrupt (not implemented)
- 20 (R/W) Enable BERR response
- 21 (R/W) Enable Multiblock protocol
- 22 (R/W) FIRST board in Multiblock system
- 23 (R/W) LAST board in Multiblock system
- 24 (R/W) Bypass External RAM (not implemented)
- 25 (R/W) Enable Debug Mode
- 26 27 spare
- 28 (R/W) Multiblock Token passed on P0
- 29 (R/W) Multiblock Token passed on P2
- 30 spare
- 31 (R/W) System Test Mode (0 = normal, 1 = test mode enabled)

#### CTRL2 – Control 2 (0xC)

- 0 (R/W) GO (allow data transfer from external FIFOs to input FIFOs)
- 1 (R/W) Enable Trigger to Module (source = CTRL1[6...4])
- 2 (R/W) Enable Sync Reset to Module (source = CTRL1[10...8])
- 3 (R/W) Enable Internal Trigger Logic
- 4 (R/W) Enable Streaming mode (NO event build)
- 5 (R/W) Select data for readout (0 = channels 1 8, 1 = channels 9 16)

6 - 7 - (not used)

8 – (R/W) – Enable Test Event Generation (for debug)

9 - 15 - (not used)

<u>Bits 16 - 31</u> are functional only in Debug Mode (CTRL1[25] = 1)

 $16 - (R/W) - Transfer data: input FIFO \rightarrow build FIFO$  (not implemented)

 $17 - (R/W) - Transfer data: build FIFO \rightarrow output FIFO$ 

30 - (R/W) - Disable external FIFO output (channels 1 - 8) (not implemented)

31 – (R/W) – Disable external FIFO output (channels 9 – 16) (not implemented)

#### BLOCK SIZE (0x10)

[15...0] - (R/W) - number of events in a BLOCK. $Stored Event Count \ge BLOCK SIZE \rightarrow CSR[3] = 1.$ 

[31...16] - (not used)

## INTERRUPT (0x14)

[7...0] - (R/W) - Interrupt ID (vector)

[10...8] - (R/W) - Interrupt Level [2..0]. Valid values = 1,...,7.

11 - 15 - (not used)

[20...16] - (R) - Geographic Address (slot number) in VME64x chassis.

21 - 22 - (not used)

23 – (R) – Parity Error in Geographic Address.

24 - 31 - (not used)

ADR32 – Address for data access (0x18)

0 - (R/W) – Enable 32-bit address decoding

1 - 6 - (not used - read as 0)

[15...7] – (R/W) – Base Address for 32-bit addressing mode (8 Mbyte total)

#### ADR\_MB – Multiblock Address for data access (0x1C)

0 - (R/W) – Enable Multiblock address decoding

1 - 6 - (not used - read as 0)

[15...7] – (R/W) – Lower Limit address (ADR\_MIN) for Multiblock access

16 - 22 - (not used - read as 0)

[31...23] – (R/W) – Upper Limit address (ADR\_MAX) for Multiblock access

The board that has the TOKEN will respond with data when the VME address satisfies the following condition:

 $ADR_MIN \leq Address < ADR_MAX.$ 

<u>SEC\_ADR – Secondary Address</u> (0x20)

[15...0] – (R/W) – Secondary Address for 24-bit addressing mode

16 - (R/W) - Enable auto-increment mode (secondary address increments by 1 after each access of the associated primary address)

<u>DELAY - Trigger/Sync\_Reset Delay</u> (0x24)

[21...16] - (R/W) - Sync reset delay

[5...0] - (R/W) - Trigger delay

#### **INTERNAL TRIGGER CONTROL** (0x28)

[23...16] - (R/W) - trigger width (4 ns per count)

[7...0] - (R/W) - trigger hold off delay (4 ns per count)

#### RESET CONTROL (0x2C)

0 - (W) - Hard reset - Control FPGA

1 – (W) – Hard reset – ADC processing FPGA 1 (channels 1 – 16)

#### (bits 2, 3, 6, 7, 9, 10 not implemented)

- 2 (W) Hard reset ADC processing FPGA 2 (channels 9 16)
- 3 (W) Hard reset HITSUM FPGA
- 4-(W)-Soft reset-Control FPGA
- 5 (W) Soft reset ADC processing FPGA 1 (channels 1 16)
- 6-(W) Soft reset ADC processing FPGA 2 (channels 9-16)
- 7 (W) Soft reset HITSUM FPGA
- 8 (W) Reset ADC data FIFO 1 (channels 1 8)
- 9-(W)-Reset-ADC data FIFO 2 (channels 9 16)
- 10-(W)-Reset-HITSUM FIFO
- 11 (W) Reset DAC (all channels)
- 12 (W) Reset EXTERNAL RAM Read & Write Address Pointers
- 13 31 (not used)

#### TRIGGER COUNT (0x30)

- [31...0] (R) total trigger count
- 31 (W) reset count

#### EVENT COUNT (0x34)

[23...0] - (R) – number of events on board (non-zero  $\rightarrow CSR[0] = 1$ ).

[31...24] - (not used)

## BLOCK COUNT - (0x38)

[31...20] – not used

[19...0] - (R) - number of event BLOCKS on board (non-zero  $\rightarrow CSR[2] = 1$ ).

## <u>BLOCK FIFO COUNT</u> - (0x3C)

- [31...6] not used
- [5...0] (R) number of entries in BLOCK WORD COUNT FIFO

## BLOCK WORD COUNT FIFO – (64 deep FIFO) (0x40)

- [31...25] not used (read as '0')
- 24 (R) count not valid (word count FIFO empty)
- [23...20] not used (read as '0')
- [19...0] (R) number of words in next event BLOCK

## INTERNAL TRIGGER COUNT (0x44)

- [31...0] (R) internal live trigger count
- 31 (W) reset count

## EXTERNAL RAM WORD COUNT (0x48)

- [31...22] not used (read as '0')
- 21 (R) RAM empty
- 20 (R) RAM full (1,048,576 eight byte words)

[19...0] - (R) - data word count (eight byte words)

#### DATA FLOW STATUS (0x4C) (for debug)

#### <u>DAC 1\_2 - DAC channels 1,2</u> (0x50)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16] (R/W) DAC value channel 1
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 2

#### <u>DAC 3\_4 – DAC channels 3,4</u> (0x54)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16]-(R/W) DAC value channel 3
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 4

## <u>DAC 5\_6 - DAC channels 5,6</u> (0x58)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16]-(R/W) DAC value channel 5
- 15 (not used)
- [14...12] (not used read as 0)

[11...0] - (R/W) - DAC value channel 6

#### <u>DAC 7\_8 - DAC channels 7,8</u> (0x5C)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16]-(R/W) DAC value channel 7
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 8

#### $\underline{DAC 9}_{10} - \underline{DAC channels 9}_{10}$ (0x60)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16]-(R/W) DAC value channel 9
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 10

#### <u>DAC 11\_12 - DAC channels 11,12</u> (0x64)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16]– (R/W) DAC value channel 11
- 15 (not used)
- [14...12] (not used read as 0)

## [11...0] - (R/W) - DAC value channel 12

#### $\underline{DAC 13}_{14} - \underline{DAC channels 13,14}$ (0x68)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...18]-(R/W) DAC value channel 13
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 14

#### $\underline{DAC 15}_{16} - \underline{DAC channels 15, 16}$ (0x6C)

- 31 (not used)
- [30...28] (not used read as 0)
- [27...16] (R/W) DAC value channel 15
- 15 (not used)
- [14...12] (not used read as 0)
- [11...0] (R/W) DAC value channel 16

#### <u>STATUS 1 – Input Buffer Status</u> (0x70)

- 31 (R) data buffer (channel 1 16) ready for input
- 30 (R) data buffer (channel 1 16) input paused
- 29 (R) not used (read as '0')
- 28 (R) data buffer (channel 1 16) empty
- 27 (R) data buffer (channel 1 16) full

[26...16] - (R) - data buffer (channel 1 - 16) word count

#### (bits 15-0 not implemented)

- 15 (R) data buffer (channel 9 16) ready for input
- 14 (R) data buffer (channel 9 16) input paused
- 13 (R) not used (read as '0')
- 12 (R) data buffer (channel 9 16) empty
- 11 (R) data buffer (channel 9 16) full
- [10...0] (R) data buffer (channel 9 16) word count

#### <u>STATUS 2 – Build Buffer Status</u> (0x74)

- [31...29] not used (read as '0')
- 28 (R) data buffer 'A' empty
- 27 (R) data buffer 'A' full
- [26...16] (R) data buffer 'A' word count
- [15...13] not used (read as '0')
- 12 (R) data buffer 'B' empty
- 11 (R) data buffer 'B' full
- [10...0] (R) data buffer 'B' word count

#### <u>STATUS 3 – Output Buffer Status</u> (0x78)

- [31...30] not used (read as '0')
- 29 (R) data buffer 'A' empty
- 28 (R) data buffer 'A' full

[27...16] - (R) - data buffer 'A' word count

[15...14] – not used (read as '0')

13 - (R) - data buffer 'B' empty

12 - (R) - data buffer 'B' full

[11...0] - (R) - data buffer 'B' word count

<u>STATUS 4 – (spare)</u> (0x7C)

[31...0] – reserved

<u>AUXILIARY 1 – (spare)</u> (0x80)

[31...0] – reserved

AUXILIARY 2 – (spare) (0x84)

[31...0] – reserved

AUXILIARY 3 – (spare) (0x88)

[31...0] – reserved

(AUXILIARY 4 - (spare) has been deleted) (7/12/11)

(The RAM is organized as two 36-bit words with a common address. Auxiliary VME access (R/W) to the RAM is provided through a pair of 32 bit data registers (RAM 1, RAM 2). Note that bits 35 - 32 of each RAM word are not accessible through VME. During data flow operations, these bits carry event marker tags (header, trailer).)

RAM Address Register (0x8C)

(7/12/11)

31 - increment address after access (R/W) of RAM 1 Data Register

30 – increment address after access (R/W) of RAM 2 Data Register

[29...21] – not used (read as 0)

[19...0] - RAM address

| RAM 1 Data Register          | (0x90)  | (7/12/11)   |
|------------------------------|---------|-------------|
| <u>Iumi i Ducu itegistei</u> | (011)0) | (,, 12, 11) |

[31...0] - RAM data word bits 67 – 36 (32 bits)

<u>RAM 2 Data Register</u> (0x94) (7/12/11)

[31...0] – RAM data word bits 31 - 0 (32 bits)

(PROM Registers 1 and 2 are used for FPGA configuration over VME.)

<u>PROM Register 1</u> (0x98) (7/12/11)

31 – READY – (R) – configuration state machine is available to accept command (i.e. no configuration process is currently executing).

[30...8] – reserved (read as 0)

[7...0] – configuration OPCODE

| PROM Register 2 | (0x9C) |
|-----------------|--------|
|-----------------|--------|

(7/12/11)

[31...0] - PROM ID - (R) response to specific OPCODE write to PROM reg 1.

## BERR Module Count (0xA0)

[31...0] – BERR count (driven by module to terminate data transmission)

BERR Total Count (0xA4)

[31...0] – BERR count (as detected on bus)

Auxiliary Scaler 1 (0xA8)

[31...0] – Total word count FPGA 1 (channel 1-16)

Auxiliary Scaler 2 (0xAC)

[31...0] – Total word count FPGA 2 (channel 9-16) (not implemented)

Auxiliary Scaler 3 (0xB0)

[31...0] – Event header word count FPGA 1 (channel 1-16)

#### Auxiliary Scaler 4 (0xB4)

[31...0] – Event header word count FPGA 2 (channel 9-16) (not implemented)

#### Auxiliary Scaler 5 (0xB8)

[31...0] – Event trailer word count FPGA 1 (channel 1-16)

## Auxiliary Scaler 6 (0xBC)

[31...0] – Event trailer word count FPGA 2 (channel 9-16)) (not implemented)

## Module Busy Level (0xC0)

[31] – Force module busy

- [30...20] reserved
- [19...0] Busy level (eight byte words)(External RAM word count > Busy level  $\rightarrow$  module busy = 1)

Generate Event Header Word (0xC4) (for debug)

[31-0] – Event Header Word

Generate Event Data Word (0xC8) (for debug)

[31-0] – Event Data Word

Generate Event Trailer Word (0xCC) (for debug)

[31-0] – Event Trailer Word

## MGT STATUS (0xD0)

- 0 (R) lane 1 up (GTX1)
- 1 (R) lane 2 up (GTX1)
- 2 (R) channel up (GTX1)
- 3 (R) hard error (GTX1)
- 4 (R) soft error (GTX1)
- 5 (R) lane 1 up (GTX2)
- 6 (R) lane 2 up (GTX2)
- 7 (R) channel up (GTX2)
- 8 (R) hard error (GTX2)
- 9 (R) soft error (GTX2)
- 10 (R) SUM DATA VALID
- 11 (R) MGT RESET ASSERTED
- [31-12] (R) Reserved

#### MGT CONTROL (0xD4)

#### 0 – **RELEASE MGT RESET** (0 = reset MGT, 1 = release reset)

[31-1] – Reserved

<u>**RESERVED** (2 registers)</u> (0xD8 - 0xDC)

#### SCALER CONTROL (0xE0)

0 - (R/W) – Enable all scalers to count (1 = enable, 0 = disable)

- 1 (W) Latch all scalers. Write '1' to simultaneously transfer all 17 scaler counts to registers for readout.
- 2 (W) Reset all scalers. Write '1' to simultaneously reset all 17 scaler counts to zero.
- [3-31] (reserved)

<u>SPARE (7 registers)</u> (0xE4 - 0xFC)

\_\_\_\_\_

<u>SCALER Registers</u> (0x300 - 0x340) (R)

SCALER[0] - (0x300) - input channel 0 count

SCALER[1] - (0x304) - input channel 1 count

SCALER[2] – (0x308) - input channel 2 count

SCALER[3] - (0x30C) - input channel 3 count

SCALER[4] - (0x310) - input channel 4 count

SCALER[5] - (0x314) - input channel 5 count

SCALER[6] - (0x318) - input channel 6 count

SCALER[7] - (0x31C) - input channel 7 count

SCALER[8] - (0x320) - input channel 8 count

SCALER[9] - (0x324) - input channel 9 count

SCALER[10] - (0x328) - input channel 10 count

SCALER[11] - (0x32C) - input channel 11 count

SCALER[12] - (0x330) - input channel 12 count

SCALER[13] - (0x334) - input channel 13 count

SCALER[14] - (0x338) - input channel 14 count

SCALER[15] - (0x33C) - input channel 15 count

TIME COUNT – (0x340) - timer (each count represents 2048 ns)

#### System Test Registers (0x400 – 0x410)

#### TEST BIT REGISTER (0x400)

- $0 (R/W) trigger_out_p0$  (1 = asserted, 0 = not asserted)
- $1 (R/W) busy_out_p0$  (1 = asserted, 0 = not asserted)
- $2 (R/W) sdlink_out_p0$  (1 = asserted, 0 = not asserted)
- $3 (R/W) token_out_p0$  (1 = asserted, 0 = not asserted)
- [4-7] (R/W) spare out test bits
- $8 (R) \text{status}_b_{in}p0$  state (1 = asserted, 0 = not asserted)
- $9 (R) token_in_p0$  state (1 = asserted, 0 = not asserted)
- [10 14] (R) reserved (read as '0')
- $15 (R) clock_{250}$  counter status (1 = counting, 0 = not counting)
- [16 31] (R) reserved (read as '0')

#### CLOCK\_250 COUNT REGISTER (0x404)

- 0 (W) Write '0' resets the counter. Write '1' initiates 20us counting interval.
- $[31 0] (R) CLK_{250}$  counter value. (Should be 5000 after count interval.)

#### <u>SYNC\_IN\_P0 COUNT REGISTER</u> (0x408)

- 0 (W) Write '0' resets the counter.
- $[31 0] (R) SYNC_{IN_P0}$  counter value.

## TRIG1\_IN\_P0 COUNT REGISTER (0x40C)

0 - (W) - Write '0' resets the counter.

 $[31 - 0] - (R) - TRIG1_IN_P0$  counter value.

## TRIG2\_IN\_P0 COUNT REGISTER (0x410)

0 - (W) - Write '0' resets the counter.

 $[31 - 0] - (R) - TRIG2_IN_P0$  counter value.

# ADC PROCESSING FPGA ADDRESS MAP: Control Bus Memory Map for FADC FPGA

| Control Bus Memory N         | 1               |              |        |                                 |                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------|-----------------|--------------|--------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name [VME ADDRESS]           | Width<br>(Bits) | Quant<br>ity | Access | Primary<br>Address<br>(Secondar | Function                                                                                                                                                                                                                                                                                                                                               |
|                              |                 |              |        | y<br>Address)                   |                                                                                                                                                                                                                                                                                                                                                        |
| STATUS0<br>[ <b>0x100</b> ]  | 16              | 1            | R      | 0x0000<br>()                    | Bits 14 to 0: Code<br>Version<br>Bit 15: 1= Command<br>can be sent to AD9230                                                                                                                                                                                                                                                                           |
| STATUS1<br>[ <b>0x104</b> ]  | 16              | 1            | R      | 0x0001<br>()                    | TRIGGER NUMBER<br>BIT 15 to 0                                                                                                                                                                                                                                                                                                                          |
| STATUS2<br>[0x108]           | 16              | 1            | R      | 0x0002<br>()                    | Tbd. Read 0                                                                                                                                                                                                                                                                                                                                            |
| CONFIG 1<br>[0x10C]          | 16              | 1            | R/W    | 0x0003<br>()                    | Bit 0-2 (process mode):<br>000 → Select option1<br>001 → Select option2<br>010 → Select option3<br>011 → Select option4<br>111 → Run option1<br>then option4 for each<br>trigger<br>Bit 3: 1:Run<br>Bit 6-5 : Number of<br>Pulses in Mode 1 and 2<br>Bit 7: Test Mode (play<br>Back).                                                                  |
| CONFIG 2<br>[ <b>0x110</b> ] |                 |              | R/W    | 0x0004<br>()                    | When 1 ADC values = 0<br>Bit $0 \rightarrow ADC 0$<br>Bit $1 \rightarrow ADC 1$<br>Bit $2 \rightarrow ADC 2$<br>Bit $3 \rightarrow ADC 3$<br>Bit $4 \rightarrow ADC 4$<br>Bit $5 \rightarrow ADC 5$<br>Bit $6 \rightarrow ADC 6$<br>Bit $7 \rightarrow ADC 7$<br>Bit $8 \rightarrow ADC 8$<br>Bit $9 \rightarrow ADC 9$<br>Bit $10 \rightarrow ADC 10$ |

|          | -  | - | 1   |            |                                      |
|----------|----|---|-----|------------|--------------------------------------|
|          |    |   |     |            | Bit $11 \rightarrow ADC 11$          |
|          |    |   |     |            | Bit $12 \rightarrow ADC 12$          |
|          |    |   |     |            | Bit $13 \rightarrow ADC 13$          |
|          |    |   |     |            | Bit $14 \rightarrow ADC 14$          |
|          |    |   |     |            | Bit $15 \rightarrow ADC 15$          |
|          |    |   |     |            |                                      |
| CONFIG 4 | 16 | 1 |     | 0x0005     | $7 \Rightarrow$ rising edge write to |
| [0x114]  |    |   |     | ()         | AD9230 ADC                           |
|          |    |   |     |            | $6 \Rightarrow 1$ write to all ADC.  |
|          |    |   |     |            | Bits 30 are don't care               |
|          |    |   |     |            | $5 \Rightarrow 0$ write to AD9230    |
|          |    |   |     |            | 1 read from                          |
|          |    |   |     |            | AD9230                               |
|          |    |   |     |            | $30 \Rightarrow$ Select ADC to       |
|          |    |   |     |            | write to                             |
| CONFIG 5 | 16 | 1 |     | 0x0006     | $158 \Rightarrow$ Registers inside   |
| [0x118]  | 10 | 1 |     | ()         | AD9230                               |
| [ouro]   |    |   |     |            | $7.0 \Rightarrow$ Data to write to   |
|          |    |   |     |            | register.                            |
| PTW      | 9  | 1 | R/W | 0x0007     | Number of ADC sample                 |
| [0x11C]  |    | - |     | ()         | to include in trigger                |
| [ouro]   |    |   |     | × ,        | window.                              |
|          |    |   |     |            | PTW = Trigger Window                 |
|          |    |   |     |            | (ns) * 250  MHz.                     |
|          |    |   |     |            | Minimum is 6.                        |
|          |    |   |     |            | Always report Even                   |
|          |    |   |     |            | Number. For odd PTW                  |
|          |    |   |     |            | number, discard the                  |
|          |    |   |     |            | last sample reported.                |
| PL       | 11 | 1 |     | 0x0008     | Number of sample back                |
| [0x120]  |    | 1 |     | ()         | from trigger point.                  |
|          |    |   |     | <b>、</b> , | PL = Trigger                         |
|          |    |   |     |            | Window(ns) * 250MHz                  |
| NSB      | 12 | 1 |     | 0x0009     | Number of sample                     |
| [0x124]  | 12 | 1 |     | ()         | before trigger point to              |
|          |    |   |     |            | include in data                      |
|          |    |   |     |            | processing. This include             |
|          |    |   |     |            | the trigger Point.                   |
|          |    |   |     |            | Minimum is 2 in all                  |
|          |    |   |     |            | mode.                                |
| NSA      | 13 | 1 | 1   | 0x000A     | Number of sample after               |
| [0x128]  |    |   |     | ()         | trigger point to include             |
|          |    |   |     |            | in data processing.                  |
|          |    |   |     |            | Minimum is (6 in mode                |
|          |    |   |     |            | 2)and (3 in mode 0                   |
|          |    |   |     |            | and 1). Number of                    |
| 1        | 1  |   |     | 1          | and 1). INUMBER OF                   |

|                                                                                       |    |    |     |                          | sample report is 1<br>more for odd and 2<br>more for even NSA<br>number.                                                |
|---------------------------------------------------------------------------------------|----|----|-----|--------------------------|-------------------------------------------------------------------------------------------------------------------------|
| TET<br>[ <b>0x12C – 0x148</b> ]<br>(2 channels per word)<br>(see <b>Note 1</b> below) | 12 | 16 |     | 0x000B -<br>0x001A<br>() | Trigger Energy<br>Threshold.                                                                                            |
| PTW DAT BUF<br>LAST ADR<br>[ <b>0x14C</b> ]                                           | 12 | 1  |     | 0x001B<br>()             | Last Address of the<br>Secondary Buffer. See<br>calculation below                                                       |
| PTW MAX BUF<br>[ <b>0x150</b> ]                                                       | 8  | 1  |     | 0x001C<br>()             | The maximum number<br>of unprocessed PTW<br>blocks that can be stored<br>in Secondary Buffer.<br>See Calculation below. |
| Test Wave Form [0x154]                                                                | 16 | 1  |     | 0x001D<br>()             | Write to PPG. Read<br>should immediately<br>follow write.                                                               |
| ADC0 Pedestal<br>Subtract<br>[0x158]                                                  | 16 | 1  | R/W | 0x001E                   | Subtract from ADC0<br>Count before Summing                                                                              |
| ADC1 Pedestal<br>Subtract<br>[0x15C]                                                  | 16 | 1  | R/W | 0x001F                   | Subtract from ADC1<br>Count before Summing                                                                              |
| ADC2 Pedestal<br>Subtract<br>[0x160]                                                  | 16 | 1  | R/W | 0x0020                   | Subtract from ADC2<br>Count before Summing                                                                              |
| ADC3 Pedestal<br>Subtract<br>[0x164]                                                  | 16 | 1  | R/W | 0x0021                   | Subtract from ADC3<br>Count before Summing                                                                              |
| ADC4 Pedestal<br>Subtract<br>[ <b>0x168</b> ]                                         | 16 | 1  | R/W | 0x0022                   | Subtract from ADC4<br>Count before Summing                                                                              |
| ADC5 Pedestal<br>Subtract<br>[0x16C]                                                  | 16 | 1  | R/W | 0x0023                   | Subtract from ADC5<br>Count before Summing                                                                              |
| ADC6 Pedestal<br>Subtract<br>[0x170]                                                  | 16 | 1  | R/W | 0x0024                   | Subtract from ADC6<br>Count before Summing                                                                              |
| ADC7 Pedestal<br>Subtract<br>[0x174]                                                  | 16 | 1  | R/W | 0x0025                   | Subtract from ADC7<br>Count before Summing                                                                              |

| ADC8 Pedestal  | 16 | 1 | R/W | 0x0026 | Subtract from ADC8   |
|----------------|----|---|-----|--------|----------------------|
| Subtract       |    |   |     |        | Count before Summing |
| [0x178]        |    |   |     |        |                      |
| ADC9 Pedestal  | 16 | 1 | R/W | 0x0027 | Subtract from ADC9   |
| Subtract       |    |   |     |        | Count before Summing |
| [0x17C]        |    |   |     |        |                      |
| ADC10 Pedestal | 16 | 1 | R/W | 0x0028 | Subtract from ADC10  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x180]        |    |   |     |        |                      |
| ADC11 Pedestal | 16 | 1 | R/W | 0x0029 | Subtract from ADC11  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x184]        |    |   |     |        |                      |
| ADC12 Pedestal | 16 | 1 | R/W | 0x002A | Subtract from ADC12  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x188]        |    |   |     |        |                      |
| ADC13 Pedestal | 16 | 1 | R/W | 0x002B | Subtract from ADC13  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x18C]        |    |   |     |        |                      |
| ADC14 Pedestal | 16 | 1 | R/W | 0x002C | Subtract from ADC14  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x190]        |    |   |     |        |                      |
| ADC15 Pedestal | 16 | 1 | R/W | 0x002D | Subtract from ADC15  |
| Subtract       |    |   |     |        | Count before Summing |
| [0x194]        |    |   |     |        |                      |

PTW MAX BUF = INT(2016 / (PTW + 8) \* 25000000)

Where:

2016  $\rightarrow$  Number of address of Secondary Buffer

PTW  $\rightarrow$  Trigger Window width in nano-second

PTW DAT BUF LAST ADR = PTW MAX BUF \* (PTW + 6)-1;

Where:

6  $\rightarrow$  4 address for Time Stamp and 2 address for Trigger Number NumberOfBytePerTrigger  $\rightarrow$  PTW \* 250 MHz.

## NOTE 1: Trigger Energy Threshold (TET) 0x12C – Channel 1 & Channel 2

- [31...28] not used
- [27...16] channel 1 threshold
- [15...12] not used
- [27...16] channel 2 threshold

## 0x130 – Channel 3 & Channel 4

- [31...28] not used
- [27...16] channel 3 threshold
- [15...12] not used
- [27...16] channel 4 threshold
- .....

## 0x148 – Channel 15 & Channel 16

- [31...28] not used
- [27...16] channel 15 threshold
- [15...12] not used
- [27...16] channel 16 threshold

# Appendix 1 – Register structure for FADC V2 (6/20/12)

| <pre>struct fadc struct {</pre> |                                  |            |          |         |      |      |    |
|---------------------------------|----------------------------------|------------|----------|---------|------|------|----|
| —                               | version;                         | /*         | (0x000 · | - 0x0FC | C) - | CTRL | */ |
| long                            |                                  |            |          |         |      |      |    |
|                                 | ctrl1;                           |            |          |         |      |      |    |
| -                               | ctrl2;                           |            |          |         |      |      |    |
| 2                               |                                  | /*         | 0x010 *  | /       |      |      |    |
| -                               | intr;                            |            |          |         |      |      |    |
|                                 | adr32;                           |            |          |         |      |      |    |
| -                               | adr mb;                          |            |          |         |      |      |    |
|                                 |                                  | /*         | 0x020 *  | /       |      |      |    |
|                                 | delay;                           |            |          |         |      |      |    |
| 2                               | trig cfg;                        |            |          |         |      |      |    |
|                                 | reset;                           |            |          |         |      |      |    |
|                                 | trig count;                      | /*         | 0x030 *  | /       |      |      |    |
|                                 | ev count;                        |            |          |         |      |      |    |
| -                               | blk count;                       |            |          |         |      |      |    |
|                                 | blk fifo count;                  |            |          |         |      |      |    |
|                                 | blk_wrd_count;                   | /*         | 0x040 *  | /       |      |      |    |
|                                 | trig live count;                 |            |          |         |      |      |    |
|                                 | mem wrd count;                   |            |          |         |      |      |    |
|                                 | flow status;                     |            |          |         |      |      |    |
| long                            | dac1 <sup>2</sup> ;              | /*         | 0x050 *  | /       |      |      |    |
| long                            | dac3_4;                          |            |          |         |      |      |    |
| long                            | dac5_6;                          |            |          |         |      |      |    |
| long                            | dac7_8;                          |            |          |         |      |      |    |
|                                 |                                  | /*         | 0x060 *  | /       |      |      |    |
|                                 | dac11_12;                        |            |          |         |      |      |    |
|                                 | dac13_14;                        |            |          |         |      |      |    |
|                                 | dac15_16;                        |            |          |         |      |      |    |
| -                               | ,                                | /*         | 0x070 *  | /       |      |      |    |
|                                 | status2;                         |            |          |         |      |      |    |
| -                               | status3;                         |            |          |         |      |      |    |
|                                 | status_in;                       | <i>.</i> . |          | ,       |      |      |    |
| -                               |                                  | /*         | 0x080 *. | /       |      |      |    |
|                                 | aux2;                            |            |          |         |      |      |    |
| -                               | aux3;                            |            |          |         |      |      |    |
|                                 | <pre>mem_adr; mem_l_data.</pre>  | /+         | 0000 +   | /       |      |      |    |
| -                               | <pre>mem1_data; mem2 data;</pre> | / ^        | 0x090 *  | ,<br>,  |      |      |    |
|                                 | prom reg1;                       |            |          |         |      |      |    |
|                                 | prom reg2;                       |            |          |         |      |      |    |
|                                 | berr count;                      | /*         | ∩~∩⊼∩ *  | /       |      |      |    |
|                                 | berr in count;                   |            |          |         |      |      |    |
|                                 | <pre>scaler_aux[6];</pre>        |            |          |         | * /  |      |    |
|                                 | busy level;                      | /*         | 0x0C0 *  | /       | /    |      |    |
|                                 |                                  |            | 0x0C4 *  |         |      |      |    |
|                                 | gen evt data;                    |            |          |         |      |      |    |
| -                               | <pre>gen evt trail;</pre>        |            |          |         |      |      |    |
|                                 | status mgt;                      |            |          |         |      |      |    |
|                                 | control mgt;                     |            |          |         |      |      |    |
| -                               | reserved_ctrl[2];                |            |          |         |      |      |    |
| long                            | <pre>scaler_ctrl;</pre>          |            |          |         |      |      |    |
| long                            | <pre>spare_ctrl[7];</pre>        | /*         | 0x0E4 -  | 0x0FC   | */   |      |    |
|                                 |                                  |            |          |         |      |      |    |

```
/* ADC processing */
long adc status0;
                        /* (0x100-1FC) */
long adc status1;
long adc status2;
long adc config1;
long adc config2;
long adc config4;
long adc_config5;
long adc_ptw;
long adc pl;
long adc nsb;
long adc_nsa;
long adc thres[8];
long adc ptw last;
long adc ptw max;
long adc test wave;
long adc pedestal[16]; /* 9/1/11 */
long spare adc[26];
                       /* 9/1/11 */
                        /* HITSUM processing */
                        /* (0x200 - 0x2FC) */
long hitsum status;
long hitsum cfg;
                        /* 2^{nd} addr (0x0 - 0xF) */
long hitsum width;
long hitsum delay;
long hitsum trig width;
long hitsum trig bits;
long hitsum window width;
long hitsum overlap bits;
long hitsum_pattern; /* 2<sup>nd</sup> addr(0x0 - 0x10000) */
long hitsum_fifo;
long hitsum sum thres;
long spare hitsum[53];
                  /* (0x300 - 0x3FC) - scalers */
long scaler[16];
long time count;
long spare scaler[47];
                    /* (0x400 - 0x4FC) - test1 */
long testbit;
long count 250;
long count sync;
long count trig1;
long count_trig2;
long spare test1[59];
```

};