

30 November 2019 (v2, 02 February 2020)

# Single Event Upset evaluations of CBC readout chips

K. Uchida, J. Borg, G. Hall, L. Jones, M. prydderch

### Abstract

The Single Event Upset rate of the CMS Binary Chip (CBC) has been measured several times using different versions of the CBC in a series of tests in a 62 MeV proton beam to evaluate its sensitivity for use in the CMS tracker following the upgrade for High Luminosity LHC operation. Each version of the chip after the very first one has been subject to modest design improvements which affect the SEU tolerance. The main results are summarised, and the expected SEU rates in CMS 2S-modules at the HL-LHC are estimated.

## 1. Introduction

## 1 Introduction

Single event upset (SEU) is a type of single event effect that arises from a significant localised 2 ionisation energy deposit in a digital circuit. In the LHC environment, this mostly arises 3 via knock-on silicon atoms generated in the chip by ionising particles or neutrons [1]. Light 4 charged hadrons, leptons or light ions do not generally deposit enough localised charge to 5 cause SEUs directly although occasional nuclear interactions with the silicon lattice in or near 6 sensitive volumes are possible SEU sources. SEU is observed as a bit-flip in a register caused when the charge generated by an ionising particle is sufficient to change the state of the regis-8 ter. Depending on the detailed circuit design, multiple simultaneous bit-flips may be possible. 9 Not many previous studies have been reported of SEU rates in front-end ASICs either at the 10 LHC or in test beam evaluations (see e.g. [2–4]) although this will be an increasingly important 11 consideration for operation at the High Luminosity LHC (HL-LHC). 12 The CBC ASICs have been manufactured using a Global Foundries 130nm CMOS technology 13 and the pipeline control logic cells and I<sup>2</sup>C registers are implemented with SEU-tolerant de-

14 signs. Several versions of the CBC have been produced, as the requirements for operation 15 in CMS have evolved. The first version, the CBC1, was a conventional LHC front-end readout 16 chip containing amplifier, comparators and pipeline memory for each channel and multiplexed 17 data output, but subsequent versions (denoted CBC2, CBC3.0 and CBC3.1) have been devel-18 oped to meet the requirements of providing data to the track-finding processors and Level-1 19 trigger, using pT-modules [5], hence with cluster-finding and stub processing logic. (A stub is 20 a pair of clusters in the two layers of sensors in the pT-module, which is consistent with a short 21 track vector of interest.) Each version of the CBC has increased the amount of digital circuitry, 22 with the largest increase between the CBC2 and CBC3.0 versions, thus potentially increasing 23 the overall SEU susceptibility, even with improvements to the SEU tolerance. 24 It is not expected that the CBC designs should be totally immune to SEUs. Therefore an evalu-25 ation of each chip has been carried out in a 62 MeV proton beam line of a cyclotron at Louvain-26 la-Neuve. The results of those tests are summarised here. Typically, even with an exposure 27 of around one or two working days, the number of SEUs observed is small so results are lim-28 ited by statistics. The importance of an SEU also depends on its location in the CBC; most of 29 the registers store values which have very limited consequences should they change, such as 30 the fine tuning of the comparator threshold for each of the 254 CBC channels. A few values 31 are more important for operation, such as the registers which store the latency value and the 32 counters for pipeline read and write pointers. SEUs which affect hit data in the pipeline are 33

expected to be unimportant, since the pipeline is regularly refreshed. However, once an SEU
has corrupted a register, this will remain the case until a chip reset is issued, or the register is
deliberately rewritten with its correct value; this is easily possible and even a low refresh rate
should be sufficient to ensure the effect of SEUs on operation can be maintained at essentially

38 negligible levels.

## 39 2 SEU measurements at Louvain

<sup>40</sup> As explained in [1] the average SEU cross sections obtained with LHC secondary particle spec-

41 tra in CMS are very similar to those from protons with energies of 60-200 MeV. Hence, the SEU

- tests of the CBC chips were all carried out in the Light Ion Irradiation Facility (LiF) at UC Lou vain. The test beam was provided by a proton cyclotron in the LiF. The proton beam energy
- vain. The test beam was provided by a proton cyclotron in the LiF. The proton beam energy
   was set to the maximum, 62 MeV, and the tests were done with the maximum available inten-
- sity at the time, which was  $\sim 2 \times 10^8$  cm<sup>-2</sup>s<sup>-1</sup>, measured with a precision of 5%. Note that this

is considerably higher than the flux expected in the LHC which is explained later. Each test had
a duration of 12 to 16 hours and CBCs in the beam received a radiation dose of 1-2 Mrad. The
total dose behaviour of the CBC3 has been studied [6] and the consequences are insignificant at
HL-LHC dose rates. At accelerated doses, an increase in the power consumption is observed,
which does not affect operation. However, because of this, care was taken during the SEU
studies to avoid any possible bias under different SEU test conditions. The beam conditions for
each test are summarised in Table 1.

In the test system, a CBC was wire-bonded on a small board connected to a support board 53 which provided differential buffering and driving of signals to and from backend electronics. 54 For the CBC2, the backend electronics was located in a nearby control room connected to the 55 support board by 5m of twisted pair cable. In the case of the CBC3.0 and CBC3.1, the back-56 end electronics was located on the floor in the beam line area behind a lead block because the 57 twisted pair cable had to be shorter for the faster signals, clocked at 320 MHz compared to 40 58 MHz for the CBC2. In the CBC2 test, just one chip was placed in the beam. For the CBC3.0, 59 one chip was placed in the beam and another outside the beam as a control, in case of external 60 interference which could resemble an SEU. In the most recent test of the CBC3.1, three chips 61 were placed in the beam, to increase statistics, and one outside the beam. The back end data 62 acquisition system was based on the GLIB board [7] for the CBC2 and the FC7 [8] for CBC3.0 63

and CBC3.1.

Table 1: The beam parameters and exposure conditions

|                                                | CBC2    | CBC3.0 | CBC3.1        |
|------------------------------------------------|---------|--------|---------------|
| proton energy [MeV]                            | 62      | 62     | 62            |
| flux $[10^8 \mathrm{cm}^{-2} \mathrm{s}^{-1}]$ | 2.5     | 2.3    | 2.0           |
| flux relative to HL-LHC                        | ×73.5   | ×67.6  | $\times 58.8$ |
| beam exposure time [h]                         | 12      | 14.6   | (3×)15.6      |
| total fluence $[10^{13} \text{ cm}^{-2}]$      | 1.1     | 1.2    | 1.1           |
| total radiation dose of CBCs in the beam [Mra  | ad] 1.5 | 1.6    | 1.5           |

# 65 3 SEU sensitivity of the CBC

The overall design of the CBC is summarised in [9] and references therein. The first version of 66 67 the CBC [10, 11] was a conventional 128 channel LHC readout chip, and was not subjected to an SEU test. The later versions, starting with the CBC2, included logic for stub-finding [12–15]. 68 The CBC2 did not include all the circuitry required to transmit stub data off-chip at the full HL-69 LHC rate. This was done in the CBC3 [16, 17] which, following studies of CBC2 SEU resilience, 70 also included modifications to further improve SEU robustness. The CBC3.1 design included 71 some minor changes intended to finalise the chip for HL-LHC operation; some of them were 72 intended to further reduce the SEU sensitivity. Following each new CBC version, SEU tests 73 were carried out to evaluate the performance. 74 The chip has 254 front-end channels, with preamplifier, gain amplifier and comparator, and 75

<sup>76</sup> reads out microstrips from two sensors, with alternate CBC channels connected to either upper

<sup>77</sup> or lower sensor [14]. In this way, it is relatively simple to compare hit patterns between the

<sup>78</sup> two layers, to identify those which are compatible with a higher transverse momentum track

<sup>79</sup> candidate ( $p_T \gtrsim 2 \text{ GeV/c}$ ). The outputs of the comparators follow two separate data paths; in

<sup>80</sup> one of them data are stored in a pipeline memory buffer. When a L1 trigger is received, the data

of interest are loaded into a 32-deep readout buffer before being read out serially, at 40 Mbps

in the CBC2, and at 320 Mbps in the CBC3. The L1 trigger counter is incremented on receipt of
 a trigger and transmitted with the data.

A second data path is responsible for identifying and reading out stubs through several stages
 of combinatorial logic. As explained elsewhere, this path runs at the LHC clock rate to transmit
 data form every beam ereasing for uses in the CMS 11 trianer has permitting real time track.

data from every beam crossing for use in the CMS L1 trigger by permitting real-time track reconstruction [18].

<sup>88</sup> The digital circuitry is used to operate the pipeline memory, to store values in  $I^2C$  registers to

<sup>1</sup> program various operating parameters in the chip, and within the pipeline itself to store binary

values representing hits until they can be read out after the latency period, which is up to 6.4

 $\mu$ s (CBC2) or 12.8  $\mu$ s (CBC3). The most relevant CBC parameters for each chip are summarised

<sup>92</sup> in Table 2. Therefore possible types of error in the CBC are bit-flips in pipeline cells, pipeline

<sup>93</sup> logic upsets, and bit-flips in I<sup>2</sup>C registers.

| Table 2: Relevant CBC parameters             |                 |                                    |  |  |  |  |
|----------------------------------------------|-----------------|------------------------------------|--|--|--|--|
|                                              | CBC2            | CBC3.0 / CBC3.1                    |  |  |  |  |
| Channels                                     | 254             | 254                                |  |  |  |  |
| Pipeline memory length                       | 256             | 512                                |  |  |  |  |
| Storage buffer depth                         | 32              | 32                                 |  |  |  |  |
| I <sup>2</sup> C registers                   | 307             | 330 / 338                          |  |  |  |  |
| Data storage (memory) cells                  | 73,536          | 138,592                            |  |  |  |  |
| Readout speed [MHz]                          | 40              | 320                                |  |  |  |  |
| Data and header frame readout time $[\mu s]$ | 6.65            | 0.95                               |  |  |  |  |
| Stub resolution                              | 1 strip         | half strip                         |  |  |  |  |
| Stub readout                                 | OR of all stubs | addresses & bends of up to 3 stubs |  |  |  |  |

