



# CALOCUBE T+ROC1 USER MANUAL

G. Martínez, J. Marín, J. Casaus. CIEMAT.

October, 2019. Firmware version v1806.

# 1. INTRODUCTION

This document contains a description of Calocube T+ROC1 firmware and it is intend to be use as a user manual.

# 2. FIRMWARE ARCHITECTURE BLOCK DIAGRAM



Figure 1 T+ROC1 firmware block diagram.

# 3. USB PROTOCOL

TROC1 uses FTDI chip FT2232H for USB Communication with a computer. This chip implements a bridge between the USB side and the FPGA side. The communication between the chip and the FPGA is base in an 8-bit wide parallel bus running at 60MHz. The software in the computer uses high-level functions in order to make USB accesses.



The FPGA implements a protocol in order to access properly to internal registers and memory. This protocol is implement in USB CTRL module (Fig. 1). The protocol is base in a header of 4 bytes in every write access; these bytes contain the base address, the number of bytes to be write or read and the Read/write bit. The format is show in table 1.

| Base address(70) Less Significant Byte |                                         |  |
|----------------------------------------|-----------------------------------------|--|
| RD(1)/WR(0)                            | Base address(148) Most Significant Bits |  |
|                                        | Number of bytes to be $RD/WR(70)$       |  |
|                                        | Number of Bytes to be RD/WR(158)        |  |

Table 1 Communication protocol command format

In order to make a write access (write from the PC into the FPGA), a FT Write function is executed containing the 4 control bytes followed by the bytes that should be written. An example is show in table 2:

|    | 0x00   |  |  |  |  |  |
|----|--------|--|--|--|--|--|
| b0 | 0x01   |  |  |  |  |  |
|    | 0x04   |  |  |  |  |  |
|    | 0x00   |  |  |  |  |  |
|    | Byte 0 |  |  |  |  |  |
|    | Byte 1 |  |  |  |  |  |
|    | Byte 2 |  |  |  |  |  |
|    | Byte 3 |  |  |  |  |  |

Table 2 Writing 4 bytes in base address 0x0100

In order to make a read access (read bytes from the FPGA), a FT Write function is executed containing the 4 control bytes. Then, a FT Read function is execute in order to get the bytes requested. An example is show in table 3.

|    | 0x00 |
|----|------|
| b1 | 0x41 |
|    | 0x04 |
|    | 0x00 |

Table 3 Reading 4 bytes from address 0x4100

# 4. REGISTER AND MEMORY MAP

| Address | RD/WR | Туре | Description                                 |
|---------|-------|------|---------------------------------------------|
| 0x00    | RD/WR | REG  | Data taking enable and test trigger control |
| 0x01    | RD/WR | REG  | Configuration TX enable                     |
| 0x02    | RD/WR | REG  | Reset (FIFOs, counters)                     |
| 0x03    | RD/WR | REG  | Test trigger period                         |
| 0x04    | RD/WR | REG  | Test trigger period                         |
| 0x05    | RD/WR | REG  | Hidra mask                                  |
| 0x06    | RD/WR | REG  | Hidra mask                                  |
| 0x07    | RD/WR | REG  | Hidra mask                                  |
| 0x08    | RD/WR | REG  | Hidra mask                                  |
| 0x09    | RD/WR | REG  | Random generator control                    |
| 0x0A    | RD/WR | REG  | Random generator control                    |





| 0x0B         | <b>RD/WR</b> | REG        | Maximum number of events in input buffer                                      |
|--------------|--------------|------------|-------------------------------------------------------------------------------|
| 0x0C         | RD/WR        | REG        | Maximum number of events written in output buffer, lower byte                 |
|              |              |            | (Burst number)                                                                |
| 0x0D         | RD/WR        | REG        | Maximum number of events written in output buffer, higher byte                |
|              |              |            | (Burst number)                                                                |
| 0x0E         | WR           | REG        | Reset of max. events in output buffer (Burst reset)                           |
| 0.00         |              | DEG        |                                                                               |
| 0x20         | RD           | REG        | Firmware version LSB                                                          |
| 0x21         | RD           | REG        | Firmware version MSB                                                          |
| 0x22         | RD           | REG        | Configuration TX FIFO FULL                                                    |
| 0x23         | RD           | REG        | Configuration TX FIFO EMPTY                                                   |
| 0x24         | RD           | REG        | Configuration RX FIFO FULL                                                    |
| 0x25         | RD           | REG        | Configuration RX FIFO EMPTY                                                   |
| 0x26         | RD           | REG        | TX Data count Bits 70, WR CLK                                                 |
| 0x27         | RD           | REG        | TX Data count Bits 158, WR CLK                                                |
| 0x28         | RD           | REG        | TX Data count Bits 70, RD CLK                                                 |
| 0x29         | RD           | REG        | TX Data count Bits 158, RD CLK                                                |
| 0x2A         | RD           | REG        | RX Link 0 Data count Bits 70, WR CLK                                          |
| 0x2B         | RD           | REG        | RX Link 0 Data count Bits 158, WR CLK                                         |
| 0x2C         | RD           | REG        | RX Link 0 Data count Bits 70, RD CLK                                          |
| 0x2D         | RD           | REG        | RX Link 0 Data count Bits 158, RD CLK                                         |
| 0x2E         | RD           | REG        | RX Link 1 Data count Bits 70, WR CLK                                          |
| 0x2F         | RD           | REG        | RX Link 1 Data count Bits 158, WR CLK                                         |
| 0x30         | RD           | REG        | RX Link 1 Data count Bits 70, RD CLK                                          |
| 0x31         | RD           | REG        | RX Link 1 Data count Bits 158, RD CLK                                         |
| 0x32<br>0x33 | RD           | REG        | RX Link 2 Data count Bits 70, WR CLK                                          |
| 0x33<br>0x34 | RD           | REG<br>REG | RX Link 2 Data count Bits 158, WR CLK                                         |
|              | RD           |            | RX Link 2 Data count Bits 70, RD CLK                                          |
| 0x35<br>0x36 | RD<br>RD     | REG<br>REG | RX Link 2 Data count Bits 158, RD CLK                                         |
| 0x30<br>0x37 | RD           |            | RX Link 3 Data count Bits 70, WR CLK                                          |
|              |              | REG        | RX Link 3 Data count Bits 158, WR CLK                                         |
| 0x38<br>0x39 | RD           | REG        | RX Link 3 Data count Bits 70, RD CLK                                          |
| 0x39<br>0x3A | RD           | REG        | RX Link 3 Data count Bits 158, RD CLK                                         |
|              | RD           | REG<br>REG | RX Link 4 Data count Bits 70, WR CLK                                          |
| 0x3B<br>0x3C | RD           |            | RX Link 4 Data count Bits 158, WR CLK                                         |
|              | RD           | REG        | RX Link 4 Data count Bits 70, RD CLK<br>RX Link 4 Data count Bits 158, RD CLK |
| 0x3D<br>0x3E | RD<br>RD     | REG<br>REG | RX Link 5 Data count Bits 70, WR CLK                                          |
| 0x3E<br>0x3F | RD           | REG        | RX Link 5 Data count Bits 70, WK CLK<br>RX Link 5 Data count Bits 158, WR CLK |
| 0x3r<br>0x40 | RD           | REG        | RX Link 5 Data count Bits 150, WK CLK                                         |
| 0x40<br>0x41 | RD           | REG        | RX Link 5 Data count Bits 70, RD CLK                                          |
| 0x41<br>0x42 |              |            | · · · · · · · · · · · · · · · · · · ·                                         |
| 0x42<br>0x43 | RD<br>RD     | REG<br>REG | RX Link 6 Data count Bits 70, WR CLK<br>RX Link 6 Data count Bits 158, WR CLK |
| 0x43<br>0x44 | RD           | REG        | RX Link 6 Data count Bits 750, RD CLK                                         |
| 0x44<br>0x45 | RD           | REG        | RX Link 6 Data count Bits 70, RD CLK<br>RX Link 6 Data count Bits 158, RD CLK |
| 0x45<br>0x46 | RD           | REG        | RX Link 7 Data count Bits 70, WR CLK                                          |
| 0x40<br>0x47 | RD           | REG        | RX Link 7 Data count Bits 70, WK CLK<br>RX Link 7 Data count Bits 158, WR CLK |
| 0x47<br>0x48 | RD           | REG        | RX Link 7 Data count Bits 158, WR CLK<br>RX Link 7 Data count Bits 70, RD CLK |
| 0x48<br>0x49 | RD<br>RD     |            | RX Link / Data count Bits 70, RD CLK<br>RX Link 7 Data count Bits 158, RD CLK |
|              |              | REG        |                                                                               |
| 0x4A<br>0x4B | RD<br>PD     | REG        | Occupancy<br>Event buffer data count                                          |
| 0x4B         | RD<br>PD     | REG        | Event buffer data count<br>Event buffer data count                            |
| 0x4C         | RD           | REG        | Event puller data coult                                                       |



