## Tileboard update

S. Kim<sup>1</sup>

<sup>1</sup>Department of Physics Florida State University

Tileboard update, 120420

## **Introduction and Summary**



- FSU HGCAL team testing candidates of different brands of cables for Tileboard (TB) and Wingboard (WB) connection
- Experimental Setup
  - UMinn TB emulator
  - FSU self-designed adaptor boards
  - Cable brand: 3M SL8801/12-10DA5-00
  - WBs substituted with SAMTEC Twinax QSH Loopback RevB v1 for simple data transmission testing

### Pictures of the MB





**FPGA** 

Suho, Kim LPCbb

# Pictures of the adaptor boards







# Pictures of the complete setup





# Adaptor-Cable-Adaptor Connection



- Adaptor-Cable-Adaptor-Loopback connection tested with FPGA bitstream to check its data transmission performance
- Adaptor-Cable-Adaptor soldered and created by the FSU HGCAL team
- Adaptor (AB) -Cable-Adaptor connection made for 3 different sets of length (369,655,1013 mm)
- Machine from FSU machine shop for precise strip off of the cable

### AB-Cable-AB connections





# FSU Machine for Cable stripping





#### Bitstream of cabletester



- Xilinx UltraScale+ FPGA (xzcu2cg-sfvc784) on TB
- LoopbackFirmware bitstream
  - Test error rate by sending data on OBUFDS and measuring received data IBUFDS
  - Our loopback is twinax QSH\_v1 Rev.B
  - Its I/O ports connection in next slide
  - Error rate printout on the PC terminal

## QSH loopback





## QSH loopback result



- 1 4 out of 9 I/O loopback connections function properly
- 2 3 out of 9 I/O loopback connections fail due to our adaptor board design
- 3 2 out of 9 I/O loopback connections fail due to absence of signal from the GBTSCA
- 4 In summary, all I/O loopback connections function as expected

# QSH loopback table result



- 1 First Column means one of 9 I/O connections within the QSH loopback connection.
- 2 Second Column means percentage of data (POS DIFF) sent out on OBUFDS
- 3 Third Column means (POS DIFF) error rate received on IBUFDS

## QSH loopback table result



 All HGCROC1 and ELINK-FAST connections are tested to have 0 error rate.

| Loopback | Data | Error    |
|----------|------|----------|
| number   | Out  | rate     |
| 0        | 1    | 0.00000  |
| 1        | 1    | 0.09660  |
| 2        | 1    | 1.52438  |
| 3        | 1    | 0.00000  |
| 4        | 1    | 0.76844  |
| 5        | 1    | 0.00000  |
| 6        | 1    | -0.00000 |
| 7        | 1    | 0.38116  |
| 8        | 1    | 0.77371  |

|       | SCA_CIK_P  | 42       | 3 | 41 FAST_CLK_P | 1 |        |
|-------|------------|----------|---|---------------|---|--------|
|       | SCA CLK N  | 44       | ı | 43 FAST_CIK_N |   | Number |
|       | SCA_IN_P   | 46       | İ | 45 FAST_CMD_P | - | 3      |
|       | SCA_IN_N   | 48       |   | 47 FAST_CMD_N | J |        |
|       | SCA_OUT_P  | 50       |   | 49 TRIG1_P    |   | Number |
|       | SCA_OUT_N  | 52       |   | 51 TRIG1_N    |   |        |
|       | DAQ1_P     | 54<br>56 |   | 53 TRIG2_P    | _ | 6      |
| - 1   | DAQ1_N     | 56       |   | 55 TRIG2_N    |   |        |
|       | DAQ2_P     | 58       |   | 57 TRIG3_P    |   |        |
| - 1   | DAQ2_N     | 60       |   | 59 TRIG3_N    |   |        |
|       |            | 62       |   | 61 TRIG4_P    | - | Number |
|       |            | 64       |   | 63 TRIG4_N    |   | 0      |
| 1     | ·          | 66       |   | 65            | • |        |
| Numbe |            | 68       |   | 67            |   |        |
|       |            | 70       |   | 69            |   |        |
| 5     |            | 70<br>72 |   | 71            |   |        |
|       |            |          |   | 73            |   |        |
|       |            | 74<br>76 |   | 75            |   |        |
|       | HGCROC_SDA | 78       |   | 77            |   |        |
|       | HGCROC_SCL | 80       |   | 79            |   |        |
|       |            |          |   |               |   |        |

Table: Loopback Summary

## Not working connections - Socket grounding