<sup>94</sup> Bit-flips in pipeline cells should be unimportant as during CMS operation the memory cells are

<sup>95</sup> overwritten every 25 ns clock cycle, so every cell in the CBC3 pipeline is refreshed once every

 $_{96}$  12.8  $\mu$ s. They can be detected in an SEU test by storing data at the start of a test with a high

<sup>97</sup> comparator threshold so that no channel hit is created and a logic 0 is written into all cells of

<sup>98</sup> the pipeline. Then later, if a logic 1 is detected, it must be due to a bit-flip in the pipeline cell. It

<sup>99</sup> can also be done in the converse way by initialising cells to logic 1 and checking for a logic 0,

and this method was also used.

Although upsets in pipeline data should be unimportant for CMS operation, it was decided to confirm it by dedicating some time to such a test. In addition, hit data stored in the pipeline are transferred to a 32-deep buffer following a trigger. However, normally only a few cells of this buffer will be occupied because of the trigger rates expected in CMS p-p running. Data in the readout buffer could stay up to  $\sim 200\mu s$  (CBC2) or  $\sim 30\mu s$  (CBC3) in the very extreme case that 32 triggers are received very close together in time. At the maximum trigger rate of 750 kHz expected at HL-LHC, Poisson fluctuations mean that this will be very rare.

White expected at THE-EFIC, I disson indefiations mean that this will be very fare.

<sup>108</sup> Pipeline logic upsets are detected by means of an error bit in the header preceding each frame of

data read out from the CBC. There are two special counters in the pipeline logic, one for the read

pointer and the other for the write pointer. The difference between their values corresponds to the trigger latency which is stored in an  $I^2C$  register. Any of the three values of read or write

<sup>111</sup> the trigger latency which is stored in an FC register. Any of the three values of read or write <sup>112</sup> pointer, or stored latency value could be affected by an SEU. If the difference between the read

and write pointer values is different from the value stored in the  $I^2C$  latency register, an error

bit is set in the data header. This kind of error will then persist until the three values are reset.

<sup>115</sup> In the case of I<sup>2</sup>C registers, bit-flips are detected by comparing the read value with the written

value. Although there are more than 300 8-bit I<sup>2</sup>C registers, 254 of them are used for channel
offsets and each register affects only one channel so the impact of an SEU is still very minor.
Some control registers which define analogue circuit parameters for the full 254 channels or
which influence the digital logic for hit detection and stub identification might have a bigger
impact on operational efficiency, but will not generally disable the chip. However, a small number of registers might generate a state which requires a reset for normal operation to continue;
no error of this type has been detected.

Different means have been adopted to make these components SEU tolerant. The pipeline logic has been designed using Whitaker cells [19]. In this case SEU events can only corrupt the cell state while writing a value at a clock edge, which lasts for an extremely short time (much less than 1 ns). Whitaker cells were not originally used for I<sup>2</sup>C registers, but this was adopted for the CBC3, as explained below.

A majority voting scheme was implemented for the  $I^2C$  registers in the CBC2, where each 128 loaded bit state is triplicated and stored; the majority of the states in the three cells defines the 129 state of the bit. This means that an SEU has to occur in at least two cells to flip the logical state 130 of the bit. In addition, an external I<sup>2</sup>C refresh signal was implemented. Once this signal is 131 sent to the CBC, each register bit is set to the majority of the three relevant cells. If this refresh 132 is carried out sufficiently often, it should be rare that more than one cell among the three has 133 changed state, so the bit-flip rate is expected to be minimal. However, from the result of the 134 SEU tests on the CBC2, the spatial separation of the triplicated logic was suspected to be too 135 small. Therefore, in the CBC3, it was replaced by Whitaker cells. 136

To compute the rates in the HL-LHC environment, it is necessary to know the flux of particles where the CBCs will be located. This is explained in the tracker upgrade TDR [5]. The maximum total ionising dose in the Outer Tracker, in the vicinity of 2S-modules, is computed to be 9 Mrad for 3000 fb<sup>-1</sup> of integrated luminosity. Assuming this is delivered over 10 years with an operational year of  $10^7$  s entirely by minimum ionising particles (MIPs), it corresponds to a maximum flux of  $3.4 \times 10^6$  cm<sup>-2</sup>s<sup>-1</sup>. The statistical uncertainties were estimated to be less than 8% [5].

# 144 4 Method of SEU testing

In each of the tests, the detailed procedure was changed slightly to adapt to differences in the
 CBC versions or the readout system. However, the method was essentially the same in each
 case, and is described below.

## 148 4.1 Pipeline logic test

Once the CBC receives a signal denoted as a fast reset, the logic is reset, as is the error bit, and the write counter starts to increment. The trigger pointer starts after the trigger latency period which is stored (in clock cycles) in an I<sup>2</sup>C register. The CBC writes data (the binary value corresponding to the signal from the front end amplifier, following a comparator and hitdetect logic) to the pipeline address at the write pointer value. The CBC reads out data from the location of the read pointer, which is the trigger counter value when it receives the trigger signal.

The pipeline logic was tested by checking the error bit in the triggered data header. If the error bit is not set (0), it means that no bit-flip occurred in either the read or write counters or the latency register during the interval between the last fast reset and the trigger signal. If the error bit changed from 0 to 1, a bit-flip must have occurred and that error persists until a fast reset

## 4. Method of SEU testing

is sent. A trigger was sent multiple times after a fast reset to accumulate statistics. An upper 160 limit was estimated for the pipeline logic error rate since this type of error was not observed. 16

#### Pipeline cell test 4.2 162

The pipeline and readout buffer cells were tested together with the pipeline logic. Triggers 163 were sent periodically so that only data for a single event was present in the readout buffer. To 164 increase sensitivity while limiting dead time in the CBC2 test, the 40 MHz clock was stopped 165 for 260 cycles and started just before the next trigger. In this way, all the data stayed in the 166 pipeline cells for at least 260 clock cycles ( $6.5\mu$ s). This was not possible for CBC3 tests due to 167 the more complex control logic for the fast serial interface with its 320 MHz clock. 168

#### I<sup>2</sup>C register test 4.3 169

The CBC chips have registers written to and read back via the I<sup>2</sup>C serial interface. Three quar-170 ters of the registers are used for the fine adjustment of the offset level for each channel with 171 respect to a single global threshold for the hit logic. There are 254 channels for both CBC2 and 172 CBC3. For the SEU tests, the contents of the I<sup>2</sup>C registers define the number of cells with logic 0 173 and 1. These could be chosen arbitrarily for offset values to populate 0s and 1s in a convenient 174 way. However, control registers were configured for normal operation in all tests, which meant 175 that arbitrarily chosen values of register settings could not be used. 176 Since the I<sup>2</sup>C registers are implemented in different types of logic cell for CBC2 and CBC3, the 177

testing methods were different. The following subsections describe them separately for each 178

CBC version. 179

#### 4.3.1 CBC2 180

 $I^2C$  register upsets were checked periodically by reading them at a time  $T_0$  after setting their 181 contents, as in Figure 1. The offset registers were set to values such that the numbers of logic 182 0 and 1 were roughly the same. The  $I^2C$  refresh signal was issued from the back end data 183 acquisition. 184

- The sequence in this test was as follows: 185
- a hard reset was sent from software, 186
- I<sup>2</sup>C registers were configured, 187
- I<sup>2</sup>C refresh signals were sent periodically from firmware or software, 188
- I<sup>2</sup>C registers were read and recorded at time T<sub>0</sub> after configuration, 189



Figure 1: I<sup>2</sup>C register test sequence.

#### 4.3.2 CBC3 190

One relevant change between the CBC2 and CBC3 was an increase in the pipeline length to 191

increase the latency. Although the memory cell circuit is fundamentally the same type, the 192

circuit was modified in three significant ways: read and write transistors were changed from NMOS to PMOS; NMOS transistors in back-to-back inverters were changed to an enclosed geometry, effectively increasing their size by a factor of 4.5; the cell layout was made more compact, so that the CBC3 memory area is less than 1.5 times larger than the CBC2 despite doubling the number of bits.

The second change probably enhanced the SEU tolerance, but the third one might have increased the SEU probability. In addition, the increased memory size required extra intermediate buffering in control and read/write lines so the memory is in manageable blocks. This introduced extra logic buffers which could be susceptible to SEU.

202

In the case of the CBC3,  $I^2C$  register upsets were checked by periodically reading them after an interval *T*. This was done for the CBC3.0 during the data taking run, in parallel with the pipeline logic and readout buffer test, and (for practical reasons) between runs for the CBC3.1.

The registers were configured once at the beginning of each run. The runs were stopped when 206 necessary, especially when bit-flips which disturbed data taking were observed. In this version 207 of the CBC, there are a small number of read-only bits for monitoring errors, and also some ex-208 tra read-only bits added to the CBC3.1 to allow to test hit data transfer to the nearest neighbour 209 chip. In total, 316 8-bit registers (of which a total of 5 bits were read-only) were checked in the 210 CBC3.0 (14 registers were omitted), and 332 8-bit registers (of which 11 bits were read-only) 211 were checked in the CBC3.1 (3 registers were omitted.) In both tests, control registers were 212 configured with values for normal data taking. 213

- <sup>214</sup> Four different configurations of channel offsets were tested in the CBC3.0, as shown in Table 3.
- <sup>215</sup> Configuration D used two values, 0x80 and 0x7f, with half the channels set to one of the values.
- <sup>216</sup> Only configuration D was used for the CBC3.1 test.

Table 3: I<sup>2</sup>C register offset settings for CBC3.0 and the total exposure time for each setting. The periodic read interval was set to 5 mins except for (\*), where it was set to 5 sec. For run D, half the channels were set to each value.