| 100WRMEMConfiguration TX FIFO4100RDMEMConfiguration RX Link 0 FIFO4900RDMEMConfiguration RX Link 1 FIFO5100RDMEMConfiguration RX Link 2 FIFO5900RDMEMConfiguration RX Link 3 FIFO5100RDMEMConfiguration RX Link 3 FIFO5900RDMEMConfiguration RX Link 4 FIFO5900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO         | FF RI  |               | REG | Configuration TV links anables      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|-----|-------------------------------------|
| #100RDMEMConfiguration RX Link 0 FIFO#900RDMEMConfiguration RX Link 1 FIFO5100RDMEMConfiguration RX Link 2 FIFO5900RDMEMConfiguration RX Link 3 FIFO5100RDMEMConfiguration RX Link 3 FIFO5000RDMEMConfiguration RX Link 4 FIFO5000RDMEMConfiguration RX Link 5 FIFO5000RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO | ILL KI | <i>)/ W</i> K | KEG | Configuration TX links enables      |
| 1900RDMEMConfiguration RX Link 1 FIFO5100RDMEMConfiguration RX Link 2 FIFO5900RDMEMConfiguration RX Link 3 FIFO5100RDMEMConfiguration RX Link 4 FIFO5000RDMEMConfiguration RX Link 5 FIFO5900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO                                                                           | 100    | WR            | MEM | Configuration TX FIFO               |
| 5100RDMEMConfiguration RX Link 2 FIFO5900RDMEMConfiguration RX Link 3 FIFO5100RDMEMConfiguration RX Link 4 FIFO5900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO                                                                                                                                                     | 4100   | RD            | MEM | Configuration RX Link 0 FIFO        |
| 5900RDMEMConfiguration RX Link 3 FIFO5100RDMEMConfiguration RX Link 4 FIFO5900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO                                                                                                                                                                                          | 1900   | RD            | MEM | <b>Configuration RX Link 1 FIFO</b> |
| 6100RDMEMConfiguration RX Link 4 FIFO6900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO                                                                                                                                                                                                                               | 5100   | RD            | MEM | <b>Configuration RX Link 2 FIFO</b> |
| 6900RDMEMConfiguration RX Link 5 FIFO7100RDMEMConfiguration RX Link 6 FIFO                                                                                                                                                                                                                                                                    | 5900   | RD            | MEM | <b>Configuration RX Link 3 FIFO</b> |
| 7100 RD MEM Configuration RX Link 6 FIFO                                                                                                                                                                                                                                                                                                      | 5100   | RD            | MEM | <b>Configuration RX Link 4 FIFO</b> |
|                                                                                                                                                                                                                                                                                                                                               | 5900   | RD            | MEM | Configuration RX Link 5 FIFO        |
|                                                                                                                                                                                                                                                                                                                                               | 7100   | RD            | MEM | Configuration RX Link 6 FIFO        |
| (900 RD MEM Configuration RX Link 7 FIFO                                                                                                                                                                                                                                                                                                      | 7900   | RD            | MEM | Configuration RX Link 7 FIFO        |

Table 1 - Register and memory map

# 5. REGISTER DESCRIPTION

#### Base address: x0

This register contains different control bit for data taking and trigger managing.

Bit 0. Data taking enable. When set to '1' event buffer data are written in FTDI chip buffer. When set to '0' RX Configuration link data are written in FTDI chip buffer.

Bit 1. When set to '1' a constant frequency trigger pulse is generate. Period is control with registers 0x3 and 0x4.

Bit 2. When a transition from '0' to '1' is detect, a single shot test trigger is generate.

Bit 3. Data test multiplexer control. When set to '0' input data from T+ROC1 are ADC data and Trigger data. When set to '1', test data generated in the FPGA are use, instead of ADC data and Trigger data.

Bit 4. Random trigger enable. When set to '1' a pseudorandom trigger is generate.

Bit 5. External trigger enable. When set to '1' external trigger input is enabled.

Bit 6 External trigger auxiliary enable. When set to '1' external Trigger auxiliary is enable

Bit 7. Unused.

#### Base address: x1

This register is use to enable transmission in Configuration links:

Bit 0. Global enable Configuration transmission. When set to '1' data in TX buffer is sent by parallel to serial transmitter. When set to '0' data is kept in the buffer. Individual data line enable for each link can be control with register 0xFF.

Bit 1 to 7. Unused.

Base address: x2





This register is use for reset different elements of internal logic;

Bit 0: FIFO reset, active high. This bit resets all FIFOs in the FPGA: Configuration, ADC data, Trigger data, Time tags and Event buffer. User should take care of setting the bit to low in order to disable the reset.

Bit 1: Counters reset, active high. This bit resets all counters of event header: Time tag (32-bit), Input Trigger (24-bit) and Accepted Trigger (24-bit). User should take care of setting the bit to low in order to disable the reset.

Bit 2 to 7: Unused

### Base address: x3

This register is use to define the period of the constant rate test Trigger generator.

### Base address: x4

This register is use to define the period of the constant rate test Trigger generator.

#### Base address: x5

This register is use to define the mask for T+ROC2 #0 and #1. The mask is active high and uses one bit per Hidra board. That is, when a certain bit is set to '0', the corresponding Hidra is readout and included in the event. When a certain bit is set to '1' the corresponding Hidra is not readout.

For Trigger data, the mask is obtained as the AND of each hexadecimal digit in the register. So Trigger data of a given TROC2 will be readout if at least one of the 4 corresponding bits is set to '0'. This means that this TROC2 is present in the system. If all the bits are set to '1', this means that the TROC2 is not connected and the corresponding Trigger data will not be readout.

Default value of all bits in the register is '0'.

#### Base address: x6

This register is use to define the mask for TROC2 #2 and #3. The mask is active high and uses one bit per Hidra board. That is, when a certain bit is set to '0', the corresponding Hidra is readout and included in the event. When a certain bit is set to '1' the corresponding Hidra is not readout.

For Trigger data, the mask is obtained as the AND of each hexadecimal digit in the register. So Trigger data of a given TROC2 will be readout if at least one of the 4 corresponding bits is set to '0'. This means that this TROC2 is present in the system. If all the bits are set to '1', this means that the TROC2 is not connected and the corresponding Trigger data will not be readout.

Default value of all bits in the register is '0'.

#### Base address: x7

This register is use to define the mask for TROC2 #4 and #5. The mask is active high and uses one bit per Hidra board. That is, when a certain bit is set to '0', the corresponding Hidra is readout and included in the event. When a certain bit is set to '1' the corresponding Hidra is not readout.

For Trigger data, the mask is obtained as the AND of each hexadecimal digit in the register. So Trigger data of a given TROC2 will be readout if at least one of the 4 corresponding bits is set to '0'. This means that this TROC2 is present in the system. If all the bits are set to '1', this means that the TROC2 is not connected and the corresponding Trigger data will not be readout.





Default value of all bits in the register is '0'.

### Base address: x8

This register is use to define the mask for TROC2 #6 and #7. The mask is active high and uses one bit per Hidra board. That is, when a certain bit is set to '0', the corresponding Hidra is readout and included in the event. When a certain bit is set to '1' the corresponding Hidra is not readout.

For Trigger data, the mask is obtained as the AND of each hexadecimal digit in the register. So Trigger data of a given TROC2 will be readout if at least one of the 4 corresponding bits is set to '0'. This means that this TROC2 is present in the system. If all the bits are set to '1', this means that the TROC2 is not connected and the corresponding Trigger data will not be readout.

Default value of all bits in the register is '0'.

### Base address: x9

This register is use to define de low-level byte of the random trigger generator counter.

#### Base address: xA

This register is use to define de high-level byte of the random trigger generator counter.

### Base address: xB

This register is use to define de maximum number of events that the system can store in the input buffers. This number is defined with bits 0 to 2, that is, is limited to 7 events by firmware. The default value is 1 event. This means that when a Trigger is receive and accepted, no new Triggers will be accept until the event is completely written in the output buffer.

#### Base address: xC

This register is use to define de maximum number of events that TROC1 can write in the output buffer without receiving a reset from the computer. This is so-called event burst number and it is obtained by a combination of registers 0xC (lower byte) and 0xD (higher byte), so the maximum event number in a burst is 65535. When 0 is written in these registers, TROC1 writes in the output every processed event without limitation, this is normal operation. This burst limitation is intended to avoid the problem with the computer buffer managing observed in Linux computers.

#### Base address: xD

This register is use to define de maximum number of events that TROC1 can write in the output buffer without receiving a reset from the computer. This is so called event burst number and it is obtained by a combination of registers 0xC (lower byte) and 0xD (higher byte), so the maximum number in a burst is 65535. When 0 is written in these registers, TROC1 writes in the output every processed event without limitation, this is normal operation. This bunch limitation is intend to avoid the problem with the computer buffer managing observed in Linux computers.

#### Base address: xD

This register is used to perform a burst reset, any write access to this register performs the burst reset independently of the data content.

#### Base address: x20





This register contains Firmware version date info:

Bits 0 to 7: Day

#### Base address: x21

This register contains Firmware version date info:

Bits 0 to 3: Month Bits 4 to 7: Year - 2018

#### Base address: x22

Bit 0: Configuration TX FIFO Full Bits 1 to 7: unused

#### Base address: x23

Bit 0: Configuration TX FIFO Empty Bits 1 to 7: unused

#### Base address: x24

Bit 0: Configuration RX link 0 FIFO Full Bit 1: Configuration RX link 1 FIFO Full Bit 2: Configuration RX link 2 FIFO Full Bit 3: Configuration RX link 3 FIFO Full Bit 4: Configuration RX link 4 FIFO Full Bit 5: Configuration RX link 5 FIFO Full Bit 6: Configuration RX link 6 FIFO Full Bit 7: Configuration RX link 7 FIFO Full

### Base address: x25

Bit 0: Configuration RX link 0 FIFO Empty Bit 1: Configuration RX link 1 FIFO Empty Bit 2: Configuration RX link 2 FIFO Empty Bit 3: Configuration RX link 3 FIFO Empty Bit 4: Configuration RX link 4 FIFO Empty Bit 5: Configuration RX link 5 FIFO Empty Bit 6: Configuration RX link 6 FIFO Empty Bit 7: Configuration RX link 7 FIFO Empty

#### Base address: x26 to x49

This registers contain information related with data counts of configuration links FIFOs as shown in table 1.

### Base address: x4A

This register contains information about the occupancy of the system, that is, the number of Triggers that have been accept but are not already released (written in the output buffer).





### Base address: x4B

This register contains information about data count in output buffer:

Bits 0 to 7: Output buffer data count (bits 0 to 7)

### Base address: x4B

This register contains information about data count in output buffer:

Bits 0 to 4: Output buffer data count (bits 8 to 12)

Bits 5 to 7: unused

#### Base address: xFF

This register is use to enable TX Configuration links individually.

Bit 0: TX Configuration link 0 enable Bit 1: TX Configuration link 1 enable Bit 2: TX Configuration link 2 enable Bit 3: TX Configuration link 3 enable Bit 4: TX Configuration link 4 enable Bit 5: TX Configuration link 5 enable Bit 6: TX Configuration link 6 enable Bit 7: TX Configuration link 7 enable

### 6. EVENT DATA FORMAT

Event data has the following sections:

- Header: contains time tags and input Trigger counters:
  - Field "Event Header" is constant with value 0xEE.
  - Field "TROC1 firmware version" contains the firmware version number"
  - Field "Time tag counter" contains the 1MHz clock cycle when the accepted Triger was registered by TROC1
  - Field "Input Trigger counter" contains the count of all enabled incoming Triggers. It also counts for internally generated test Trigger, when enabled.
  - Filed "Accepted Trigger counter" contains the count of all accepted Triggers.
  - Field "Trigger enable mask" contains the enable vector for different trigger sources that is loaded in the FPGA following the next codification:
    - Bit 0: FPGA constant frequency Trigger generator enable
    - Bit 1: FPGA software Trigger enable
    - Bit 2: FPGA pseudo random Trigger generator enable
    - Bit 3: external Trigger enable



- Bit 4: external Trigger Aux. enable
- Field "Trigger type" contains the information of the Trigger source that produced the event, following the next codification:
  - Bit 0: FPGA constant frequency Trigger generator flag
  - Bit 1: FPGA software Trigger flag
  - Bit 2: FPGA pseudo random Trigger generator flag
  - Bit 3: external Trigger flag
  - Bit 4: external Trigger Aux. flag
- Field "Occupancy" contains the ordering of the event in the input buffer when the Trigger was registered, that is, if Occupancy = 1, the buffer was empty when the Trigger corresponding to the event was accepted.
- Hidra Mask: contains Hidra mask set in Configuration registers 5,6,7 and 8.
- **Trigger data**: contains data from Self Trigger outputs from Hidra chips. There is one Trigger data link per TROC2 board. It also contains a 32-bit Trigger counter that should be the same values as TROC1 "Accepted Trigger Counter". Trigger data from each TROC2 board is protect with a 16-bit checksum.
- **Trigger logic tags**: this is the results of applying the Trigger logic to trigger data. It is included in the event as tags to crosscheck the logic by offline software.
- **ADC data**: this data Data from each Hidra board ADC, plus information about Hidra chip Gain. It also contains a 16-bit counter with TROC2 time tag, that is, the elapsed time between last reset and input Trigger in 60 Mhz clock cycle steps. Data from each Hidra board is protect with a 16-bit checksum.
- Global checksum: 16 bit checksum of all previous data of the event.

A representation of all data fields are show in Table 2. The minimum event data length is 31 bytes (all Hidras masked), and the maximum is 4751 bytes (all Hidra boards enabled).





| Section              | Field                  | Data                    | Index |
|----------------------|------------------------|-------------------------|-------|
|                      | Event header           | <b>0xEE</b> (constant)  | 0     |
|                      | TROC1 Firmware         | FW version(158)         | 1     |
|                      | version                | FW version(70)          | 2     |
|                      |                        | Time tag(3124)          | 3     |
|                      | Time tag counter: 4    | Time tag(3124)          | 4     |
|                      | bytes                  | Time tag(2510)          | 5     |
|                      | (1us resolution)       | Time tag(70)            | 6     |
|                      |                        | Input Trigger(3124)     | 7     |
|                      | Input Trigger Counter: | Input Trigger (2316)    | 8     |
| Header: constant     | 4 bytes                | Input Trigger (158)     | 9     |
| length of 22 bytes   |                        | Input Trigger(70)       | 10    |
|                      |                        | Accepted Trigger(3124)  | 11    |
|                      | Accepted Trigger       | Accepted Trigger(2316)  | 12    |
|                      | Counter: 4 bytes       | Accepted Trigger(158)   | 13    |
|                      |                        | Accepted Trigger(70)    | 14    |
|                      | Trigger enable mask    | x"0" & Enable mask(30)  | 15    |
|                      | Trigger type           | x"0" & Trigger type(30) | 16    |
|                      | Occupancy              | x"0" & Occupancy(30)    | 17    |
|                      |                        | Mask(70)                | 18    |
|                      |                        | Mask(158)               | 19    |
|                      | Hidra mask: 4 bytes    | Mask(2316)              | 20    |
|                      |                        | Mask(3124)              | 21    |
|                      |                        | Hidra 0, ASIC 1, CH(70) |       |
|                      |                        | Hidra 0, ASIC 2, CH(70) |       |
|                      |                        | •••                     |       |
|                      |                        | Hidra 3, ASIC 4, CH(70) |       |
|                      | TROC2 N                | Trigger Counter(70)     |       |
|                      | (22 bytes)             | Trigger Counter(158)    |       |
|                      |                        | Trigger Counter(2316)   |       |
| Trigger Data: 22     |                        | Trigger Counter(3124)   |       |
| bytes/TROC2          |                        | Trigger Checksum(70)    |       |
| Min: 0 TROC2         |                        | Trigger Checksum(158)   | +22   |
| Min: 0 bytes         |                        | Hidra 0, ASIC 1, CH(70) |       |
| Max: 8 TROC2         |                        | Hidra 0, ASIC 2, CH(70) |       |
| Max 176 bytes        |                        | •••                     |       |
|                      |                        | Hidra 3, ASIC 4, CH(70) |       |
|                      | TROC2 M                | Trigger Counter(70)     |       |
|                      | (22 bytes)             | Trigger Counter(158)    |       |
|                      |                        | Trigger Counter(2316)   |       |
|                      |                        | Trigger Counter(3124)   |       |
|                      |                        | Trigger Checksum(70)    |       |
|                      |                        | Trigger Checksum(158)   | +22   |
|                      | Multiplicity (2 bytes) | Multiplicity(158)       |       |
|                      |                        | Multiplicity(70)        |       |
| Trigger Logic tags:  | X projection           | X projection(70)        |       |
| constant length of 7 | Y projection           | Y projection(70)        |       |
| bytes                |                        | Z projection(2316)      |       |
|                      | Z projection( 3 bytes) | Z projection(158)       |       |
|                      |                        | Z projection(70)        | +7    |





|                                                                 |                              | 0xBB                                            |      |
|-----------------------------------------------------------------|------------------------------|-------------------------------------------------|------|
|                                                                 |                              | Hidra Board number                              |      |
|                                                                 |                              | ASIC 1, CH0, LSB                                |      |
|                                                                 |                              | ASIC 1, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 1, CH15, LSB                               |      |
|                                                                 |                              | ASIC 1, CH15, MSB                               |      |
|                                                                 |                              | ASIC 2, CH0, LSB                                |      |
|                                                                 |                              | ASIC 2, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 2, CH15, LSB                               |      |
|                                                                 |                              | ASIC 2, CH15, MSB                               |      |
|                                                                 |                              | ASIC 3, CH0, LSB                                |      |
|                                                                 |                              | ASIC 3, CH0, MSB                                |      |
|                                                                 |                              | •••                                             |      |
|                                                                 | Hidra Board X                | ASIC 3, CH15, LSB                               |      |
|                                                                 | (142 bytes)                  | ASIC 3, CH15, MSB                               |      |
|                                                                 |                              | ASIC 4, CH0, LSB                                |      |
|                                                                 |                              | ASIC 4, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 4, CH15, LSB                               |      |
|                                                                 |                              | ASIC 4, CH15, MSB                               |      |
|                                                                 |                              | Gain ASIC 1, CH(70)                             |      |
|                                                                 |                              | Gain ASIC 1, CH(158)                            |      |
| ADC data:                                                       |                              | · · · · · · · · · · · · · · · · · · ·           |      |
| 142bytes/Hidra board                                            |                              | <br>Gain ASIC 4, CH(70)                         |      |
| Min: 0 Hidra<br>Min: 0 bytes<br>Max: 32 Hidra<br>Max:4544 bytes |                              | Gain ASIC 4, CH(70)<br>Gain ASIC 4, CH(158)     |      |
|                                                                 |                              | TROC2 time tag(70)                              |      |
|                                                                 |                              | TROC2 time tag(70)<br>TROC2 time tag(158)       |      |
|                                                                 |                              | ADC Data Checksum(70)                           |      |
|                                                                 |                              | ADC Data Checksum(70)<br>ADC Data Checksum(158) | +142 |
| _                                                               |                              |                                                 | +142 |
|                                                                 |                              | 0xBB<br>Hidra Board number                      |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 1, CH0, LSB                                |      |
|                                                                 |                              | ASIC 1, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 1, CH15, LSB                               |      |
|                                                                 |                              | ASIC 1, CH15, MSB                               |      |
|                                                                 |                              | ASIC 2, CH0, LSB                                |      |
|                                                                 | Hidra Board Y<br>(142 bytes) | ASIC 2, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 2, CH15, LSB                               |      |
|                                                                 |                              | ASIC 2, CH15, MSB                               |      |
|                                                                 |                              | ASIC 3, CH0, LSB                                |      |
|                                                                 |                              | ASIC 3, CH0, MSB                                |      |
|                                                                 |                              |                                                 |      |
|                                                                 |                              | ASIC 3, CH15, LSB                               |      |
|                                                                 |                              | ASIC 3, CH15, MSB                               |      |
|                                                                 |                              | ASIC 4, CH0, LSB                                |      |
|                                                                 |                              | ASIC 4, CH0, MSB                                |      |
|                                                                 |                              | •••                                             |      |
|                                                                 |                              | ASIC 4, CH15, LSB                               |      |
|                                                                 |                              | ASIC 4, CH15, MSB                               | 1    |

| COBIERNO<br>DE ESPAÑA | MINISTERIO<br>DE CIENCIA, INNOVACIÓN<br>Y UNIVERSIDADES | Cenero de Investigaciones<br>Energésicas, Medicambienailes<br>y Tecnológicas |      |
|-----------------------|---------------------------------------------------------|------------------------------------------------------------------------------|------|
|                       |                                                         | Gain ASIC 1, CH(70)                                                          |      |
|                       |                                                         | Gain ASIC 1, CH(158)                                                         |      |
|                       |                                                         | Gain ASIC 4, CH(70)                                                          |      |
|                       |                                                         | Gain ASIC 4, CH(158)                                                         |      |
|                       |                                                         | TROC2 time tag(70)                                                           |      |
|                       |                                                         | TROC2 time tag(158)                                                          |      |
|                       |                                                         | ADC Data Checksum(70)                                                        |      |
|                       |                                                         | ADC Data Checksum(158)                                                       | +142 |
| Global checksum       |                                                         | Global checksum(70)                                                          |      |
| (2 bytes)             |                                                         | Global checksum(150)                                                         | +2   |

Table 2 – TROC1 data format

# 7. EXAMPLE OF DAQ PROGRAM INIT

This section contains an example of a typical initialization of the data acquisition program.

This is the sequence that should be implemented:

- FTDI USB session initialization
- TROC1 Reset
- TROC1 Configuration buffers initialization
- TROC2 "Hold Delay" setting
- TROC2 "Hold Gain Delay" setting
- TROC1 constant frequency internal trigger generator period setting
- TROC1 Hidra Mask setting
- TROC2 RS232 enable and Trigger enable
- TROC1 Trigger enable setting and Data Taking enable

# 7.1. FTDI USB session initialization

Initialize USB session using standard FTDI functions:

- FT\_Create\_Device\_Info\_list
- FT\_Get\_Device\_Info\_List
- FT\_Open\_Device\_By\_Serial\_Number (From this moment it is assumed that an FThandle is available to manage FT accesses)
- FT\_Set\_Bit\_Mode (Single Channel 245 Synchronous FIFO)
- FT\_Set\_Timeouts (Timeout time should be greater than maximum time between consecutive triggers in order to avoid writting zeroes between two events in output data file)
- FT\_purgue (this is equivalent to make an FT\_Read of 65536 bytes)

# 7.2. T+ROC1 Reset

This is intended to reset TROC1 FPGA internal buffers, event building process and counters. It consists of writing 0x03 in TROC1 register 0x02 in order to activate the resets, and then write 0x00 in the same register in order to disable the resets.

TxBuffer[0] = 0x02; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8)



