# Pietro Giuseppe Bressana

#### PERSONAL INFORMATION

DATE OF BIRTH: 18 October 1989

NATIONALITY: Italian

ADDRESS: Faculty of Informatics, Università della Svizzera italiana (USI),

Via Giuseppe Buffi 13, 6904 Lugano, Switzerland.

WEB: pietrobressana.github.io EMAIL: pietro.bressana@usi.ch

SKYPE: Pietro Bressana
GOOGLE SCHOLAR ID: Pietro Bressana

#### RESEARCH INTERESTS

Programmable data planes, Network debugging, FPGA-based hardware design.

#### **EDUCATION**

PhD Candidate in Computer Science SEPTEMBER 2016 Università della Svizzera Italiana (USI), Via Giuseppe Buffi 13, 6904 Lugano, Switzerland. **PRESENT** Advisor: Prof. Robert Soulé Master's degree, Computer Engineering FEBRUARY 2013 Politecnico di Milano, DECEMBER 2015 Piazza Leonardo da Vinci, 32, 20133 Milano, Italy. Thesis date: 18 DECEMBER 2015 OCTOBER 2008 Bachelor's degree, Electronic Engineering Politecnico di Milano, FEBRUARY 2013 Piazza Leonardo da Vinci, 32, 20133 Milano, Italy. Diploma, Scientific High School SEPTEMBER 2003 Liceo Scientifico Leonardo da Vinci, **JULY 2008** Via Stazione, 1, 26013 Crema, Italy.

### **HONORS & AWARDS**

NOVEMBER 2017 SNF Doc.Mobility Fellowship (26,400 CHF)

6-months research period at Cambridge University (UK).

#### **EMPLOYMENT HISTORY**

SEPTEMBER 2016

**Teaching Assistant** 

Present

Università della Svizzera Italiana (USI),

Via Giuseppe Buffi 13, 6904 Lugano, Switzerland.

-> Computer Architecture, Prof. Marc Langheinrich (2017/18)

AUGUST 2016 (one month)

Research Assistant

Università della Svizzera Italiana (USI),

Via Giuseppe Buffi 13, 6904 Lugano, Switzerland.

Main activity: Leading the efforts to implement and evaluate

consensus protocols in NetFPGA SUME boards and training a PhD student in programming NetFPGAs,

within NetPaxos research project.

Advisors: Prof. Robert Soulé and Prof. Rolf Krause

**JUNE 2016** 

Research Assistant

Università della Svizzera Italiana (USI),

**JULY 2016** 

Via Giuseppe Buffi 13, 6904 Lugano, Switzerland.

*Main activity*: Installation, setup and configuration of the new cluster that will be used by the Institute of Computational Science (ICS).

Advisor: Prof. Rolf Krause

FEBRUARY 2016

Research Assistant

MAY 2016

Università della Svizzera Italiana (USI),

Via Giuseppe Buffi 13, 6904 Lugano, Switzerland.

Main activity: Leading the efforts to implement and evaluate consensus protocols in NetFPGA SUME boards and

training a PhD student in programming NetFPGAs,

within NetPaxos research project.

Advisors: Prof. Robert Soulé and Prof. Fernando Pedone

#### ACADEMIC EXPERIENCE

FEBRUARY 2018 | Visiting PhD Student

The Computer Laboratory.

JULY 2018 University of Cambridge, United Kingdom.

Advisor: Dr. Noa Zilberman

Funded by SNF Doc.Mobility Fellowship

DECEMBER 2017 | Attending Barefoot Academy | BA 101

Barefoot Networks.

Santa Clara, CA, United States.

APRIL 2017 | Attending NetFPGA Developers Summit 2017

The Computer Laboratory.

University of Cambridge, United Kingdom.

MARCH 2017 | Leading a demo about Emu project at University Booth

Emu: Rapid FPGA Prototyping of Network Services in C#.

