> > On Tue, 2021-12-14 at 14:12 +0000, Ronan Randles wrote:
> > > This patchset introduces a Gen library for DPDK. This library provides an 
> > > easy
> > > way to generate traffic in order to test software based network 
> > > components.
> > >
> > > This library enables the basic functionality required in the traffic 
> > > generator.
> > > This includes: raw data setting, packet Tx and Rx, creation and 
> > > destruction of a
> > >  Gen instance and various types of data parsing.
> > > This functionality is implemented in "lib/gen/rte_gen.c". IPv4 parsing
> > > functionality is also added in "lib/net/rte_ip.c", this is then used in 
> > > the gen
> > > library.
> > >
> > > A sample app is included in "examples/generator" which shows the use of 
> > > the
> > gen
> > > library in making a traffic generator. This can be used to generate 
> > > traffic by
> > > running the dpdk-generator generator executable. This sample app supports
> > > runtime stats reporting (/gen/stats) and line rate limiting
> > > (/gen/mpps,<target traffic rate in mpps>) through telemetry.py.
> > >
> > > As more features are added to the gen library, the sample application will
> > > become more powerful through the "/gen/packet" string parameter
> > > (currently supports IP and Ether address setting). This will allow every
> > > application to generate more complex traffic types in the future without
> > > changing API.
> >
> > A good start, thanks.
> >
> > Testpmd can do txonly, rxonly, forwarding, but no rx+tx only :) I guess
> > that's the key of a GEN. testpmd also has "--stats-period" to show
> > statistics in non-interactive mode, very close to a GEN, but not
> > enough. Testpmd can toggle a lot of settings like offloading, that's an
> > advantage. Do you see an chance to make the lib part of testpmd?
> >
> > I tried to leverage Scapy syntax into testpmd [1][2]: to set fancy
> > template - useful to test flows, or dump packet using different scapy
> > detail level. unfotunately I don't have time to finish it. Parsing
> > packet from string is boring, any consideration on this?
> 
> Hi Steven,
> 
> Yes I recall the patchset to extend DPDK with python/scapy itself, and indeed 
> this was my first approach too!
> I build a proof-of-concept for enabling a 
> "run-python-script-inside-eth-null-PMD-rx-function" approach.
> Although this worked (in a clunky way, using packet.__bytes__() in python 
> script..), the performance was
> extremely low. An optimization was to pre-calculate e.g. 1 million packets, 
> and leave them all in memory,
> which causes memory waste, and lack of performance due to memory-boundedness 
> in the CPU.
> 
> There is a fundamental blocking issue here - the generation/creation of 
> packets is slow. Even updating a
> single flow, or single parameter of the packet, could/would require 
> recalculation of checksums... so leads
> to the C code needing to know the L2/L3/L4 offsets. Even then, the 
> re-calculation over 1-million packets
> puts a lot of memory pressure - the packets cannot be re-used (from mempool 
> lcore cache) if they need
> to be "unique" through pre-computation, resulting in cache-trashing.
> 
> As a solution, moving to a native/C language based creation of a "base 
> packet" (template) with "modifiers"
> seemed a good fit. It allows best-case performance (mempool cache) and lowest 
> compute per-packet.
> The "modifiers" are "pay for what you need" approach to flows/updates/etc, 
> allowing user to choose
> the right balance of traffic-complexity vs CPU-cost to generate it.
> 
> All in all; handling string-parsing in C is not fun - but by paying that 
> price we can gain many other things...

Just to throw in an alternate thought:
Instead of trying to re-implement scapy's abilities and face all related 
complexities (string parsings, etc.) -
might be choose another way: allow user to write his own packet fillers via 
eBPF?   
I.E: user write and compile eBPF program that will fill l2/l3/l4 headers, set 
mbuf flags, etc.
Then it will be loaded by packet-generator and executed for each outgoing 
packet.
That way user will have full flexibility and extensibility in defining his 
outgoing traffic.  
Again from developer/maintainer point of view such packet-gen app will probably 
require
much less effort.    
Though yes - user will need to do more work on his own - write actual packet 
filler code.