|                              | Setting type     | time [h] |
|------------------------------|------------------|----------|
|                              | A: all 0xff      | 4.64     |
| $\backslash \langle \rangle$ | B: all 0x00      | 1.62     |
|                              | C: all 0x0f      | 2.80     |
|                              | D: 0x80/0x7f     | 2.49     |
| /                            | D: 0x80/0x7f (*) | 0.42     |
|                              |                  |          |
|                              |                  |          |

# **5** SEU results from the CBC2

A detailed discussion of the CBC2 tests and results is given in [20]. No errors attributable to SEUs were observed in the pipeline logic in an interval of  $1.2 \times 10^4$  s, which corresponds to  $9.0 \times 10^5$  s, or 11 days, at HL-LHC. With a confidence level of 99%, this corresponds to a Poissonian upper limit on the rate per CBC of 0.019 SEU h<sup>-1</sup>.

<sup>222</sup> 78 bit-flips were observed in I<sup>2</sup>C registers during the test, which took place over two days in <sup>223</sup> 2014. Of those, 21 were  $0 \rightarrow 1$  and 57 were  $1 \rightarrow 0$  bit-flips. There were a few examples of <sup>224</sup> multiple bit-flips; 14 registers were affected in this way, comprising 5× 2-bit-flips, 6× 3-bit-<sup>225</sup> flips and 3× 4-bit-flips. The results are summarised in Tables 4 and 5. Run 9B was simply to <sup>226</sup> verify that no bit-flips were observed without beam.

In both single and multiple upset cases, flips  $0 \rightarrow 1$  were less frequent than those  $1 \rightarrow 0$ . Of the 227 single bit-flips, there were  $8 \times 0 \rightarrow 1$  compared to  $30 \times 1 \rightarrow 0$ . In the multiple bit-flips, there 228 were  $13 \times 0 \rightarrow 1$  compared to  $27 \times 1 \rightarrow 0$ . This could indicate a different SEU cross section 229 for the *p* and *n* nodes. It was suspected that the multiple bit-flips might occur if the three cells 230 used for triplication were too close to each other, so that a single SEU event could change the 231 state of multiple cells in a register, but this was ruled out from an examination of the circuit 232 layout. Later studies on the CBC3 suggest that it might be a result of I<sup>2</sup>C registers being reset 233 to the last written value or the default value, which is hard to verify from the CBC2 data. 234

Using the data from Run 4 and 12 in Tables 4 and 5, a total of 27 registers experienced a bit flip in 130 min exposure. Data from other runs was ignored, because of uncertainties in the efficiency of the refresh mechanism. Scaling this to the HL-LHC, in a flux of  $3.4 \times 10^6$  cm<sup>-2</sup>s<sup>-1</sup>, would lead to an SEU event rate of approximately  $0.17 \text{ CBC}^{-1}\text{h}^{-1}$  which was considered higher than desirable. Hence improvements to the design were sought.

There were no observed bit-flips in the pipeline control logic and it was therefore decided thatWhitaker cells should be adopted for the next iteration of the design.

Table 4: Summary of CBC2 bit-flips in  $I^2C$  registers.  $N^{cycle}$  is the number of 10 min periods used for each run.

| Run    | Beam | Num            | per of bit-    | flips |                    | 1                        | I  | <sup>2</sup> C refresh |
|--------|------|----------------|----------------|-------|--------------------|--------------------------|----|------------------------|
|        |      | 0  ightarrow 1 | 1  ightarrow 0 | Total | $N^{\text{cycle}}$ | Total/N <sup>cycle</sup> | Hz | pulse length           |
| Run 4  | On   | 5              | 11             | 16    | 7                  | $2.29 \pm 0.57$          | -  | - \                    |
| Run 6  | On   | 1              | 5              | 6     | 7                  | $0.86 {\pm} 0.35$        | 1  | 1 msec                 |
| Run 8  | On   | 6              | 4              | 10    | 6                  | $1.67 \pm 0.53$          | 10 | 1 msec                 |
| Run 9A | On   | 5              | 21             | 26    | 4                  | $6.50 \pm 1.27$          | 10 | 25 nsec                |
| Run 9B | Off  | 0              | 0              | 0     | 3                  | $0.00{\pm}0.00$          | 10 | 25 nsec                |
| Run 12 | On   | 4              | 16             | 20    | 6                  | $3.33 {\pm} 0.74$        | -  | -                      |
| Total  |      | 21             | 57             | 78    | $\square$          | $\sim$                   |    |                        |
|        |      | _//            |                |       |                    |                          |    |                        |

Table 5: I<sup>2</sup>C register bit-flips in the CBC2, where multiple bit changes occurred. The page and address specify the 8-bit I<sup>2</sup>C register.

| Ēv | rent | Run | Page | Address | Written value                          | Read value                             | Default value |
|----|------|-----|------|---------|----------------------------------------|----------------------------------------|---------------|
|    | 1    | 4   | 2    | 0xfd    | 01101000                               | 01010000                               | 1000000       |
|    | 2    | 4   | 2    | 0x80    | 0101 <mark>10</mark> 00                | 0101 <mark>01</mark> 00                | 10000000      |
|    | 3    | 4   | 2    | 0x25    | 0101 <mark>10</mark> 01                | 0101 <mark>01</mark> 01                | 10000000      |
|    | 4    | 8   | 2    | 0xb1    | 010 <mark>0</mark> 01 <mark>10</mark>  | 010 <mark>1</mark> 01 <mark>01</mark>  | 10000000      |
|    | 5 🔪  | 8   | 2    | 0xe0    | 01010 <mark>000</mark>                 | 01010 <mark>1</mark> 01                | 10000000      |
|    | 6    | 8   | 2    | 0x45    | 0100 <mark>1</mark> 10 <mark>0</mark>  | 0100 <mark>0</mark> 10 <mark>1</mark>  | 10000000      |
|    | 7    | 9A  | 2    | 0x1d    | 0 <mark>1</mark> 00 <mark>1</mark> 110 | 0 <mark>0</mark> 00 <mark>010</mark> 0 | 10000000      |
|    | 8    | 9A  | 2    | 0x64    | <mark>01</mark> 001100                 | 10000000                               | 10000000      |
|    | 9    | 9A  | 2    | 0x93    | 0101 <mark>1110</mark>                 | 0101 <mark>0101</mark>                 | 10000000      |
| 1  | 10   | 9A  | 1    | 0x28    | <b>1111111</b> 1                       | 01010101                               | 00000000      |
| 1  | 1    | 9A  | 2    | 0x10    | 0 <mark>1</mark> 0000 <mark>11</mark>  | 00000000                               | 10000000      |
| 1  | 12   | 9A  | 2    | 0x29    | 01010 <mark>000</mark>                 | 01010 <mark>1</mark> 01                | 10000000      |
| 1  | 13   | 12  | 1    | 0x28    | <b>1111111</b> 1                       | 01010101                               | 00000000      |
| 1  | 14   | 12  | 2    | 0x33    | 0101 <mark>101</mark> 1                | 0101 <mark>010</mark> 1                | 1000000       |

8

## <sup>242</sup> 6 SEU results from the CBC3.0

This test was carried out in 2017. As explained the principal change relevant for SEU performance was to replace triplicated logic in the I<sup>2</sup>C registers by Whitaker cells.

<sup>245</sup> 12.4 hours were dedicated to measure the SEU rates. However, a wrong procedure for most of <sup>246</sup> the data taking resulted in a fast reset being sent just before the L1 trigger for 11 hours of data <sup>247</sup> taking so only 1.4 hours could be used to estimate the SEU rate in the pipeline logic. No errors <sup>248</sup> were observed in an interval of 5040 s, which corresponds to  $3.4 \times 10^5$  s at HL-LHC. With a <sup>249</sup> confidence level of 99%, this corresponds to a Poissonian upper limit on the rate of 0.049 SEU <sup>250</sup> h<sup>-1</sup>.

Because of the error in the operation procedure, only the 1.4 hours of data taking could be used to estimate the error rate on hit data in the pipeline. In  $5.1 \times 10^6$  triggers, no fake hits were detected.

In the case of I<sup>2</sup>C registers, the test was not affected by the wrong procedure and the entire 12.4 hours of data could be used. The results are given in Table 6 and in detail in the Appendix. 25 bit-flips were observed. All of them were of single bits. Again  $0 \rightarrow 1$  flips were less frequent than  $1 \rightarrow 0$ , here by a ratio of 1:24. Most bits experienced a flip, but lower order bits appear to be more frequent, particularly bit-4 of [0:7].

The rate corresponds to  $8.6 \times 10^{-6} \text{ s}^{-1}$  or  $0.031 \pm 0.006 \text{ CBC}^{-1}\text{h}^{-1}$  in CMS. This is significantly

lower than in the CBC2, as expected, but is not zero. This is because there are still some SEU-

sensitive nodes in the register circuitry. An SEU on a write node causes the storage cell to flip

to the last write transaction on the bus. An SEU on the reset node causes the cell to flip to its
 default value.

| Setting type  | duration [h] | Number of bit-flips |                   |                   |  |  |
|---------------|--------------|---------------------|-------------------|-------------------|--|--|
|               |              | Total               | $0 \rightarrow 1$ | $1 \rightarrow 0$ |  |  |
| A (all 0xff)  | 4.64         | 14                  | 0                 | 14                |  |  |
| B (all 0x00)  | 1.62         | 2                   | 1                 | 1                 |  |  |
| C (all 0x0f)  | 2.80         | 4                   | 0                 | 4                 |  |  |
| D (0x80/0x7f) | 2.91         | 5                   | 0                 | 5                 |  |  |
| Total         | 11.97        | 25                  | 1                 | 24                |  |  |
|               | /            |                     |                   |                   |  |  |

Table 6: Summary of CBC3.0 bit-flips in I<sup>2</sup>C registers.

## **264** 6.1 Direct exposure to heavy ions

