# Solar Orbiter HET/EPT Digital FPGA # Stephan I. Böttcher # ${\rm SVN~Revision~8147} \\ {\rm Date~2020\text{-}12\text{-}03~21\text{:}53\text{:}06~+0100~(Do,~03~Dez~2020)}$ Document code: SO-EPD-KIE-DA-0001 Issue 1 Rev 0.3 # Contents | 1 | Intr | roduction | 6 | |---|------|----------------------------------|------------| | 2 | Mo | de of Operation | 6 | | | 2.1 | Data Acquisition | 7 | | | 2.2 | Data Checkout | 7 | | | 2.3 | Slow Control | 7 | | | 2.4 | | 8 | | | | 2.4.1 Serial Commands via LVDS | 8 | | | | | 9 | | | 2.5 | Master Control Message | 9 | | | 2.6 | | 10 | | | | | 10 | | | | | 11 | | | | | 11 | | | | 2.6.4 Analog Trigger Event Data | 12 | | | | | 12 | | 3 | Tele | emetry packets | L <b>2</b> | | | 3.1 | Serial Packet Format | 13 | | | 3.2 | | 13 | | | | 3.2.1 Status and Error Registers | 14 | | | | 3.2.2 Address Registers | | | | | | 15 | | | | 9 | | | | | 3.2.4 | UART Status | |---|-----|---------|-------------------------------------------------------| | | | 3.2.5 | Heater Registers | | | 3.3 | Histog | gram Data | | | | 3.3.1 | Data Product Scheduler | | | | 3.3.2 | Data Compression | | | | 3.3.3 | Unencoded Data | | | 3.4 | Memo | ry Readout | | | | 3.4.1 | External SRAM | | | | 3.4.2 | EEPROM Readout | | | | 3.4.3 | Configuration Table Readout | | | | 3.4.4 | Counter Readout | | | | 3.4.5 | Memory Index Registers | | | 3.5 | Fronte | end Readout | | | | 3.5.1 | Analog Readout Items | | | | 3.5.2 | Analog Housekeeping | | | | 3.5.3 | Temperature Capture | | | | 3.5.4 | Peeking | | | | 3.5.5 | Single Channel Trigger Counters | | | 3.6 | L2 Str | reaming | | | | 3.6.1 | Samples Readout | | | 3.7 | Monit | oring Parameters | | | | 3.7.1 | Register readout | | | | 3.7.2 | Histogram Data | | | | 3.7.3 | Counter Memory Readout | | | | 3.7.4 | HET-EPT Analog Frontend Readout 30 | | | ъ. | | | | 4 | | | uisition 31 | | | 4.1 | | Height Data Packets | | | | 4.1.1 | Event Packet Reception | | | | 4.1.2 | L3 Event Class | | | 4.0 | 4.1.3 | Trigger and Prescale Counters | | | 4.2 | | Buffer | | | | 4.2.1 | Feeding the L3 trigger processor | | | | 4.2.2 | PHA storage | | | | 4.2.3 | Test Data Injection | | | 4.9 | 4.2.4 | Event Data Formats | | | 4.3 | L3 trig | | | | | 4.3.1 | HIST Instruction | | | 1 1 | 4.3.2 | PHA Instruction | | | 4.4 | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | 4.5 | Sampl | le Mode | | | 4.6 | Timestamp Clock | 10 | |---|-----|--------------------------------------------|----------| | 5 | Ope | erational Heater 4 | .1 | | | 5.1 | Heater Modes of Operation | 11 | | 6 | Coı | int Rate Series Compression 4 | 2 | | | 6.1 | Histogram Windows | 12 | | | 6.2 | Counter Cadence | 12 | | | 6.3 | Compression Unit | 13 | | | | 6.3.1 Encoder | 13 | | | | 6.3.2 Basic Encoder Operations | 14 | | | | 6.3.3 Cadence Sequence without Compression | 15 | | | | 6.3.4 Compression Sequence | 15 | | | | 6.3.5 Compression Sequence with Summing | 17 | | | | | 17 | | | 6.4 | | 17 | | | | 6.4.1 Encoding in Full Poisson Resolution | 18 | | | | | 19 | | | | | 19 | | | | | 19 | | 7 | EEI | PROM 5 | 0 | | | 7.1 | EEPROM Page Write | 50 | | | | O | 50 | | | | | 51 | | | | | 51 | | 8 | Inn | uts and Outputs 5 | 1 | | O | _ | Power | | | | 8.2 | The clocks | | | | 0.2 | 8.2.1 TODO | | | | 8.3 | ICU Asynchronous Serial Link | | | | 0.0 | v | 53 | | | | · | 54 | | | | | 54 | | | 8.4 | | 55 | | | 0.4 | · | 55 | | | 8.5 | | )<br>56 | | | 0.0 | | | | | | 0 0 | 56<br>56 | | | | Ų Ų | 90<br>58 | | | | | | | | 8.6 | PWM output | 58 | |----|-------|----------------------------------------------------------------|----| | | 8.7 | Device Pinouts | 58 | | 9 | Tmn | lementation Details | 58 | | 9 | 9.1 | | 58 | | | 9.1 | External Memory Access | | | | | 9.1.1 Memory Port to Arbitration Unit Interface | 59 | | | | 9.1.2 Memory Driver Interface | 59 | | | | 9.1.3 Memory drivers | 59 | | | | 9.1.4 Memory Port | 60 | | | | 9.1.5 Memory Port Priorities | 61 | | | | 9.1.6 Memory EDAC | 61 | | | 9.2 | UART | 62 | | | | 9.2.1 Baud Rate Generator | 62 | | | | 9.2.2 Abort Sequence | 63 | | | | 9.2.3 PPS Receiver | 63 | | | 9.3 | Serializer/Deserializer | 64 | | | ~1 | | | | 10 | Cha | ingelog | 64 | | | | | | | L | ist ( | of Tables | | | | | 01 165165 | | | | 1 | Digital Board Counters, frontend L2 triggers | 22 | | | 2 | Digital Board Counters, SEU Errors | 23 | | | 3 | Digital Board Counters, communication | 23 | | | 4 | Digital Board, Trigger Counters | 24 | | | 5 | Digital Board, UART | 24 | | | 6 | Analog Housekeeping Readings | 27 | | | 7 | Parameters to extract from the register readout packet. Offset | | | | | is in bytes, length is in bits | 29 | | | 8 | Frontend parameters | 31 | | | 9 | Event Pulse Height Packet Format | 32 | | | 10 | L3 Data Set Format | 33 | | | 11 | L3 instruction opcodes | 38 | | | 12 | Sample Packet Format | 40 | | | | | 43 | | | 13 | Cadence Modulus Table | | | | 14 | Encoding Format without Drop | 48 | | | 15 | Encoding Format with Drop=3 | 49 | | | 16 | Input and Output Ports | 52 | | | 17 | Engineering to Flight Mapping of Memory Ports | 57 | # List of Figures | 1 | Proposed LVDS Termination Circuit | 54 | |---|-----------------------------------|----| | 2 | LV-PECL Termination Schematic | 55 | # 1 Introduction The HET/EPT sensor employs two FPGAs, one each on the analog and the digital boards. The FPGA on the analog board will control the ADCs, perform digital filtering, L1 and L2 trigger processing, and housekeeping acquisition. The digital board FPGA is described in this document. # 2 Mode of Operation The operations of the FPGA are grouped in three threads of execution: - 1. data acquisition, - 2. data checkout, and - 3. slow control. All functions are controlled via command messages and a *Pulse Per Second* (PPS) signal. Both command messages and PPS signals can be received from the ICU and generated autonomously in the FPGA. During nominal operation, the PPS is received once per second from the ICU and the necessary command messages are generated inside the FPGA synchronized to the PPS. No command messages from the ICU are required during nominal operation. Command messages for configuration and slow control need to be send by the ICU via LVDS serial communication. ### 2.1 Data Acquisition Data acquisition involves - 1. reception of event data packets from the analog FPGA, - 2. buffering (up to four packets), - 3. L3 trigger processing, - 4. histogram counting, and - 5. PHA data storage. Histograms and PHA data are stored in the external SRAM. The storage areas are double buffered, one buffer for acquisition and one being checked out for telemetry. Once configured and enabled, the data acquisition operates completely autonomously. #### 2.2 Data Checkout In parallel to the data acquisition, the checkout proceeds from data acquired previously. The execution of the checkout is controlled by a command table in the PPS scheduler. The scheduled tasks include - starting and stopping data acquisition between acquisition periods, - switch buffers between acquisitions, - perform analog housekeeping acquisitions and telemetry, - send counters and other status housekeeping, - send PHA data buffers, - kick the operational heater, - reconfigure the frontend, to clear out SEU, - calculate and send histogram data telemetry. #### 2.3 Slow Control Once configured and operational, there shall be no or very little commanding of the sensor from the ICU. Tasks that may arise during operation include • changing trigger parameters, - initiate diagnostic telemetry, or - writing new data into the EEPROM. Writing into configuration memory to tune trigger parameters should be safe at any time as long as the changes do not change the trigger algorithm and leave the trigger operational between all writes. The analog frontend configuration is not normally changed directly, but stored in the PPS scheduler and updated once per second between acquisitions. Diagnostic telemetry must not be initiated during telemetry checkout, else the data streams collide and garbage is emitted. The PPS schedule shall include spots that are reserved for synchronous actions, like EEPROM page write or diagnostic telemetry. The command to execute the action will be written into reserved slots in PPS schedule table. A further entry in the table will automatically clear the command message from the table after is was emitted, so it will be executed only once. Writing EEPROM pages is safe as long as the memory port occupation does not interfere. EEPROM access is rather slow and blocks the external memory bus. The execution of the EEPROM page write shall be synchronized to the PPS schedule. ### 2.4 Command Messages A command message includes three items: - an address (14 bit), - a size tag (2 bits), and - a data word (64 bits). The address identifies the recipient of the message. The size tag indicates how many bits shall be interpreted from the data word: - 0: zero bits, - 1: 16 bits, - 2: 32 bits, or - 3: 64 bits. Most recipients ignore the size tag and just accept as much of the data word as they need. Bits beyond the indicated size are expected to be zero. #### 2.4.1 Serial Commands via LVDS Messages are received from the ICU via LVDS signaling through a UART operating at 115 200 baud. The serial message format is specific to the Kiel sensor units: | 0x 3c3d | |----------------------------------------------------| | $\langle sz \rangle$ $\langle address \rangle$ | | | | | | | | $\langle data \rangle (\langle sz \rangle \geq 1)$ | | < <i>crc&gt;</i> | The CRC is computed according to the following parameters as defined in http://www.ross.net/crc/download/crc\_v3.txt $$\begin{array}{ll} \text{WIDTH} &= 16 \\ \text{POLY} &= 0 \text{x} \, 1021 \\ \text{INIT} &= 0 \text{x} \, \text{ffff} \\ \text{REFOUT} &= 0 \\ \text{REFIN} &= 0 \\ \text{XOROUT} &= 0 \text{x} \, 0000 \end{array}$$ Only as many data words are transmitted as indicated by the $\langle sz \rangle$ tag. The received message data is padded to the left with zeros to fill 64 bits. Word and byte ordering is big endian. #### 2.4.2 PPS scheduled messages The PPS scheduler emits messages that are indistinguishable from serially received messages, i.e., the recipients cannot tell where they came from. There is only one difference: the PPS scheduler can emit data words with nonzero bits beyond the indicated size. That should not matter, because those recipients that do look at the size tag ignore the data beyond the indicated size. # 2.5 Master Control Message A message to address $0x\,0000$ issues strobes<sub>64</sub>. These are simple command pulses to trigger some action or effect. Most of the strobes set or clear enables<sub>8</sub> or confs<sub>16</sub> bits, so these act more like master control registers. $strobes_{64}[23:16]$ set the corresponding bits in $enables_8$ . $strobes_{64}[31:24]$ clear those bits. A bit that is both to be set and cleared will be toggled. Similarly, $strobes_{64}[47:32]$ set, and $strobes_{64}[63:48]$ clear bits in $confs_{16}$ . Most bits in $confs_{16}$ are unused. #### Command message: | 3 | C | 0x 0000 | | | |----|-------------|--------------|----------------------|---------------------| | | clr c | $onfs_{16}$ | set co | $\mathfrak{s}_{16}$ | | c] | Lr enables8 | set enables8 | actions <sub>8</sub> | resets <sub>8</sub> | ### 2.6 Link to the Analog Board Communication between the digital board FPGA and the analog board FPGA goes over synchronous serial links, with a data and a clock signal for each direction, with LVDS signaling. The clock frequency is 48 MHz. The clock towards the analog board is used as the master clock of the analog FPGA. The serial links employ 20-bit frames to transfer 16-bit words over two channels. Two bits provide a synchronization edge, one bit selects the channel, one bit can be used for line balancing, but here it is just toggled for each frame. #### Synchronous serieal link frames: | 1 | 0 | i | c | | | | | | | < da | ta | > | | | | | | |---|---|---|---|-----|-----|-----|---|---|---|------|-----|---|---|---|---|---|-----| | | | | | 4 1 | - 1 | - 1 | 1 | 1 | 1 | - 1 | 1 1 | | ı | 1 | 1 | 1 | - 1 | Bit c is zero for control channel data and one for stream channel data. When no data is to be sent, the link transfers a control message of zero. When the i bit is set, all the remaining bits of the frame are inverted. A stream of control messages zero will include exactly one falling edge per frame, regardless of the i-bit. Link synchronization can always be immediately recovered when the link is idle. These links provide four channels, two in each direction, which operate all independently. Control Digital to Analog: Enables and strobes, Stream Digital to Analog: command messages, Control Analog to Digital: status and configuration readback, and Stream Analog to Digital: data acquisition. #### 2.6.1 Command Messages to the Analog Board Command messages can be sent to the analog board FPGA via the stream channel. The messages complies to the IRENA command format, with 14 address bits and none or 16 data bits. | Ρ | Ana | lo | g Board | Command Messag | <u>z</u> ∈ | | | | | | | |---|-------|----|-------------------|---------------------------|------------|--|--|--|--|--|--| | | 1 p | 0 | $0_{1}0_{1}0_{1}$ | $\langle address \rangle$ | | | | | | | | | Г | .7.4. | | | | | | | | | | | The $\langle data \rangle$ frame is only present when the p bit is set. The analog board responds to a subset of the address range with 10 valid address bits, and four most significant bits zero. There are two ways to generate messages to the analog board, either with the command message described here, or with an analog readback command described in section 3.5. #### Command message: | $\langle sz \rangle 0 1 0 0 \langle address \rangle$ | | |------------------------------------------------------|--------------------| | <data 3=""></data> | <data 2=""></data> | | <data 1=""></data> | <data 0=""></data> | If the command has $\langle sz \rangle = 0$ , a message without data is sent. Otherwise the command data is send in multiple messages to consecutive addresses on the analog board. The word ordering is little endian. #### 2.6.2 Analog Board Responses When the analog board returns data in response to a command messages, the data is sent through the control channel, using two frames per 16-bit data word. Each returned word is prefixed with a fixed header. This allows to distinguish data words with content zero from the idle link. The analog board returns data only when it receives an analog readback command described in section 3.5. #### 2.6.3 Analog Frontend Control The control channel to the analog board is used to send states and strobes. The channel can support up to 15 state bits and up to 15 strobes. When a strobe needs to be sent, a control word is sent with the most significant data bit zero, and the strobe set in the corresponding bit position. ``` a strobes<sub>16</sub>[1]=strobes<sub>64</sub>[14]: random, trigger, a strobes<sub>16</sub>[3]=strobes<sub>64</sub>[3]: timestamp clock reset, a strobes<sub>16</sub>[13]=strobes<sub>64</sub>[4]: readback FIFO reset, ``` ``` a strobes<sub>16</sub>[14]=strobes<sub>64</sub>[5]: data FIFO reset. ``` Every few microseconds, the digital board will send a control message with the most significant data bit set. The remaining bits are enable bits which will be latched by the analog board to control is operations. ``` a states<sub>16</sub>[0]=enables<sub>8</sub>[5]: analog master enable, a states<sub>16</sub>[1]=confs<sub>16</sub>[1]: samples mode enable, a states<sub>16</sub>[3]=enables<sub>8</sub>[4]: timestamp clock enable, a states<sub>16</sub>[13]=confs<sub>16</sub>[6]: readback disable, a states<sub>16</sub>[14]: event buffer full. ``` #### 2.6.4 Analog Trigger Event Data The stream channel from the analog board is used to transfer trigger event data packets. Two types of packets are supported, pulse height event packets, and sample packets. When sample packets are enabled, the analog board will not send pulse height event packets. #### 2.6.5 High Speed Calibration Mode In nonflight operation during calibration campains it is very desirable to acquire data at high rate from the analog board. For this purpose it is possible to send the data stream from the analog board directly to the redundant LVDS link. This mode is enabled by setting bit $confs_{16}[0]$ . Reception of commands in the redundant receiver is not impacted by activating high speed mode. The data and clock from the analog board are time multiplexed on the single redundant line. A microframe of four bits at 96 Mbps consists of the sequence 0, 1, A, and B, with two data bits A and B. The GSE samples the stream at 384 MHz, identifies the rising edges, and extracts data and clock, which are then decoded by an instance of the same module as present in the digital board FPGA. # 3 Telemetry packets Telemetry emitted by the FPGA is tagged with an APID. Eight bits xx of the APID can be arbitrarily configured for each packet emitted. These bits shall steer the processing of the packet in the ICU. The upper eight bits distinguish the included data types: 0x 01xx: Register readout. 0x 03xx: Histogram data. 0x 05xx: Memory readout. 0x 08xx: Frontend readout. 0x 57EA: L2 streaming. (TBC) The last packet type shall not ever be issued when the sensor is integrated. These packets are issued in L2 streaming mode, where all frontend data packets are sent directly to the serial line. This function will be used for sensor calibration. This mode is someimes referred to as *Slow Speed Streaming*, to distinguish it from the *High Speed Streaming* of the analog board bitstream via the redundant channel. #### 3.1 Serial Packet Format Telemetry packets are sent to the ICU in the STF packet format defined for EPD. The first two bytes of the STF packet payload is the APID. | 0x beba | | | | | | | | | | | | |------------------------|--|--|--|--|--|--|--|--|--|--|--| | 0x cafe | | | | | | | | | | | | | 0, 0, 0 $n+4$ | | | | | | | | | | | | | $\langle apid \rangle$ | | | | | | | | | | | | | <data></data> | | | | | | | | | | | | | | | | | | | | | | | | | | < <i>crc&gt;</i> | | | | | | | | | | | | # 3.2 Register Readout A register readout is initiated with a corresponding command message. The message address is the same as the issued APID, i.e., $0 \times 01xx$ . The message shall have 16 bits of data, which select from a set from 16 items to be sent in the resulting telemetry packet. Each item results in 64 bits of data. | Con | Command message: | | | | | | | | | | | | | | |-----|------------------|---|---|-----|---|---|---|---|---|---|-----|---|---|---| | 1 | | ı | 0 | x0: | 1 | | | | ı | | xx | | ı | ı | | | ı | ı | ı | ı | ı | ı | ı | ı | ı | ı | _3_ | 2 | 1 | 0 | The items selected by the given bit number are 0: status and error registers, 1: address registers, - 2: modulus timer registers, - 3: scratch register, - 4: Nominal Uart and PPS status. - 5: Redandant UART and PPS status. - 6: heater registers, All other items are reserved, they return zeros. #### 3.2.1 Status and Error Registers confs<sub>16</sub> and enables<sub>8</sub> are control bits that are set and cleared with a master control message. version<sub>8</sub> is a constant identifier of the FPGA and the version of the code. errors<sub>8</sub> are bits that are set when something happened. #### Register 0 Readout: | trigger | $class_{16}$ | con: | $fs_{16}$ | |-------------------|----------------------|----------------------|---------------------| | misc <sub>8</sub> | enables <sub>8</sub> | version <sub>8</sub> | errors <sub>8</sub> | The $misc_8$ bits are zero, except for bit $misc_8[0]$ , which is the state of the EEPROM BUSY signal. The error bits are cleared by $strobes_{64}[7]$ . errors<sub>8</sub>[7:6]: 0 (unused) errors<sub>8</sub>[5]: lost synchronization to analog board, errors<sub>8</sub>[4]: ATBRK received, errors<sub>8</sub>[3]: single-bit error in the external SRAM, errors<sub>8</sub>[2]: multi-bit error in the external SRAM, errors<sub>8</sub>[1]: single-bit error in FPGA RAM, $errors_8[0]$ : multi-bit error in FPGA RAM. #### 3.2.2 Address Registers These are address pointers for various memory related operations. #### Register 1 Readout: | 0 | dum | $\operatorname{pp}\operatorname{page}_{12}$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | |------------------------|-----------------------|---------------------------------------------|-------------------------------------------------------| | miscpage <sub>19</sub> | enc page <sub>6</sub> | pha base7 | pha page <sub>12</sub> | #### 3.2.3 Modulus Timer Registers All of the FPGA's notion of time. #### Register 2 Readout: | i fini <sub>3</sub> | $ $ init $_3$ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ | $\begin{smallmatrix} \mod count_{12} \\ \vdash $ | |---------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | usec | $ond_{24}$ | The i bit set when the PPS scheduler is not active. The modulus scheduler counts $\mu$ seconds divided down from the FPGA clock. At each $\mu$ second it issues a tick. Messages from the PPS scheduler are issued in phase with the $\mu$ second tick, messages from the ICU are delayed to fall in the middle of the tick period, to not collide with PPS scheduler messages. The EEPROM page write delays are derived from the $\mu$ second tick. A PPS or $strobes_{64}[2]$ resets the $\mu$ seconds counter. The counter is 24-bits long, so we can support PPS intervals up to 16 seconds. The modulus scheduler counts seconds (as defined by the PPS interval) in a cycles of length 3600, i.e., one hour. The $mod count_{12}$ reflects the current second within that cycles. The cycle is reset by a $strobes_{64}[1]$ . The cycle is factored into seven data acquisition cadence counters $$3600 = 5 \times 2 \times 3 \times 2 \times 5 \times 2 \times 6$$ Three moduli in the range 0...7 mark significant times in the cycle. $mod_3$ marks the beginning of a data acquisition cadence periods. All cadence levels at or below $mod_3$ are beginning in the current second. fini<sub>3</sub> marks the end of the cadence periods. All cadence levels at or below fini<sub>3</sub> end in the current second. This modulus tells how many data products are generated in the current second. init<sub>3</sub> is a rather complicated modulus used to initialize encoding sequences. All encoded data product with acquisition cadence equal fini<sub>3</sub> and encoding cadence at or below init<sub>3</sub> will initialize an new compression sequence in this second. fini<sub>3</sub> and init<sub>3</sub> are part of the science data packet headers. The parser obviously needs to know these moduli to decode the data bitstream. #### 3.2.4 UART Status The status of the UART and PPS receiver. #### Register 4/5 Readout: | uart status9 | 0 | ppsflags7 | | $\mathtt{length}_{16}$ | 1 1 1 | |-----------------|-----------|----------------------|---------|------------------------|-------| | $length_{16}$ 0 | 1 1 1 1 1 | period <sub>26</sub> | 1 1 1 1 | 1 1 1 1 | 1 1 1 | ``` uart status<sub>9</sub>[8]: AT-break active. uart status 9[7]: RX break active. uart status_9[6]: RX busy. uart status<sub>9</sub>[5]: RX active. uart status_9[4]: RX frame error. uart status<sub>9</sub>[3]: RX line status. uart status<sub>9</sub>[2]: PPS line status. uart status_9[1]: TX empty. uart status_9[0]: TX break (not used, alway zero). ppsflags<sub>7</sub>[6]: PPS is good. ppsflags<sub>7</sub>[5]: PPS is selected. pps flags<sub>7</sub>[4]: PPS is too seldom, i.e., two PPS received on the other line. pps flags<sub>7</sub>[3]: PPS is too long, longer than 500 \,\mu s. pps flags<sub>7</sub>[2]: PPS is too short, shorter than 1 \mu s. pps flags<sub>7</sub>[1]: PPS is too fast, more than 5 ms too early. ppsflags<sub>7</sub>[0]: PPS is too slow, more than 5 ms too late. length<sub>16</sub>: PPS length, in units of 24 MHz clocks. period<sub>26</sub>: PPS period error, in units of 24 MHz clocks. ``` #### 3.2.5 Heater Registers The temperature, resulting duty cycle of the operational heater, and remaining heater time in PWM cycles. See section 5. ### Register 6 Readout: | 0 | · · · · · · · · · · · · · · · · · · · | duration <sub>24</sub> | |---|---------------------------------------|------------------------| | 0 | dutycycle <sub>8</sub> | ) temp $_{12}$ | ## 3.3 Histogram Data A command message to the *Data Product Scheduler* (DPS) will initiate the assembly of a histogram data packet. These are the main data products of the sensor. Command message: | 3 | | ı | ۱, | )x() | 3 | ı | | | | $x_{\mid}x$ | : | <br>ı | | | | | | | | | | | |---|---|---|----|------|---|---|--------|-----|----|------------------|---|-------|---|-------|---|-------|---|---|---|-----|--------------------|----------| | | ı | | | | | L | | L | | | | ı | ı | ı | | <br>1 | ı | ı | ı | | $flg_2$ | $tmod_3$ | | | 1 | _ | , | | | ı | <br>ad | ldŗ | eș | s <sub>1,1</sub> | 1 | <br>, | | <br>1 | , | 1 | 1 | | | cou | $\mathtt{nt}_{12}$ | | This command instructs the DPS to execute $count_{12}$ items starting at address<sub>11</sub> from the data products table. If the current modulus is at least $tmod_3$ , the resulting data will be sent in a telemetry packet. The payload of the data packet is a stream of items with varying bit sizes, starting with an 8-bit header telling the cadence modulus, followed by optionally compressed histogram counter sums. The last byte is filled with unspecified bits. The format of the header is The flg<sub>2</sub>-bits from the command message are included in the 8 bit packet header. They carry no semantics within the sensor unit and can be used to multiplex up to four data product streams into one CCSDS telemetry packet stream. The packet is assembled in a special telemetry FIFO, to establish the packet size before transmission is started. This FIFO can assemble packets of up to $2\,\mathrm{kBytes}$ . #### 3.3.1 Data Product Scheduler A table with 2048 entries configures individual histogram window sums. A window sum is calculated as the sum of histogram counters from a 2-dimensional region in the external memory. Data Product Table Item: | | | ystrid | 916 <sub>1 1 1 1 1</sub> | | 1 1 2 | size <sub>8</sub> | | xsize <sub>8</sub> | |---------------|---------|---------------------------------|--------------------------|-----|-------|-------------------|----|--------------------| | ${\sf res}_3$ | $enc_3$ | $\operatorname{\mathtt{sum}}_3$ | $c$ $t$ $a$ $comp_2$ | 1 1 | | addr | 18 | | Three bits have these meanings: - c: Clear each histogram memory word after reading. - t: Send the result to the telemetry. - a: Add the result of the previous data product. The c-bit is used to clear the histogram memory for the next acquisition. The DPS can be started with a message-id $0 \times 02xx$ , instead of $0 \times 03xx$ , which will prevent the assembly of a data packet, e.g., for clearing a memory region. The a-bit can be used to build more complex data products. An item with the a-bit shall follow an item without the t-bit. The first sum is not sent for compression, but included in the following data item. The memory window is defined by $\mathtt{addr}_{18}$ , $\mathtt{xsize}_8$ , $\mathtt{ysize}_8$ , and $\mathtt{ystride}_{16}$ . The sum starts at $\mathtt{addr}_{18}$ . The address is incremented $\mathtt{xsize}_8$ times by one. Then it is incremented by $\mathtt{ystride}_{16}$ and the run through the x is repeated. The $\mathtt{ystride}_{16}$ increment happens $\mathtt{ysize}_8$ times. The total number of memory locations being added is $$(x \operatorname{size}_8 + 1) \times (y \operatorname{size}_8 + 1)$$ The MSB of the memory address is the complement of enables<sub>8</sub>[3], i.e., the hist page bit, selecting the part of memory not currently used for data acquisition. #### 3.3.2 Data Compression A data item that has the t-bit set is sent to the compression engine. The compression is controlled by $sum_3$ , $enc_3$ and $res_3$ . The DPS will execute every second. Most data products shall be produced at a longer cadence. The sum<sub>3</sub> modulus tells the compressor for how long to sum the data before transmission. The data packet will be generated every second, but include only data items that have run their summing period. The modulus values are given in Table 13 on page 43. The res<sub>3</sub> modulus shall be the same as the sum<sub>3</sub> modulus. If res<sub>3</sub> has a lower value than sum<sub>3</sub>, a sparse count rate is produced. The data is generated at the cadence specified in sum<sub>3</sub>, but the counter is reset at the cadence given in res<sub>3</sub>. Counts before the last reset are lost. If res<sub>3</sub> has a larger value than sum<sub>3</sub>, the data sent will accumulate over multiple data items. This does not work with compression. The enc<sub>3</sub> modulus tells the compressor for which stretches of time the lossy running difference compression shall be applied to the stream of counts. If enc<sub>3</sub> is not larger than sum<sub>3</sub>, the data will be send unencoded according to the format specified in comp<sub>2</sub>. Otherwise they are subject to further compression. The compression cycle is reset at the cadence given by enc<sub>3</sub>. The compressor maintains a data record for each data product in main memory. Each record occupies four words. The base address is configured in encpage<sub>6</sub>, i.e., bits [18:13] of the memory address. If a telemetry packet includes only data products that require summing, i.e., all $sum_3 > 0$ , the data packets between the sums would include only the 8-bit header. The DPS shall be started with $tmod_3$ equal to the smallest $sum_3$ , to suppress these empty telemetry packets in between. #### 3.3.3 Unencoded Data Most science data will be encoded with variable bit sizes. The format of unencoded data is defined with two bits comp<sub>2</sub>, selecting one of four representations for the counters. The unencoded data is unsigned. comp<sub>2</sub>=00: 16 bit unsigned floating point, 4-bit exponent. $comp_2=01$ : 8 bit representing $8 \cdot (\log_2(c) + 1)$ . $comp_2=10$ : 24 bit unsigned integer. comp<sub>2</sub>=11: encoded uncompressed counter. The format of an unsigned 16-bit float is The represented counter value is $$\begin{split} C &= \mathtt{mant}_{12} & \text{for} \quad \mathtt{exp}_4 = 0, \\ C &= (\mathtt{mant}_{12} + 2^{12}) \cdot 2^{\mathtt{exp}_4 - 1} & \text{for} \quad \mathtt{exp}_4 > 0. \end{split}$$ The floating point or $\log_2$ representations do not need to be converted to plain integers for comparisson to some threshold. The $\log_2$ representation can be used in trigger or monitoring logic for ratio cuts. # 3.4 Memory Readout The memory readout engine can read words from various sources: - external SRAM. - external EEPROM. - configuration tables in the FPGA - PPS schedule table, - data products table, - L3 code memory, - counters. Readout is initiated with #### Command message: | 3 | 0x05 | | |---|-----------------------|----------------------| | | 1 1 1 1 1 1 | count | | | $\dots$ count $_{11}$ | ${\tt address}_{24}$ | The read data will be packed into a telemetry packet. Using message address $0 \times 04xx$ will also perform the reads of the memory, but not transmit a packet. This can be used to perform EDAC scrubbing on configuration memories. Which memory is read and how the final memory addresses are calculated is encoded in address<sub>24</sub>. The number of words read is count<sub>11</sub>. The word size depends on the kind of memory or is encoded in address<sub>24</sub> as well. The telemetry packet payload is prefixed with 32 bits #### Memory readout header: | counts | $address_{2A}$ | |--------|----------------| | | | Three most significant bits of $count_{11}$ are omitted. The address<sub>24</sub> is the calculated read address of the first data word. This may be different from the address<sub>24</sub> given in the command message. ### 3.4.1 External SRAM The external SRAM is read in words of 32 bits. No EDAC decoding is performed. The most significant bits of address<sub>24</sub> encode how the address shall be calculated: 0x8aaaaa: direct addressing,0x9aaaaa: histogram page, OxAaaaaa: PHA page, OxBaaaaa: misc page<sub>18:0</sub> indexed. Direct addressing leaves the given address unchanged. Histogram page access selects the half of the SRAM which is not currently being used for data acquisition, unless address<sub>24</sub>[18] is set, to access the active half. For PHA page readout, three bit ranges of the memory address are replaced, based on the content of the phabase<sub>18:12</sub> and phapage<sub>11:0</sub> registers. phabase<sub>18:12</sub> points to the memory where PHA data is being stored by data acquisition. Readout address bit 18 is the complement of phabase[18]. Address bits [17:12] are replaced by the corresponding bits from phabase. The lowest 12 bits are the sum of the address given in the command message and the phapage register. The miscpage<sub>18:0</sub> register can be used for dribble readout of large memory regions. The same readout command is issued repeatedly from the PPS schedule, followed by an appropriate increment of the miscpage register. For PHA data readout the phapage register can be used in this fashion. #### 3.4.2 EEPROM Readout Readout of the EEPROM yields bytes, i.e., 8-bit words. Two modes are supported: Ox Caaaaa: direct addressing, Ox Faaaaa: misc page<sub>18:0</sub> indexed. #### 3.4.3 Configuration Table Readout The configuration tables are stored in 72-bit wide memory blocks inside the FPGA. Eight bits are used for EDAC redundancy, leaving 64-bits of information. Readout yields error corrected 64-bit words. Dribble readout is available via the dumppage11:0 register: 0x0C2aaa: direct addressing, 0x2C2aaa: dumppage<sub>11:0</sub> indexed. The address ranges are 0x 0C2400-0x 0C25FF: L3 code. 0x 0C2600-0x 0C26FF: PPS schedule table. 0x 0C2800-0x 0C2FFF: data products table. The word size is encoded in $address_{24}[19:18]$ of the command message (0x 0c). If a smaller word size is specified, the words will be only partially transmitted. Don't do that. #### 3.4.4 Counter Readout The FPGA keeps a set of 128 counters in a memory block of width 36 bit. After EDAC correction the counters are 29 bits wide. dump page 11:0 indexing is available: 0x0800aa: direct addressing, 0x2800aa: dumppage<sub>11:0</sub> indexed. The word size is encoded in $address_{24}[19:18]$ . For the counter readout, three word sizes are implemented: $0 \times 0800 aa$ : 32-bit unsigned integers. 0x 0400*aa*: 16-bit unsigned floating point, 12-bit mantissa, 0x 0000*aa*: 8-bit unsigned floating point, 3-bit mantissa. Tables 1 to 5 list the counters provided by the HET-EPT digital board. Unused counters up to index 127 are present, but nothing increments them. Only one counter can increment per clock cycle. An event to be counted will be latched until it gets access to the counter memory. When further events for the same counter occur before it could be submitted, the additional events will be lost. Table 1: Digital Board Counters, frontend L2 triggers | Index | Description | |-------|-------------------------------------------------| | 0 | $\times 1$ triggers lost on the analog board. | | 1 | $\times 2$ triggers lost on the analog board. | | 2 | $\times 4$ triggers lost on the analog board. | | 3 | $\times 8$ triggers lost on the analog board. | | 4 | $\times 16$ triggers lost on the analog board. | | 5 | $\times 32$ triggers lost on the analog board. | | 6 | $\times 64$ triggers lost on the analog board. | | 7 | $\times 128$ triggers lost on the analog board. | | 8 | L2 #0 triggers. | | 9 | L2 #1 triggers. | | 10 | L2 #2 triggers. | | 11 | L2 #3 triggers. | | 12 | L2 #4 triggers. | | 13 | L2 #5 triggers. | | 14 | L2 #6 triggers. | | 15 | L2 #7 triggers. | #### 3.4.5 Memory Index Registers The memory index registers are manipulated by command messages. The values are read via register readout telemetry item 1. histbase<sub>[18]</sub>=enables<sub>8</sub>[3]: This bit is used as address bit [18] for histogram data acquisition. phabase<sub>18:12</sub>: Base address for PHA data storage. Table 2: Digital Board Counters, SEU Errors # Index Description - 16 Counter memory uncorrectable SEU errors. - 17 Telemetry FIFO uncorrectable SEU errors. - 18 L3 register uncorrectable SEU errors. - 19 Data product schedule uncorrectable SEU errors. - 20 L3 trigger code uncorrectable SEU errors. - 21 PPS schedule uncorrectable SEU errors. - 22 (unused) reserved for frontend SEU errors. - 23 SRAM uncorrectable SEU errors. - 24 Counter memory single bit SEU errors. - 25 Telemetry fifo single bit seu errors. - 26 L3 register single bit SEU errors. - 27 Data product schedule single bit SEU errors. - 28 L3 trigger code single bit SEU errors. - 29 PPS schedule single bit SEU errors. - 30 (unused) reserved for frontend SEU errors. - 31 SRAM single bit SEU errors. Table 3: Digital Board Counters, communication #### Index Description - 32 PPS accepted. - 33 PPS received via message. - 34 PPS received via 1 Hz clock from ICU. - 35 Data product packets. - 36 Memory readout packets. - 37 Register readout packets. - 38 Frontend readout packets. - 39 Packet collisions. - 40 messages received from ICU. - 41 messages executed from PPS schedule. - 42 EEPROM bytes written. - 43 EEPROM bytes read or written. - 44 ATBRK received, errors<sub>8</sub>[4]. - 45 Lost analog board sync., errors<sub>8</sub>[0]. - 46 Unused. - 47 Unused. Table 4: Digital Board, Trigger Counters | Index | Description | |-------|-----------------------------------------| | 48 | Lost events received from the frontend. | | 49 | Data products encoded. | | 50 | L3 trigger started. | | 51 | PHA records stored/counted. | | 52 | Histogram windows computed. | | 53 | Histogram bin increments. | | 54 | Triggers received for class 0. | | 55 | Triggers received for class 1. | | 56 | Triggers received for class 2. | | 57 | Triggers received for class 3. | | 58 | TFIFO put while pushing. | | 59 | TFIFO init while sending. | | 60 | Window sum valid. | | 61 | Floating point result valid. | | 62 | $\log_2(c)$ result valid. | | 63 | Compression result valid. | Table 5: Digital Board, UART | Index | Description | |-------|--------------------------------------------| | 64 | Valid bytes received. | | 65 | Invalid bytes received (STOP bit missing). | | 66 | Messages received. | | 67 | Message header format errors. | | 68 | Message timeouts. | | 69 | CRC errors. | | 70 | FIFO uncorrectable SEU errors. | | 71 | FIFO single bit SEU errors. | | 72 | Streaming mode: packet lost. | | 73 | Streaming mode: packet init. | | 74 | Streaming mode: packet submit. | | 75 | Streaming mode: packet put. | | 76 | Unused. | | 77 | Unused. | | 78 | Unused. | | 79 | Unused. | | | | phapage<sub>11:0</sub>: Index register for PHA readout. miscpage<sub>18:0</sub>: Index register for external memory dribble readout. dump page<sub>11:0</sub>: Index register for internal memory dribble readout. encbase<sub>18:13</sub>: Base address for the data compression memory. And there is a scratch<sub>64</sub> register, which has no function at all, but shall be used as a versioning tool to inject into the telemetry, to help the parsers on the ground to figure out what configuration was used. The scratch<sub>64</sub> register is returned as readout item 3. To manipulate the index registers the command message addresses are ``` 0x 0004: pha base_{18:12}, pha page_{11:0} = \text{data}_{18:0}. 0x 0005: pha page_{11:0} = \text{data}_{11:0}. 0x 0006: pha base_{18:12} += \text{data}_{18:12}, pha page_{11:0} += \text{data}_{11:0}. 0x 0007: enc base_{18:13} = \text{data}_{18:13}. 0x 0008: misc page_{18:0} = \text{data}_{18:0}. 0x 0009: misc page_{18:0} increment. 0x 0000A: dump page_{11:0} = \text{data}_{11:0}. 0x 000B: dump page_{18:0} increment. 0x 000F: scratch_{64} = \text{data}_{64}. ``` hist base<sub>[18]</sub> is set or cleared with strobes from a master control message. The MSB of phabase<sub>18:12</sub>[18] can be toggled with strobes[11]. The miscpage<sub>18:0</sub> and dumppage<sub>18:0</sub> increment commands allow for quite a bit of flexibility to control the memory regions covered. The message data provides an increment amount, two masks, and a constant. | | $\mathtt{miscpage}_{18:0}$ | $\mathtt{dump}\mathtt{page}_{18:0}$ | |--------------------------------------------|----------------------------|-------------------------------------| | $<\!\!increment\ value\!\!>$ | $\mathtt{data}_{18:0}$ | $\mathtt{data}_{11:0}$ | | <pre><increment mask=""></increment></pre> | $\mathtt{data}_{50:32}$ | $\mathtt{data}_{27:16}$ | | $<\!\!keep\ mask\!\!>$ | $\mathtt{data}_{50:32}$ | $\mathtt{data}_{43:32}$ | | $<\!\!constant\!\!>$ | | $\mathtt{data}_{59:48}$ | The index register will be incremented by the *<increment value>*. All bit positions not set in the *<increment mask>* will be cleared from the sum. All bit positions set in the *<keep mask>* will be keep from the old value of the index register. Finally, all bits set in *<constant>* will be set in the index register. Let's see how much of this is useful. #### 3.5 Frontend Readout A message to address 0x1ff on the analog board will initiate the return of an analog readback packet to the digital board. This data stream will normally be ignored by the digital board. A special analog readback command message can be used as an alternative way to issue such a readback message to the analog board #### Command message: | 2 | 0x.08 | | | |---|-----------|-------------|------------------------| | | 1 1 1 1 1 | tempoffset8 | ${\sf itemsmask}_{15}$ | This command will save the telemetry tag xx and enable the transmission of the next analog readback packet wrapped into a telemetry packet with APID 0x 08xx. The analog readback packet includes the items mask<sub>15</sub> as first data word. The digital board FPGA will use the returned mask to calculate the size of the packet. So, unfortunately, the engine that forwards the analog readback needs to have hardwired knowledge of the size of the items that may be returned. #### 3.5.1 Analog Readout Items The bits in the items mask<sub>15</sub> select the items that shall be returned. The items are variable sized blocks of 16-bit words. - 0: Filter configuration, 8 words. - 1: Trigger configuration, 92 words. - 2: Timestamp clock, 2 words. - 3: HK ADC readout, packed, 12 words. - 4: HK ADC readout, unpacked, 16 words. - 5: Raw sample peek, 30 words. - 6: Pulse height peek, 30 words. - 7: Pulse phase peek, 30 words. - 8: Single channel trigger counter read, 30 words. - 9: Single channel trigger counter read and clear, 30 words. - 10: Single channel trigger counter clear only, 0 words. Bits [14:11] are unused/reserved. The items are send starting with the highest selected bit. #### 3.5.2 Analog Housekeeping Sixteen ADC readings with 12-bit resolution are returned either packed, or unpacked one reading per words with the channel number prefixed. Table 6: Analog Housekeeping Readings HET preamp temperature - 1 500 EPT preamp temperature 2 401 HET VREF, $+2.5 \,\mathrm{V}$ 3 501 EPT sensor temperature 4 402 HET sensor temperature 1 5 502 EPT VFET/2, +5 V 6 403 HET VFET/2, +5 V 7 503 EPT VANA/2, +6 V 8 404 HET sensor temperature 2 9 EPT VREF, $+2.5 \,\mathrm{V}$ 504 405 Shaper VCC/2, +5V10 11 505 Bias Current - 12 406 Power board t - 12 406 Power board temperature - 13 506 Bias Voltage 400 - 14 407 Analog board temperature - 15 507 Digital board temperature #### 3.5.3 Temperature Capture To control the operational heater, it may be necessary to know the temperature of the sensor unit. Among the items that can be returned from the analog board are readings of voltages and temperature sensors. When the tempoffset<sub>8</sub> field in the command message is non-zero, it will be used as a word offset into the returned analog readback packet. Twelve least significant bits from the indicated word will be copied to the temp<sub>12</sub> register. The tempoffset<sub>8</sub> shall point to a word from an unpacked HK ADC readout. Some packed HK ADC readout channels may also work if they are properly aligned. To capture a temperature from an analog readout packet without issuing a telemetry packet, the command message can be issued with address $0 \times 09xx$ instead of $0 \times 08xx$ . #### 3.5.4 Peeking The digital filter continuously issues pulse height reconstruction parameters and raw ADC samples for each data acquisition channel. Peek readout cap- tures a set of these values. Raw sample peek returns a set of ADC samples, to diagnose problems with the analog signal baselines. Pulse height/phase peeks may be useful to estimate noise amplitudes. The digital filter needs to be enabled via enables<sub>8</sub>[5] for any peek to yield the expected data. #### 3.5.5 Single Channel Trigger Counters Each signal channel has a counter that increments when its L1 trigger threshold is exceeded. The counters can optionally be cleared after reading, or even be cleared without reading. The counters values are provided in 16-bit unsigned floating point representation with 12-bit mantissa. ### 3.6 L2 Streaming When the data acquisition is enabled on the analog board, a trigger event packet is sent for every valid L2 trigger. Normally, this data is sent to the L3 trigger processor and, on request from L3, saved into PHA storage. For calibration of the sensor it will be necessary to get direct access to the event packets. The bit confs<sub>16</sub>[2] enables L2 streaming mode, all event packets received from the analog board will be wrapped into a telemetry packet. L2 streaming uses the telemetry FIFO. When the fifo is full, the packets trying to get in will be dropped. #### 3.6.1 Samples Readout The analog board FPGA can be set to samples mode. Instead of trigger event packets, L2 triggers will issue a configurable stream of sample packets, including consecutive sets of raw ADC readings. This is like a 30 channel digital oscilloscope, and can be used to diagnose the pulse shapers. Samples mode is enabled by setting bit $confs_{16}[1]$ . If streaming mode is enabled as well, the packets will be sent to telemetry. Sample packets will be forwarded to the L3 trigger, and can be saved in PHA buffers. This may lead to scenarios to use sample mode in flight for troubleshooting, with readout through PHA storage. ### 3.7 Monitoring Parameters The Sensor unit will send several packets to the ICU for purposes other than being forwarded to the spacecraft and to ground, i.e, • monitoring sensor status and health, - data to be sent in s20 packets, - trigger burst mode, and - detect high particle rate conditions. These functions need information from the sensor unit. The ICU will extract values from sensor packets and store them in its global parameters storage. Parameter extraction is governed by a table in the ICU configuration that specifies for each extractable parameter: - a parameter-ID, - the sensor-ID, - the packet-APID, - byte offset into the packet, - length in bytes of the value to extract, big endian, - a mask (32 bits) to clear selected bits from the value. A parameter is identified by a 16-bit parameter-ID. This section lists possible/proposed parameters to extract from sensor packets, and how they may become useful. #### 3.7.1 Register readout Sensor status is extracted via register readout, as described in section 3.2. Table 7 assumes that the first seven registers are read, i.e., the register mask is 0x007F. With a different mask the offsets will change. The STEP sensor may define more registers that may require monitoring, these may be added to the table in the future. Table 7: Parameters to extract from the register readout packet. Offset is in bytes, length is in bits. | Name | offset | length | description | |-------------|--------|--------|-------------------------------------| | status | 2 | 64 | variius status and error bits | | time | 22 | 12 | cadence counter, second of the hour | | duty cycle | 56 | 8 | OP heater duty cycle | | temperature | 57 | 12 | OP heater temperature reference | #### 3.7.2 Histogram Data A packet with data derived from the acquired histograms will be formatted for the ICU, i.e., without variable length encoding. Most of these will be 8 bits values representing the eight times the logarithm of base two of the counter value. This format is suitable to be directly put into s20 packets as requested by RPW. The format is also suitable for relative trigger cuts, because differences in parameter values represent ratios of counter values. A second useful format available is 16 bits unsigned floating point representations of counter values. These can be directly compared to thresholds, since the representation interpreted as an unsigned integer is monotonous with the represented counter value. For absolute difference trigger cuts, the counters can be represented as plain integers in 24 bits. The packet from an HET-EPT sensor shall include - ten $\log_2$ values from EPT as requested by RPW, covering four energy ranges for electrons and one energy range for ions, from two directions, at a time resolution of 1 s. - the same ten values at time resolution 10 s, - further data from HET and EPT as required. The data items must be sorted by time resolution. Longer cadence data needs to be appended to shorter cadence data, so that each data item is always at the same byte offset in the packet. The ICU will reserve a set of parameter-IDs for trigger parameters that can be configured during the mission to extract the required data items for monitoring and trigger purposes. The parameters to be sent in \$20 will be alloated with fixed IDs. Triggers can use any parameters available, including the \$20 parameters. #### 3.7.3 Counter Memory Readout The digital board counters may include items which are useful for monitoring or trigger purposes. Event or trigger counters can be used to identify high rate environments. SEU error counters may be used to monitor sensor health. Message counters can flag unusual activity, i.e., for a flag in a status word that indicates a message reception in a sensor unit. The available counters are listed in tables 1 to 5. #### 3.7.4 HET-EPT Analog Frontend Readout A packet from the frontend board will contain at least the housekeeping ADC readings in unpacket format. The single channel trigger counters may be usefull for high rate triggers. The frontend packet with items $\max_{15}=0 \times 0110$ will provide the parameters at the offsets given in Table 8. The ICU may define parameters with fixed semantics for the housekeeping ADC readings. These readings are prefixed with a 4-bit channel number which may need to be masked out when extracting the parameters. That's why the length is givel as 12 bits. The single channel counters are 16 bits unsigned floating point. These may be extracted into general trigger parameters as required. Table 8: Frontend parameters | Name | offset | length | description | |---------------|--------|--------|--------------------------------| | sc 00 | 2 | 16 | L1 trigger counter channel 0. | | sc01 | 4 | 16 | L1 trigger counter channel 1. | | | | | | | sc 29 | 60 | 16 | L1 trigger counter channel 29. | | нк $400$ | 62 | 12 | HET preamp temperature | | ${ m HK}~500$ | 64 | 12 | EPT preamp temperature | | ${ m HK}~401$ | 66 | 12 | HET VREF, $+2.5\mathrm{V}$ | | нк $501$ | 68 | 12 | EPT sensor temperature | | ${ m HK}~402$ | 70 | 12 | HET sensor temperature 1 | | ${ m HK}502$ | 72 | 12 | EPT VFET/2, $+5 \mathrm{V}$ | | ${ m HK}403$ | 74 | 12 | HET VFET/2, $+5 \mathrm{V}$ | | нк $503$ | 76 | 12 | EPT $VANA/2$ , $+6V$ | | ${ m HK}~404$ | 78 | 12 | HET sensor temperature 2 | | нк $504$ | 80 | 12 | EPT VREF, $+2.5\mathrm{V}$ | | нк $405$ | 82 | 12 | Shaper $VCC/2$ , $+5V$ | | нк $505$ | 84 | 12 | Bias Current | | нк $406$ | 86 | 12 | Power board temperature | | нк $506$ | 88 | 12 | Bias Voltage | | нк $407$ | 90 | 12 | Analog board temperature | | нк $507$ | 92 | 12 | Digital board temperature | # 4 Data Acquisition Various bits from the master control registers control the data acquisition process: $enables_8[0]$ : event reception enable, enables<sub>8</sub>[1]: L3 trigger enable, enables<sub>8</sub>[2]: PHA storage enable, enables<sub>8</sub>[4]: timestamp clock enable. enables<sub>8</sub>[5]: analog frontend enable, $confs_{16}[0]$ : high speed calibration mode enable, confs<sub>16</sub>[1]: sample mode enable, confs<sub>16</sub>[2]: L2 streaming mode enable, ### 4.1 Pulse Height Data Packets When the L2 trigger in the analog board FPGA identifies a valid particle event, a data packet is sent to the digital board. There are eight L2 triggers, and each has an associated channel mask identifying the signal channels that are important to analyze the particle hit. Data is sent for all channels that are selected by any valid L2 trigger. The data packet starts with the channel mask. Table 9: Event Pulse Height Packet Format | | 1 1 1 1 1 1 | Ox BEEF | A128 | | |---|-------------|-----------------|-------------------------------------------------------|----------------| | R | | channe | elmask30 | | | | trig8 | prescale8 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | | | | A <sub>18</sub> | BB <sub>10</sub> | T <sub>4</sub> | - - - The MSB of the channel mask word identifies random triggers that are activated by strobes<sub>64</sub>[14]. Those event packets will contain data for all 30 channels. The header further contains three fields trigs: bitmask of L2 triggers. prescale<sub>8</sub>: number of event packets that where dropped because the FIFOs were full, since the last transmitted packet. dtime<sub>16</sub>: time since the last trigger in $\mu$ seconds. For each selected channel a record of 32 bits will be sent, containing three data fields $A_{18}$ : pulse height, i.e., filter channel A. BB<sub>10</sub>: pulse phase, i.e., filter channel B, ten bits selected by the leading bit in $A_{18}$ . $T_4$ : pulse age. #### 4.1.1 Event Packet Reception The digital board monitors the stream channel from the analog board for the sync header of event packets 0x BEEF A128 or sample packets 0x 5A61, and initiates the packet parser when it is idle, or when there where unrecognized data in the stream before the currently parsed packet. Event packet reception cannot be disabled at this stage. The parser will capture the channel mask<sub>30</sub>, and expect as many channel records as requested. The data will be send to three destinations - the L3 data set, - the PHA data set, and - in streaming mode to the telemetry FIFO. The telemetry FIFO receives the packet unchanged, if streaming mode is enabled. The L3 and PHA data sets are transferred simultaneously to the event buffer. Each data set contains 32 words with 32 bits each. The L3 data set will later be loaded into the L3 register file, the PHA data set will be saved in a PHA buffer when so instructed by the L3 processor. The PHA data set receives the words from the event packet unchanged. The data for each signal channel will we written to a fixed position in the data set, i.e., unselected channels will be substituted with zeros in the data sets. PHA data is saved without EDAC protection into the external SRAM. Table 10: L3 Data Set Format | 0 | $\begin{array}{c c} & \text{channel } \mathtt{mask}_{21:0} \\ \hline \end{array}$ | | | | | |-------------------------------------------------------|-----------------------------------------------------------------------------------|-------------------|--|--------------------|------------------------| | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | trig <sub>8</sub> | | channel: | $ exttt{nask}_{29:22}$ | | A <sub>18</sub> | (sign extended) | | | $0_{1}0_{1}0_{1}1$ | T <sub>4</sub> | - - - The word size of the L3 trigger processor is only 29 bits because of EDAC overhead. Some reformatting is necessary to make sure all relevant data fits into the registers. The L3 trigger will not receive the BB<sub>10</sub> fields of the channel records, nor the prescale<sub>8</sub> field of the headers. The dtime<sub>16</sub> field is truncated to 13 bits with overflow check. L3 data set word 0 receives the part of the channel mask corresponding to HET channels. Word 1 receives the channel mask bits for EPT channels, and further header data. The remaining data set words are each associated with a fixed signal channel. For unselected channels all zeros are written. Available channel data are formatted such that the whole register value can be used as the pulse height, the data in the LSB contributing insignificant noise. #### 4.1.2 L3 Event Class The L3 trigger processor has four entry points, i.e., there can be four different programs called for different event classes. The event class is established by the packet reception unit from the L2 trigs bits. The mapping from trig<sub>8</sub> to event class is provided by the trigger class<sub>16</sub> register, which can be set with Command message: | 1 | ı | 1 1 | 0x0 | 001 | 1 | ı | ı | ı | |---|---|-----|--------|-------------------|---|---|---|---| | | ı | tri | ggercl | ass <sub>16</sub> | 1 | ı | ı | | The event class is a 2-bit number. The MSB of the event class is set, when any of the L2 trig<sub>8</sub> bits is active that is also set in the upper half of trigger class<sub>16</sub>[15:8]. The lower bit of the event class is set when any of the L2 triggers selected by the lower half trigger class<sub>16</sub>[7:0]] is set. The proposed value for the trigger class<sub>16</sub> register is | | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | |--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--| |--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--| with a proposed configuration of L2 triggers $trig_{8}[0]$ : EPT ion forward, trig<sub>8</sub>[1]: EPT electrons backward, trig<sub>8</sub>[2]: EPT ion backward, trig<sub>8</sub>[3]: EPT electrons forward, trig<sub>8</sub>[4]: HET forward stopping, trig<sub>8</sub>[5]: HET forward penetrating, trig<sub>8</sub>[6]: HET backward stopping, trig<sub>8</sub>[7]: HET backward penetrating, With this L2 trigger menu, the L3 trigger classes are: - 0: EPT trigger, no HET triggers present. - 1: HET forward stopping, no other HET triggers. - 2: HET backward stopping, no other HET triggers. - 3: Het penetrating. EPT triggers are presumably more frequent than HET triggers. The class 0 program does not need to bother with HET. The HET programs need to check for possible EPT triggers as well. HET stopping trigger classes do not need to look for signals in the downstream detectors. HET penetrating needs to do the most work. The downstream hits may be crosstalk or it may be a real penetrating particle. #### 4.1.3 Trigger and Prescale Counters The data reception unit counts the occurrences of set bits in prescale<sub>8</sub> and trig<sub>8</sub> for all received event packets. The counters are located at address 0 to 7 (prescale<sub>8</sub>) and 8 to 15 trig<sub>8</sub> of the counter memory. The counts of the prescale<sub>8</sub> bits can be weighed by bit significance and added together give the total number of events lost in the analog board. #### 4.2 Event Buffer L3 and PHA data sets are written into the event buffer memory, which is 128 word of 64 bits, excluding EDAC overhead. The words contain the L3 and PHA parts, 32 words for one data set. Four event data sets fit into the buffer memory. Incoming event data is always written into the next available data set space. When the set is complete, - if enables<sub>8</sub>[0] is not set, the data set will be discarded and ignored. - Else, when the event buffer is full, the data set will be discarded, and counted as lost. - Else, the data set is queued for processing by the L3 processor, i.e., the data set write pointer advances to the next slot. #### 4.2.1 Feeding the L3 trigger processor The L3 trigger processor operates on a register file with 256 registers. The L3 event data sets are loaded into the last 32 registers before the trigger is executed. When events are queued in the buffer, and the L3 trigger processor is idle, and the PHA storage unit is idle, the L3 processor is loaded and started. The data set memory space is then released from L3 but still locked for PHA storage. But all previous data sets are released from PHA at this point and become available for new incoming data. The event buffer keeps track of the event class that was assigned to each data set. The L3 trigger is started at the instruction address with the event class as the two MSB and zeros in the LSB, i.e., at addresses $0 \times 000$ , $0 \times 100$ , $0 \times 200$ , or $0 \times 300$ . #### 4.2.2 PHA storage The L3 trigger processor may decide to save the PHA data sets into a PHA buffer in external memory. 16 buffers with 256 memory words of space are available, 32 bits each, 1kByte per buffer 16 kBytes total. L3 decides into which buffer the data shall go. The idea is that rare events are saved in separate buffers, so they are not lost. The frequent events will fill their buffers fast and all further events will be dropped. The PHA storage is not protected with EDAC redundancy. The data is not considered essential for science analysis. EDAC protected memory words leave only 26 bits, which is not a good match for the storage of PHA data. The location of the PHA buffers in the external memory is configured via phabase<sub>18:12</sub>. The PHA storage unit keeps two counters for each PHA buffer. nevents<sub>24</sub> is the number of events that where supposed to be stored in the buffer, and nwords<sub>8</sub> is the pointer to the last word in the buffer that was written. These two counters are written into the first words of the PHA buffer for each event, i.e., nevents<sub>24</sub> continues to count when the buffer is full. | nevents <sub>24</sub> | nwords8 | |-----------------------|---------| | | | The PHA data set is appended to the buffer data, until it is full. The end of a full buffer will likely contain an incomplete event data set. Only the event header and valid channel data are saved. The headers allow to reconstruct the storage size of each event. The MSB of $phabase_{18:12}$ is toggled with $strobes_{64}[11]$ . That effectively saves the set of filled PHA buffers for telemetry readout, and make a new set available for data acquisition. The new set needs to be cleared with $strobes_{64}[8]$ , which resets all internal copies of $nevents_{24}$ and $nwords_8$ to zero, and writes zeros into the first word of each PHA buffer. ## 4.2.3 Test Data Injection Test data can be injected into the PHA buffer via command messages to address $0x\,0003$ . A message with size tag zero resets the input register pointer, i.e., the next data will go into slot 0 of the event data set. | Command message: | | | | | | | | | |------------------|---------|--|--|--|--|--|--|--| | 0 | 0x 0003 | | | | | | | | Messages with size 64-bits write into the next word of the event buffer, with the PHA data in the upper half of the data word and the L3 data in the lower half. | Command | message: | |---------|----------| | | | | 3 | 0x 0003 | | | | | | |---|--------------------------------------------------------------------------------------------------------|-------------|-------|-----|-----|-------| | | <pha d.<="" td=""><td>ATA SET &gt; 1</td><td>1 1 1</td><td>1 1</td><td></td><td></td></pha> | ATA SET > 1 | 1 1 1 | 1 1 | | | | | <l3 da<="" td=""><td>TA <math>SET</math></td><td>1 1 1</td><td>1 1</td><td>1 1</td><td>1 1 1</td></l3> | TA $SET$ | 1 1 1 | 1 1 | 1 1 | 1 1 1 | The data set is submitted by a message with data size 16-bits. The two LSB encode the event class. | Con | Command message: | | | | | | | | | | | | |-----|------------------|---|---|---|---|---|--|---|---|---|---|----| | 1 | 0x 0003 | | | | | | | | | | | | | | | ı | ı | i | ı | ı | | ı | 1 | 1 | ı | ec | The analog frontend should be disabled when the injection is in use, else the data may collide with real triggers. #### 4.2.4 Event Data Formats $\dots$ TODO # 4.3 L3 trigger The L3 trigger is a programmable processor with separate program and register memory. Both memories are EDAC protected. EDAC errors in the program are corrected in the memory when encountered. EDAC errors in the register memory are corrected for read but not in memory. The program memory stores 1024 instructions. An instruction word is 32 bits. Two instructions are stored in one configuration memory word. The registers are 29 bits, stored in 36 bit wide memory blocks including 7 bits of EDAC redundancy. The result of the computation of each instruction is stored in the register file at the address that is the same as the eight LSB of the instruction address. The program leaves a trail of values behind as it executes. The processor maintains two condition bits. Execution of any instruction is conditional depending on the value of those bits. An instruction where the condition is false will save the result of the previous instruction. The opcodes are designed specifically for the work of a L3 trigger. There are instructions for calibration and corrections of pulse height values to energy units. It can compute $\log_2$ of pulse energies, for histogram binning and ratio cuts. The experience gained from the MSL RAD trigger went into the design of this processor. Table 11: L3 instruction opcodes ``` STOP cc00 0000 0--- --- ---- ---- cc00 0000 10-- --- --- ---- NOP cc00 0000 11-- --uu uuuu uuuu ---- ---- GOTO u_{10} cc00 0001 ---- ---- xxxx xxxx \mathbf{R}_{x} LOG R_d = R_x POKE cc00 0010 ---- dddd dddd xxxx xxxx R_x\{u_5\} BITC cc00 0011 nOSC ---- u uuuu xxxx xxxx R_x\{u_5\} BITS cc00 0011 n1SC ---- uuuu xxxx xxxx R_x\{v_5:u_5\} cc00 0100 ---- --vv vvvu uuuu xxxx xxxx BRNG R_x, u_8, v_8 TRIM cc00 0101 vvvv vvvv uuuu uuuu xxxx xxxx R_x * m_{12} \gg e_4 MULI cc00 0110 eeee mmmm mmmm mmmm xxxx xxxx R_x + u_{16} PHA cc00 0111 uuuu uuuu uuuu uuuu xxxx xxxx R_x \gg i_4 + R_y \gg j_4 ADD cc00 1000 yyyy yyyy jjjj iiii xxxx xxxx R_x \gg i_4 - R_y \gg j_4 SUB cc00 1001 yyyy yyyy jjjj iiii xxxx xxxx R_x \gg i_4 + R_y \gg j_4 HIST cc00 1100 yyyy yyyy jjjj iiii xxxx xxxx HIST R_x \gg i_4 - R_y \gg j_4 cc00 1101 yyyy yyyy jjjj iiii xxxx xxxx R_x + u_8 \ll R_y CMP cc01 0ooo yyyy yyyy uuuu uuuu xxxx xxxx R_x \ll R_y + u_8 CMP cc01 1000 yyyy yyyy uuuu uuuu xxxx xxxx R_x + i_{21} ADDI cc1i iiii iiii iiii iiii xxxx xxxx ``` Three opcodes produce output. - STOP: Stop the processor, to accept another event. - HIST: Increment a histogram counter. - PHA: Submit the PHA data set to a PHA buffer. Please refer to the Solar Orbiter Level 3 Trigger Instruction Set Manual for details. An assembler, disassembler and simulator is available. #### 4.3.1 HIST Instruction The HIST opcode computes the same value as an ADD or SUB instruction. The result is taken as the memory address in external SRAM. The memory location is read, incremented by one and the result written. The memory access is EDAC protected, the histogram counters are 26 bits. The increment is checked for overflow, the counters do not wrap. Bits [17:0] of the memory address are the result of the HIST computation, the MSB is hist base<sub>[18]</sub>=enables<sub>8</sub>[3]. hist base<sub>[18]</sub> shall be toggled every second. The PPS scheduler shall issue a command to the data product scheduler that clears the memory areas used for histogramming after the data products were extracted. The HIST opcode executes an ADD because it may be common to add two $\log_2$ energy values as an index into 2-dimensional histograms, or add a histogram index to a base address. #### 4.3.2 PHA Instruction The PHA opcode computes an ADDI. Four LSB bits of the result are transmitted to the PHA storage unit to select the PHA buffer where the data shall be stored, if space permits. # 4.4 Streaming mode Do not enable streaming mode, unless you are prepared to handle a lot of packets on the serial line. Disable all other telemetry sources when you do. # 4.5 Sample Mode When sample mode is enabled, the analog board sends sample packets instead of event pulse height packets. Three conditions must be true to activate sample mode, - the bit confs<sub>16</sub>[1] must be set, - the register nsamples<sub>8</sub> must be nonzero, and - the register tsamples<sub>8</sub> must be nonzero. nsamples<sub>8</sub> is the number of sample packets that shall be sent for each enabled L2 trigger, and tsamples<sub>8</sub> is the mask of L2 triggers enabled for sample mode. Both registers are part of the filter configuration, at address $0x\,0107$ in the analog board command address space | tsamples <sub>8</sub> | $\tt nsamples_8$ | |-----------------------|------------------| | 1 1 1 1 1 1 1 1 | | A sample packet includes a timestamp with $\mu$ seconds resolution, and 30 ADC readings sampled simultaneously from the channel ADCs. Recording about 16 consecutive sample packets captures the pulse shapes that were analyzed for the peak heights that lead to the trigger. The L3 trigger probably cannot do much with the sample packets, except to store them in a PHA buffer. Table 12: Sample Packet Format | 0x 5A61 | | |-------------------------------------|-------------------------------------| | <ch 0=""></ch> | <pre><ch 1=""></ch></pre> | | <ch 2=""> <ch 3=""> </ch></ch> | <ch 4=""> <ch 5=""></ch></ch> | | <ch 5=""> <ch 6=""></ch></ch> | <ch 7=""></ch> | | <ch 8=""></ch> | <ch 9=""> <ch 10=""></ch></ch> | | <ch 10=""> <ch 11=""></ch></ch> | <ch 12=""> <ch 13=""> </ch></ch> | | <ch 13=""> <ch 14=""></ch></ch> | <ch 15=""></ch> | | <ch 16=""></ch> | <ch 17=""> <ch 18=""></ch></ch> | | <ch 18=""> <ch 19=""> </ch></ch> | <pre><ch 20=""></ch></pre> | | <ch 21=""> <ch 22=""></ch></ch> | <ch 23=""></ch> | | <ch 24=""></ch> | <ch 25=""> <ch 26=""></ch></ch> | | <ch 26=""> <ch 27=""></ch></ch> | <ch 28=""> <ch 29=""></ch></ch> | | <ch 29=""></ch> | <ti> <timestamp></timestamp></ti> | # 4.6 Timestamp Clock The analog board FPGA has a 32-bit clock incrementing at 1 MHz when enabled. The timestamp is included in sample packets. The clock can be reset with strobes<sub>64</sub>[3]. # 5 Operational Heater To drive an operational heater, the digital board FPGA provides a PWM output. At a frequency of 125 kHz the output can drive a square wave with duty cycle adjusted in 192 steps from 0% to 100%. The output shall be filtered to provide a DC voltage to the gate of a heater n-MOSFET. The PWM output cannot be turned on permanently. A command message needs to be send periodically to keep it operating ## Command message: | 3 | | 0x 0002 | | | |---|--------|--------------------------|--------------------------|------------------| | | | | $\mathtt{duration}_{24}$ | | | | $sh_2$ | $\mathtt{setpoint}_{12}$ | max <sub>8</sub> | min <sub>8</sub> | The heater will be turned on for $duration_{24}$ cycles. The duty cycle will be calculated from the $temp_{12}$ register and the parameters of the message. The $temp_{12}$ is assumed to hold a temperature reading spied from a recent analog housekeeping reading. The lower the value of $temp_{12}$ the higher the temperature. The duty cycle is calculated by the formula $$\mathtt{dutycycle} = (\mathtt{temp} - \mathtt{setpoint})/2^{\mathtt{sh}}$$ The result is clipped to the range $\min_8$ to $\max_8$ . If $\min_8$ and $\max_8$ have the same value, the duty cycle is set to that fixed value. Values from 192 up result in 100% duty cycle. The duty cycle is computed once when the message is received and will not update when temp<sub>12</sub> changes. # 5.1 Heater Modes of Operation The heater can be autonomously operated by the sensor unit. The PPS schedule may include commands for the temperature readout and to kick the heater periodically. In case of a temperature sensor failure the heater will misbehave, but the probability for such a failure is low, and the consequences not likely dramatic. Alternatively, the ICU shall analyze the sensor housekeeping readings periodically, figure out if the sensors deliver plausible results and kick the heater via command messages. The ICU can consider sensor readings from multiple temperature sensor. A combined approach requires the ICU to monitor the housekeeping readings and heater behavior and reconfigure the sensor in case of anomalies, e.g., select a different heater. Reconfiguration involves manipulation of the PPS schedule, which is non-trivial for the ICU to do autonomously. There may be a few canned sequences for switching between two temperature sensors or to turn the heater off. # 6 Count Rate Series Compression The main data products of the sensor are time series of count rates. The L3 trigger classifies energetic particle triggers and counts the occurrences of triggers of a large number of classes for consecutive periods of one second. The checkout units needs to reduce the information in these counters to telemetry products of a few hundred bits per second. This reduction is achieved in three steps: - 1. Binning of the trigger classes into fewer, physically relevant particle classes. - 2. Rebinning of the resulting time series to longer cadence. - 3. Representation of the counter values in a compact format, which involves removing statistically insignificant information. The reduction process is controlled by the data products scheduler, and executed by the histogram window unit and the compression unit. # 6.1 Histogram Windows The counters accumulated during data acquisition are mostly one or two dimensional histograms. The events are classified by one or two energy parameters, binned equidistantly in units $\log_2(E)$ . The rebinning will provide projections of the data on physically relevant dimensions, or specific selections of particle types. Finer binned products will be produced with longer cadence, some smaller sets will be provided with higher time resolution. ### 6.2 Counter Cadence Governing the cadence periods of the data products is the modulus unit. This is a set of seven small counters that divide time into eight cadence units, each being a multiple of the previous. At the root is the period of the PPS signal from the ICU. The modulus<sub>3</sub> value is the level of the longest cadence interval that ended with the currently processed acquisition. All shorter cadences end at the same time. The modulus unit also provides the information to the compression unit which cadence interval begin with the current acquisition. The PPS scheduler uses the modulus unit to qualify tables entries for execution. Table 13: Cadence Modulus Table. | mod | div | cadence | |-----|-----|----------------------| | 0 | | 1 second, no summing | | 1 | 5 | 5 seconds | | 2 | 2 | 10 seconds | | 3 | 3 | 30 seconds | | 4 | 2 | 1 minute | | 5 | 5 | 5 minutes | | 6 | 2 | 10 minutes | | 7 | 6 | 1 hour | # 6.3 Compression Unit The heart of the compression unit is a machine that can execute seven basic operations. The input is a histogram window sum acquired during the last second. The unit further computes and uses three numbers stored in external memory separately for each data product, to save state from one acquisition to the next. The encoding scheduler controls which of the basic operations need to be executed for the given data product at the current modulus. #### 6.3.1 Encoder The very central part of the compression unit is the encoder, which computes a variable length encoding of an approximation of a signed integer value. The encoder operates with one parameter drop2, governing how many LSB of the input value will be omitted from the encoded result. When this parameter is zero, the result will include representation for all bits that are significant when the Poisson distribution applies. The parameter can call for up to three more bits to be dropped. An input value of zero will be encoded in a single bit. With drop<sub>2</sub> larger than zero, a range of inputs around zero will be represented as zero. Larger inputs will be represented by increasingly larger representations, about as large as the number of significant bits of the original value. The encoded representation is sent to the telemetry FIFO. A second output of the encoder unit returns the exact value represented by the encoded bits, i.e., the number that the decoder finds in the received telemetry. # 6.3.2 Basic Encoder Operations Three numbers are stored in external memory for every data product to compute sums and compressed time series data - A the accumulator to build the sum of consecutive acquisitions, - -L minus the number of counts that the receiver on the ground decodes from the telemetry for the previous acquisition cadence, - R the residue, i.e., the number of counts that should have been included in the number last sent, but were lost due to the encoding. The encoder machine is started by issuing a nonzero $\mathfrak{op}_3$ instruction, and with input value D. The operations are 1: Encode the residue at the end of a compression cadence $$E = \operatorname{encode}_0(R)$$ 2: Encode an intermediate value in full time resolution $$Q = D + R - L$$ $$E = \operatorname{encode}_{3}(Q)$$ $$R = Q - \operatorname{decode}(E)$$ $$-L = -L - \operatorname{decode}(E)$$ 3: Encode the first value of a compression cadence in full time resolution $$Q = D$$ $E = \operatorname{encode}_0(Q)$ $R = Q - \operatorname{decode}(E)$ $-L = -\operatorname{decode}(E)$ 4: Add to the accumulator $$A = A + D$$ 5: Initialize the accumulator for a new summing cadence period $$A = D$$ 6: Encode an intermediate sum $$Q = A + D + R - L$$ $$E = \text{encode}_3(Q)$$ $$R = Q - \text{decode}(E)$$ $$-L = -L - \text{decode}(E)$$ 7: Encode the first sum of a compression cadence $$Q = A + D$$ $$E = \operatorname{encode}_{0}(Q)$$ $$R = Q - \operatorname{decode}(E)$$ $$-L = -\operatorname{decode}(E)$$ All E or some A may be sent to the telemetry FIFO, at appropriate times. A, -L, and R are read from, and/or stored in external SRAM to be available for the next acquisition period, as indicated. There is a special case: if $-L \ge -8$ , then -L will be set to zero. The next value will be transmited as absolute value, not a running difference. This is to avoid oscillations in the data stream with low count rates. (Early versions of the module were treating small L differently: if -L was zero, or not read at all, and Q is so small that it encodes to the smallest representation, but not zero, and drop<sub>3</sub> is nonzero, then the new -L = 0.) #### 6.3.3 Cadence Sequence without Compression For a data product without compression, i.e., $sum_3 \ge enc_3$ , only $op_3=4$ or 5 will be called. In the first or only second of a summing period $op_3=5$ , all further seconds $op_3=4$ . In the last second, the resulting A will be converted to one of four possible representations, and put into the telemetry FIFO. This is useful for very low cadence data products or for data products that shall be analyzed on board the S/C, e.g., for burst mode trigger evaluation. The available representations were described in section 3.3.3 on page 19. #### 6.3.4 Compression Sequence For a data product with full time resolution a value will be sent every second, with compression. The data are counters which are expected to deliver almost the same number of hits every second distributed according to the Poisson distribution. This gives two handles for compression: - The lower half of the bits representing the counter are noise and can be dropped. - By computing running differences, the numbers become smaller. The stream of counters is divided into encoding periods by the enc<sub>3</sub> parameter of the data product. The encoding period is started by sending a compressed representation of the first value without dropping excess bits using op<sub>3</sub>=3 $$Q = D$$ $$E = \operatorname{encode}_{0}(Q)$$ $$R = Q - \operatorname{decode}(E)$$ $$-L = -\operatorname{decode}(E)$$ Two number are kept: R is the difference between the encoded value D and the number represented by the encoding. This number will be added to the next value, so the counts will not be forgotten. L is the encoded number, i.e., the value that is received for this counter on the ground after decoding the telemetry. For the following counter values the difference between the new value and the last will be encoded, plus the residue that was dropped by the encoder. The last value that is subtracted must be the value known on the ground L, not what we liked to have sent, so that it can be added when decoding. $$Q = D + R - L$$ $$E = \operatorname{encode}_{3}(Q)$$ $$R = Q - \operatorname{decode}(E)$$ $$-L = -L - \operatorname{decode}(E)$$ Q is the new value that we want to send. It will be encoded with three extra bits dropped. When the last encoded value was send, one further number will be encoded and sent to the telemetry packet, so there is one more number in the data stream than there were counter values $$E = \operatorname{encode}_0(R)$$ The last residue R is send without dropping bits. For very low count rate products, the stream will likely contain only zeros. One or two hits during the encoding periods will be dropped. At the end of the period those hits have accumulated in the residue R. This last encoding makes sure they are not lost. The time resolution degrades to the encoding period, but that cannot be a problem for count rates that low. ## 6.3.5 Compression Sequence with Summing The same compression sequence will be performed for data with reduced time resolution, except that each value that is submitted to the procedure is the sum of a series of inputs. Each summing period starts with $op_3=5$ to initialize the accumulator with the first D, followed by the required number of $op_3=4$ to compute the sum. The last input value is fed into an encoding operation. The first sum is encoded without loss of bits using $op_3=7$ $$Q = A + D$$ $$E = \operatorname{encode}_{0}(Q)$$ $$R = Q - \operatorname{decode}(E)$$ $$-L = -\operatorname{decode}(E)$$ The remaining sums use op<sub>3</sub>=6, which does it all $$Q = A + D + R - L$$ $$E = \text{encode}_3(Q)$$ $$R = Q - \text{decode}(E)$$ $$-L = -L - \text{decode}(E)$$ When the last sum of a compression period was encoded, the residue R will be immediately encoded and sent as well, as described above. # 6.3.6 Encoding scheduler The compression unit is driven by the encoding scheduler, which is kicked into action when the histogram window unit delivers a window sum. Depending on the sum<sub>3</sub> and enc<sub>3</sub> parameters of the data product and the status of the modulus unit, the scheduler decides which operation(s) the compression unit needs to perform. Secondly, it decides if and how the results shall be transfered to the telemetry FIFO. Only when the histogram window unit, the compression unit and the encoding scheduler finished their action will the data product scheduler initiate processing of the next data product, or signal to the telemetry FIFO to close the packet and send it out. # 6.4 Encoding Format The format of the encoder output may be best visualized with a table, Tables 14 and 15. This first column is a range of input numbers, the third shows the resulting bit pattern. The second column shows the encoding error. The last two columns compare the length of an unsigned number of that magnitude with the length of the encoding. Table 14: Encoding Format without Drop | input | error | encoding | input/output length | |---------------|-----------|---------------------|---------------------| | 0 | $\pm 0$ | 0 | 0/1 | | 1-15 | $\pm 0$ | 1s0xxxx | 4/7 | | 16-31 | $\pm 1$ | 1s10xxx- | 5/7 | | 32-63 | $\pm 2$ | 1s1100xxx | 6/9 | | 64-127 | $\pm 4$ | 1s1101xxx | 7/9 | | 128 - 255 | $\pm 4$ | 1s11100xxxx | 8/11 | | 256-511 | $\pm 8$ | 1s11101xxxx | 9/11 | | 512-1023 | $\pm 8$ | 1s111100xxxxx | 10/13 | | 1024-2047 | $\pm 16$ | 1s111101xxxxx | 11/13 | | 2048-4095 | $\pm 16$ | 1s1111100xxxxxx | 12/15 | | 4096-8191 | $\pm 32$ | 1s1111101xxxxxx | 13/15 | | 8192-16383 | $\pm 32$ | 1s11111100xxxxxxx | 14/17 | | 16384-32767 | $\pm 64$ | 1s11111101xxxxxxx | 15/17 | | 32768 - 65535 | $\pm 64$ | 1s111111100xxxxxxxx | 16/19 | | 65536-131071 | $\pm 128$ | 1s111111101xxxxxxxx | 17/19 | . . . ### 6.4.1 Encoding in Full Poisson Resolution The number zero is represented by a single bit 0. All other pattern must start with a 1, followed by the sign of the input value s. The rest of the pattern represents the absolute value of the input. The length of the encoding depends on the number of bits needed to represent the input. It is encoded in a stream of 1-s followed by a 0, followed by another bit that tells if the length of the input value is even or odd. After this length encoding follow a number of bits from the binary representation of the absolute value of the input, starting with the bit after the leading 1, obviously. These are marked x in the table. The dashes – represent the bits from the input number that are not included in the encoding. The first three lines represent special cases. Numbers in the range -15...15 are represented exactly, encoded in seven bits. Numbers up to 31 are also encoded in seven bits but loose the LSB. This encoding is denoted $encode_0()$ in the previous section. Table 15: Encoding Format with Drop=3 | input | error | encoding | input/output length | |--------------|------------|------------------|---------------------| | 0-3 | $\pm 3$ | 0 | 2/1 | | 4-15 | $\pm 4$ | 1s0x | 4/4 | | 16-31 | $\pm 8$ | 1s10 | 5/4 | | 32-63 | $\pm 16$ | 1s1100 | 6/6 | | 64-127 | $\pm 32$ | 1s1101 | 7/6 | | 128 - 255 | $\pm 32$ | 1s11100x | 8/8 | | 256-511 | $\pm 64$ | 1s11101x | 9/8 | | 512-1023 | $\pm 64$ | 1s111100xx | 10/10 | | 1024-2047 | $\pm 128$ | 1s111101xx | 11/10 | | 2048-4095 | $\pm 128$ | 1s1111100xxx | 12/12 | | 4096-8191 | $\pm 256$ | 1s1111101xxx | 13/12 | | 8192-16383 | $\pm 256$ | 1s11111100xxxx | 14/14 | | 16384-32767 | $\pm 512$ | 1s11111101xxxx | 15/14 | | 32768-65535 | $\pm 512$ | 1s111111100xxxxx | 16/16 | | 65536-131071 | $\pm 1024$ | 1s111111101xxxxx | 17/16 | | | | | | . . . # 6.4.2 Encoding with Drop=3 Table 15 shows the ecoding with $drop_2=3$ , i.e., each line has three fewer x and three more -. This encoding is denoted $encode_3()$ in the previous section. The compression scheme in this application does not use $drop_2=1$ or $drop_2=2$ . ### 6.4.3 Decoding The decoder assumes that the first dash in a pattern is a zero, and all futher dashes represent ones, i.e., it rounds pessimistically. The exception is the non-normalized case of the second line, 1s00---. With $drop_2=3$ the three dashes represent 101, i.e, the value 5. #### 6.4.4 NaN In the case drop<sub>2</sub>=0, two bit pattern represent redundant zeros: 1s00000. The encoder does not generate these patterns. The largest pattern emitted are 27 bits long 1s1111111111101xxxxxxxxxxxx for inputs in the range 33554432...67108863. # 7 EEPROM Each sensor unit is equipped with an EEPROM of size 128 kBytes, for persistent storage of the sensor configuration. Storage space in the ICU is not appropriate for two reasons: there is not enough space available, and there are two ICUs where it is difficult to keep the configuration stores consistent. The EEPROM content is not used directly by any logic in the FPGA. The ICU is assumed to read the content at boot, check if it is valid, and use the information to configure the sensor. The EEPROM is connected to the data and address lines that also drive the external SRAM, so that any access needs to go through the same memory port arbiter. Most memory access ports to not provide access to the EEPROM address space, the two exceptions are - the memory readout unit described above, and - the EEPROM page write unit. # 7.1 EEPROM Page Write The EEPROM chip is organized in pages of 128 Bytes. The page write unit can write to a range of Bytes in a single page. It automatically performs the magic incantations to turn the EEPROM into write mode, writes the desired data, and waits for the prescribed period of time for the EEPROM to burn the data into the storage cells. ### 7.1.1 Page Upload A range of 16 command message addresses is used to upload data into the 128 Byte page buffer in FPGA internal memory. This memory is not EDAC protected. The messages must be tagged for 64 bits data size, as each uploads eight bytes. The bytes are ordered little endian. | Command | message. | |---------|----------| | Command | message. | | 3 | c | )x 0EE <i>a</i> | | | |---|--------------------|---------------------|---------------------|------------| | | byte7 <sub>8</sub> | byte 6 <sub>8</sub> | byte 5 <sub>8</sub> | byte $4_8$ | | | byte3 <sub>8</sub> | byte 2 <sub>8</sub> | byte 1 <sub>8</sub> | byte 08 | a represent four MSB [7:3] of the address in the page. The whole page can be uploaded with 16 messages. ### 7.1.2 Page Write A message to any address in the same range, but with size tagged for 32 bits data submits the page to the EEPROM ## Command message: | 2 | , , , , , o | )x 0EEx | | | |-------------------------|-------------|---------|----------------------------|---------------------------| | byte count <sub>8</sub> | | | page address <sub>10</sub> | byte address <sub>7</sub> | This command will be ignored if it is received less than 16 milliseconds since the previous page write. The datasheet claims that the EEPROM needs at most 15 milliseconds to complete a write. The flight EEPROM chip provides a separate pin to indicate if it is busy. This pin is not used. The page write is performed in four phases: - A series of magic writes turns the EEPROM into write mode. - Writing bytes to a range of addresses, all in the same page, i.e., only the 7 LSB may change. - About $100 \,\mu\text{s}$ of inactivity convince the EEPROM that the page is complete, so it starts the burning process. - The actual transfer to the persistent storage takes up to 15 ms. Obviously, the FPGA must perform the first two actions and then wait. Writing data bytes starts at the page address<sub>10</sub>,byte address<sub>7</sub> given. and proceeds for byte count<sub>8</sub> bytes, incrementing only the byte address<sub>7</sub>, which may wrap around. At least one byte will be written, even if byte count<sub>8</sub> is zero. It is not an error to wrap around and to write previously written bytes again, but pointless. The bytes will be read from the page buffer at the byte address, so if a partial page shall be written, the data needs to be uploaded to the corresponding location in the buffer. With byte count<sub>8</sub>>= 128, the initial byte address, does not matter much. #### 7.1.3 Access Time The memory driver implements access cycles that allow to drive an EEPROM chip with up to 250 ns access time. # 8 Inputs and Outputs The I/O ports are - clock input, - ICU asynchronous serial communication, - synchronous serial ports to the analog board, - external memory bus, and - PWM output for the operational heater. Table 16: Input and Output Ports | Name | Dir | I/o Standard | EM pin | Description | |---------------------------------------------------------------|-----------------------------------|-------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------| | xclk | in | CMOS | 101, CLKFP | 48 MHz clock | | ARxD<br>ARxC<br>ATxD | in<br>in<br>out | LV-PECL<br>LV-PECL<br>LV-PECL | 217/216, HCLK<br>229/228, HCLK<br>210/211 | deserializer data<br>deserializer clock<br>serializer data | | ATxC | out | LV-PECL | 208/209 | serializer clock | | Cx[1:2]<br>Rx[1:2]<br>Tx[1:2]<br>TxE[1:2] | in<br>in<br>out<br>out | CMOS<br>CMOS<br>CMOS | 147,119<br>148,122<br>125,117<br>123,118 | PPS inputs UART inputs UART outputs LVDS driver enables | | RAM D [31:0] RAM A [18:0] RAM nCE [0:3] RAM nWE [0:3] RAM nOE | inout<br>out<br>out<br>out<br>out | CMOS CMOS CMOS CMOS | <br>242,240,47,50<br>51,234,112,113<br>241 | SRAM/EEPROM address<br>SRAM/EEPROM data<br>SRAM chip selects<br>SRAM write enables<br>SRAM output enable | | EEPROM nCE EEPROM nWE EEPROM nOE EEPROM nRES EEPROM BUSY | out<br>out<br>out<br>out<br>in | CMOS CMOS CMOS CMOS | 38<br>25<br>34<br>24<br>n/a | EEPROM chip select EEPROM write enable EEPROM output enable EEPROM reset output EEPROM busy | | OH PWM [1:2] | | | 184,185 | | # 8.1 Power The RTAX FPGA core is powered with 1.5 V, all I/O banks are powered with $3.3\,\mathrm{V}.$ ## 8.2 The clocks An external crystal oscillator is driving a CLKP input with LV-CMOS signaling. The frequency is 48 MHz. This clock is driving a global HCLK via an HCLKINT buffer. This clock is called xclk. The input clock is devided by two, the 24 MHz clock is driven to another global HCLK called mclk. The xclk is used to drive the synchronous serializer towards the analog board and so provide a clock to the analog board FPGA. The HCLK inputs are used for the synchronous deserializer inputs from the analog board. The deserializer uses the clock received there. The mclk drives all other logic. #### 8.2.1 TODO The EM digital board uses the CLKFP input for the master clock. Future revisions may move it to an HCLK input. The ARXD input need not use an HCLK. This move has not been implemented for the EM2 model RTAX proto board, and will most probably not make it into QM and flight models. # 8.3 ICU Asynchronous Serial Link Communication with the ICU requires four LVDS inputs and two LVDS outputs. The RTAX2000 chip supports the LVDS I/O standard, but we will not use that for two reasons. - LVDS requires an I/O supply voltage of 2.5 V. - There is a perceived risk to connect an external I/O line directly to the FPGA. External LVDs drivers/receivers convert CMOS levels to/from LVDs. The ports are - the PPS receivers Cx[1:2], - the UART receivers Rx[1:2], and - the UART transmitters Tx[1:2]. #### 8.3.1 ICU Cold Redundancy Two sets of LVDS lines connect to the cold redundant ICUs. The drivers for each set share an LVDS driver/receiver chip. Each chip includes two drivers and two receivers, one driver is unused. #### 8.3.2 Driver Enable The LVDS driver can be disabled by the FPGA. These enables are connected to the inverted value of confs<sub>16</sub>[5:4]. When all bits in confs<sub>16</sub> are reset at boot, the drivers are enabled. The running ICU may set the respective bit to disable the driver for the other ICU, to save power. This is not implemented on the PQM. #### 8.3.3 LVDS Termination The standard LVDS specification calls for loop current $I_{\rm L}=3.5\,\rm mA$ terminated at the receiver with $R_{\rm T}=100\Omega$ . The flight LVDS drivers will be implemented with two chips UT54LVDM055LV. These chips drive a loop current of $I_{\rm L}=10\,\rm mA$ , and are supposed to be terminated with $R_{\rm T}=35\Omega$ . For interoperability with GSE and to minimize EMI emissions, the termination circuit shall be implemented as schown in Fig. 1, with en extra shunt at the driving end, and a center tap on the receiver termination. Figure 1: Proposed LVDS Termination Circuit. The shunt limits the loop current to $I_{\rm L}=5\,{\rm mA}$ and the voltage swing to $500\,{\rm mV}$ , closer to the standard. It also provides a backtermination to swallow any backward traveling signal, from EMI or reflections. The center tap on the split termination resistor terminates limits the common mode EMI at high frequency, to avoid stress on the reciever and EMI susceptibility. # 8.4 Synchronous Serial Ports The communication with the analog board is accomplished with synchronous serial ports, with a data and a clock signal in each direction. LVDS signaling shall be used to minimize EMI with the analog circuits, but proper LVDS is not available. The RTAX FPGAs provide an LV-PECL I/O standard to be used with $3.3\,\mathrm{V}$ on the power lines. Figure 2: LV-PECL Termination Schematic #### 8.4.1 Termination The LV-PECL I/O standard will be used with slightly nonstandard voltage swing and termination, to reduce power consumption and EMI. The outputs have series termination resistors with $R_{\rm out}=316\,\Omega$ , the input is terminated with $R_{\rm inp}=100\,\Omega$ . The current in the loop is $$I = \frac{V_{\text{ccIO}}}{2R_{\text{out}} + R_{\text{inp}}} = \frac{3.3 \text{ V}}{732 \Omega} = 4.5 \text{ mA}$$ The voltage swing is $$\Delta V = \pm I R_{\rm inp} = \pm 450 \,\mathrm{mV}$$ which is well beyond the requirement mentioned in the RTAX datasheet. # 8.5 Memory Bus The external memory bus includes - address outputs RAMA[18:0], - bidirectional data port RAMD[31:0], - low active chip enables separate for SRAM and EEPROM, RAMnCE[0:3] and EEPROMnCE, - low active write enables, RAMnWE[0:3] and EEPROMnWE, - low active output enables, RAM nOE and EEPROM nOE, - a reset output for the EEPROM, EEPROMnRES. The flight EEPROM chip provides a busy indicator, EEPROMBUSY, and a reset pin EEPROMnRES. Engineering EEPROM do not provide EEPROMnRES nor EEPROMBUSY. The memory driver does not make use of them. The EEPROM res is controlled by $confs_{16}[7]$ , i.e., the EEPROM will be enabled when $confs_{16}$ is cleared at boot. The state of EEPROM BUSY is available in the register 0 readout. The EEPROM in the PQM is not functional, because the write cycle time of the driver is too short. It cannot be written. The flight SRAM can be addressed byte-wise. The FPGA does not use that capability. The four chip and write enables emit the same internal signals. All access is full 32 bits wide. ### 8.5.1 Engineering Model Memory Prototype and engineering models with RTAX FPGA use the board layout for flight, but with the memory chips replaced by non-flight parts on a daughter board. The daughter board is soldered on the footprint of the flight SRAM and holds both a 16-bit SRAM and an EEPROM chip. The EEPROM chip is functionally equivalent. The SRAM chips requires a different memory driver that performs two physical 16-bit accesses for one logical 32-bit access. The additional address bit and the control signals are mapped to the control pins of the fight SRAM footprint. The non-flight chips share the write and output enables. This is supported by the mode in which the memory drivers work. #### 8.5.2 Engineering Model 2 Memory The second EM model uses the same non-flight memory chips, but two of them, for real 32-bit operation. This setup operates with the flight mem- Table 17: Engineering to Flight Mapping of Memory Ports | EM | FM | FPGA | $\mathrm{EM}$ | FM | FPGA | |-------|------------|------|---------------|------------|------| | A[0] | A[0] | 57 | D[0] | D[5] | 83 | | A[1] | A[1] | 58 | D[1] | D[6] | 110 | | A[2] | A[2] | 58 | D[2] | D[7] | 111 | | A[3] | A[3] | 60 | D[3] | D[4] | 82 | | A[4] | A[4] | 52 | D[4] | D[3] | 81 | | A[5] | A[5] | 46 | D[5] | D[2] | 68 | | A[6] | A[6] | 45 | D[6] | D[1] | 53 | | A[7] | A[7] | 44 | D[7] | D[0] | 56 | | A[8] | A[8] | 27 | D[8] | D[8] | 15 | | A[9] | A[9] | 30 | D[9] | D[9] | 14 | | A[10] | A[10] | 35 | D[10] | D[10] | 13 | | A[11] | A[11] | 31 | D[11] | D[11] | 12 | | A[12] | A[12] | 41 | D[12] | D[12] | 9 | | A[13] | A[13] | 26 | D[13] | D[13] | 8 | | A[14] | A[14] | 40 | D[14] | D[14] | 7 | | A[15] | A[15] | 21 | D[15] | D[15] | 6 | | A[16] | A[16] | 39 | n0E | RAM nOE | 241 | | A[17] | A[17] | 235 | nWE | RAM nWE[0] | 51 | | A[18] | A[18] | 116 | RAMnCE | RAM nCE[2] | 47 | | A[19] | RAM nWE[3] | 113 | EEPROM nCE | RAM nCE[0] | 242 | ory driver. This provides the necessary testing before the design shall be committed to flight chips. ## 8.5.3 Engineering Model 1 Memory The first EM model has later been fitted with the same SRAM setup as EM 2, and with a PQM EEPROM. The model now uses the flight memory driver and confirms the functioning of the flight EEPROM. # 8.6 PWM output The PWM output for the operational heater is avialable in both polarities. The inverted pin is not connected on the digital board. The idea was to use AC-coupling, rectification and filtering to drive the gate of an n-MOSFET. The heater would turn off if the output is stuck either high or low. The EM board layout supports such a circuit. But the gate voltage does not reach the required values. The PWM output shall be filtered such that the mean output voltage drives the gate of the heater transistor. ### 8.7 Device Pinouts . . . # 9 Implementation Details This section is decidedly incomplete. It may get expanded ... # 9.1 External Memory Access The digital board FPGA has access to external memory chips through a common bus. Several logic units need access to the memory for read and/or write. Memory arbitration units provide prioritized access to multiple memory ports. During development of the logic, and for prototype models, several different memory architectures were employed. The arbitration units drive an abstracted memory interface to a memory driver. The driver can be transparently substituted for any physical memory architecture in use. Some memory access need EDAC protection, some do not. Direct access is granted by the primary arbitration unit, which interfaces to the driver of the physical memory. EDAC protected access is granted by the secondary arbitration unit, which interfaces to a virtual memory driver. The physical port of the virtual memory driver connects to a memory port of the primary arbitration unit. The primary memory is accessed in units of 32 bit words. EDAC protected access yield words with 26 bits, six bits are used for EDAC redundancy. # 9.1.1 Memory Port to Arbitration Unit Interface The arbitration units are configured for the required number of ports. For each port a req input is provided, a high level indicates the desire to perform an access. Access is granted to each port via the ack output. When ack is high, the port must put the addr<sub>19</sub>, write, and data<sub>32</sub> on the global bus. For read access, the arbitration unit provides a val output to each port, to tell when the returned data is valid for that port. There is a global data output port q<sub>32</sub>, and the data is valid for only one mclk cycle. To avoid deadlocks, each port is supported with a pending output that indicates that a read is pending for that port. The idea is that val is used to trigger the use of the returned data, but use pending to perform state transitions in the scheduler. pending is implemented with a guarantee that is will deassert eventually. Waiting for a missed val may take forever. #### 9.1.2 Memory Driver Interface The memory driver is signaled with a pulse on go from the arbitration unit to execute an access cycle. The driver responds by asserting busy until is is ready to accept the next go. busy will be deasserted for the cycle before the next go may be issued. If the cycle time is only two clock cycles the busy will not be asserted. For read access, the driver issues a pulse on valid one cycle before the data on q<sub>32</sub> is valid. pend is asserted between busy and valid if necessary. #### 9.1.3 Memory drivers Several memory drivers have been written, some of them used on prototype units. memasync32: Asynchronous SRAM with 32 bit data bus. Two mclk cycles per access. Can drive the flight SRAM. memasync32ee: Asynchronous SRAM with 32 bit data bus and EEPROM connected to the MSB of the data bus. This is the flight memory driver for the digital board. The driver needs two mclk cycles for SRAM access. EEPROM access can be synthesized for 24 MHz or 48 MHz mclk to use 7 or 15 mclk cycles. This driver is used on the second engineering module to drive a pair of 16-bit SRAM. memasync16ee: Asynchronous SRAM with 16 bit data bus and EEPROM connected to the LSB of the data bus. This driver needs two physical SRAM accesses for one logical cycle. It is used on the engineering models where the SRAM is substituted by a 16-bit version. The 24 MHz variant issues a physical access cycle in every mclk, it uses the xclk at 48 MHz to do the timing of the control signals. The driver is as fast as the flight driver in this case. The 48 MHz variant needs two mclk cycles for each physical access, four cycles for a logical cycle. EEPROM cycles are the same as for memasync32ee. memasync8: This driver is used on SIRENA boards with a rather slow asynchronous SRAM with 8-bit data bus. A physical access cycle requires four mclk cycles, or one more to switch data bus direction. A logical cycle requires four physical cycles, obviously. memasync8m: This driver is used on the FLYRENA prototype digital board. The SRAM chip is the same as on the SIRENA. 16 bits of the address bus are multiplexed on the data bus into external latches. A physical access cycle requires at least four mclk cycles, more if the address latches need update, or to switch data bus direction. A logical cycle requires four physical cycles. mem26edac: Virtual driver, that connects the secondary arbiter for EDAC access to the primary arbiter. This driver also takes care of the hamming coding and error correction, but is does not automatically rewrite corrected errors into the SRAM. #### 9.1.4 Memory Port Memory port modules interface between the clients and the arbitration unit. A client issues an access request with a pulse on aen and/or den. The memory addr<sub>19</sub> must be provided together with aen. den initiates a write cycle, the data<sub>32</sub> must be provided as the same time. den without aen reuses the last address. This is convenient for read-modify-write cycles. The port module asserts busy until the request was accepted by the arbitration unit. For read cycles a ppend signal is asserted as well until busy is deasserted. ppend must be combined with the arbiters pend to wait for outstanding reads to finish. The memory port units take care to deliver $addr_{19}$ , write, and $data_{32}$ to the arbiter and memory driver at the correct time. ### 9.1.5 Memory Port Priorities The primary arbiter supports four memory ports, the secondary arbiter supports three EDAC protected ports, from highest to lowest priority - 1. write only port for PHA data storage, - 2. write only port for EEPROM page writes, - 3. secondary arbiter for EDAC access, - (a) histogram counter increment port, - (b) data compression state memory port, - (c) histogram window sum port, - 4. read only memory telemetry readout port. Data acquisition ports are higher priority than telemetry readout ports. The gaps between processed triggers should not interfere with the timely execution of checkout activity. EEPROM write have a rather high priority, to make sure there are no gaps between write that make the EEPROM think the page is complete and can be burned. A histogram window sum could easily block access for long enough if it were higher priority than the EEPROM write. ### 9.1.6 Memory EDAC Six Hamming code bits can protect at most 26 data bits, and can be stored together in a 32 bit memory word. The data bits are located in the physical memory word in their natural order, i.e., the binary digits of the bit number indicate the parity bits that the bit position contribute to. Bits 1, 2, 4, 8, and 16 contribute to only one parity, so these bits are five of the six hamming codes. Bit number 0 is the sixth parity bit, to which all bits contribute that have an even number of 1s in their bit number. All physical bits contribute to an odd number of parity bits, the stored parity is even, i.e., when the parities are calculated for reads, they must come out zero. When a single bit is flipped, an odd number of parities are wrong. The five upper parities encode the flipped bit's number. When two bits are flipped, an even number of parities are wrong, indicating an uncorrectable error. The data bits are at the bit positions with two or more 1s in their bit number, 3, 5–7, 6–15, and 17–31. All this is important to know if an EDAC protected memory is read for diagnostic telemetry. ### 9.2 UART The Universal Asynchronous Receiver and Transmitter operate at the bit rate of 115 200 baud. Reprogrammable prototypes may be configured to operate at 1.5 Mbaud, or even 3 Mbaud with 48 MHz mclk, for calibration runs with high data rates. The asynchronous serial receiver is designed to be very picky. The bit levels must be stable for half a bit period. This is to avoid accepting noise in the inactive line as input. The downside is that the bit rate must match the nominale rate of $115\,200$ baud within $1.5\,\%$ . ### 9.2.1 Baud Rate Generator The bit clock is provided by the fractional baud rate generator. For the receiver, a clock with 16 times the bit rate is provided. The transmister is running from a clock with the nominal bit rate. The generator has three parameters, DIV, FRAC, and BAUDMODULO. The input clk is $\texttt{MCLK} = 24\,000\,000$ . The receiver bit clock is $$16 \times \texttt{BAUD} = \frac{\texttt{MCLK}}{\texttt{DIV} + \frac{\texttt{FRAC}}{\texttt{BAUDMODULO}}}.$$ For the desired bit rate BAUD = 115200, the parameters can be derived as $$\begin{array}{ll} \text{DIV} & = & \frac{\text{MCLK}}{16 \times \text{BAUD}} \\ \text{FRAC} & = & \frac{\text{MCLK} \times \text{BAUDMODULO}}{16 \times \text{BAUD}} - \text{DIV} \times \text{BAUDMODULO} \end{array}$$ with DIV rounded towards zero. BAUDMODULO shall be chosen that the division in the formula for frac yields an integer number. With BAUDMODULO =48 we get $$\begin{array}{ll} \text{DIV} & = & \frac{24\,000\,000}{16\times115\,200} = 13 \\ \text{FRAC} & = & \frac{24\,000\,000\times48}{16\times115\,200} - 13\times48 = 1 \end{array}$$ The resulting band rate is exactly 115 200 band, as precise as the crystal oscillator. This must be hardwired into the FPGA, obviously. The ICU cannot provide exactly 115 200 baud. Their algorithm is $$BAUD(x) = \frac{1}{(x+1) \times 300 \,\mathrm{ns}},$$ and with x = 28, we get BAUD(28) = $114\,942.53$ baud. The baud rate generator in the FPGA has been instantiated with the following parameters: $$\begin{array}{rcl} {\rm BAUDMODULO} &=& 240 \\ {\rm DIV} &=& \frac{24\,000\,000}{16\times114\,942} = 13 \\ {\rm FRAC} &=& \frac{24\,000\,000\times240}{16\times114\,942} - 13\times240 = 12 \end{array}$$ resulting in a bitrate of $$\mathtt{BAUD} = \frac{1}{16} \ \frac{24\,000\,000}{13 + \frac{12}{240}} = 114\,942.53.$$ This is close enough to work with GSE that provide exactly 115 200 baud, and matches the ICU bitrate exactly. ### 9.2.2 Abort Sequence The logic in the FPGA has been carefully designed from the start to not ever lock up in an unresponsive state. Especially the UART receiver must have this property, since there is no RESET facility, except for a power cycle that can force the system out of such a state. When the UART and the message receiver respond, it is possible to send a master control message to reset any misbehaving unit, but that should never be necessary. Well, you never know. The UART monitors the received input for a special sequence that will issue an attn signal to the core logic. The sequence consists of three character $\langle LF \rangle$ , 'A', 'T', followed by a $\langle break \rangle$ , i.e., a zero with a frame error. A $\langle break \rangle$ is not part of any nominal message, so the sequence cannot match by accident. The attn signal has almost the same effect as a strobes<sub>64</sub>[0]. #### 9.2.3 PPS Receiver The PPS receivers performs stringent checks before the pulse is accepted and forwarded to the core logic. - The length of the pulses must be between $1 \mu s$ and $500 \mu s$ . - The time between pulses must be a multiple of a second within 5.5 ms. To be precise, a rising edge on a Cx line is considered a valid PPS, if - the time between the previous rising edge and the previous falling edge is at least $1 \mu s$ and at most $500 \mu s$ , and - the time between the previous rising edge and this rising edge is a multiple of a second, with a total error of not more than 5.5 ms. The delivery of the PPS to the core logic is delayed by about ten mclk cycles, about half a $\mu s$ . There are two PPS receivers that are accepting pulses. When both receivers see good pulses, the selection will not switch between them, but continue to use the one that came online first. The period between PPS may be any multiple of a second. If the active source becomes quiet, the channel is still marked good, because no bad pulse was received. This prevents the switch to the receiver that is still sending. This misfeature was corrected in version v04. A channel is considered inactive after two good pulses were received on the other channel since the last pulse was received. # 9.3 Serializer/Deserializer . . . # 10 Changelog Current SVN Revision 8147. ### SVN Revision 4005 #### Section 2.6.3 Update strobes<sub>64</sub> and enables<sub>8</sub> allocations. #### Section 3.2 Update register readout allocations, scratch register, two UART status registers, move heater register. #### Section 3.2.1 Add misc<sub>8</sub> register for chip periphery status, i.e., EEPROM BUSY. #### Section 3.2.4 Move and update UART status register description. #### Table 4 Add counter 60: Streaming mode: packet lost. ### Section 3.4.5 Add scratch<sub>64</sub> register description. ## Section 3.7.1 Update for register reallocation. ### Section 4 Update for strobes<sub>64</sub> and enables<sub>8</sub> reallocations. ### Section 6.3.3 Mention that there are four available representations for count rate numbers. ### Section 8.3.2 Describe the LVDS driver enable bits. #### Section 8.5 Describe the EEPROMnRES bit. #### Section 8.5.3 Describe rework of EM 1 with PQM EEPROM. #### Section 9.2.1 Update the baud rate generator parameters for the real ICU-supported values. # Since SVN Revision 2415 #### Section 9.2.3 Add note about changed PPS source selection. # Section 8.5.2 EM2 memory driver. # Section 3.2.4 Register 4 definition. ### Section 2.6.5 Explain high speed calibration mode implementation. Removed the old section that outlined a different implementation. ### Section 3.3.1 Sparce count rates via res<sub>3</sub>. # Since SVN Revision 2268 ### Section 3.2.1 Use states<sub>8</sub> as FPGA and version identification. ### Section 3.3 Science data header format. # Section 3.2.3 Explain time. ### Section 3.3 Remove B bit, add $flg_2$ . FPGA design change: Data products header is always 8 bit, with init and fini modulus, and two informational flag bits. #### Section 5 Fix: $max_8 - min_8$ were swapped. ## Since SVN Revision 2249 ## Titlepage Change Document code: SO-EPD-KIE-DA-0001 Issue 1 Rev 0. ## Document Minor spelling fixes and clarifications. #### Section 3.2.1 errors<sub>8</sub>[5:4] documented. ### Section 3.3.3 Add byte aligned, uncompressed histogram data. Floating point format, 16-bit unsigned. #### Section 4.3 Seven EDAC bits in L3 register words. Mention the instruction set manual. #### Section 7.1.2 EEPROM page write waits 16 milliseconds. ### Table 17 EM memory pins table fixed. #### Section Calibration Mode Analog Data Streaming added. This section was later removed. ### Section 9.1.3 Memory driver memasync16ee drives 16 data pins. Memory driver memasync8 is operational in SIRENA. # Since SVN Revision 2230 # Section 3 Memory readout command is $0 \times 05xx$ . # Since SVN Revision 2118 # Titlepage Add Document code: SO-EPD-KIE-DA-0001 Issue 0. # Since SVN Revision 2110 # Section 8.3.3 LVDS Termination, added, with Fig. 1.