Ciemat Centro de Investigaciones Energéticas, Medicambientales y Tecnológicas

TxBuffer[2] = 0x01;//TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; // TROC1 number of bytes(15..8) TxBuffer[4] = 0x03; //Content of register

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

TxBuffer[0] = 0x02; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x01; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; // TROC1 number of bytes(15..8)TxBuffer[4] = 0x00; //Content of register

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

# 7.3. T+ROC1 Configuration links enable

This is need in order to enable the TX of Configurationuration accesses from TROC1 to TROC2. Register 0x01 contains a global enable for all buffers. Register 0xFF contains one enable per Configurationuration link (TROC2)

TxBuffer[0] = 0x01; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x01; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8)TxBuffer[4] = 0x01; //Content of register

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

TxBuffer[0] = 0xFF; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x01; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; // TROC1 number of bytes(15..8) $TxBuffer[4] = TROC2\_Configurationuration\_mask; //Content of register$ 

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

# 7.4. TROC2 "Hold Delay" setting

Nedded for writing Hold Delay parameter in TROC2 FPGA

TxBuffer[0] = 0x00; //TROC1 base address(7..0) TxBuffer[1] = 0x01; //TROC1 base address(15..8) TxBuffer[2] = 0x06; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) TxBuffer[4] = 0x00; //TROC2 control register address TxBuffer[5] = 0x80; //TROC2 control register content TxBuffer[6] = 0x26; //TROC2 data register address TxBuffer[7] = Hold\_Delay\_lower\_byte;// TROC2 data register content TxBuffer[8] = 0x27; // TROC2 data register address TxBuffer[9] = Hold\_Delay\_higher\_byte; // TROC2 data register content

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);