Salvator Galea, Nik Sultana, Pietro Bressana, David Greaves, Robert

Soulé, Andrew W. Moore, and Noa Zilberman. Design, Automation and Test in Europe (DATE17)

Lausanne, Switzerland.

DECEMBER 2016 | Visiting PhD Student

(two weeks) | The Computer Laboratory.

University of Cambridge, United Kingdom.

Advisor: Dr. Noa Zilberman

AUGUST 2016 | Sub-reviewer

The International Conference on Reconfigurable Computing and FPGAs

(ReConFig 2016). Cancun, Mexico.

Reviewer: Prof. Robert Soulé

JUNE 2015 | Visitor

Design Automation Conference 2015.

San Francisco, USA.

## P4Debug

SEPTEMBER 2017

**PRESENT** 

Despite the importance of computer networks and the abundance of network problems, engineers lack the tools and support necessary for debugging network hardware. This appears to be changing. A new breed of switches that can be programmed with high-level languages such as P4 match the speed of fixed function devices. This trend raises an important question: Can we leverage this new programmability for debugging network hardware? The goal of this project is to extend programmable network hardware with functionality to enable debugging. We propose a novel debugging framework, named P4Debug, that leverages recent advances in network programmability and hardware design, by providing unprecedented visibility into the internal state and operations of network devices. To evaluate P4Debug, we will develop a prototype that leverages several existing technologies, including the NetFPGA SUME framework and Xilinx SDNet P4-to-FPGA compiler.

#### Emu

January 2017

SEPTEMBER 2017

Emu is a framework for network functions on FPGAs, which builds upon Kiwi, a HLS compiler that allows computational scientists to program FPGAs with .NET code.

The goal of Emu is to make it easy for software developers with no expertise in hardware languages to quickly develop, test, and deploy network applications on an FPGA.

Moreover, using Emu, developers can run their network functions as normal processes, using virtual or real NICs, and using network simulators, simplifying debugging and testing.

Indeed, the current implementation of Emu supports CPUs, simulation environments, and FPGAs.

Further, Emu provides debugging and profiling tools that enable developers to inspect the behavior of the application at runtime.

#### **NetPaxos**

FEBRUARY 2016

AUGUST 2016

The goal of this project is to develop a new set of optimized consensus protocols that leverage recent advances in network programmability and hardware design.

These protocols will dramatically improve the performance of storage and replication systems that are the fundamental infrastructure for distributed and cloud computing services.

My main task as a research assistant was to implement Paxos consensus protocol inside NetFPGA SUME boards using Connectal Framework (Cornell University), NetFPGA SUME Framework (Cambridge University) and Xilinx SDNet.

Project website: www.inf.usi.ch/faculty/soule/netpaxos.html

#### exaFPGA

OCTOBER 2014

DECEMBER 2015

This project focuses on automatic hardware acceleration of C code with an explicit focus on power/performance metric, for the next generation of super-computing platforms, which is expected to deliver unprecedented performance for the benefit of all the scientific disciplines involving huge amount of computations.

As a master's student, I was in charge to design and to build the multi-FPGA architecture of the system.

Project website: exafpga.necst.it