> 
> I think that a "gen" engine for TestPMD could be interesting for certain 
> use-cases yes. As your links below,
> the "expect" behaviour is a particularly nice way of working for testing! 
> There is an implementation for
> net/null PMD to create packets with Gen library, but is not ready for 
> upstream so was not included in V2.
> 
> For multi-flow latency testing, I'm not sure if TestPMD is the ideal tool, as 
> it does not prioritize RX/latency
> at all costs: e.g lcores perform both RX and TX functionality. The dedicated 
> "example/generator" is a sample
> application that provides the basis for a more latency/jitter focused 
> application, however there is much work
> to do there to make it a production-ready tool.
> 
> Note that at the moment, the status of the Gen work is as follows;
> - Upstream discussion: 
> http://mails.dpdk.org/archives/dev/2022-January/232965.html
> - V2 patch: 
> http://patches.dpdk.org/project/dpdk/cover/20220121103122.2926856-1-ronan.rand...@intel.com/
> 
> Regards, -Harry
> 
> PS: Side note around Python/Scapy: its an *awesome* tool. I like it a lot, 
> but for DPDK levels of performance,
> and in a latency/performance critical use-case, I'm not convinced it is the 
> right tool to use.
> 
> 
> > [1]: https://github.com/steevenlee/dpdk/commits/upstream_scapy
> > [2]: doc
> > https://github.com/steevenlee/dpdk/blob/875b8407f769465837513d29a495af3cc
> > 1a29765/doc/guides/howto/scapy.rst
> >
> > >
> > > Harry van Haaren (6):
> > >   gen: add files for initial traffic generation library
> > >   gen: add basic Rx and Tx routines and tests
> > >   gen: add raw packet data API and tests
> > >   gen: add parsing infrastructure and Ether protocol
> > >   gen: add gen IP parsing
> > >   examples/generator: import code from basicfwd.c
> > >
> > > Ronan Randles (6):
> > >   net: add string to IPv4 parse function
> > >   net: add function to pretty print IPv4
> > >   examples/generator: enable gen library for traffic gen
> > >   examples/generator: telemetry support
> > >   examples/generator: link status check added
> > >   examples/generator: line rate limiting
> > >
> > >  app/test/meson.build           |   4 +
> > >  app/test/test_gen.c            | 184 +++++++++++
> > >  app/test/test_net.c            |  87 ++++++
> > >  doc/api/doxy-api-index.md      |   3 +-
> > >  doc/api/doxy-api.conf.in       |   1 +
> > >  examples/generator/main.c      | 483 ++++++++++++++++++++++++++++
> > >  examples/generator/meson.build |  13 +
> > >  examples/meson.build           |   1 +
> > >  lib/gen/meson.build            |   6 +
> > >  lib/gen/rte_gen.c              | 553 +++++++++++++++++++++++++++++++++
> > >  lib/gen/rte_gen.h              | 114 +++++++
> > >  lib/gen/version.map            |  10 +
> > >  lib/meson.build                |   1 +
> > >  lib/net/meson.build            |   1 +
> > >  lib/net/rte_ip.c               |  58 ++++
> > >  lib/net/rte_ip.h               |  38 +++
> > >  lib/net/version.map            |   9 +
> > >  17 files changed, 1565 insertions(+), 1 deletion(-)
> > >  create mode 100644 app/test/test_gen.c
> > >  create mode 100644 app/test/test_net.c
> > >  create mode 100644 examples/generator/main.c
> > >  create mode 100644 examples/generator/meson.build
> > >  create mode 100644 lib/gen/meson.build
> > >  create mode 100644 lib/gen/rte_gen.c
> > >  create mode 100644 lib/gen/rte_gen.h
> > >  create mode 100644 lib/gen/version.map
> > >  create mode 100644 lib/net/rte_ip.c
> > >

Reply via email to