# 7.5. TROC2 "Hold Gain Delay" setting

Nedded for writing Hold Gain Delay parameter in TROC2 FPGA

TxBuffer[0] = 0x00; //TROC1 base address(7..0) TxBuffer[1] = 0x01; //TROC1 base address(15..8) TxBuffer[2] = 0x00; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) TxBuffer[4] = 0x00; //TROC2 control register address TxBuffer[5] = 0x80; //TROC2 control register content TxBuffer[6] = 0x24; //TROC2 data register address  $TxBuffer[7] = Hold_Gain_Delay_lower_byte; // TROC2 data register content$  TxBuffer[8] = 0x25; // TROC2 data register address $TxBuffer[9] = Hold_Gain_Delay_higher_byte; // TROC2 data register content$ 

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

### 7.6. TROC1 constant frequency internal trigger generator period setting

This is need in order to use TROC1 FPGA Trigger generator.

TxBuffer[0] = 0x03; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x02; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) TxBuffer[4] = Trigger\_period\_lower\_byte; //TROC1 register content TxBuffer[5] = Trigger\_period\_higher\_byte; //TROC1 register content

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

# 7.7. TROC1 Hidra Mask setting

Writing of Hidra Mask 32-bit word to TROC1 registers. This defines the length of the event.

TxBuffer[0] = 0x05; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x04; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) TxBuffer[4] = Hidra\_Mask\_byte0; //TROC1 register content TxBuffer[5] = Hidra\_Mask\_byte1; //TROC1 register content TxBuffer[6] = Hidra\_Mask\_byte2; //TROC1 register content TxBuffer[7] = Hidra\_Mask\_byte3; //TROC1 register content

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

