## AMC40 Firmware Coordination

Guillaume Vouters, Cyril Drancourt, Stéphane T'Jampens

13 december 2012 LHCb upgrade Electronics meeting











- 1. Kick off meeting
- 2. Coordination
- 3. Methodology
- 4. Workshop





3.

5.

7.

## LHCb

#### TELL40 firmware kick-off

chaired by Ken Wyllie (CERN), Renaud Le Gac (Universite d'Aix - Marseille II (FR)) Thursday, March 1, 2012 from 14:00 to 18:00 (Europe/Zurich) at CERN ( 13-1-017 )

#### Thursday, March 1, 2012 14:00 - 14:10 Introduction 10' Speaker: Ken Wyllie (CERN) Material: Slides 🗐 📆 14:10 - 14:25 Toward a readout project 15' Speaker: Renaud Le Gac (Universite d'Aix - Marseille II (FR)) Material: Slides 14:25 - 14:45 Tools oriented toward a multi-user project 20' Speaker: John Evans (CERN) 14:45 - 15:05 FPGA Low Level Interface 20' Speaker: Jean-Pierre Cachemiche (Universite d'Aix - Marseille II (FR)) Material: Slides 15:05 - 15:25 First thought on the TELL40 FPGA architecture 20' Speaker: Cyril Drancourt (Annecy IN2P3 (FR)) Material: Transparents 🗐 15:25 - 15:45 Current view on the VELOPIX readout 20' Speakers: Chris Parkes (University of Manchester (GB)), Jan Buytaert Slides 🗐 📆 document 📆 15:45 - 16:05 Current view on the TFC & ECS FPGAs 20' Speaker: Federico Alessio (CERN) Current TFC Development Methodology as input 5' Speaker: Richard Jacobsson Material: Slides 🗐 🃆 Upgraded TFC Point of View 15' Speaker: Federico Aliessio Material: Slides 🗐 📆 16:05 - 16:25 Round table discussion around methodology and common tools 20' 16:25 - 16:35 Conclusions 10'



1. 2. 3.

> 4. 5.

6.7.

8.9.

#### Team

We are going to use a new generation of fpga.

Such a big FPGA requires to have multi developers for one firmware. The way to work on a FPGA is changing, we can't do it alone.

We need to work together.

From that comes the idea of a common firmware as much as possible, since we electronics engineers are lacking.

We need people to organize how and how much we can do a common firmware.

But we need to work as a Team





1. 2.

3.4.

6.

8.9.

## Firmwares development coordinators

LAPP accepted to play the role of coordinators

Laboratoire d'Annecy le Vieux de Physique des Particules

Coordinator of the firmwares development team :

- Guillaume Vouters (Electronic Coord.)
- Cyril Drancourt (Electronic Coord.)
- Stephane T'Jampens (Scientific Coord.)











1. 2. 3.

3. 4. 5. 6. 7.

8.

9.

## **Upgrade Electronic Setup**



## The current organization

| WP 1.2.2 | Firmware development                      | Participant(s)         | O(FTE) | Cost | Developpers                               |
|----------|-------------------------------------------|------------------------|--------|------|-------------------------------------------|
| 0        | Coordination                              | Annecy                 |        | _    | Stéphane T'Jampens + Cyril Drancourt      |
| 1        | Specifications, documentation and reviews | Annecy                 |        | -    | Stéphane T'Jampens + Cyril Drancourt      |
| 2        | Low Level Interface                       | Marseille              | 6      | -    | Jean-Pierre Cachemiche et al.             |
| 3        | Data Centre Bridging                      | CERN                   |        | _    | Rainer Schwemmen                          |
| 4        | TELL40 MEPs building                      | Annecy (tbc)           | 4      | _    | Cyril Drancourt et al.                    |
| 5        | TELL40 generic user                       | Annecy (tbc)           | 2      | _    | Cyril Drancourt et al.                    |
| 6        | ODIN40, TFC&ECS                           | CERN                   |        | _    | Federico Alessio + Richard Jacobsson      |
| 7        | VELO pixel                                | Manchester, AGH-Krakow |        | -    | Chris Park et al. + Tomasz Szumlak et al. |
| 8        | VELO strip                                | Manchester, AGH-Krakow |        | -    | Chris Park et al. + Tomasz Szumlak et al. |
| 9        | Central Fiber Tracker                     |                        |        | _    |                                           |
| 10       | Scilicon Strip Tracker                    |                        |        | _    |                                           |
| 11       | OT                                        | Dormunt                |        | -    | Stefan Swientek et al.                    |
| 12       | RICH                                      | Cambridge              |        | _    | Stephen Wotton                            |
| 13       | TORCH                                     |                        |        | -    |                                           |
| 14       | CALO                                      |                        |        | _    |                                           |
| 15       | MUON                                      | Cagliari, Frascati     |        | _    | Adriano Lai + Paolo Ciambrone et al       |
| 16       | LLT CALO                                  | Annecy                 | 2.5    | _    | Cyril Drancourt et al.                    |
| 17       | LLT MUON                                  | Marseille              | 2      |      | Jean-Pierre Cachemiche et al.             |
| 18       | LLT L0DU                                  | Clermont               |        | _    | Régis Lefèvre et al.                      |
| 19       | CCPC and test bench                       | Rio (CBPF)             |        |      | André Massaferri                          |

To be updated!!



## 2. Coordination

1.

2. 3.

4.

5.6.

7.8.

9.

## AMC40





1. 2. 3. 4. 5. 6. 7.

9.

## STRATIX V

|                           | Stratix V GX |     |    |    |    |    | Strati     | x V GT | Stratix V GS |    |    |    |            |    | Stratix V E |    |          |
|---------------------------|--------------|-----|----|----|----|----|------------|--------|--------------|----|----|----|------------|----|-------------|----|----------|
| Package                   | A3           | A4  | A5 | A7 | A9 | AB | <b>B</b> 5 | B6     | C5           | C7 | D3 | D4 | <b>D</b> 5 | D6 | D8          | E9 | EB       |
| EH29-H780                 | ~            |     |    |    |    |    |            |        |              |    | ~  | ~  |            |    |             |    |          |
| HF35-F1152 <sup>(2)</sup> | /            | /   | /  | ~  |    |    |            |        |              |    | /  | /  | /          |    |             |    |          |
| KF35-F1152                | 1            | /   | 1  | 1  |    |    |            |        |              |    |    |    |            |    | e .         |    |          |
| KF40-F1517 / KH40-H1517   | /            | /   | /  | /  | /  | /  |            |        |              |    |    | ~  | /          | 1  | /           |    |          |
| NF40 / KF40-F1517 (3)     |              |     | /  | /  |    |    |            |        | 1            | /  |    |    |            |    |             |    |          |
| RF40-F1517                |              |     |    |    |    |    | /          | /      |              |    |    |    |            |    |             |    |          |
| H40-H1517                 |              |     |    |    |    |    |            |        |              |    |    |    |            |    |             | 1  | 1        |
| RF43-F1760                |              |     |    |    |    |    | /          | /      | 5            |    |    |    |            |    |             |    |          |
| NF45-F1932                |              | e e | 1  | 1  | 1  | 1  |            | e e    |              |    |    |    |            | 1  | 1           |    |          |
| F45-F1932                 |              |     |    |    |    |    |            |        | 1            |    |    |    |            |    |             | /  | <b>V</b> |

The choice of the FPGA needs to be validated !!



## 2. Coordination

4.

6.

2.

5.

7.

9.

8.

Hight Level Processing

Low Level Interface

STRATIX V firmware

Common

Specific **Event** Processing

throttle PCI-express 10 GbE x-FPGA **DDR3** Tests GBT DCB (1)

AMC40 on TELL40

AMC40 on ODIN40 or SOL40 or TRIG40

Specific Ck + throttle PCI-express 10 GbE x-FPGA DDR3 Tests GBT **DCB** 

2.

3. 4.

5.

7.

8.9.

#### **Work Environment**

- Mailing Lists (We need your contacts)
- Versioning (SVN, git?)
- Twiki
- Bug tracking (To report the possible bugs)
  - → Forge Redmind
- Firmware development Tools

### Firmware development

#### **Needs**

- A simple and unique development tool
- Clear separation between common functions and specific code
- Hierarchical approach
- Quick design
- Test bench for every developed function and for the whole board

→ Quartus + QSYS

QSYS



Powerful system integration tool

Save time by avoiding writing HDL code for interconnection

#### Mainly two kinds of interface

Avalon Memory mapped interfaces:

Commands

Reading and writing of control registers

Memory control

Avalon **Streaming** interface:

Data flow

#### From To Farm Network Front End ATCA 40 **GBT** 10GbE **GBT FPGA** ECS gath 12 IN 12 INOUT 12 IN 10 GbE interface GBT Interface **GBT** Interface Low Level Interface x 12 Test OL Tx Test OL Rx Time Aligoment DAQ Aligament **BUFFER** Memory Memory TFC online DDR3 gath Core x 12 12 Memories 12 Memories 16 \* N bits 16 \* N bits X\_FPGA gath MEP x 12 x 12 building **Memory Controller Event Processing BUFFER Buffer Controller** Throttle OUT Low level Counters and Registers interface

Avalon Streaming

## 3. Methodology

Premilinary User Code architecture

To be discussed and improved with detector and DAQ requirements

## Specification

- Low level interface (Marseille)
- TELL40 algorithm (LAPP)
- Specific user data processing (Each Detector)

2.

3. 4. 5.

5.6.

7.

8.

9.

1. 2. 3.

5.6.7.8.9.

#### What we need to know

## Most important first :

Contact list

We need to know who to contact and meet to talk about the detector needs

Please send an email with a contact list to

→ guillaume.vouters@lapp.in2p3.fr

#### Then:

- Front End Header Structure
- Interfaces for the event processing bloc
- Data length max with NZS
- Etc ...

We will try to meet you between January and February to understand the detectors needs.



1.
3.
4.
6.
7.
8

https://e-groups.cern.ch/e-groups/Egroup.do?egroupName=lhcb-upgradeamc40-firmwares&tab=3

#### E-group: Ihcb-upgrade-amc40-firmwares (Static)



## AMC40 firmware development Workshop

#### Planned on mid March 2013 at CERN

The purpose is to gather firmware developers to discuss in particular about :

- Work environment
- Development tools
- Specifications
- QSYS Blocks
- Interfaces





Coordination is needed as we need to work together as a Team

That means we need to see each detector group and the DAQ online one to understand the needs and manage to do something compliant and convenient for everybody.

We need to use the same environment (SVN, Twiki, Bug tracking) and tools (Quartus and Qsys)

A Workshop will be organized on mid March 2013



# Thank you for your attention



## Backup Slides

1. 2. 3.

4.

5.6.

7.8.

9.

Beware!!

### **Compilation is tremendously long**

- → You need at least **20 Gb of RAM and 64 bits processor** 
  - → 32 bits does not compile!
    - → 4 cores or more strongly advised.

#### **Tools**

#### **Test benches**

- High level function calls through Bus Functional Modules (BFM)
- QSYS automatically generates a test bench



- Standard interfaces enable reuse of your testing environment
- Qsys provides a suite of verification IPs
- Qsys automatically generates a testbench





1.
2.
3.
4.
5.

5.6.7.8.

#### **AMC40 Architecture PCIe** interface QSYS memory mapped interfaces PLLs, Remote Command Status programming Registers registers Modes: Modes: FE sink mode, Emulated data ejection mode, Simulated data injection mode, Switch emulation, trafic shaping Event capture Injection Injection & monitoring & monitoring Path configuration: Path configuration: buffers buffers Internal or external loopback Internal or external loopback Channel masking, Channel masking, Channel resync Channel resync Monitoring: Monitoring: Bkplane in Bkplane out Syncronization status, Buffer size, OL in OL out Average rate, Average rate, User code Interfaces Interfaces Max delay between events from a same bunch GBT. GBT. QSYS 10 GbE 10 GbE Modes: Normal. QSYS streaming Autotest Path configuration: RAM Single, double buffering buffer Monitoring: Memory usage,