Conference publications TITLE Emu: Rapid Prototyping of Networking Services. **AUTHORS** Nik Sultana, Salvator Galea, David Greaves, Marcin Wójcik, Jonny Shipton, Richard Clegg, Luo Mai, Pietro Bressana, Robert Soulé, Richard Mortier, Paolo Costa, Peter Pietzuch, Jon Crowcroft, Andrew W Moore, Noa Zilberman. SUBMITTED The 2017 USENIX Annual Technical Conference (USENIX ATC '17). https://atc17.usenix.hotcrp.com/paper/202?cap=0202a47MuHT4|7dc URL A Polyhedral Model-based Framework for Dataflow Implementation TITLE on FPGA devices of Iterative Stencil Loops. **AUTHORS** Giuseppe Natale, Giulio Stramondo, Pietro Bressana, Riccardo Cattaneo, Donatella Sciuto, Marco D. Santambrogio. **SUBMITTED** International Conference On Computer Aided Design (ICCAD) 2016. http://ieeexplore.ieee.org/document/7827654/ Url http://dl.acm.org/citation.cfm?id=2966995 URL Technical reports TITLE Network Hardware-Accelerated Consensus. Huynh Tu Dang, Pietro Bressana, Han Wang, Ki Suh Lee, Hakim Weath-**AUTHORS** erspoon, Marco Canini, Fernando Pedone, Robert Soulé. Arxiv - May 2016. SUBMITTED http://arxiv.org/abs/1605.05619 Url USI Technical Report Series in Informatics - March 2016. SUBMITTED Url http://www.inf.usi.ch/faculty/soule/usi-tr-2016-03.pdf

**FPGAs** 

LANGUAGES | Verilog, C, Bluespec BSV, VHDL, P4, PX.

Tools | Xilinx Vivado, VivadoHLS, SDK, Xilinx ISE, Xilinx SDNet,

Xilinx P4SDNet, NetFPGA SUME framework (Cambridge University),

Connectal framework (Cornell University), Bluespec,

FLEXid license management.

BOARDS NetFPGA SUME, VC707, VC709, ZC702, Avnet Spartan-6 LX9 MicroBoard.

DEVICES Virtex7, Zynq, Spartan6, Opsero FPGADrive FMC NVMe,

Cypress QDRII+ SRAM, Micron DDR3 SDRAM SODIMM,

uSD card (SD-mode and SPI-mode).

IPS PLDA QuickPCIe, Xilinx Aurora, Xilinx DCM and PLL, Xilinx MIG,

Xilinx PCIe, Xilinx Microblaze, Xilinx Partial Reconfiguration,

OpenCores SDSPI SD-card controller.

Data plane programming

LANGUAGES P4.

Tools | Barefoot Capilano SDE.

DEVICES | Barefoot Tofino.

 $\mu$ Cs

LANGUAGES C

Tools | Arduino IDE, Fritzing.

BOARDS | Arduino UNO, Arduino pro mini.

DEVICES ATmega328P, Wi-Fi (ESP8266), Bluetooth (BLE 4.0), GPS, GSM,

Accelerometer, Magnetometer, Gyro.

Other Skills

LANGUAGES C, Java, Python, MATLAB, SQL, LaTeX, Bash Scripting, HTML, P4.

Tools MATLAB, Eclipse, Eclipse JEE, MySQL, Python Kernprof, GitHub, Slurm,

XCat, Pacemaker, Corosync, Ganglia, Paraview, Intel DPDK, Callgrind,

Kcachegrind.

OPERATING | Linux (Ubuntu, CentOS), Microsoft Windows, Apple Mac OSX.

SYSTEMS

## LANGUAGES

| I       |                                   |
|---------|-----------------------------------|
| İTALIAN | Mother tongue.                    |
| English | Professional working proficiency. |
| French  | Basic knowledge.                  |

## Courses

First Certificate in English, Level B2.

Autocad basic course.

European computer driving licence (ECDL).

Basic course on safety, Politecnico di Milano.

Hazard analysis and critical control points (HACCP).

## DRIVING LICENSE

TYPE B (cars).

## **VOLUNTEER WORK**

| 2003 - 2017 | Volunteer, Catholic Agency for International Aid and Development,<br>Caritas Cremonese, Cremona (Italy). |
|-------------|----------------------------------------------------------------------------------------------------------|
| 2003 - 2017 | Volunteer and Team leader, Food gathering management, Fondazione Banco Alimentare Onlus, Milano (Italy). |
| 2005 - 2017 | IT Responsible, Parrocchia San Vittore Martire, Agnadello (Italy).                                       |
| 2005 - 2017 | Barista, Oratorio San Giovanni Bosco, Agnadello (Italy).                                                 |