### 7.8. TROC2 RS232 enable and Trigger enable

This access is need in order to enable Trigger in TROC2. The full content of the register is overwrite, so it is important to provide the desired setting for the other control bits in the same register, according to the following map (see TROC2 description register):



Bit 0: 0 sequence reset / 1 normal operation.
Bit 1: GAIN2SEL.
Bit 2: 0 RS232 reset active / 1 RS232 normal operation.
Bit 3: 0 external trigger / 1 internal trigger (for test purposes)
Bit 4: 0 normal operation / 1 internal trigger counter reset
Bit 5: Used for test purposes. Should be 0 during normal operation
Bit 6: Used for test purposes. Should be 0 during normal operation
Bit 7: 1 Configuration / 0 data taking

For normal operation with RS232 scalers enabled the content of the register should be:

### TROC2\_Reg0=0x05;

For normal operation with RS232 enabled and GAIN1 forced, the content of the register should

be:

TROC2\_Reg0=0x07;

TxBuffer[0] = 0x00; //TROC1 base address(7..0) TxBuffer[1] = 0x01; //TROC1 base address(15..8) TxBuffer[2] = 0x00; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) TxBuffer[4] = 0x00; //TROC2 control register address $TxBuffer[5] = TROC2\_Reg0; //TROC2 \text{ control register content}$ 

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);