During the course of other tests, data have been collected with prototype modules read out by 265 the CBC3.0 exposed to heavy ions in the CERN H8 test beam. Although these do not gener-266 ate such large localised charge deposits in the CBC ASIC as atomic knock-on events, they do 267 generate very large ionisation signals in the sensors and are of interest because they resemble 268 knock-on ion events within the sensors, for light ions at least. A fully stripped ion will gen-269 erate a charge signal in silicon  $Z^2$  times larger than a singly charged hadron, where Z is the 270 atomic number of the ion. For example, xenon ions (Z = 54) with 150A GeV/c, which were 271 used in H8, will generate signals in the sensors of almost 3000 MIPs ( $\sim$ 12 pC in 300  $\mu$ m silicon), 272 which is well beyond the linear dynamic range of the CBC. The response to such sensor signals 273 was studied to verify that the recovery time of the amplifier circuit was sufficiently fast. The 274 response to such signals was observed to be limited to a localised overload affecting only a 275 few nearby channels, with the size diminishing significantly away from the central core, from 276

which they recover within 3  $\mu$ s at the centre, and shorter times for the peripheral signals.

This also provided an opportunity to expose the CBC directly to a xenon beam in November 279 2017. The main difference between SEU-type events and exposure to a high energy ion beam 280 is that the beam traverses the ASIC so the energy deposited is distributed approximately uni-281 formly along the path of the beam, rather than in a very small volume as is the case when a 282 knock-on ion comes to rest. This would imply a deposit of ~40 fC in 1  $\mu$ m depth, using the 283 figures above.

The conditions in the beam did not permit a qualitative evaluation of SEU rates, since the flux was not well measured. However, a number of SEUs were observed, but no damage to the exposed CBCs resulted. In any case, such an exposure is not expected in CMS.

## 287 7 SEU results from the CBC3.1

The CBC3.1 is expected to be the final version of the CBC, having included a small number of minor changes to correct or improve small details of performance.

The I<sup>2</sup>C registers for the CBC3 were designed in such a way that the SEU-tolerant Whitaker 290 register cell for each bit of an 8-bit register employs its own set of standard inverters to buffer 291 the reset and write signals, and produce their inverse for the purpose of controlling both n 292 and p-type transistor switches in the circuit. These inverters are small in dimension, resulting 293 in small node capacitances that make the circuit more susceptible to upset when an ionising 294 particle deposits charge on the sensitive nodes. This was reasoned to be the cause of the single 295 bit-flips observed during testing of the CBC3. To counter this without major changes to the 296 ASIC, it was shown by simulation that by merging together all of the reset lines, and likewise all 297 of the write lines, for every bit across the 8-bit register, the effective capacitance of the sensitive 298 nodes was multiplied eight times and required a greater charge deposit to cause an upset. The 299 registers in CBC3.1 were re-wired to implement this strategy. 300

A consequence of this modification is that any particle depositing enough charge on either the reset or write line to the 8-bit register will potentially cause all eight bits to upset. To increase further the capacitance and hence the resistance to SEU, the size of the inverter cells used on CBC3.1 was also increased as much as possible within the constraints of the existing layout, leading to devices three times their original size. Simulations of the modified circuit using standard corner models for the technology showed the modified circuit to be resistant up to a deposited charge of 864 fC, over thirty times greater than for the unmodified circuit.

The CBC3.1 test was carried out in 2019. As statistics had regularly been a limit to the measurements, they were increased by equipping the setup with four CBC3.1 chips, three of which were exposed to the beam, with the fourth control chip outside the beam.

An unexpected event was observed once in each of the three chips in the beam but not at-312 tributed to an SEU during the 15.4 hours of data taking. In each case, a small group of con-313 secutive I<sup>2</sup>C registers was reset to their default values. It was believed that this was caused by 314 an upset in the nearby interface electronics which was only partially shielded from the beam 315 and not radiation hard. However, it was not possible conclusively to rule them out as SEUs 316 occurring in the CBCs themselves, even though the behaviour was not believed to be consis-317 tent with the design of the CBC register control distribution. This remains a subject for further 318 investigation. 319

No pipeline logic errors were observed in 3662 seconds in the three exposed CBC3.1s. Combined with the results from the CBC3.0, this leads to a 99% confidence level Poisson upper limit on the rate per CBC of 0.017 SEU  $h^{-1}$ . This is only slightly less than the limit established for the CBC2 but the memory is twice the size, with more extensive control logic.

A small number of errors in the pipeline memory data were observed. Triggers were sent at 20 kHz with the latency between the write and read pointers set to 12.5  $\mu$ s, which is almost the maximum value which will be allowed in CMS, checking for both 1  $\rightarrow$  0 and 0  $\rightarrow$  1 types of error. 74 unexpected values in the three CBCs were observed in the 7.32  $\times$  10<sup>7</sup> triggers. Taking into the account the flux relative to HL-LHC this corresponds to a false hit rate of 2.2  $\times$  10<sup>-11</sup> per trigger in CMS, which can be compared with an expected occupancy  $\sim$ 1-2%.

15.4 hours were dedicated to measuring the SEU rate in the  $I^2C$  registers, which was where 330 possible changes compared to the CBC3.0 were expected. In the entire test, the content of each 331 register remained unchanged, and the 254 offset registers were all configured so that half of 332 them took the value 0x80 and the other half 0x7f. In this way the offset was in both cases in 333 the middle of the range but with seven 0s in one case and seven 1s in the other. While the 334 numbers of logic 0 and 1 in the configuration used in the test were almost equal, the default 335 values are dominated by 0, as shown in Table 7. Table 8 shows the number of bits for different 336 configurations which could be checked during each test. 337

Table 7: The number of logic 0 and 1 in the 330 8-bit registers for the default settings of the CBC3.1 and for the configuration used in the test. Eight registers which were not checked are ignored.

|                    | Number of logic 0 | Number of logic 1 |  |  |  |
|--------------------|-------------------|-------------------|--|--|--|
| Default settings   | 2026              | 614               |  |  |  |
| Test configuration | 1234              | 1406              |  |  |  |
|                    |                   |                   |  |  |  |

Table 8: The number of logic 0 and 1 in the 330 8-bit registers which could be compared with the value in the first column for different test configurations of the CBC3.1. A bit which is set to 1 can only be checked for a  $1 \rightarrow 0$  transition, for example.

|    |                  | Number of logic 0 | Number of logic 1 |
|----|------------------|-------------------|-------------------|
|    | Default settings | 153               | 945               |
|    | 0xc1             | 462               | 878               |
| // | 0x55             | 610               | 696               |
|    | 0x00             | 0                 | 1406              |
|    | 0xff             | 1234              | 0                 |
|    | 0x41             | 306               | 1053              |
|    |                  |                   |                   |

For the CBC3.0 test, the last written value to the I<sup>2</sup>C register was always the same (0x41) but different values were used in the CBC3.1 exposures, as listed in Table 9, to study its influence more carefully. One register was written with the chosen value, e.g. 0x55, after all the registers had been read to check their contents. Then, 0x55 stayed in the latch and if the write line of any register were to experience an SEU, that value would be written to the register.

81 register value changes were observed, of which 38 altered a single bit. The three CBC3.1s 343 appeared to behave similarly with 34, 23 and 24 SEUs observed in each of them. The detailed 344 results are shown in the Appendix. In summary, there were  $10 \times 2$ -bit,  $3 \times 3$ -bit,  $9 \times 4$ -bit,  $4 \times 6$ -345 bit,  $14 \times 7$ -bit and  $3 \times 8$ -bit flips. This behaviour was more complicated than originally expected 346 and the register content changes were studied to seek any patterns which could explain it. As 347 explained earlier for the CBC3.0, two types of expected correlation were with the default value 348 of the register setting, and the last written  $I^2C$  value transmitted to the CBC. In most cases, the 349 bits which changed took a value which was consistent with the same bits in either the default 350 setting, or the last written value. 351

| Run ID | Last written value | duration [h] | No. SEU | rate [h <sup>-1</sup> ] |
|--------|--------------------|--------------|---------|-------------------------|
| 1      | 0xc1               | 0.45         | 6       | $13.4\pm5.5$            |
| 2      | 0xc1               | 1.21         | 10      | $8.2\pm2.6$             |
| 3      | 0x55               | 2.01         | 13      | $6.5\pm1.8$             |
| 4      | 0x00               | 0.96         | 0       | $0.0\pm0.0$             |
| 5      | 0xff               | 0.72         | 6       | $8.4\pm3.4$             |
| 6      | 0x00/0xff          | 1.37         | 10      | $7.3\pm2.3$             |
| 7      | 0x00/0xff          | 0.88         | 3       | $3.4\pm2.0$             |
| 8      | 0x00/0xff          | 0.91         | 5       | $5.5\pm2.5$             |
| 9      | 0x00/0xff          | 0.62         | 5       | $8.1\pm3.6$             |
| 10     | 0x00/0xff          | 1.06         | 2       | $1.9\pm1.3$             |
| 11     | 0x41               | 0.94         | 2       | $2.1 \pm 1.5$           |
| 12     | 0x41               | 0.99         | 0       | $0.0\pm0.0$             |
| 13     | 0x00/0xff          | 3.25         | 19      | $5.8 \pm 1.3$           |
| total  |                    | 15.36        | 81      | $5.3\pm0.6$             |
|        |                    |              |         | $\rightarrow$           |

Table 9: The conditions of each CBC3.1 test and numbers of SEUs observed. The periodic read interval was 2 sec. As explained in the text, several runs were taken alternating the last written value between 0x00 and 0xff.

It was found that the rate of bit-flips depended most strongly on the last written value. In particular, if the value was 0x00, the rate was significantly lower than when it was 0xff. Therefore, to improve the statistics under those conditions, each periodic I<sup>2</sup>C register check, carried out at 2 s intervals, was followed by writing a register with either 0x00 and 0xff, toggling so that the last value alternated between 0x00 and 0xff, for a total of 8.1 hours. This method was adopted to avoid any risk of radiation effects from the accumulated dose biasing the result. The conditions for each configuration and the numbers of SEUs observed are summarized in

359 Table 9.

