samplevnf¶
1. samplevnf Release Notes¶
1.1. Introduction¶
This project provides a placeholder for various sample VNF (Virtual Network Function) development which includes example reference architecture and optimization methods related to VNF/Network service for high performance VNFs.
The sample VNFs are Open Source approximations* of Telco grade VNF’s using optimized VNF + NFVi Infrastructure libraries, with Performance Characterization of Sample† Traffic Flows.
* Not a commercial product. Encourage the community to contribute and close the feature gaps.
† No Vendor/Proprietary Workloads
1.2. VNF supported¶
- Carrier Grade Network Address Translation (CG-NAT) VNF
- Firewall (vFW) VNF
- Access Control List (vACL) VNF
Please refer docs folder for individual VNF release notes.
2. samplevf Installation Guide¶
2.1. Introduction¶
This project provides a placeholder for various sample VNF (Virtual Network Function) development which includes example reference architecture and optimization methods related to VNF/Network service for high performance VNF
The sample VNFs are Open Source approximations* of Telco grade VNF’s using optimized VNF + NFVi Infrastructure libraries, with Performance Characterization of Sample† Traffic Flows.
* Not a commercial product. Encourage the community to contribute and close the feature gaps.
† No Vendor/Proprietary Workloads
2.2. VNF supported¶
- Carrier Grade Network Address Translation (CG-NAT) VNF
- Firewall (vFW) VNF
- Access Control List (vACL) VNF
Please refer docs folder for individual VNF Installation guide.
Note:- Each VNF should include a installation document explain the process to install and run VNF.
3. vCGNAPT samplevnf¶
3.1. vCGNAPT - Release Notes¶
3.1.1. Introduction¶
This is the beta release for vCGNAPT VNF. vCGNAPT application can be run independently (refer INSTALL.rst).
3.1.2. User Guide¶
Refer to README.rst for further details on vCGNAPT, HLD, features supported, test plan. For build configurations and execution requisites please refer to INSTALL.rst.
3.1.3. Feature for this release¶
This release supports following features as part of vCGNAPT
- vCGNAPT can run as a standalone application on bare-metal linux server or on a virtual machine using SRIOV and OVS dpdk.
- Static NAT
- Dynamic NAT
- Static NAPT
- Dynamic NAPT
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
- UDP, TCP and ICMP protocol passthrough
- Multithread support
- Multiple physical port support
- Limiting max ports per client
- Limiting max clients per public IP address
- Live Session tracking to NAT flow
- PCP support
- NAT64
- ALG SIP
- ALG FTP
3.1.4. System requirements - OS and kernel version¶
This is supported on Ubuntu 14.04 and 16.04 and kernel version less than 4.5
- VNFs on BareMetal support:
- OS: Ubuntu 14.04 or 16.04 LTS kernel: < 4.5 http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- VNFs on Standalone Hypervisor
HOST OS: Ubuntu 14.04 or 16.04 LTS http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- OVS (DPDK) - 2.5
- kernel: < 4.5
- Hypervisor - KVM
- VM OS - Ubuntu 16.04/Ubuntu 14.04
3.1.5. Known Bugs and limitations¶
- Hadware Load Balancer feature is supported on fortville nic FW version 4.53 and below.
- L4 UDP Replay is used to capture throughput for dynamic cgnapt
- Hardware Checksum offload is not supported for IPv6 traffic.
- CGNAPT on sriov is tested till 4 threads
3.1.6. Future Work¶
- SCTP passthrough support
- Multi-homing support
- Performance optimization on different platforms
3.1.7. References¶
- Following links provides additional information for differenet version of DPDKs
3.2. vCGNAPT - Readme¶
3.2.1. Introduction¶
This application implements vCGNAPT. The idea of vCGNAPT is to extend the life of the service providers IPv4 network infrastructure and mitigate IPv4 address exhaustion by using address and port translation in large scale. It processes the traffic in both the directions.
It also supports the connectivity between the IPv6 access network to IPv4 data network using the IPv6 to IPv4 address translation and vice versa.
3.2.1.1. About DPDK¶
The DPDK IP Pipeline Framework provides set of libraries to build a pipeline application. In this document, CG-NAT application will be explained with its own building blocks.
This document assumes the reader possess the knowledge of DPDK concepts and IP Pipeline Framework. For more details, read DPDK Getting Started Guide, DPDK Programmers Guide, DPDK Sample Applications Guide.
3.2.2. Scope¶
This application provides a standalone DPDK based high performance vCGNAPT Virtual Network Function implementation.
3.2.3. Features¶
- The vCGNAPT VNF currently supports the following functionality:
- Static NAT
- Dynamic NAT
- Static NAPT
- Dynamic NAPT
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
- UDP, TCP and ICMP protocol passthrough
- Multithread support
- Multiple physical port support
- Limiting max ports per client
- Limiting max clients per public IP address
- Live Session tracking to NAT flow
- NAT64
- PCP Support
- ALG SIP
- ALG FTP
 
3.2.4. High Level Design¶
The Upstream path defines the traffic from Private to Public and the downstream path defines the traffic from Public to Private. The vCGNAPT has same set of components to process Upstream and Downstream traffic.
In vCGNAPT application, each component is constructed as IP Pipeline framework. It includes Master pipeline component, load balancer pipeline component and vCGNAPT pipeline component.
A Pipeline framework is collection of input ports, table(s), output ports and actions (functions). In vCGNAPT pipeline, main sub components are the Inport function handler, Table and Table function handler. vCGNAPT rules will be configured in the table which translates egress and ingress traffic according to physical port information from which side packet is arrived. The actions can be forwarding to the output port (either egress or ingress) or to drop the packet.
3.2.5. vCGNAPT Graphical Overview¶
The idea of vCGNAPT is to extend the life of the service providers IPv4 network infrastructure and mitigate IPv4 address exhaustion by using address and port translation in large scale. It processes the traffic in both the directions.
+------------------+
|                 +-----+
| Private consumer | CPE  |---------------+
|   IPv4 traffic  +-----+                 |
+------------------+                      |
               +------------------+       v        +----------------+
               |                  | +------------+ |                |
               |   Private IPv4   | |  vCGNAPT   | |    Public      |
               |  access network  | |   NAT44    | |  IPv4 traffic  |
               |                  | +------------+ |                |
               +------------------+       |        +----------------+