### 7.9. TROC1 Trigger enable setting and Data Taking enable

This defines the enabled Trigger sources in TROC1 and enables data readout by writing in TROC1 register 0, with the following codification:

Reg0, bit 0: data taking enable Reg0, bit 1, constant rate Trigger enable Reg0, bit 2: single shot soft Trigger enable Reg0, bit 3, test data enable Reg0, bit 4, random trigger enable Reg0, bit 5: external Trigger enable Reg0, bit 6, auxiliary external Trigger enable

For normal operation with both external Triggers enabled, the content of the register should be:

TROC1\_Reg0=0x61;

TxBuffer[0] = 0x00; //TROC1 base address(7..0) TxBuffer[1] = 0x00; //TROC1 base address(15..8) TxBuffer[2] = 0x01; //TROC1 number of bytes(7..0) TxBuffer[3] = 0x00; //TROC1 number of bytes(15..8) $TxBuffer[4] = TROC1\_Reg0; //TROC1 \text{ register content}$ 

FT\_Write(ftHandle, TxBuffer, sizeof(TxBuffer), &BytesWritten);



From this moment data will be accessible in USB after Trigger arrival.

# 8. TROC1 FIRMWARE UPDATE PROCEDURE

This section contains a description of the procedure for updating TROC1 non-volatile memory by using Xilinx USB programming cable and Impact software.

- 8.1. Connect Xilinx USB programming cable to programming connector at TROC1, J1.
- 8.2. Launch Impact and initiate JTAG Chain

