

# NFV Use-case Enablement on DPDK and FD.IO

Cristian Dumitrescu, SW Architect, Intel Jasvinder Singh, SW Engineer, Intel

DPDK Summit Userspace - Dublin- 2016



# NFV Use-case Enablement on DPDK and FD.IO DPDK

- Edge Router Use-case Overview
- Implementation using DPDK
- Implementation using FD.IO VPP

### Edge Router Use-case Overview

# DPDK



### Implementation using DPDK (1)

# DPDK

Core 1 HT0

Routing

TX0

TX1



#File"<DPDK>/examples/ip\_pipeline/edge\_router\_downstream.cfg":

#### [PIPELINE1]

type = ROUTING core = 1 pktq\_in = RXQ0.0 RXQ1.0 pktq\_out = SWQ0 SWQ1 SINK0 encap = ethernet\_qinq ip\_hdr\_offset = 270

#### [PIPELINE2]

type = PASS-THROUGH core = 1h pktq\_in = SWQ0 SWQ1 TM0 TM1 pktq\_out = TM0 TM1 SWQ2 SWQ3

### [PIPELINE3]

type = PASS-THROUGH core = 1 pktq\_in = SWQ2 SWQ3 pktq\_out = TXQ0.0 TXQ1.0

### [MEMPOOL0]

pool\_size = 2M

# File "<DPDK>/examples/ip\_pipeline/edge\_router\_upstream.cfg":

Flow

Classification

Core 1 HT1

Edge Router (Upstream)

#### [PIPELINE1]

RX0

RX1

type = FIREWALL core = 1 pktq\_in = RXQ0.0 RXQ1.0 pktq\_out = SWQ0 SINK0 n\_rules = 4096 pkt\_type = qinq\_ipv4

Core 1 HT0

Firewall

#### [PIPELINE3]

type = FLOW\_CLASSIFICATION core = 1h pktq\_in = SWQ0 pktq\_out = SWQ1 SINK1 n\_flows = 65536 key\_size = 8 key\_offset = 268 hash\_offset = 128 Key mask = 00000FFF00000FFF

### [PIPELINE4]

Meter

type = FLOW\_ACTIONS core = 1h pktq\_in = SWQ1 pktq\_out = SWQ2 n\_flows = 65536 n\_meters\_per\_flow = 1 flow\_id\_offset = 132 ip\_hdr\_offset = 278 color\_offset = 136

#### [PIPELINE5]

type = ROUTING core = 1 pktq\_in = SWQ2 pktq\_out = TXQ0.0 TXQ1.0 SINK2 encap = ethernet\_mpls mpls\_color\_mark = yes ip\_hdr\_offset = 278 color\_offset = 136

### Implementation using DPDK (2)

# DPDK

### Step 1: Functional development

- Focus on functional correctness and block-level
   performance optimizations
- Each pipeline on separate CPU core

### Step 2: Optimal mapping to CPU cores

- Identify optimal mapping of pipelines to CPU cores for single app instance (golden mapping)
- Maximize performance per physical CPU core: max(P/N), where: P=app throughput, N=#physical CPU cores

### Step 3: Performance scale up

- Replicate the golden mapping several times
- Run multiple app instances on different CPU cores







### Implementation using FD.IO VPP (1)

# DPDK

- VPP Framework
  - Process a vector of packets (frame) using directed graph of nodes
  - Large library of network functions
- Egress Traffic Management in VPP
  - Leverage DPDK QoS library (librte\_sched)
  - 5-level hierarchical scheduler to make best use of available bandwidth



### Implementation using FD.IO VPP(2)

# DPDK

### #File ``/etc/vpp/startup.conf":

unix {
 interactive
 log /tmp/vpp.log
 cli-listen localhost:5002
 full-coredump
}

### dpdk {

socket-mem 16384,16384
dev 0000:02:00.0 {num-rx-queues 2 hqos}
dev 0000:04:00.0 {num-rx-queues 2 hqos}
num-mbufs 1000000

## cpu { main-core 0 corelist-workers 1,2,3,4

corelist-hqos-threads 5,6



# Questions?

Cristian Dumitrescu cristian.dumitrescu@intel.com

Jasvinder Singh jasvinder.singh@intel.com

### Legal Disclaimers



No license (express or implied, by estoppel or otherwise) to any intellectual property rights is granted by this document.

Intel disclaims all express and implied warranties, including without limitation, the implied warranties of merchantability, fitness for a particular purpose, and non-infringement, as well as any warranty arising from course of performance, course of dealing, or usage in trade.

This document contains information on products, services and/or processes in development. All information provided here is subject to change without notice. Contact your Intel representative to obtain the latest forecast, schedule, specifications and roadmaps.

Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. **No computer system can be absolutely secure**. Check with your system manufacturer or retailer or learn more at intel.com.

© 2016 Intel Corporation. Intel, the Intel logo, Intel. Experience What's Inside, and the Intel. Experience What's Inside logo are trademarks of Intel. Corporation in the U.S. and/or other countries.

\*Other names and brands may be claimed as the property of others.