<sup>360</sup> 72 events were consistent with bit-flips to the last written value, while 31 events were consistent <sup>361</sup> with bit-flips to the default value (see Figure 2 where the register changes are categorized ac-<sup>362</sup> cording to the new flipped values). For many of the flipped bits, the default and the last written <sup>363</sup> value were the same, thus indistinguishable. All of the four SEUs which were not consistent <sup>364</sup> with either a flip to the default or last written value were single  $1 \rightarrow 0$  bit-flips.

Combining the data from Runs 4-10 and 13, 47 SEUs were observed in 4.76 h when the last written value was 0xff, while only 3 SEUs were observed in 5.00 h when the last value was 0x00, a ratio of 16.5, with a large statistical error because of the small number of 0x00 SEUs. Of these 3 events, 2 are single bit-flips while the third is an 8-bit transition from 0xff to 0x00; all three are consistent with the last written value, while the two single bit-flips are also consistent with the default value.

From these results it is possible to compute the expected SEU rate in CMS at the HL-LHC, for different choices of the last written value, which are shown in Table 10. By choosing a value of 0x00, it should be possible to operate in CMS with an SEU rate of  $0.010 \pm 0.006 \text{ CBC}^{-1}\text{h}^{-1}$ . If the anomalous events mentioned earlier are also attributed to genuine CBC SEUs and not the interface circuitry, then this would increase the rate in CMS to  $0.014 \pm 0.006 \text{ CBC}^{-1}\text{h}^{-1}$ .

## 376 7.1 Operation in CMS

Although SEUs in CMS during the HL-LHC era may be more troublesome than in the past, there is no specification for an acceptable rate, and SEU effects will in any case clearly depend

on the specific consequences for the affected ASIC and its location. Atomic knock-ons will in-



Figure 2: The 81 SEU events in I<sup>2</sup>C registers categorized according to the new (flipped) value: the default value (red), the last written value (blue), or neither. Of the 72 events where the register changed to the last written value, 43 had multiple bit-flips. The 4 events inconsistent with both the last written value and the default value were all single  $1 \rightarrow 0$  bit-flips.

Table 10: Comparison of SEU rates in the CBC3.0 and CBC3.1 I<sup>2</sup>C registers depending on the last written register value.

|   | CBC version | Last written value | SEU rate at HL-LHC |
|---|-------------|--------------------|--------------------|
| ~ |             |                    | $[CBC^{-1}h^{-1}]$ |
| / | CBC3.0      | -                  | $0.031\pm0.006$    |
|   |             |                    |                    |
|   | CBC3.1      | all used           | $0.090\pm0.010$    |
|   | CBC3.1      | 0xff               | $0.168 \pm 0.025$  |
|   | CBC3.1      | 0xc1               | $0.164 \pm 0.041$  |
|   | CBC3.1      | 0x55               | $0.110\pm0.030$    |
|   | CBC3.1      | 0x41               | $0.018 \pm 0.012$  |
|   | CBC3.1      | 0x00               | $0.010\pm0.006$    |
|   |             |                    |                    |

evitably be more frequent closer to the beam but the innermost detector ASICs are presently 380 at a relatively early stage of development. The impact of SEUs may be most strongly felt on 381 control functions, rather than on data corruption, which has been demonstrated by these mea-382 surements to be trivial for the CBC data. In the CBC, an upset affecting the stored value of 383 the latency or the read or write counters would force that chip out of synchronisation which 384 would corrupt the data until the correct values have been restored. However, a significant 385 number of chips would need to go out of sync before there is a noticeable effect on data quality, 386 given the redundancy in the track finding, and large number of tracks being measured in each 387 interaction. 388

It is also difficult to be guided by experience from the present silicon strip tracker. SEUs were not explicitly monitored during data taking, except by counting the front-end ASICs which went out of sync during a run. However, this was difficult to correlate with luminosity, since global CMS resets were issued during data taking in response to unexpected conditions in a wide range of sub-systems which had not been foreseen.

In future, it seems wise to monitor the status of the registers on (all) the ASICs to keep a record of the rate of SEUs, and react if required. About twenty CBC registers have a global effect on the chip, hence should be monitored most frequently, e.g. at  $\sim$ 1 Hz. Conversely, it does not seem useful to continuously monitor the 254 threshold offset values, which affect only a single channel, but the pipeline logic could also be monitored at  $\sim$ 1 Hz, especially since the error bit in the CBC header may be ambiguous when it reaches the data acquisition.

Monitoring the register contents requires an  $I^2C$  read transaction, which takes about 40  $\mu$ s at the 1 MHz I<sup>2</sup>C clock frequency used. There are 7,680 2S-modules in CMS [5], each containing 16 CBC chips, so 122,880 CBCs in total. An upset rate of 0.01 SEU CBC<sup>-1</sup>h<sup>-1</sup>, monitoring 20 of the 338 registers, implies 0.02 registers s<sup>-1</sup> in the entire system would require a reset. This can easily be accomplished by rewriting the value at a convenient moment in data taking, such as a pause for system resets or during a calibration operation in another sub-system, once the actual operating conditions are better established.

## 407 8 Conclusions

SEU tests have been carried out on several versions of the CBC readout ASIC. In the final 408 version of the chip, the CBC3.1, no pipeline logic error was observed in the equivalent of 11 409 days of continuous operation in CMS at the HL-LHC and gives a 99% Poisson upper limit of 410 0.017 SEU CBC<sup>-1</sup>h<sup>-1</sup>. A fake hit rate in any channel of  $2.2 \times 10^{-11}$  per trigger in CMS was 411 inferred from the measurements, which can be compared with an expected occupancy of 1-2%. 412 3 SEU events were observed in  $I^2C$  registers in the equivalent of 903 h, or 38 days, of HL-LHC 413 operation, providing the last value written to an  $I^2C$  register on the chip was set to be 0x00, 414 which is a rate of  $0.010 \pm 0.006 \text{ CBC}^{-1}\text{h}^{-1}$ . 415

Only a handful of I<sup>2</sup>C registers have a significant effect on the chip by, for example, controlling latency values, amplifier bias settings or global values of the comparator thresholds. Most of the I<sup>2</sup>C registers store comparator offset values which are for the fine tuning of signal thresholds for a single channel and hence will have little effect on operation should they be disturbed. However, it will be desirable to monitor SEU rates in the experiment to ensure expectations are met. Checking the contents of the most sensitive registers and recording changes will be useful, and correction can be undertaken with no impact on operation during data taking.

# 423 Acknowledgments

We thank Mark Raymond and Davide Braga for important contributions to earlier stages of this work. We gratefully acknowledge financial support from the UK Science and Technology Facilities Council and Advanced European Infrastructures for Detectors at Accelerators (AIDA) for some of the beam time. We also thank the Imperial College High Energy Physics electronics workshop and the local support during the beam tests from the Light Ion Facility at UC Louvain-la-Neuve, particularly Martin Delcourt, Jérôme de Favereau and Christoph Delaere.

# 430 References

[1] M. Huhtinen and F. Faccio, "Computational method to estimate single event upset rates
 in an accelerator environment", *Nucl. Instrum. Meth. A* 450 (2000) 155,
 doi:10.1016/S0168-9002(00)00155-8.

- [2] E. Noah et al., "Single event upset studies on the CMS tracker APV25 readout chip",
- <sup>435</sup> Nucl. Instrum. Meth. A **492** (2002) 434, doi:10.1016/S0168-9002(02)01356-6.
- [3] M. Friedl, T. Bauer, and M. Pernicka, "Single event effects on the APV25 front-end chip", Nucl. Instrum. Meth. A 501 (2003) 189, doi:10.1016/S0168-9002 (02) 02031-4.
- [4] L. Eklund et al., "SEU rate estimates for the ATLAS/SCT front-end ASIC", Nucl. Instrum.
   Meth. A 515 (2003) 415, doi:10.1016/j.nima.2003.07.003.
- [5] CMS Collaboration, "The phase-2 upgrade of the CMS Tracker Technical Design Report",
   CMS Note CERN-LHCC-2017-009, CMS-TDR-014, 2017.
- [6] S. S. E. Nasr-Storey and [CMS Outer Tracker Upgrade Collaboration], "Recent
  developments in the cbc3, a cms microstrip readout asic for track-trigger modules at the
  hl-lhc", *Nucl. Instrum. Meth. A* 936 (2019) 278, doi:10.1016/j.nima.2018.11.005.
- [7] P. Vichoudis et al., "The Gigabit Link Interface board (GLIB), a flexible system for the
  evaluation and use of GBT-based optical links", *JINST* 5 (2010) C11007,
  doi:10.1088/1748-0221/5/11/C11007.
- [8] M. Pesaresi et al., "The FC7 AMC for generic DAQ and control applications in CMS", JINST 10 (2015) C03036, doi:10.1088/1748-0221/10/03/C03036.
- [9] M. Prydderch, "CBC3.1 User Manual, Version 1.4", technical report.
- [10] M. Raymond et al., "The CMS binary chip for microstrip tracker readout at the SLHC",
   *JINST* 7 (2012) C01033, doi:10.1088/1748-0221/7/01/C01033.
- [11] W. Ferguson et al., "The CBC microstrip readout chip for CMS at the high luminosity
   LHC", JINST 7 (2012) C08006, doi:10.1088/1748-0221/7/08/C08006.
- [12] D. Braga et al., "CBC2: A microstrip readout ASIC with coincidence logic for trigger
   primitives at HL-LHC", JINST 7 (2012) C10003,
- 457 doi:10.1088/1748-0221/7/10/C10003.
- [13] D. Braga, "Development of the readout electronics for the high luminosity upgrade of the
   CMS outer strip tracker", imperial college ph.d thesis, 2016.

14