| ISE IMPACT (P.68d) - [Boundary Scan]                                                                                                            |               |                         | _                          | _ |                             |       |
|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------|----------------------------|---|-----------------------------|-------|
| Se File Edit View Operations Output Debug Window He                                                                                             | lp.           |                         |                            |   |                             | - # × |
|                                                                                                                                                 |               |                         |                            |   |                             |       |
| PRACT Flows  Provide Chain  Reading Scanding California (C S X  System AC  System AC  Web Talk Data  Web Talk Data                              |               | Right click to Add Devi | ce or Entialize ITAG chain |   |                             |       |
| 3                                                                                                                                               | Boundary Scan |                         |                            |   |                             |       |
| Console                                                                                                                                         |               |                         | - Contraction              |   |                             | +□ @× |
| Welcome to IMPACT<br>IMPACT Version: 34.6<br>// *** BATCH CND : setMode -bs<br>// *** BATCH CND : setMode -bs<br>// *** BATCH CND : setMode -bs |               |                         |                            |   |                             | ~     |
| Console O Errors 1 Warnings                                                                                                                     |               |                         |                            |   |                             |       |
| Automatically identifies the boundary-scan chain composition                                                                                    |               |                         |                            |   | No Cable Connection No File | Open  |
| 🚳 📋 🖸 🧑 ≽ 🕅                                                                                                                                     |               |                         |                            |   | ES 🔺 🏴 😭 😝                  | 12:11 |

You should see the following chain:

| DE ESPAÑA                                                                                                                                                                                          | MINISTERIO<br>DE CIENCIA, INNOVACIÓN<br>Y UNIVERSIDADES | Ciernole<br>Centro de Investigaciones<br>Energificicas, Medicambientales<br>y Tecnológicas |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| SE IMPACT (P.20131013) - [Boundary Scan]     File Edit, View Operations Output Debug W     PACT Flow     Boundary Scan     Superact Rece     Grade RROM File (PROM File Formatter)     WebTak Data | ndow Help                                               |                                                                                            |  |
| MPACT Processes<br>Available Operations are:                                                                                                                                                       | withnown_0_€.bsd bypass                                 |                                                                                            |  |
| PPACT Boundary Scan Chain Debug TD0 TD1 D TD T                                                                                                                    | •• D B X ERROR-MPACT - Bedi re                          | ader is not available for device 1.                                                        |  |
|                                                                                                                                                                                                    |                                                         |                                                                                            |  |
| Scan DR Execute                                                                                                                                                                                    | Se Boundar                                              | Identify Succeeded                                                                         |  |

The error message is because Impact software does not have the internal JTAG description of Spartan 7 FPGA. You should provide .BSD file to avoid this issue.

Click "OK" in the error message window. You should see the following message:

| 🐼 ISE iMPACT (P.20131013) - [Boundary Scan]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                  |                             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| Solution File Edit View Operations Output Debug Window                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Help                                                                                                                                                                                                             | _ 8 )                       |
| 🗋 🏓 🛃 📫 🛗 🗮 🗮 🎘 🛱 🔚 🖬 🥓 😢                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                  |                             |
| (PPACT Flows     ( | Rught click drive to select operations       TDI     Examp       unknown_0_6     xct2p       TDO     bypasa                                                                                                      |                             |
| MPACT Processes ++ C<br>Available Operations are:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                  |                             |
| MPACT Boundary Scan Chan Debug ++ C TD0 TD0 TD TD O TD O TS O Execute Scan DR Execute Scan DR Execute                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Auto Ausign Configuration Files Query Dialog     Do you want to continue and assign configuration files()?     Don't show this message again, save the setting in preference.     Yes No      Identify Succeeded |                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Boundary Scan                                                                                                                                                                                                    |                             |
| Console                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | a) are spired to this logation: (C)(Vilinu))                                                                                                                                                                     | ++□ 6 >                     |
| WINFOLIMPHOI - THE UNKNOWN GEVICE BSDL TILE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | a) are saved to this location: 'C:\Allink\'                                                                                                                                                                      |                             |
| < m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                  | Þ                           |
| Console 🔇 Errors 🔔 Warnings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Configuration Platform Cable US                                                                                                                                                                                  | BII 6 MHz usb-h             |
| 🚳 🤌 🛅 🖸 🌆                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ES 🔺 🏴 🔐                                                                                                                                                                                                         | (+) 12:20<br>(+) 24/07/2019 |



Click "No"

You should see the following window:

| 🐼 ISE iMPACT (P.20131013) - [Boundary Scan]             |                |                                                  |                    |      |                     | - 0 %                             |
|---------------------------------------------------------|----------------|--------------------------------------------------|--------------------|------|---------------------|-----------------------------------|
| 🛞 File Edit View Operations Output Debu                 |                |                                                  |                    |      |                     | _ <i>6</i> ×                      |
| 🗋 ờ 🖬 🕺 🗅 🖸 🗙 🗄 🗰 💥 🗄                                   | 🖻 🗉 🔑 K        | ?                                                |                    |      |                     |                                   |
| MPACT Flows                                             | ↔ 🗆 🗗 X        | TDI                                              | xcr32p<br>bypass   |      |                     |                                   |
|                                                         | Device Program | ming Properties - Device 1 Progr                 | ramming Properties |      |                     |                                   |
| MPACT Processes                                         | Category       |                                                  |                    |      |                     |                                   |
| Available Operations are:                               | Boundary-Sca   | n<br>Unknown Type GENERATED_UN<br>PROM2 xcf32p ) | KNOWN <u>0</u> 6)  |      | Property Name Value |                                   |
| MPACT Boundary Scan Chain Debug                         |                |                                                  |                    |      |                     |                                   |
| TDO                                                     |                |                                                  |                    |      |                     |                                   |
| TDI 0<br>TMS 0 Execute<br>Pulse TCK<br>Test Logic Reset |                |                                                  |                    |      |                     |                                   |
| Scan JR Execute Scan DR Execute                         |                |                                                  |                    |      |                     |                                   |
|                                                         |                |                                                  |                    |      | OK Cancel Apply     | Help                              |
|                                                         | _              | 0                                                |                    |      |                     |                                   |
|                                                         |                | 8                                                | Boundary Scan      |      |                     |                                   |
| Console                                                 | SDL file(s) an | e saved to this locat                            | ion: 'C:\Xilinx    | ¢\ ' |                     | + □ ♂ ×                           |
| •                                                       |                |                                                  |                    |      |                     |                                   |
| Console Console Karnings                                |                |                                                  |                    |      | Configuration P     | latform Cable USB II 6 MHz usb-hs |
| 🚳 ⋵ 📋 🖸 🧿                                               |                |                                                  | 8                  |      |                     | ES 12:22                          |

Click "Cancel"

Then you should see the JTAG chain:

