# TCP/IP in hardware

- using SME

Mark Jan Jacobi & Jan Meznik

University of Copenhagen

May 23, 2019

## Background and Motivation

Dedicated hardware needs to transmit data in real time, but OS network stacks are usually not enough!

Dedicated Network cards are not perfect either:

#### Weaknesses of network cards

- Only basic programmability
- Incompatible APIs
- Licensed VHDL code blobs
- Seldom swap-able
- Price!



Figure: An Intel FPGA NIC

#### A performant, efficient, and flexible network stack in FPGA!

#### How? Using SME!

- Easy & intuitive hardware modelling
- Implicit clock
- Built-in simulation utilities
- VHDL code generation
- Verification by comparing VHDL signals with C# simulation

#### SME and FPGA

Skip this if SME has been covered



Application FTP, DHCP, SSH, etc.



Application FTP, DHCP, SSH, etc. Transport TCP, UDP, DCCP, etc.



Application FTP, DHCP, SSH, etc.
Transport TCP, UDP, DCCP, etc.
Internet IPv4, IPv6, ICMP, etc.



Application FTP, DHCP, SSH, etc.

Transport TCP, UDP, DCCP, etc.

Internet IPv4, IPv6, ICMP, etc.

Data Link ARP, MAC (Ethernet, Wi-Fi), etc.

#### Architecture



Clock-delays and congestion



- Clock-delays and congestion
- Limited subset of programming language utilities

```
// These are not allowed
O.M = new Func<int >(() =>
{ return 42; });

void Method(ref int x) {}
int* p1 = &x;
```

- Clock-delays and congestion
- Limited subset of programming language utilities
- Data de-multiplexing

- Clock-delays and congestion
- Limited subset of programming language utilities
- Data de-multiplexing
- Limited (fast) memory

- Clock-delays and congestion
- Limited subset of programming language utilities
- Data de-multiplexing
- Limited (fast) memory
- Information sharing is by design hard in SME

### Questions

?