- Following loopback connections are NOT getting 0 error rate
- It's turns out to be a problem of the circuit design, not a problem with bitstream or cables.
- Currently designed FSU sockets grounds all HGCROC2 DAQ,TRIG signals



## QSH loopback table result



 All HGCROC2 signals from OBUFDS are grounded in adaptor boards. Thus, signals don't loop-back and have non-zero error rate.

| Loopback | Data | Error    |
|----------|------|----------|
| number   | Out  | rate     |
| 0        | 1    | 0.00000  |
| 1        | 1    | 0.09660  |
| 2        | 1    | 1.52438  |
| 3        | 1    | 0.00000  |
| 4        | 1    | 0.76844  |
| 5        | 1    | 0.00000  |
| 6        | 1    | -0.00000 |
| 7        | 1    | 0.38116  |
| 8        | 1    | 0.77371  |

SCA CIK P FAST CLK P 44 46 48 FAST\_CMD\_P FAST\_CMD\_N SCA IN N SCA\_OUT\_N TRIG1\_N DAQ1\_P DAQ2 P TRIG3 P 60 TRIG3 N 62 64 TRIG4\_P TRIG4\_N 63 66 68 67 Number 69 71 Number 70 72 74 76 73 75 Number 77 79 HGCROC SDA

Table: Loopback Summary

#### Not working connections - GBTSCA



Second, Our TB emulator has no GBTSCA as its component.
 Any I/O, which receives signal from GBTSCA, will show error rate



## QSH loopback table result



No signal is detected in IBUFDS due to absence of GBTSCA.
 Thus, we get non-zero error rate.

| Loopback | Data | Error    |
|----------|------|----------|
| number   | Out  | rate     |
| 0        | 1    | 0.00000  |
| 1        | 1    | 0.09660  |
| 2        | 1    | 1.52438  |
| 3        | 1    | 0.00000  |
| 4        | 1    | 0.76844  |
| 5        | 1    | 0.00000  |
| 6        | 1    | -0.00000 |
| 7        | 1    | 0.38116  |
| 8        | 1    | 0.77371  |

|     |       | SCA | A CIK P  | 42       | 18 | 41 | FAST_CLK_P |
|-----|-------|-----|----------|----------|----|----|------------|
|     |       |     | A_CIK_N  | 44       |    | 43 | FAST_CLK_N |
|     |       | SC  | A IN P   | 46       |    | 45 | FAST CMD P |
|     |       | SC  | A/IN_N   | 48       |    | 47 | FAST_CMD_N |
|     |       | SCA | _OUT_P   | 50       |    | 49 | TRIG1_P    |
|     |       | SQ  | A_OUT_N  | 52       |    | 51 | TRIG1_N    |
|     |       | DA  | Q1 P     | 54       |    | 53 | TRIG2_P    |
|     |       | /ĎΑ | Q1_N     | 56       |    | 55 | TRIG2_N    |
|     | /     | DA  | Q2_P     | 58       |    | 57 | TRIG3_P    |
|     | 1     | DA  | .Q2_N    | 60       |    | 59 | TRIG3_N    |
| Nim | mber  | /   |          | 62       |    | 61 | TRIG4_P    |
| 7   | IIDCI |     |          | 64       |    | 63 | TRIG4_N    |
| 1   | _/    |     |          | 66       |    | 65 |            |
|     | /     |     |          | 68       |    | 67 |            |
|     | /     |     |          | 70<br>72 |    | 69 |            |
|     | ¥     |     |          | 72       |    | 71 |            |
| N I | mber  |     |          | 74       |    | 73 |            |
|     | nber  |     |          | 76       |    | 75 |            |
| 8   |       |     | CROC_SDA | 78       |    | 77 |            |
|     |       | HG  | CROC_SCL | 80       |    | 79 |            |
|     |       |     |          |          |    |    |            |

Table: Loopback Summary

### Result and interpretation



- FSU's Adaptor-Cable-Adaptor-loopback connection
  - FPGA bitstream editable to adapt to loopback other than twinax\_QSH\_RevB\_v1
  - Adaptor-cable-Adaptor connection was all properly soldered with no short-circuit
  - FSU machine shop's cable stripper also has decent performance.
  - Based on absence of GBTSCA and design of the socket board,
     All I/O loopback connections function as expected
- Cable 3M SL8801/12-10DA5-00's performance tested to be compatible for TB-WB connection

#### **Future**



- Presence of GBTSCA and change in the adaptor board design can lead to test of all I/O ports connections.
- Cable brands other than 3M SL8801/12-10DA5-00 can be tested as well.

# Back-Up