| GOBIERNO<br>DE ESPAÑA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MINISTERIO<br>DE CIENCIA, INNOVACIÓN<br>Y UNIVERSIDADES | Cierco de Investigaciones<br>Energisicas, Medicambientales<br>y Tecnológicas |                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------|-----------------------|
| Image: Set MMPACT (P 20131013) - (Boundary Scan)         Image: File       Edit       View       Operations       Output       Del         Image: Set Ministry Set Ministry       Image: Set Ministry Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry         Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry         Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry         Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry       Image: Set Ministry |                                                         | 8                                                                            | - 6                   |
| MPACT Processes<br>Available Operations are:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | unkovn_0_6.848 kpp                                      |                                                                              |                       |
| PPACT Boundary Scen Chain Debug<br>TDO<br>TDO<br>TDO<br>TDO<br>TO<br>TO<br>TO<br>TO<br>TO<br>TO<br>TO<br>TO<br>TO<br>T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | + □ Ø X                                                 |                                                                              |                       |
| Scan DR Execute<br>Scan DR Execute                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                         | Identify Succeeded                                                           |                       |
| Console<br>U.INFO:IMFACT - The UNRIGONN device<br>Console<br>Console<br>Console<br>Console                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | BODL file(s) are saved to this location: '              | C:\Xilinx\'                                                                  | ++ 🗆 £                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                         |                                                                              | Cable USB II 6 MHz us |

8.3. Right Click on the first part in the chain XCF16P, this is the Spartan 7 FPGA. Then select "Assign new Configurationuration file", an explorer window will arise so you can select the .BSD file.

| SE iMPACT (P.20131013) - [Boundary Scan]                    |                                                                  |                                                  |
|-------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------|
| 😵 File Edit View Operations Output Debug Window Help        |                                                                  | _ @ ×                                            |
| 🗋 ờ 🖬  🖉 🕼 🗙 🏭 📰 💥 🗉 🛸 🗖 🎤                                  | 2                                                                |                                                  |
| MPACE Flows → □ Ø X                                         | unknown_0_6.8xd<br>TDD                                           |                                                  |
| MPACT Processes ++ C & X                                    |                                                                  |                                                  |
| Available Operations are:                                   |                                                                  |                                                  |
| MPACT Boundary Scan Chain Debug ++ 🗆 🗗 🗗                    | BSDL Query      Do you have a BSDL or BIT file for this device ? |                                                  |
| TDO TO P PAGE TO PAGE TO PAGE TO C                          | Yes No Cancel Cancel Al                                          |                                                  |
| Test Logic Reset                                            |                                                                  |                                                  |
| Scan IR Execute                                             |                                                                  |                                                  |
|                                                             | Boundary Scan                                                    |                                                  |
| Consta                                                      | Boundary Scan                                                    |                                                  |
| Console<br>WINFOINBRACT - The UNKNOWN device BSDL file(s) a | re saved to this location: 'C:\Xilinx\'                          | + □ # ×<br><br>,                                 |
|                                                             |                                                                  | Configuration Platform Cable USB II 6 MHz usb-hs |
| 🚳 🤌 😭 🖸 🏹 🔼                                                 |                                                                  | ES                                               |

Assign the file XC7S75\_FGGA676.BSD



8.4. Right Click on the second part in the chain XCF32P, this is the non volatile flash memory. Then select "Assign new Configurationuration file", an explorer window will arise so you can select the .mcs file.

A warning message may pop up before assigning the file, alerting you about byte swapping in the memory file, this is normal, click "OK".

8.5. Once the file is assigned, right click in the second part again and select the option "Program"

| ISE iMPACT (P.20131013) - [Boundary Scan]                   |                                 |                         |                                  |
|-------------------------------------------------------------|---------------------------------|-------------------------|----------------------------------|
| File Edit View Operations Output Debug Window Help          |                                 |                         | - 8 ×                            |
| 🗋 🆻 🛃 🕺 🗅 🗋 🗙 🏭 🏥 🎎 💥 😂 📑                                   | □ <i>₽ \</i> ?                  |                         |                                  |
| MPACT Flows ↔ □ ♂ ×                                         |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
| Boundary Scan     SystemACE                                 |                                 |                         |                                  |
| Create PROM File (PROM File Formatter)                      |                                 |                         |                                  |
| ⊕ 📄 WebTalk Data                                            | TDI \$23UMC \$23UMC             |                         |                                  |
|                                                             | Program                         | n                       |                                  |
|                                                             | xc7s75_fgga676 xcf32 Verify     |                         |                                  |
|                                                             | xc7s75_fgga676 troc1_v170 Erase |                         |                                  |
|                                                             | TDOBlank C                      | heck                    |                                  |
|                                                             | Readba                          | ck                      |                                  |
| iMPACT Processes ↔ □ 8 ×                                    | Get Dev                         | rice ID                 |                                  |
| Available Operations are:                                   | Get Dev                         | rice Checksum           |                                  |
| A Program                                                   |                                 | rice Signature/Usercode |                                  |
| A Verify                                                    | One Ste                         |                         |                                  |
| Erase     Blank Check                                       | One Ste                         |                         |                                  |
| Readback                                                    | one ste                         | p 7341                  |                                  |
| Get Device ID                                               | Assign I                        | New Configuration File  |                                  |
| ight Get Device Checksum                                    | Set Proc                        | gramming Properties     |                                  |
| Get Device Signature/Usercode                               | Set Eras                        | e Properties            |                                  |
| Get Device Customer Code                                    | Launch                          | File Assignment Wizard  |                                  |
| iMPACT Boundary Scan Chain Debug ↔ 🗆 🗗 🗙                    | Lauren                          | File Assignment Wizard  |                                  |
| тво                                                         |                                 |                         |                                  |
| TDI 0 💌                                                     |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
| TMS 0 💌 Execute                                             |                                 |                         |                                  |
| Pulse TCK                                                   |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
| Test Logic Reset                                            |                                 |                         |                                  |
| Scan IR Execute                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
| Scan DR Execute                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             |                                 |                         |                                  |
|                                                             | Boundary Scan                   |                         |                                  |
| Console                                                     |                                 |                         | + □ 8 ×                          |
| <pre>// *** BATCH CMD : setAttribute -position 2 -att</pre> | r packageName -value ""         |                         | <u>^</u>                         |
|                                                             |                                 |                         | -                                |
| < <u> </u>                                                  |                                 |                         | Þ.                               |
| Errors 🔬 Warnings                                           |                                 |                         |                                  |
|                                                             |                                 | Configuration PI        | atform Cable USB II 6 MHz usb-hs |
|                                                             |                                 |                         | ES 12:28                         |

8.6. After few minutes you will get a "Programming Succeeded" message, this means everything went right. The file is write in the Flash memory and will be loaded in the FPGA in every power cycle.