+------------------+                      |
|                 +-----+                 |
| Private consumer| CPE |-----------------+
|  IPv4 traffic   +-----+
+------------------+
    Figure 1: vCGNAPT deployment in Service provider network
3.2.6. Components of vCGNAPT¶
In vCGNAPT, each component is constructed as a packet framework. It includes Master pipeline component, driver, load balancer pipeline component and vCGNAPT worker pipeline component. A pipeline framework is a collection of input ports, table(s), output ports and actions (functions).
3.2.6.1. Receive and transmit driver¶
Packets will be received in bulk and provided to load balancer thread. The transmit takes packets from worker thread in a dedicated ring and sent to the hardware queue.
3.2.6.2. ARPICMP pipeline¶
ARPICMP pipeline is responsible for handling all l2l3 arp related packets.
This component does not process any packets and should configure with Core 0, to save cores for other components which processes traffic. The component is responsible for: 1. Initializing each component of the Pipeline application in different threads 2. Providing CLI shell for the user 3. Propagating the commands from user to the corresponding components. 4. ARP and ICMP are handled here.
3.2.6.3. Load Balancer pipeline¶
Load balancer is part of the Multi-Threaded CGMAPT release which distributes the flows to Multiple ACL worker threads.
Distributes traffic based on the 2 or 5 tuple (source address, source port, destination address, destination port and protocol) applying an XOR logic distributing the load to active worker threads, thereby maintaining an affinity of flows to worker threads.
Tuple can be modified/configured using configuration file
3.2.7. vCGNAPT - Static¶
The vCGNAPT component performs translation of private IP & port to public IP & port at egress side and public IP & port to private IP & port at Ingress side based on the NAT rules added to the pipeline Hash table. The NAT rules are added to the Hash table via user commands. The packets that have a matching egress key or ingress key in the NAT table will be processed to change IP & port and will be forwarded to the output port. The packets that do not have a match will be taken a default action. The default action may result in drop of the packets.
3.2.8. vCGNAPT - Dynamic¶
The vCGNAPT component performs translation of private IP & port to public IP & port at egress side and public IP & port to private IP & port at Ingress side based on the NAT rules added to the pipeline Hash table. Dynamic nature of vCGNAPT refers to the addition of NAT entries in the Hash table dynamically when new packet arrives. The NAT rules will be added to the Hash table automatically when there is no matching entry in the table and the packet is circulated through software queue. The packets that have a matching egress key or ingress key in the NAT table will be processed to change IP & port and will be forwarded to the output port defined in the entry.
Dynamic vCGNAPT acts as static one too, we can do NAT entries statically. Static NAT entries port range must not conflict to dynamic NAT port range.
3.2.8.1. vCGNAPT Static Topology¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 1) IXIA
operation:
Egress --> The packets sent out from ixia(port 0) will be CGNAPTed to ixia(port 1).
Igress --> The packets sent out from ixia(port 1) will be CGNAPTed to ixia(port 0).
3.2.8.2. vCGNAPT Dynamic Topology (L4REPLAY)¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 0)L4REPLAY
operation:
Egress --> The packets sent out from ixia will be CGNAPTed to L3FWD/L4REPLAY.
Ingress --> The L4REPLAY upon reception of packets (Private to Public Network),
will immediately replay back the traffic to IXIA interface. (Pub -->Priv).
3.2.8.3. How to run L4Replay¶
After the installation of samplevnf:
go to <samplevnf/VNFs/L4Replay>
./buid/L4replay -c  core_mask -n no_of_channels(let it be as 2) -- -p PORT_MASK --config="(port,queue,lcore)"
    eg: ./L4replay -c 0xf -n 4 -- -p 0x3 --config="(0,0,1)"