- [14] G. Hall et al., "CBC2: A CMS microstrip readout ASIC with logic for track-trigger 460 modules at HL-LHC", Nucl. Instrum. Meth. A 765 (2014) 214, 461 doi:10.1016/j.nima.2014.04.056. 462 [15] D. Braga et al., "Characterization of the CBC2 readout ASIC for the CMS strip-tracker 463 high-luminosity upgrade", JINST 9 (2014) C03001, 464 doi:10.1088/1748-0221/9/03/C03001. 465 [16] M. L. Prydderch et al., "CBC3: a CMS microstrip readout ASIC with logic for track-trigger 466 modules at HL-LHC", pos twepp-17, 001, 2018. doi:10.22323/1.313.0001. 467 [17] K. Uchida et al., "Results from the CBC3 readout ASIC for CMS 2S-modules", Nucl. 468 Instrum. Meth. A 924 (2019) 175-180, doi:org/10.1016/j.nima.2018.09.051. 469 [18] R. Aggleton et al., "An FPGA based track finder for the L1 trigger of the CMS experiment 470 at the High Luminosity LHC", JINST 12 (2017) P12019, 471 doi:10.1088/1748-0221/12/12/P12019. 472
- <sup>473</sup> [19] S. Whitaker, J. Canaris, and K. Liu, "SEU hardened memory cells for a CCSDS
- 474 Reed-Solomon encoder", IEEE Trans. Nucl. Sci. 38 (1991) 1471–1477,
- 475 doi:10.1109/23.124134.
- [20] K. Uchida et al., "Single event upset tolerance evaluation of the CBC2 readout chip",
- 477 CMS Detector Note DN-2017/009, 2017.

# 478 Appendix

Table 11: The complete list of  $I^2C$  register bit-flips in the CBC3.0. The page and address specify the 8-bit  $I^2C$  register. The last written value was always 0x41. A, B, C and D refer to the channel offset values used and are specified in Table 3.

| Setting type | Page          | Address                      | Written value                          | Read value               | Default value |
|--------------|---------------|------------------------------|----------------------------------------|--------------------------|---------------|
|              | $\frac{1}{2}$ | $\frac{1001033}{0\times 17}$ | 111111111                              | 11111011                 | 1000000       |
| Δ            | 2             | $0x^{2}d$                    | 11111111111111111111111111111111111111 | 11011111                 | 10000000      |
| A            | 2             | 0x2u                         | 11111111<br>11111111                   | 11011111                 | 10000000      |
| A            | 2             | 0xC4                         |                                        | 11111101                 | 10000000      |
| A            | 2             | 0x5d                         |                                        | 11111101                 | 1000000       |
| А            | 2             | 0xd3                         | 11111 <mark>1</mark> 111               | 11111 <mark>0</mark> 111 | 1000000       |
| А            | 2             | 0x4f                         | 1 <mark>1</mark> 111111                | 1 <mark>0</mark> 111111  | 1000000       |
| А            | 2             | 0x97                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| А            | 2             | 0x01                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| А            | 2             | 0x08                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| А            | 1             | 0x29                         | 111111 <mark>1</mark> 1                | 111111 <mark>0</mark> 1  | 11111111      |
| А            | 2             | 0x6d                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| А            | 2             | 0xa6                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| А            | 2             | 0xab                         | 1111 <mark>1</mark> 111                | 1111 <mark>0</mark> 111  | 10000000      |
| В            | 1             | 0x1b                         | 00000 <mark>1</mark> 00                | 00000000                 | 00000000      |
| В            | 2             | 0x37                         | 00000000                               | 10000000                 | 10000000      |
| С            | 2             | 0xc8                         | 00001111                               | 0000111 <mark>0</mark>   | 10000000      |
| С            | 2             | 0xef                         | 00001 <mark>1</mark> 11                | 00001 <mark>0</mark> 11  | 10000000      |
| С            | 2             | 0xdc                         | 00001111                               | 00001101                 | 10000000      |
| С            | 2             | 0xfa                         | 0000 <mark>1</mark> 111                | 00000111                 | 10000000      |
| D            | 2             | 0x99                         | 0111 <mark>1</mark> 111                | 01110111                 | 10000000      |
| D            | 2             | 0xda                         | 0 <mark>1</mark> 111111                | 0 <mark>0</mark> 111111  | 10000000      |
| D            | 2             | 0xda                         | 0111 <mark>1</mark> 111                | 0111 <mark>0</mark> 111  | 10000000      |
| D            | 2             | 0xa0                         | 0111 <mark>1</mark> 111                | 0111 <mark>0</mark> 111  | 10000000      |
| D            | 2             | 0xa4                         | 0111 <mark>1</mark> 111                | 0111 <mark>0</mark> 111  | 1000000       |

D 2 0xda 011 D 2 0xa0 011 D 2 0xa4 011

| Evt. | Page   | Addr.         | Written                              | Read                                 | Default       | Last written | Ι | II             | $1 \rightarrow 0$ | $0 \rightarrow 1$ | #bfs                |
|------|--------|---------------|--------------------------------------|--------------------------------------|---------------|--------------|---|----------------|-------------------|-------------------|---------------------|
|      |        |               |                                      |                                      | Run ID 1      |              |   |                |                   |                   |                     |
| 1    | 2      | 0x7e          | 1000000                              | 11000001                             | 10000000      | 11000001     | 0 | 1              | 0                 | 2                 | 2                   |
| 2    | 2      | 0xac          | 0 <mark>1</mark> 111111              | 0 <mark>0</mark> 111111              | 10000000      | 11000001     | 1 | 0              | 1                 | 0                 | 1                   |
| 3    | 1      | 0x4d          | <mark>0</mark> 110011 <mark>0</mark> | <mark>1</mark> 110011 <mark>1</mark> | 01100110      | 11000001     | 0 | 1              | 0                 | 2                 | 2                   |
| 4    | 2      | 0xfe          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 10000000      | 11000001     | 1 | 1              | 0                 | 1                 | 1                   |
| 5    | 1      | 0x3c          | <mark>1</mark> 1111111               | <mark>0</mark> 1111111               | 11111111      | 11000001     | 0 | 0              | 1                 | 0                 | 1                   |
| 6    | 2      | 0xdf          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 1000000       | 11000001     | 1 | 1              | 0                 | 1                 | 1                   |
|      |        |               |                                      |                                      | Run ID 2      |              |   |                |                   |                   |                     |
| 7    | 1      | 0x3d          | 11111111                             | 10111111                             | 11111111      | 11000001     | 0 | 0              | 1                 | 0                 | 1                   |
| 8    | 2      | 0x27          | 1000000                              | 11000001                             | 10000000      | 11000001     | 0 | 1              | 0                 | 2                 | 2                   |
| 9    | 1      | 0x1c          | 10000100                             | 10000101                             | 00000000      | 11000001     | 0 | 1              | Õ                 | 1                 | 1                   |
| 10   | 2      | 0xfb          | 01111111                             | 11111111                             | 10000000      | 11000001     | 1 | 1              | Õ                 | 1                 | 1                   |
| 11   | 2      | 0xa7          | 01111111                             | 11111111                             | 10000000      | 11000001     | 1 | 1              | Õ                 | 1                 | 1                   |
| 12   | 2      | 0x70          | 10000000                             | 11000001                             | 10000000      | 11000001     | 0 | 1              | Ő                 | 2                 | 2                   |
| 13   | 1      | 0x13          | 00000000                             | 11000001                             | 00000000      | 11000001     | Ő | $\overline{1}$ | Ő                 | 3                 | 3                   |
| 14   | 2      | 0x7b          | 10000000                             | 11000001                             | 10000000      | 11000001     | Ő | 1              | Ő                 | 2                 | 2                   |
| 15   | 1      | 0x41          | 10101010                             | 1101010                              | 10101010      | 11000001     | 0 | 1              | Ő                 | 1                 | 1                   |
| 16   | 2      | 0x5a          | 10000000                             | 11000001                             | 10000000      | 11000001     | 0 | 1              | 0                 | 2                 | 2                   |
|      |        |               |                                      |                                      | Run ID 3      |              | - | -              | -                 |                   |                     |
| 17   | 2      | 0v1d          | 1000000                              | 11010101                             | 1000000       | 01010101     | 0 | 1              | 0                 | 1                 |                     |
| 17   | 2      | 0x40<br>0x73  | 10000000                             | 11010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4                 | - <del>1</del><br>/ |
| 10   | 2      | 0x75          | 01111111                             | 011110101                            | 10000000      | 01010101     | 1 | 0              | 0                 | 4                 | 1<br>1              |
| 19   | 2      | 0x91          | 10000000                             | 11010101                             | 10000000      | 01010101     | 1 | 1              | 1<br>1            | 0                 | 1                   |
| 20   | ے<br>1 | 0x41          | 1000000                              | 01010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4                 | 4                   |
| 21   | 1      | 0x15          | 10000000                             | 01010100                             | 10000000      | 01010101     | 0 | 1              | 0                 | 3                 | 3                   |
| 22   | 2      | 0x57          | 1000000                              | 11010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4                 | 4                   |
| 23   | ے<br>1 | 0x25<br>0xE1  | 1000000                              | 01010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 3                 | 3                   |
| 24   | 1      | 0x51          | 10000000                             | 01010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4                 | 4                   |
| 25   | ے<br>1 | 0x06          | 01010000                             | 01010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4<br>2            | 4                   |
| 20   | 1      | 0x06          | 1000000                              | 11010101                             | 10000000      | 01010101     | 0 | 1              | 0                 | ے<br>۱            | ے<br>۲              |
| 2/   | 2      | 0x0C          | 00101101                             | 01111101                             | 10000000      | 01010101     | 0 | 1              | 0                 | 4                 | 4                   |
| 20   | 1      | 0x03          | 10000000                             | 01111101                             | 10000000      | 01010101     | 0 | 1              | 0                 | ے<br>۱            | 2<br>4              |
|      |        | 0x19          | 1000000                              | 11010101                             | 1000000       | 01010101     | 0 | 1              | 0                 | 4                 | 4                   |
|      |        | $\rightarrow$ |                                      |                                      | Run ID 4      |              |   |                |                   |                   |                     |
|      |        | $\rightarrow$ | /_/                                  | -                                    | none observed |              |   |                |                   |                   |                     |
|      |        |               |                                      |                                      | Run ID 5      |              |   |                |                   |                   |                     |
| 30   | 2      | 0x5a          | 10000000                             | 10111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 6                 | 6                   |
| 31   | 2      | 0x8c          | 011111111                            | 11111111                             | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 32   | 2      | 0xb1          | 01111111                             | 11111111                             | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 33   | 2      | 0x69          | 1000000                              | 11111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 34   | 2      | 0x0a          | 1000000                              | 11111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 35   | 2      | 0x92          | 011111111                            | 11111111                             | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
|      |        |               |                                      |                                      | Run ID 6      |              |   |                |                   |                   |                     |
| 36   | 2      | 0xfd          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 37   | 2      | 0x6d          | 10000000                             | 11111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 38   | 2      | 0x45          | 10000000                             | 11111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 39   | 2      | 0x94          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 40   | 2      | 0x4a          | 10000000                             | 11111111                             | 1000000       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 41   | 2      | 0x86          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 42   | 2      | 0xc5          | <mark>0</mark> 1111111               | <mark>1</mark> 1111111               | 1000000       | 11111111     | 1 | 1              | 0                 | 1                 | 1                   |
| 43   | 2      | 0xba          | 01111 <mark>1</mark> 11              | 01111 <mark>0</mark> 11              | 1000000       | 11111111     | 1 | 0              | 1                 | 0                 | 1                   |
| 44   | 1      | 0x50          | 0000001                              | 11111111                             | 0000010       | 11111111     | 0 | 1              | 0                 | 7                 | 7                   |
| 45   | 1      | 0x53          | 0000000                              | 11111100                             | 00000000      | 11111111     | 0 | 1              | 0                 | 6                 | 6                   |