Back-Up



- Now, we can start creating QSH's XDC file.
- Before that, I tried various experiment in QTH, to better understand the terminal output info
  - 1 QTHInverted
  - 2 QTHhalfInverted
  - 3 QTHwrongAssign
- Each of items above taught me some useful information.
- Place of inversion discovered in Link: loopback-top.v at L76



 After discovery of place of inversion, inverting differential signals in All bytegenerators tried

|     | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
|-----|---|---|---|---|---|---|---|---|---|
| Inv | Υ | Υ | Υ | Υ | Υ | Υ | Υ | Υ | Υ |

Table: Inversion table

```
9.3,245237888
9.3,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,245237888
9.1,24523788
9.1,24523788
9.1,24523788
9.1,24523788
9.1,24523788
9.1,24523788
9.1,24523788
9.1,24523788
9.1,2452378
11.6,24522277
11.6,24522277
11.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,24522277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,2452277
12.6,245227
12.6,245227
12.6,24522
```

 When signals are inverted, the terminal reads the error rate received (0) in the second column and the data went out (2E10) in the third column



Inverting only odd number bytegenerators tried.

|     | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
|-----|---|---|---|---|---|---|---|---|---|
| Inv | N | Υ | N | Υ | N | Υ | N | Υ | N |

Table: Inversion table



- Each row in time slot means each bytegenerator
- Used to think each row in time slot meant error rate for sub-time interval.



Assigning pins to pins that are not connected via loopback

|      | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
|------|---|---|---|---|---|---|---|---|---|
| Loop | N | N | N | N | N | N | N | N | N |

Table: Inversion table

```
### CLIMPAT MOTHER - INCOMPRISED - NO MECAL - MORPHIZE - LINE | MO
```

Not getting "0" value for either column



- Although looking trivial, it gave principles that
  - 1 When signal is inverted, second and third columns are inverted
  - 2 Each row means bytegenerator number
  - 3 When no loop formed, both columns read non-zero value



 To write down QSH XDC file, start with the easiest bytegenerator

| QTH/QSH Out-                            | QTH Input     | QSH Input     |
|-----------------------------------------|---------------|---------------|
| put                                     |               |               |
| HGCROC1-TRIG-                           | HGCROC1-TRIG- | HGCROC1-TRIG- |
| IN-P(N)2 [F2,E2]                        | OUT-P(N)3     | OUT-N(P)3     |
| ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | [A9,A8]       | [A8,A9]       |

- PACKAGE\_PIN [get\_ports A9 HGCROC1\_TRIG\_OUT\_P3]
- PACKAGE\_PIN [get\_ports A8 HGCROC1\_TRIG\_OUT\_N3]
- Inversion from A8,A9 design, Inverting those legs No Inversion





bytegenerator1

| QTH/QSH Out-     | QTH Input     | QSH Input        |  |
|------------------|---------------|------------------|--|
| put              |               |                  |  |
| HGCROC1-TRIG-    | HGCROC2-TRIG- | HGCROC1-TRIG-    |  |
| IN-P(N)1 [G6,F6] | OUT-P(N)0     | in-N(P)0 [E8,F8] |  |
|                  | [A7,A6]       |                  |  |

- PACKAGE\_PIN [get\_ports F8 HGCROC2\_TRIG\_OUT\_P0]
- PACKAGE\_PIN [get\_ports E8 HGCROC2\_TRIG\_OUT\_N0]
- Inversion from E8,F8 design, Inverting those legs No Inversion





bytegenerator2

| QSH Output    | QTH Output    | QTH/QSH Input     |
|---------------|---------------|-------------------|
| HGCROC2-TRIG- | HGCROC1-TRIG- | HGCROC2-TRIG-     |
| OUT-N(P)0     | OUT-P(N)0     | out-P(N)1 [B4,A4] |
| [A6,A7]       | [F8,E8]       | , , -             |

- PACKAGE\_PIN [get\_ports A7 HGCROC1\_TRIG\_OUT\_P0]
- PACKAGE\_PIN [get\_ports A6 HGCROC1\_TRIG\_OUT\_N0]
- Inverting Output legs Inversion



bytegenerator3

| QTH/QSH Out-   | QTH Input     | QSH Input      |
|----------------|---------------|----------------|
| put            |               |                |
| fc-sig-in-p(n) | HGCROC2-TRIG- | fc-clk-in-n(p) |
| [C9,B9]        | OUT-P(N)2     | [D6,D7]        |
|                | [E1,D1]       |                |