3.2.9. Installation, Compile and Execution¶
Plase refer to <samplevnf>/docs/vCGNAPT/INSTALL.rst for installation, configuration, compilation and execution.
3.3. vCGNAPT - Installation Guide¶
3.3.1. vCGNAPT Compilation¶
After downloading (or doing a git clone) in a directory (samplevnf)
3.3.1.1. Dependencies¶
- DPDK supported versions ($DPDK_RTE_VER = 16.04, 16.11, 17.02 or 17.05) Downloaded and installed via vnf_build.sh or manually from [here] (http://fast.dpdk.org/rel/)
- libpcap-dev
- libzmq
- libcurl
3.3.1.2. Environment variables¶
Apply all the additional patches in ‘patches/dpdk_custom_patch/’ and build dpdk required only for DPDK version 16.04.
export RTE_SDK=<dpdk directory>
export RTE_TARGET=x86_64-native-linuxapp-gcc
This is done by vnf_build.sh script.
3.3.2. Auto Build:¶
$ ./tools/vnf_build.sh in samplevnf root folder
Follow the steps in the screen from option [1] –> [9] and select option [8] to build the vnfs. It will automatically download selected DPDK version and any required patches and will setup everything and build vCGNAPT VNFs.
Following are the options for setup:
----------------------------------------------------------
 Step 1: Environment setup.
----------------------------------------------------------
[1] Check OS and network connection
[2] Select DPDK RTE version
----------------------------------------------------------
 Step 2: Download and Install
----------------------------------------------------------
[3] Agree to download
[4] Download packages
[5] Download DPDK zip
[6] Build and Install DPDK
[7] Setup hugepages
----------------------------------------------------------
 Step 3: Build VNFs
----------------------------------------------------------
[8] Build all VNFs (vACL, vCGNAPT, vFW, UDP_Replay)
[9] Exit Script
An vCGNAPT executable will be created at the following location samplevnf/VNFs/vCGNAPT/build/vCGNAPT
3.3.3. Manual Build:¶
- Download DPDK supported version from dpdk.org 
- unzip dpdk-$DPDK_RTE_VER.zip and apply dpdk patches only in case of 16.04 (Not required for other DPDK versions) - cd dpdk - patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-management.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-Rx-hang-when-disable-LLDP.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-status-change-interrupt.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-VF-bonded-device-link-down.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/disable-acl-debug-logs.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/set-log-level-to-info.patch
 
- build dpdk - make config T=x86_64-native-linuxapp-gcc O=x86_64-native-linuxapp-gcc
- cd x86_64-native-linuxapp-gcc
- make
 
- Setup huge pages - For 1G/2M hugepage sizes, for example 1G pages, the size must be specified explicitly and can also be optionally set as the default hugepage size for the system. For example, to reserve 8G of hugepage memory in the form of eight 1G pages, the following options should be passed to the kernel: * default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048
- Add this to Go to /etc/default/grub configuration file.
- Append “default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048”
- to the GRUB_CMDLINE_LINUX entry.
 
 
 
- Setup Environment Variable - export RTE_SDK=<samplevnf>/dpdk
- export RTE_TARGET=x86_64-native-linuxapp-gcc
- export VNF_CORE=<samplevnf> or using ./tools/setenv.sh
 
- Build vCGNAPT VNFs - cd <samplevnf>/VNFs/vCGNAPT
- make clean
- make
 
- An vCGNAPT executable will be created at the following location - <samplevnf>/VNFs/vCGNAPT/build/vCGNAPT
 
3.3.4. Run¶
3.3.4.1. Setup Port to run VNF¶
For DPDK versions 16.04
1. cd <samplevnf>/dpdk
2. ./tools/dpdk_nic_bind.py --status <--- List the network device
3. ./tools/dpdk_nic_bind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-16.04/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 16.11
1. cd <samplevnf>/dpdk
2. ./tools/dpdk-devbind.py --status <--- List the network device
3. ./tools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-16.11/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 17.xx
1. cd <samplevnf>/dpdk
2. ./usertools/dpdk-devbind.py --status <--- List the network device
3. ./usertools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-17.05/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
Make the necessary changes to the config files to run the vCGNAPT VNF
eg: ports_mac_list = 00:00:00:30:21:F0 00:00:00:30:21:F1
3.3.4.2. Dynamic CGNAPT¶
Update the configuration according to system configuration.
./vCGNAPT -p <port mask> -f <config> -s <script> - SW_LoadB
./vCGNAPT -p <port mask> -f <config> -s <script> -hwlb <num_WT> - HW_LoadB
3.3.4.3. Static CGNAPT¶
Update the script file and add Static NAT Entry
e.g,
;p <pipeline id> entry addm <prv_ipv4/6> prvport> <pub_ip> <pub_port> <phy_port> <ttl> <no_of_entries> <end_prv_port> <end_pub_port>
;p 3 entry addm 152.16.100.20 1234 152.16.40.10 1 0 500 65535 1234 65535
3.3.4.4. Run IPv4¶
Software LoadB:
cd <samplevnf>/VNFs/vCGNAPT/build
./vCGNAPT -p 0x3 -f ./config/arp_txrx-2P-1T.cfg  -s ./config/arp_txrx_ScriptFile_2P.cfg
Hardware LoadB:
cd <samplevnf>/VNFs/vCGNAPT/build
./vCGNAPT -p 0x3 -f ./config/arp_hwlb-2P-1T.cfg  -s ./config/arp_hwlb_scriptfile_2P.cfg --hwlb 1
3.3.4.5. Run IPv6¶
Software LoadB:
cd <samplevnf>/VNFs/vCGNAPT/build
./vCGNAPT -p 0x3 -f ./config/arp_txrx-2P-1T-ipv6.cfg  -s ./config/arp_txrx_ScriptFile_2P.cfg
Hardware LoadB:
cd <samplevnf>/VNFs/vCGNAPT/build
./vCGNAPT -p 0x3 -f ./config/arp_hwlb-2P-1T-ipv6.cfg  -s ./config/arp_hwlb_scriptfile_2P.cfg --hwlb 1
3.3.4.6. vCGNAPT execution on BM & SRIOV¶
To run the VNF, execute the following:
samplevnf/VNFs/vCGNAPT# ./build/vCGNAPT -p 0x3 -f ./config/arp_txrx-2P-1T.cfg -s ./config/arp_txrx_ScriptFile_2P.cfg
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vCGNAPT configuration file
-s SCRIPT FILE: vCGNAPT script file
3.3.4.7. vCGNAPT execution on OVS¶
To run the VNF, execute the following:
samplevnf/VNFs/vCGNAPT# ./build/vCGNAPT -p 0x3 ./config/arp_txrx-2P-1T.cfg -s ./config/arp_txrx_ScriptFile_2P.cfg --disable-hw-csum
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vCGNAPT configuration file
-s SCRIPT FILE: vCGNAPT script file
--disable-hw-csum :Disable TCP/UDP hw checksum
4. vFW samplevnf¶
4.1. vFW - Release Notes¶
4.1.1. Introduction¶
This is a beta release for Sample Virtual Firewall VNF. This vFW can application can be run independently (refer INSTALL.rst).
4.1.2. User Guide¶
Refer to README.rst for further details on vFW, HLD, features supported, test plan. For build configurations and execution requisites please refer to INSTALL.rst.
4.1.3. Feature for this release¶
This release supports following features as part of vFW
- Basic packet filtering (malformed packets, IP fragments)
- Connection tracking for TCP and UDP
- Access Control List for rule based policy enforcement
- SYN-flood protection via Synproxy* for TCP
- UDP, TCP and ICMP protocol pass-through
- CLI based enable/disable connection tracking, synproxy, basic packet filtering
- L2L3 stack support for ARP/ICMP handling
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
- Hardware and Software Load Balancing
- Multithread support
- Multiple physical port support
4.1.4. System requirements - OS and kernel version¶
This is supported on Ubuntu 14.04 and Ubuntu 16.04 and kernel version less than 4.5
- VNFs on BareMetal support:
- OS: Ubuntu 14.04 or 16.04 LTS kernel: < 4.5 http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- VNFs on Standalone Hypervisor:
HOST OS: Ubuntu 14.04 or 16.04 LTS http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- OVS (DPDK) - 2.5
- kernel: < 4.5
- Hypervisor - KVM
- VM OS - Ubuntu 16.04/Ubuntu 14.04
4.1.5. Known Bugs and limitations¶
- Hadware Load Balancer feature is supported on fortville nic FW version 4.53 and below.
- Hardware Checksum offload is not supported for IPv6 traffic.
- vFW on sriov is tested upto 4 threads
- Http Multiple clients/server with HWLB is not working
4.1.6. Future Work¶
Following would be possible enhancement functionalities
- Automatic enable/disable of synproxy
- Support TCP timestamps with synproxy
- FTP ALG integration
- Performance optimization on different platforms
4.1.7. References¶
Following links provides additional information for differenet version of DPDKs
4.2. vFW - Readme¶
4.2.1. Introduction¶
The virtual firewall (vFW) is an application implements Firewall. vFW is used as a barrier between secure internal and an un-secure external network. The firewall performs Dynamic Packet Filtering. This involves keeping track of the state of Layer 4 (Transport)traffic,by examining both incoming and outgoing packets over time. Packets which don’t fall within expected parameters given the state of the connection are discarded. The Dynamic Packet Filtering will be performed by Connection Tracking component, similar to that supported in linux. The firewall also supports Access Controlled List(ACL) for rule based policy enforcement. Firewall is built on top of DPDK and uses the packet library.
4.2.1.1. About DPDK¶
The DPDK IP Pipeline Framework provides a set of libraries to build a pipeline application. In this document, vFW will be explained in detail with its own building blocks.
This document assumes the reader possesses the knowledge of DPDK concepts and packet framework. For more details, read DPDK Getting Started Guide, DPDK Programmers Guide, DPDK Sample Applications Guide.
4.2.2. Scope¶
This application provides a standalone DPDK based high performance vFW Virtual Network Function implementation.
4.2.3. Features¶
- The vFW VNF currently supports the following functionality:
- Basic packet filtering (malformed packets, IP fragments)
- Connection tracking for TCP and UDP
- Access Control List for rule based policy enforcement
- SYN-flood protection via Synproxy* for TCP
- UDP, TCP and ICMP protocol pass-through
- CLI based enable/disable connection tracking, synproxy, basic packet filtering
- Multithread support
- Multiple physical port support
- Hardware and Software Load Balancing
- L2L3 stack support for ARP/ICMP handling
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
 
4.2.4. High Level Design¶
The Firewall performs basic filtering for malformed packets and dynamic packet filtering incoming packets using the connection tracker library. The connection data will be stored using a DPDK hash table. There will be one entry in the hash table for each connection. The hash key will be based on source address/port,destination address/port, and protocol of a packet. The hash key will be processed to allow a single entry to be used, regardless of which direction the packet is flowing (thus changing the source and destination). The ACL is implemented as libray stattically linked to vFW, which is used for used for rule based packet filtering.
TCP connections and UDP pseudo connections will be tracked separately even if theaddresses and ports are identical. Including the protocol in the hash key will ensure this.
The Input FIFO contains all the incoming packets for vFW filtering. The vFW Filter has no dependency on which component has written to the Input FIFO. Packets will be dequeued from the FIFO in bulk for processing by the vFW. Packets will be enqueued to the output FIFO. The software or hardware loadbalancing can be used for traffic distribution across multiple worker threads. The hardware loadbalancing require ethernet flow director support from hardware (eg. Fortville x710 NIC card). The Input and Output FIFOs will be implemented using DPDK Ring Buffers.
4.2.5. Components of vFW¶
In vFW, each component is constructed using packet framework pipelines. It includes Rx and Tx Driver, Master pipeline, load balancer pipeline and vfw worker pipeline components. A Pipeline framework is a collection of input ports, table(s),output ports and actions (functions).
4.2.5.1. Receive and Transmit Driver¶
Packets will be received in bulk and provided to LoadBalancer(LB) thread. Transimit takes packets from worker threads in a dedicated ring and sent to hardware queue.
4.2.5.2. Master Pipeline¶
The Master component is part of all the IP Pipeline applications. This component does not process any packets and should configure with Core 0, to allow other cores for processing of the traffic. This component is responsible for 1. Initializing each component of the Pipeline application in different threads 2. Providing CLI shell for the user control/debug 3. Propagating the commands from user to the corresponding components
4.2.5.3. ARPICMP Pipeline¶
This pipeline processes the APRICMP packets.
4.2.5.4. TXRX Pipelines¶
The TXTX and RXRX pipelines are pass through pipelines to forward both ingress and egress traffic to Loadbalancer. This is required when the Software Loadbalancer is used.
4.2.5.5. Load Balancer Pipeline¶
The vFW support both hardware and software balancing for load balancing of traffic across multiple VNF threads. The Hardware load balancing require support from hardware like Flow Director for steering of packets to application through hardware queues.
The Software Load balancer is also supported if hardware load balancing can’t be used for any reason. The TXRX along with LOADB pipeline provides support for software load balancing by distributing the flows to Multiple vFW worker threads. Loadbalancer (HW or SW) distributes traffic based on the 5 tuple (src addr, src port, dest addr, dest port and protocol) applying an XOR logic distributing to active worker threads, thereby maintaining an affinity of flows to worker threads.
4.2.5.6. vFW Pipeline¶
The vFW performs the basic packet filtering and will drop the invalid and malformed packets.The Dynamic packet filtering done using the connection tracker library. The packets are processed in bulk and Hash table is used to maintain the connection details. Every TCP/UDP packets are passed through connection tracker library for valid connection. The ACL library integrated to firewall provide rule based filtering.
4.2.5.7. vFW Topology¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 1) IXIA
operation:
Egress --> The packets sent out from ixia(port 0) will be Firewalled to ixia(port 1).
Igress --> The packets sent out from ixia(port 1) will be Firewalled to ixia(port 0).
4.2.5.8. vFW Topology (L4REPLAY)¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 0)L4REPLAY
operation:
Egress --> The packets sent out from ixia will pass through vFW to L3FWD/L4REPLAY.
Ingress --> The L4REPLAY upon reception of packets (Private to Public Network),
will immediately replay back the traffic to IXIA interface. (Pub -->Priv).
4.2.5.9. How to run L4Replay¶
After the installation of samplevnf
go to <samplevnf/VNFs/L4Replay>
./buid/L4replay -c  core_mask -n no_of_channels(let it be as 2) -- -p PORT_MASK --config="(port,queue,lcore)"
    eg: ./L4replay -c 0xf -n 4 -- -p 0x3 --config="(0,0,1)"