Table 12: CBC3.1 bit-flips in I<sup>2</sup>C registers. Columns I and II show if the bit-flips are consistent with the default value or the last written value. 1 = consistent, 0 = inconsistent.

| Evt. | Page | Addr. | Written                 | Read                    | Default       | Last written | Ι | Π | $1 \rightarrow 0$ | 0→1 | #bfs |
|------|------|-------|-------------------------|-------------------------|---------------|--------------|---|---|-------------------|-----|------|
|      |      |       |                         |                         | Run ID 7      |              |   |   |                   |     |      |
| 46   | 2    | 0xb6  | <b>0</b> 1111111        | <b>1</b> 1111111        | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 47   | 2    | 0xe0  | 01 <mark>1</mark> 11111 | 01 <mark>0</mark> 11111 | 1000000       | 11111111     | 1 | 0 | 1                 | 0   | 1    |
| 48   | 2    | 0x0b  | 1000000                 | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
|      |      |       |                         |                         | Run ID 8      |              |   |   |                   |     |      |
| 49   | 2    | 0x30  | 1000000                 | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 50   | 2    | 0xf9  | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 51   | 1    | 0x0e  | 1111 <mark>00</mark> 11 | 1111 <mark>11</mark> 11 | 00000000      | 11111111     | 0 | 1 | 0                 | 2   | 2    |
| 52   | 2    | 0xfb  | 01111 <mark>1</mark> 11 | 01111 <mark>0</mark> 11 | 1000000       | 11111111     | 1 | 0 | 1                 | 0   | 1    |
| 53   | 1    | 0x04  | 01010000                | 11111111                | 00101110      | 11111111     | 0 | 1 | 0                 | 6   | 6    |
|      |      |       |                         |                         | Run ID 9      |              |   |   |                   |     |      |
| 54   | 2    | 0xa9  | 011 <mark>1</mark> 1111 | 011 <mark>0</mark> 1111 | 1000000       | 00000000     | 1 | 1 | 1                 | 0   | 1    |
| 55   | 2    | 0x15  | 1000000                 | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 56   | 2    | 0x01  | 10000000                | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 57   | 2    | 0x55  | 10000000                | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 58   | 1    | 0x0c  | 00010000                | 00000000                | 00010000      | 11111111     | 0 | 0 | 1                 | 0   | 1    |
|      |      |       |                         |                         | Run ID 10     |              |   |   |                   |     |      |
| 59   | 2    | 0xe0  | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000      | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 60   | 1    | 0x41  | 10101010                | 11111111                | 10101010      | 1111111      | 0 | 1 | 0                 | 4   | 4    |
|      |      |       |                         |                         | Run ID 11     |              |   |   |                   |     |      |
| 61   | 2    | 0x23  | 1000000                 | 10000001                | 1000000       | 01000001     | 0 | 1 | 0                 | 1   | 1    |
| 62   | 2    | 0x24  | 1 <mark>0</mark> 000000 | 11000001                | 10000000      | 01000001     | 0 | 1 | 0                 | 2   | 2    |
|      |      |       |                         | $\sim$                  | Run ID 12     |              |   |   |                   |     |      |
|      |      |       |                         |                         | none observed | d b          |   |   |                   |     |      |
|      |      |       |                         |                         | Run ID 13     | ÷            |   |   |                   |     |      |
| 63   | 2    | 0x80  | 01111111                | 11111111                | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 64   | 2    | 0x63  | 10000000                | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 65   | 1    | 0x04  | 01010000                | 11111111                | 00101110      | 11111111     | 0 | 1 | 0                 | 6   | 6    |
| 66   | 2    | 0x9c  | <mark>0</mark> 1111111  | <b>1</b> 1111111        | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 67   | 2    | 0x94  | <mark>0</mark> 1111111  | <b>1</b> 1111111        | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 68   | 2    | 0xd2  | <mark>0</mark> 1111111  | <b>1</b> 1111111        | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 69   | 2    | 0x50  | 10000000                | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 70   | 2    | 0x37  | 10000000                | 11111111                | 1000000       | 11111111     | 0 | 1 | 0                 | 7   | 7    |
| 71   | 1    | 0x0c  | 00000000                | 11111111                | 00010000      | 11111111     | 0 | 1 | 0                 | 8   | 8    |
| 72   | 1    | 0x0c  | 11111111                | 0000000                 | 00010000      | 00000000     | 0 | 1 | 8                 | 0   | 8    |
| 73   | 2    | 0xec  | 01111111                | 00111111                | 10000000      | 00000000     | 1 | 1 | 1                 | 0   | 1    |
| 74   | 2    | 0xed  | 011111111               | 11111111                | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 75   | 2    | 0xe7  | 01111111                | 11111111                | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 76   | 1    | 0x51  | 0000000                 | 11111111                | 00000000      | 11111111     | 0 | 1 | 0                 | 8   | 8    |
| 77   | 2    | 0xdd  | 011111111               | 11111111                | 10000000      | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 78   | 2    | 0xf0  | 011111111               | <b>1</b> 11111111       | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 79   | 1    | 0x46  | 111111111               | 111110111               | 11111111      | 11111111     | 0 | 0 | 1                 | 0   | 1    |
| 80   | 2    | 0xa2  | 011111111               | 111111111               | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |
| 81   | 2    | 0xe2  | 01111111                | 11111111                | 1000000       | 11111111     | 1 | 1 | 0                 | 1   | 1    |

Table 13: CBC3.1 bit-flips in I<sup>2</sup>C registers continued. Columns I and II show if the bit-flips are consistent with the default value or the last written value. 1 = consistent, 0 = inconsistent.

| Evt | Page | Addr | Written                 | Read                     | Default  | Last written | Ι | II | $1 \rightarrow 0$ | $0 \rightarrow 1$ | # bitflips |
|-----|------|------|-------------------------|--------------------------|----------|--------------|---|----|-------------------|-------------------|------------|
| 1   | 2    | 0x7e | 1000000                 | 11000001                 | 1000000  | 11000001     | 0 | 1  | 0                 | 2                 | 2          |
| 2   | 2    | 0xac | 0 <mark>1</mark> 111111 | 0 <mark>0</mark> 111111  | 10000000 | 11000001     | 1 | 0  | 1                 | 0                 | 1          |
| 6   | 2    | 0xdf | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 10000000 | 11000001     | 1 | 1  | 0                 | 1                 | 1          |
| 9   | 1    | 0x1c | 1000010 <mark>0</mark>  | 1000010 <mark>1</mark>   | 00000000 | 11000001     | 0 | 1  | 0                 | 1                 | 1          |
| 11  | 2    | 0xa7 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 10000000 | 11000001     | 1 | 1  | 0                 | 1                 | 1          |
| 13  | 1    | 0x13 | 00000000                | <b>11</b> 00000 <b>1</b> | 00000000 | 11000001     | 0 | 1  | 0                 | 3                 | 3          |
| 15  | 1    | 0x41 | 1 <mark>0</mark> 101010 | 1 <b>1</b> 101010        | 10101010 | 11000001     | 0 | 1  | 0                 | 1                 | 1          |
| 17  | 2    | 0x4d | 10000000                | 11010101                 | 10000000 | 01010101     | 0 | 1  | 0                 | 4                 | 4          |
| 20  | 2    | 0x4f | 10000000                | 11010101                 | 10000000 | 01010101     | 0 | 1  | 0                 | 4                 | 4          |
| 22  | 2    | 0x57 | 10000000                | 11010101                 | 10000000 | 01010101     | 0 | 1  | 0                 | 4                 | 4          |
| 23  | 2    | 0x25 | 10000000                | 11000101                 | 10000000 | 01010101     | 0 | 1  | 0                 | 3                 | 3          |
| 26  | 1    | 0x06 | 01010 <mark>000</mark>  | 01010 <mark>1</mark> 01  | 01101010 | 01010101     | 0 | 1  | 0                 | 2                 | 2          |
| 28  | 1    | 0x03 | 0 <mark>010</mark> 1101 | 0 <mark>1</mark> 111101  | 00001010 | 01010101     | 0 | 1  | 0                 | 2                 | 2          |
| 30  | 2    | 0x5a | 1000000                 | 10111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 6                 | 6          |
| 33  | 2    | 0x69 | 10000000                | 11111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 35  | 2    | 0x92 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 37  | 2    | 0x6d | 10000000                | 11111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 43  | 2    | 0xba | 01111 <mark>1</mark> 11 | 01111 <mark>0</mark> 11  | 10000000 | 11111111     | 1 | 0  | 1                 | 0                 | 1          |
| 48  | 2    | 0x0b | 10000000                | 11111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 51  | 1    | 0x0e | 1111 <mark>00</mark> 11 | 1111 <mark>11</mark> 11  | 00000000 | 11111111     | 0 | 1  | 0                 | 2                 | 2          |
| 52  | 2    | 0xfb | 01111 <mark>1</mark> 11 | 01111 <mark>0</mark> 11  | 10000000 | 11111111     | 1 | 0  | 1                 | 0                 | 1          |
| 56  | 2    | 0x01 | 10000000                | 11111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 58  | 1    | 0x0c | 00010000                | 00000000                 | 00010000 | 11111111     | 0 | 0  | 1                 | 0                 | 1          |
| 59  | 2    | 0xe0 | <mark>0</mark> 1111111  | <b>1</b> 1111111         | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 60  | 1    | 0x41 | 10101010                | 11111111                 | 10101010 | 11111111     | 0 | 1  | 0                 | 4                 | 4          |
| 65  | 1    | 0x04 | 01010000                | 111111111                | 00101110 | 11111111     | 0 | 1  | 0                 | 6                 | 6          |
| 66  | 2    | 0x9c | <mark>0</mark> 1111111  | <b>1</b> 1111111         | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 68  | 2    | 0xd2 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 69  | 2    | 0x50 | 10000000                | 11111111                 | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 71  | 1    | 0x0c | 00000000                | 11111111                 | 00010000 | 11111111     | 0 | 1  | 0                 | 8                 | 8          |
| 72  | 1    | 0x0c | 11111111                | 00000000                 | 00010000 | 00000000     | 0 | 1  | 8                 | 0                 | 8          |
| 75  | 2    | 0xe7 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 76  | 1    | 0x51 | 00000000                | 11111111                 | 00000000 | 11111111     | 0 | 1  | 0                 | 8                 | 8          |
| 80  | 2    | 0xa2 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111   | 1000000  | 11111111     | 1 | 1  | 0                 | 1                 | 1          |

