On Thu, 15 Mar 2018 16:15:21 +0000
"Melik-Adamyan, Areg" <areg.melik-adam...@intel.com> wrote:

> Hello.
> 
> Within Intel, we developed and open-sourced a DPDK based high-level library 
> and runtime named Network Function Framework for Go (NFF-Go: 
> https://github.com/intel-go/nff-go) which is intended to simplify packet 
> processing applications, especially for cloud-native deployment. Based on 
> DPDK NFF-Go provides higher-level packet processing functions in native Go 
> alongside with simple, powerful runtime.
> NFF-Go library itself is not a set of wrappers over 'C' calls to DPDK as that 
> would result in poor performance due to the 300-1500 cycles that can be spent 
> by a context switch. Instead, NFF-Go uses pointers from the DPDK 
> initialization of the device mbuf structures. It permits copying of packet 
> data between Go's safe and DPDK/C unsafe memory. NFF-Go works everywhere 
> where DPDK works.
> *Capabilities:* Library provides functions to create packet processing graph 
> from user-defined or predefined functions. The graph can be arbitrary but 
> will need to have a single entry point. The user can freely use both 
> synchronous and asynchronous programming capabilities provided by Go 
> language. Also, auto-scaling is automatically provided by the built-in 
> scheduler using cores as needed, and freeing them after use. NFF-Go provides 
> an alternative development environment for creating network functions using a 
> smaller number of lines of code compared to DPDK/C without sacrificing 
> performance. These capabilities make it possible to implement 
> run-till-completion packet processing model.  The library includes a 
> component called boundary node, which allows consuming packet data from all 
> types of sources: Ethernet, file, memory buffer, remote procedure call and 
> then applying the packets to the processing graph which will be transparently 
> deployed through any cloud orchestration engine.
> *Benefit* NFF-Go is based on the DPDK and lowers the entry barrier for 
> bringing packet processing to less experienced developers and push towards 
> cloud-native usages. We strongly believe that NFF-Go is complementary to 
> DPDK. Having a closer link between them should help both projects - it will 
> ease pickup from one source/repo the needed set of features to be used, 
> rather than us just providing a disjointed collection of software projects 
> which are hosted in different places.
> 
> We expect the initial commit to include the following:
> 
> -          Low, Asm - low-level C and ASM code for gluing DPDK
> 
> -          Packet - a library that provides an abstraction for packet and 
> tools to manipulate
> 
> -          Flow  - library to provide an abstraction for packet flows
> 
> -          Scheduler - runtime and a scheduler for auto-scaling and 
> integration with RSS
> 
> -          Examples:
> 
> o   Forwarding - simple L3 forwarding
> 
> o   Firewall - an example of simple ACL based firewall
> 
> o   Tutorial - step based tutorial how to use NFF-Go
> 
> o   NAT - an example of production grade Network Address Translation
> 
> o   AntiDDOS - simple example of AntiDDOS on L3
> 
> -          Automation scripts - helping to build, deploy and test 
> applications on a single host
> 
> Thanks,
> Areg Melik-Adamyan
> Engineering Manager
> Developer Products Divison
> Intel Corporation

I am ok with it being on DPDK, but might it make more sense on github or under 
FD.io?
Or is there some legal and/or political reason not to?

Reply via email to