4.2.6. Installation, Compile and Execution¶
Plase refer to <samplevnf>/docs/vFW/INSTALL.rst for installation, configuration, compilation and execution.
4.3. vFW - Installation Guide¶
4.3.1. vFW Compilation¶
After downloading (or doing a git clone) in a directory (samplevnf)
4.3.1.1. Dependencies¶
- DPDK supported versions ($DPDK_RTE_VER = 16.04, 16.11, 17.02 or 17.05). Downloaded and installed via vnf_build.sh or manually from [here] (http://fast.dpdk.org/rel/dpdk-$DPDK_RTE_VER.zip). Both the options are available as part of vnf_build.sh below.
- libpcap-dev
- libzmq
- libcurl
4.3.1.2. Environment variables¶
Apply all the additional patches in ‘patches/dpdk_custom_patch/’ and build dpdk (NOTE: required only for DPDK version 16.04).
export RTE_SDK=<dpdk directory>
export RTE_TARGET=x86_64-native-linuxapp-gcc
This is done by vnf_build.sh script.
4.3.2. Auto Build¶
$ ./tools/vnf_build.sh in samplevnf root folder
Follow the steps in the screen from option [1] –> [9] and select option [8] to build the vnfs. It will automatically download selected DPDK version and any required patches and will setup everything and build vFW VNFs.
Following are the options for setup:
----------------------------------------------------------
 Step 1: Environment setup.
----------------------------------------------------------
[1] Check OS and network connection
[2] Select DPDK RTE version
----------------------------------------------------------
 Step 2: Download and Install
----------------------------------------------------------
[3] Agree to download
[4] Download packages
[5] Download DPDK zip
[6] Build and Install DPDK
[7] Setup hugepages
----------------------------------------------------------
 Step 3: Build VNFs
----------------------------------------------------------
[8] Build all VNFs (vACL, vCGNAPT, vFW, UDP_Replay)
[9] Exit Script
An vFW executable will be created at the following location samplevnf/VNFs/vFW/build/vFW
4.3.3. Manual Build¶
- Download DPDK supported version from dpdk.org 
- unzip dpdk-$DPDK_RTE_VER.zip and apply dpdk patches only in case of 16.04 (Not required for other DPDK versions) - cd dpdk - patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-management.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-Rx-hang-when-disable-LLDP.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-status-change-interrupt.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-VF-bonded-device-link-down.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/disable-acl-debug-logs.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/set-log-level-to-info.patch
 
- build dpdk
- make config T=x86_64-native-linuxapp-gcc O=x86_64-native-linuxapp-gcc
- cd x86_64-native-linuxapp-gcc
- make
 
 
- Setup huge pages
- For 1G/2M hugepage sizes, for example 1G pages, the size must be specified explicitly and can also be optionally set as the default hugepage size for the system. For example, to reserve 8G of hugepage memory in the form of eight 1G pages, the following options should be passed to the kernel: * default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048
- Add this to Go to /etc/default/grub configuration file.
- Append “default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048”
- to the GRUB_CMDLINE_LINUX entry.
 
 
 
 
- Setup Environment Variable - export RTE_SDK=<samplevnf>/dpdk
- export RTE_TARGET=x86_64-native-linuxapp-gcc
- export VNF_CORE=<samplevnf>
 - or using ./tools/setenv.sh 
- Build vFW VNFs - cd <samplevnf>/VNFs/vFW
- make clean
- make
 
- The vFW executable will be created at the following location - <samplevnf>/VNFs/vFW/build/vFW
 
4.3.4. Run¶
4.3.4.1. Setup Port to run VNF¶
The tools folder and utilities names are different across DPDK versions.
For DPDK versions 16.04
1. cd <samplevnf>/dpdk
2. ./tools/dpdk_nic_bind.py --status <--- List the network device
3. ./tools/dpdk_nic_bind.py -b igb_uio <PCI Port 0> <PCI Port 1>
 .. _More details: http://dpdk.org/doc/guides-16.04/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 16.11
1. cd <samplevnf>/dpdk
2. ./tools/dpdk-devbind.py --status <--- List the network device
3. ./tools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
 .. _More details: http://dpdk.org/doc/guides-16.11/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 17.xx
1. cd <samplevnf>/dpdk
2. ./usertools/dpdk-devbind.py --status <--- List the network device
3. ./usertools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
 .. _More details: http://dpdk.org/doc/guides-17.05/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
Make the necessary changes to the config files to run the vFW VNF
eg: ports_mac_list = 00:00:00:30:21:01 00:00:00:30:21:00
4.3.4.2. Firewall Run commands¶
Update the configuration according to system configuration.
./vFW -p <port mask> -f <config> -s <script> - SW_LoadB
./vFW -p <port mask> -f <config> -s <script> -hwlb <num_WT> - HW_LoadB
4.3.4.2.1. Run IPv4¶
To run the vFW in Software LB or Hardware LB with IPv4 traffic
Software LoadB:
cd <samplevnf>/VNFs/vFW/
./build/vFW -p 0x3 -f ./config/VFW_SWLB_IPV4_SinglePortPair_4Thread.cfg  -s ./config/VFW_SWLB_IPV4_SinglePortPair_script.tc
Hardware LoadB:
cd <samplevnf>/VNFs/vFW/
./build/vFW -p 0x3 -f ./config/VFW_HWLB_IPV4_SinglePortPair_4Thread.cfg  -s ./config/VFW_HWLB_IPV4_SinglePortPair_script.cfg --hwlb 4
4.3.4.2.2. Run IPv6¶
To run the vFW in Software LB or Hardware LB with IPvr64 traffic
Software LoadB:
cd <samplevnf>/VNFs/vFW
./build/vFW -p 0x3 -f ./config/VFW_SWLB_IPV6_SinglePortPair_4Thread.cfg  -s ./config/VFW_SWLB_IPV6_SinglePortPair_script.tc
Hardware LoadB:
cd <samplevnf>/VNFs/vFW/
./build/vFW -p 0x3 -f ./config/VFW_HWLB_IPV6_SinglePortPair_4Thread.cfg  -s ./config/VFW_HWLB_IPV6_SinglePortPair_script.tc --hwlb 4
4.3.4.2.3. vFW execution on BM & SRIOV¶
To run the VNF, execute the following
samplevnf/VNFs/vFW# ./build/vFW -p 0x3 -f ./config/VFW_SWLB_IPV4_SinglePortPair_4Thread.cfg  -s ./config/VFW_SWLB_IPV4_SinglePortPair_script.tc
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vFW configuration file
-s SCRIPT FILE: vFW script file
4.3.4.2.4. vFW execution on OVS¶
To run the VNF, execute the following:
samplevnf/VNFs/vFW# ./build/vFW -p 0x3 -f ./config/VFW_SWLB_IPV4_SinglePortPair_4Thread.cfg  -s ./config/VFW_SWLB_IPV4_SinglePortPair_script.tc --disable-hw-csum
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vFW configuration file
-s SCRIPT FILE: vFW script file
--disable-hw-csum :Disable TCP/UDP hw checksum
5. vACL samplevnf¶
5.1. vACL - Release Notes¶
5.1.1. Introduction¶
This is a beta release for Sample Virtual ACL VNF. This vACL can application can be run independently (refer INSTALL.rst).
5.1.2. User Guide¶
Refer to README.rst for further details on vACL, HLD, features supported, test plan. For build configurations and execution requisites please refer to INSTALL.rst.
5.1.3. Feature for this release¶
- The vACL VNF currently supports the following functionality:
- CLI based Run-time rule configuration.(Add,Delete,List,Display,Clear,Modify)
- Ipv4 and ipv6 standard 5 tuple packet Selector support.
- Multithread support
- Multiple physical port support
- Hardware and Software Load Balancing
- L2L3 stack support for ARP/ICMP handling
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
 
5.1.4. System requirements - OS and kernel version¶
This is supported on Ubuntu 14.04 and 16.04 and kernel version less than 4.5
- VNFs on BareMetal support:
- OS: Ubuntu 14.04 or 16.04 LTS kernel: < 4.5 http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- VNFs on Standalone Hypervisor
HOST OS: Ubuntu 14.04 or 16.04 LTS http://releases.ubuntu.com/16.04/ Download/Install the image: ubuntu-16.04.1-server-amd64.iso
- OVS (DPDK) - 2.5
- kernel: < 4.5
- Hypervisor - KVM
- VM OS - Ubuntu 16.04/Ubuntu 14.04
5.1.5. Known Bugs and limitations¶
- Hardware Load Balancer feature is supported on Fortville nic ACL version 4.53 and below.
- Hardware Checksum offload is not supported for IPv6 traffic.
- vACL on sriov is tested upto 4 threads
5.1.6. Future Work¶
- Following would be possible enhancements
- Performance optimization on different platforms
 
5.1.7. References¶
Following links provides additional information for differenet version of DPDKs
5.2. vACL - Readme¶
5.2.1. Introduction¶
This application implements Access Control List (ACL). ACL is typically used for rule based policy enforcement. It restricts access to a destination IP address/port based on various header fields, such as source IP address/port, destination IP address/port and protocol. It is built on top of DPDK and uses the packet framework infrastructure.
5.2.1.1. About DPDK¶
The DPDK IP Pipeline Framework provides a set of libraries to build a pipeline application. In this document, vACL will be explained in detail with its own building blocks.
This document assumes the reader possesses the knowledge of DPDK concepts and packet framework. For more details, read DPDK Getting Started Guide, DPDK Programmers Guide, DPDK Sample Applications Guide.
5.2.2. Scope¶
This application provides a standalone DPDK based high performance vACL Virtual Network Function implementation.
5.2.3. Features¶
- The vACL VNF currently supports the following functionality
- CLI based Run-time rule configuration.(Add, Delete, List, Display, Clear, Modify)
- Ipv4 and ipv6 standard 5 tuple packet Selector support.
- Multithread support
- Multiple physical port support
- Hardware and Software Load Balancing
- L2L3 stack support for ARP/ICMP handling
- ARP (request, response, gratuitous)
- ICMP (terminal echo, echo response, passthrough)
- ICMPv6 and ND (Neighbor Discovery)
 
5.2.4. High Level Design¶
The ACL Filter performs bulk filtering of incoming packets based on rules in current ruleset, discarding any packets not permitted by the rules. The mechanisms needed for building the rule database and performing lookups are provided by the DPDK API. http://dpdk.org/doc/api/rte__acl_8h.html
The Input FIFO contains all the incoming packets for ACL filtering. Packets will be dequeued from the FIFO in bulk for processing by the ACL. Packets will be enqueued to the output FIFO. The Input and Output FIFOs will be implemented using DPDK Ring Buffers.
The DPDK ACL example: http://dpdk.org/doc/guides/sample_app_ug/l3_forward_access_ctrl.html #figure-ipv4-acl-rule contains a suitable syntax and parser for ACL rules.
5.2.5. Components of vACL¶
In vACL, each component is constructed using packet framework pipelines. It includes Rx and Tx Driver, Master pipeline, load balancer pipeline and vACL worker pipeline components. A Pipeline framework is a collection of input ports, table(s),output ports and actions (functions).
5.2.5.1. Receive and Transmit Driver¶
Packets will be received in bulk and provided to LoadBalancer(LB) thread. Transimit takes packets from worker threads in a dedicated ring and sent to hardware queue.
5.2.5.2. Master Pipeline¶
The Master component is part of all the IP Pipeline applications. This component does not process any packets and should configure with Core 0, to allow other cores for processing of the traffic. This component is responsible for 1. Initializing each component of the Pipeline application in different threads 2. Providing CLI shell for the user control/debug 3. Propagating the commands from user to the corresponding components
5.2.5.3. ARPICMP Pipeline¶
This pipeline processes the APRICMP packets.
5.2.5.4. TXRX Pipelines¶
The TXTX and RXRX pipelines are pass through pipelines to forward both ingress and egress traffic to Loadbalancer. This is required when the Software Loadbalancer is used.
5.2.5.5. Load Balancer Pipeline¶
The vACL support both hardware and software balancing for load blalcning of traffic across multiple VNF threads. The Hardware load balncing require support from hardware like Flow Director for steering of packets to application through hardware queues.
The Software Load balancer is also supported if hardware loadbalancing can’t be used for any reason. The TXRX along with LOADB pipeline provides support for software load balancing by distributing the flows to Multiple vACL worker threads. Loadbalancer (HW or SW) distributes traffic based on the 5 tuple (src addr, src port, dest addr, dest port and protocol) applying an XOR logic distributing to active worker threads, thereby maintaining an affinity of flows to worker threads.
5.2.5.6. vACL Pipeline¶
The vACL performs the rule-based packet filtering.
5.2.5.6.1. vACL Topology¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 1) IXIA
operation:
  Egress --> The packets sent out from ixia(port 0) will be sent through ACL to ixia(port 1).
  Igress --> The packets sent out from ixia(port 1) will be sent through ACL to ixia(port 0).