Table 14: Summary of CBC3.1 bit-flips in I<sup>2</sup>C registers for chip 1.

Table 15: Summary of CBC3.1 bit-flips in  $I^2C$  registers for chip 2.

| Evt | Page | Addr | Written                 | Read                    | Default  | Last written | Ι | II | $1 \rightarrow 0$ | $0 \rightarrow 1$ | # bitflips |
|-----|------|------|-------------------------|-------------------------|----------|--------------|---|----|-------------------|-------------------|------------|
| 3   | 1    | 0x4d | <mark>0</mark> 1100110  | 11100111                | 01100110 | 11000001     | 0 | 1  | 0                 | 2                 | 2          |
| 5   | 1    | 0x3c | <mark>1</mark> 1111111  | <mark>0</mark> 1111111  | 11111111 | 11000001     | 0 | 0  | 1                 | 0                 | 1          |
| 8   | 2    | 0x27 | 1 <mark>0</mark> 000000 | 1 <mark>1</mark> 000001 | 10000000 | 11000001     | 0 | 1  | 0                 | 2                 | 2          |
| 16  | 2    | 0x5a | 1 <mark>0</mark> 000000 | 1 <mark>1</mark> 000001 | 10000000 | 11000001     | 0 | 1  | 0                 | 2                 | 2          |
| 19  | 2    | 0x9f | 01111 <mark>1</mark> 11 | 01111 <mark>0</mark> 11 | 10000000 | 01010101     | 1 | 0  | 1                 | 0                 | 1          |
| 29  | 2    | 0x19 | 1000000                 | 1 <mark>1010101</mark>  | 10000000 | 01010101     | 0 | 1  | 0                 | 4                 | 4          |
| 36  | 2    | 0xfd | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 38  | 2    | 0x45 | 10000000                | 11111111                | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 39  | 2    | 0x94 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 40  | 2    | 0x4a | 10000000                | 11111111                | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 41  | 2    | 0x86 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 46  | 2    | 0xb6 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 49  | 2    | 0x30 | 10000000                | 111111111               | 10000000 | > 11111111   | 0 | 1  | 0                 | 7                 | 7          |
| 54  | 2    | 0xa9 | 01111111                | 01101111                | 10000000 | 00000000     | 1 | 1  | 1                 | 0                 | 1          |
| 55  | 2    | 0x15 | 10000000                | 11111111                | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 61  | 2    | 0x23 | 10000000                | 10000001                | 10000000 | 01000001     | 0 | 1  | 0                 | 1                 | 1          |
| 62  | 2    | 0x24 | 1000000                 | 11000001                | 10000000 | 01000001     | 0 | 1  | 0                 | 2                 | 2          |
| 63  | 2    | 0x80 | 01111111                | <b>1</b> 1111111        | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 64  | 2 <  | 0x63 | 10000000                | 11111111                | 10000000 | 11111111     | 0 | 1  | 0                 | 7                 | 7          |
| 73  | 2    | 0xec | 0 <mark>1</mark> 111111 | 00111111                | 10000000 | 00000000     | 1 | 1  | 1                 | 0                 | 1          |
| 77  | 2    | 0xdd | <mark>0</mark> 1111111  | <b>1</b> 11111111       | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 78  | 2    | 0xf0 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
| 81  | 2    | 0xe2 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1 | 1  | 0                 | 1                 | 1          |
|     |      |      | //                      |                         |          |              |   |    |                   |                   |            |

Table 16: Summary of CBC3.1 bit-flips in I<sup>2</sup>C registers for chip 4.

| Evt | Page | Addr | Written                 | Read                    | Default  | Last written | Ι  | II | $1 \rightarrow 0$ | $0 \rightarrow 1$ | # bitflips |
|-----|------|------|-------------------------|-------------------------|----------|--------------|----|----|-------------------|-------------------|------------|
| 4   | 2    | 0xfe | 01111111                | <mark>1</mark> 1111111  | 1000000  | 11000001     | 1  | 1  | 0                 | 1                 | 1          |
| 7   | 1    | 0x3d | 1 <mark>1</mark> 111111 | 1 <mark>0</mark> 111111 | 11111111 | 11000001     | 0  | 0  | 1                 | 0                 | 1          |
| 10  | 2    | 0xfb | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 1000000  | 11000001     | 1  | 1  | 0                 | 1                 | 1          |
| 12  | 2    | 0x70 | 1 <mark>0</mark> 000000 | 1 <mark>1</mark> 000001 | 1000000  | 11000001     | 0  | 1  | 0                 | 2                 | 2          |
| 14  | 2    | 0x7b | 1 <mark>0</mark> 000000 | 1 <mark>1</mark> 000001 | 1000000  | 11000001     | 0  | 1  | 0                 | 2                 | 2          |
| 18  | 2    | 0x73 | 10000000                | 1 <mark>1010101</mark>  | 1000000  | 01010101     | 0  | 1  | 0                 | 4                 | 4          |
| 21  | 1    | 0x15 | 00000000                | 0 <mark>10101</mark> 00 | 00000000 | 01010101     | 0  | 1  | 0                 | 3                 | 3          |
| 24  | 1    | 0x51 | 0000000                 | 0 <mark>1010101</mark>  | 00000000 | 01010101     | 0  | 1  | 0                 | 4                 | 4          |
| 25  | 2    | 0x08 | 1000000                 | 1 <mark>1010101</mark>  | 1000000  | 01010101     | 0  | 1  | 0                 | 4                 | 4          |
| 27  | 2    | 0x0c | 1000000                 | 1 <mark>1010101</mark>  | 10000000 | 01010101     | 0  | 1  | 0                 | > 4               | 4          |
| 31  | 2    | 0x8c | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1  | 1  | 0                 | 1                 | 1          |
| 32  | 2    | 0xb1 | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 10000000 | 11111111     | 1  | 1  | 0                 | 1                 | 1          |
| 34  | 2    | 0x0a | 10000000                | 11111111                | 10000000 | 11111111     | 0  | 1  | 0                 | 7                 | 7          |
| 42  | 2    | 0xc5 | <b>0</b> 1111111        | <b>1</b> 1111111        | 10000000 | 11111111     | )1 | 1  | 0                 | 1                 | 1          |
| 44  | 1    | 0x50 | 00000001                | 11111111                | 00000010 | 11111111     | 0  | 1  | 0                 | 7                 | 7          |
| 45  | 1    | 0x53 | 0000000                 | 11111100                | 00000000 | 11111111     | 0  | 1  | 0                 | 6                 | 6          |
| 47  | 2    | 0xe0 | 01 <mark>1</mark> 11111 | 01011111                | 10000000 | 11111111     | 1  | 0  | 1                 | 0                 | 1          |
| 50  | 2    | 0xf9 | <b>0</b> 1111111        | <b>1</b> 1111111        | 1000000  | 11111111     | 1  | 1  | 0                 | 1                 | 1          |
| 53  | 1    | 0x04 | 01010000                | 11111111                | 00101110 | 11111111     | 0  | 1  | 0                 | 6                 | 6          |
| 57  | 2    | 0x55 | 10000000                | 11111111                | 1000000  | 11111111     | 0  | 1  | 0                 | 7                 | 7          |
| 67  | 2    | 0x94 | <mark>0</mark> 1111111  | <b>1</b> 11111111       | 1000000  | 11111111     | 1  | 1  | 0                 | 1                 | 1          |
| 70  | 2    | 0x37 | 10000000                | 11111111                | 10000000 | 11111111     | 0  | 1  | 0                 | 7                 | 7          |
| 74  | 2    | 0xed | <mark>0</mark> 1111111  | <mark>1</mark> 1111111  | 1000000  | 11111111     | 1  | 1  | 0                 | 1                 | 1          |
| 79  | 1    | 0x46 | 1111111111              | 1111 <mark>0</mark> 111 | 11111111 | 11111111     | 0  | 0  | 1                 | 0                 | 1          |