- PACKAGE\_PIN [get\_ports D7 HGCROC2\_TRIG\_OUT\_P2]
- PACKAGE\_PIN [get\_ports D6 HGCROC2\_TRIG\_OUT\_N2]
- Inversion from D7,D6 design, Inverting those legs No Inversion



bytegenerator4

| QSH Output    | QTH Output     | QTH/QSH Input     |
|---------------|----------------|-------------------|
| HGCROC2-TRIG- | fc-clk-in-p(n) | HGCROC2-TRIG-     |
| OUT-N(P)2     | [D7,D6]        | out-P(N)3 [E5,D5] |
| [D1,E1]       |                | _                 |

Table: bytegenerator4

- PACKAGE\_PIN [get\_ports E1 fc-clk-in-p]
- PACKAGE\_PIN [get\_ports D1 fc-clk-in-n]
- Inverting Output legs, Inversion from D1,E1 design, Inversion from E5,D5 design - Inversion

**LPCbb** 



bytegenerator5

| QTH/QSH Out-     | QTH Input    | QSH Input    |
|------------------|--------------|--------------|
| put              |              |              |
| HGCROC1-DAQ-     | HGCROC1-DAQ- | HGCROC1-DAQ- |
| IN-P(N)0 [E9,D9] | OUT-P(N)1    | OUT-N(P)1    |
| . ,              | [G8,F7]      | [F7,G8]      |

- PACKAGE\_PIN [get\_ports G8 HGCROC1\_DAQ\_OUT\_P1]
- PACKAGE\_PIN [get\_ports F7 HGCROC1\_DA1\_OUT\_N1]
- Inverting G8,F7 legs Inversion



bytegenerator6

| QSH Ou  | tput    | QTH Output    | QTH/QSH Input |
|---------|---------|---------------|---------------|
| HGCRO   | C2-DAQ- | SCA-MISO-p(n) | HGCROC2-DAQ-  |
| OUT-N(  | P)1     | [AE9,AE8]     | OUT-P(N)0     |
| [B1,C1] | ,       |               | [E4,E3]       |

- PACKAGE\_PIN [get\_ports C1 SCA-MISO-p]
- PACKAGE\_PIN [get\_ports B1 SCA-MISO-n]
- Inversion from B1,C1 design, Inverting those legs No Inversion



#### bytegenerator7

| QSH Out-  | QTH Out-  | QTH Input | QSH Input |
|-----------|-----------|-----------|-----------|
| put       | put       |           |           |
| SCA-MOSI- | SCA-      | HGCROC2-  | SCA-MOSI- |
| p,SCA-    | MOSI-p(n) | DAQ-OUT-  | n,SCA-    |
| MISO-n    | [AC9,AD9] | P(N)1     | MISO-p    |
| [AC9,AE8] |           | [C1,B1]   | [AD9,AE9] |

- PACKAGE\_PIN [get\_ports AE8 SCA-MOSI-n]
- PACKAGE\_PIN [get\_ports AE9 HGCROC2\_DAQ\_OUT\_P1]
- PACKAGE\_PIN [get\_ports AD9 HGCROC2\_DAQ\_OUT\_N1]



bytegenerator8

| QSH Out-   | QTH Out-  | QTH Input | QSH Input  |
|------------|-----------|-----------|------------|
| put        | put       |           |            |
| SCA-CLK-   | SCA-      | CK-40M-   | SCA-CLK-   |
| p,CK-40M-n | CLK-p(n)  | p(n)      | n,CK-40M-p |
| [AF7,C4]   | [AF7,AF6] | [D4,C4]   | [AF6,D4]   |

- PACKAGE\_PIN [get\_ports C4 SCA-CLK-n]
- PACKAGE\_PIN [get\_ports AF6 CK-40M-p]
- PACKAGE\_PIN [get\_ports D4 SCA-CLK-n]

## QSH loopback printout



```
[HGCAL dev@localhost ~1$ python ber scan.py
0,2618980864,0
0,2388256709,230724155
0.1024982908.1593997956
0,2618980864,0
0,1481080272,1137900592
0.2618980864.0
0,3,2618980861
0.2076700364.542280500
0,1476282404,1142698460
10,2564436736,0
10.1856745667.707691069
10,950492067,1613944669
10,2564436736,0
10,1318877668,1245559068
10,2564436736,0
10,0,2564436736
10,2041804883,522631853
10,1502149069,1062287667
20,2563008512,0
20,1417696411,1145312101
20,919710335,1643298177
20,2563008512.0
20,1186319309,1376689203
20,2563008512,0
20.0.2563008512
```