5.2.5.6.2. vACL Topology (L4REPLAY)¶
IXIA(Port 0)-->(Port 0)VNF(Port 1)-->(Port 0)L4REPLAY
operation:
  Egress --> The packets sent out from ixia will pass through vACL to L3FWD/L4REPLAY.
  Ingress --> The L4REPLAY upon reception of packets (Private to Public Network),
  will immediately replay back the traffic to IXIA interface. (Pub -->Priv).
5.2.5.6.3. How to run L4Replay¶
After the installation of samplevnf
go to <samplevnf/VNFs/L4Replay>
./buid/L4replay -c  core_mask -n no_of_channels(let it be as 2) -- -p PORT_MASK --config="(port,queue,lcore)"
eg: ./L4replay -c 0xf -n 4 -- -p 0x3 --config="(0,0,1)"
5.2.6. Installation, Compile and Execution¶
Plase refer to <samplevnf>/docs/vACL/INSTALL.rst for installation, configuration, compilation and execution.
5.3. vACL - Installation Guide¶
5.3.1. vACL Compilation¶
After downloading (or doing a git clone) in a directory (samplevnf)
5.3.1.1. Dependencies¶
- DPDK supported versions ($DPDK_RTE_VER = 16.04, 16.11, 17.02 or 17.05): Downloaded and installed via vnf_build.sh or manually from [here] (http://fast.dpdk.org/rel/)
- libpcap-dev
- libzmq
- libcurl
5.3.1.2. Environment variables¶
Apply all the additional patches in ‘patches/dpdk_custom_patch/’ and build dpdk
export RTE_SDK=<dpdk directory>
export RTE_TARGET=x86_64-native-linuxapp-gcc
This is done by vnf_build.sh script.
5.3.2. Auto Build:¶
$ ./tools/vnf_build.sh in samplevnf root folder
Follow the steps in the screen from option [1] –> [9] and select option [8] to build the vnfs. It will automatically download selected DPDK version and any required patches and will setup everything and build vACL VNFs.
Following are the options for setup:
----------------------------------------------------------
 Step 1: Environment setup.
----------------------------------------------------------
[1] Check OS and network connection
[2] Select DPDK RTE version
----------------------------------------------------------
 Step 2: Download and Install
----------------------------------------------------------
[3] Agree to download
[4] Download packages
[5] Download DPDK zip
[6] Build and Install DPDK
[7] Setup hugepages
----------------------------------------------------------
 Step 3: Build VNFs
----------------------------------------------------------
[8] Build all VNFs (vACL, vCGNAPT, vFW, UDP_Replay)
[9] Exit Script
An vACL executable will be created at the following location samplevnf/VNFs/vACL/build/vACL
5.3.3. Manual Build:¶
- Download DPDK supported version from dpdk.org 
- unzip dpdk-$DPDK_RTE_VER.zip and apply dpdk patches only in case of 16.04 (Not required for other DPDK versions) - cd dpdk - patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-management.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-Rx-hang-when-disable-LLDP.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-link-status-change-interrupt.patch
- patch -p1 < VNF_CORE/patches/dpdk_custom_patch/i40e-fix-VF-bonded-device-link-down.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/disable-acl-debug-logs.patch
- patch -p1 < $VNF_CORE/patches/dpdk_custom_patch/set-log-level-to-info.patch
 
- build dpdk - make config T=x86_64-native-linuxapp-gcc O=x86_64-native-linuxapp-gcc
- cd x86_64-native-linuxapp-gcc
- make
 
- Setup huge pages - For 1G/2M hugepage sizes, for example 1G pages, the size must be specified explicitly and can also be optionally set as the default hugepage size for the system. For example, to reserve 8G of hugepage memory in the form of eight 1G pages, the following options should be passed to the kernel: * default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048
- Add this to Go to /etc/default/grub configuration file.
- Append “default_hugepagesz=1G hugepagesz=1G hugepages=8 hugepagesz=2M hugepages=2048”
- to the GRUB_CMDLINE_LINUX entry.
 
 
 
- Setup Environment Variable - export RTE_SDK=<samplevnf>/dpdk 
- export RTE_TARGET=x86_64-native-linuxapp-gcc 
- export VNF_CORE=<samplevnf> - or using ./tools/setenv.sh 
 
- Build vACL VNFs - cd <samplevnf>/VNFs/vACL
- make clean
- make
 
- The vACL executable will be created at the following location - <samplevnf>/VNFs/vACL/build/vACL
 
5.3.4. Run¶
5.3.4.1. Setup Port to run VNF¶
For DPDK versions 16.04
1. cd <samplevnf>/dpdk
2. ./tools/dpdk_nic_bind.py --status <--- List the network device
3. ./tools/dpdk_nic_bind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-16.04/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 16.11
1. cd <samplevnf>/dpdk
2. ./tools/dpdk-devbind.py --status <--- List the network device
3. ./tools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-16.11/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
For DPDK versions 17.xx
1. cd <samplevnf>/dpdk
2. ./usertools/dpdk-devbind.py --status <--- List the network device
3. ./usertools/dpdk-devbind.py -b igb_uio <PCI Port 0> <PCI Port 1>
.. _More details: http://dpdk.org/doc/guides-17.05/linux_gsg/build_dpdk.html#binding-and-unbinding-network-ports-to-from-the-kernel-modules
Make the necessary changes to the config files to run the vACL VNF
eg: ports_mac_list = 00:00:00:30:21:00 00:00:00:30:21:00
5.3.4.2. ACL run commands¶
Update the configuration according to system configuration.
./build/vACL -p <port mask> -f <config> -s <script> - SW_LoadB
./build/vACL -p <port mask> -f <config> -s <script> -hwlb <num_WT> - HW_LoadB
5.3.4.2.1. Run IPv4¶
Software LoadB
 cd <samplevnf>/VNFs/vACL/
 ./build/vACL -p 0x3 -f ./config/IPv4_swlb_acl_1LB_1t.cfg  -s ./config/ IPv4_swlb_acl.tc
Hardware LoadB
 cd <samplevnf>/VNFs/vACL/
 ./build/vACL -p 0x3 -f ./config/IPv4_hwlb_acl_1LB_1t.cfg  -s ./config/IPv4_hwlb_acl.tc --hwlb 1
5.3.4.2.2. Run IPv6¶
Software LoadB
cd <samplevnf>/VNFs/vACL/
./build/vACL -p 0x3 -f ./config/IPv6_swlb_acl_1LB_1t.cfg  -s ./config/IPv6_swlb_acl.tc
Hardware LoadB
cd <samplevnf>/VNFs/vACL/
./build/vACL -p 0x3 -f ./config/IPv6_hwlb_acl_1LB_1t.cfg  -s ./config/IPv6_hwlb_acl.tc --hwlb 1
5.3.4.2.3. vACL execution on BM & SRIOV¶
To run the VNF, execute the following
samplevnf/VNFs/vACL# ./build/vACL -p 0x3 -f ./config/IPv4_swlb_acl_1LB_1t.cfg  -s ./config/ IPv4_swlb_acl.tc
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vACL configuration file
-s SCRIPT FILE: vACL script file
5.3.4.2.4. vACL execution on OVS¶
To run the VNF, execute the following:
samplevnf/VNFs/vACL# ./build/vACL -p 0x3 -f ./config/IPv4_swlb_acl_1LB_1t.cfg  -s ./config/ IPv4_swlb_acl.tc --disable-hw-csum
Command Line Params:
-p PORTMASK: Hexadecimal bitmask of ports to configure
-f CONFIG FILE: vACL configuration file
-s SCRIPT FILE: vACL script file
--disable-hw-csum :Disable TCP/UDP hw checksum
