12. dpdk-test-regex Tool

The dpdk-test-regex tool is a Data Plane Development Kit (DPDK) application that allows functional testing and performance measurement for the RegEx PMDs.

It is based on precompiled rule file, and an input file, both of them can be selected using command-line options.

In general case, each PMD has its own rule file.

By default the test supports one QP per core, however a higher number of cores and QPs can be configured. The QPs are evenly distributed on the cores. All QPs are assigned the same number of segments of input file to parse. Given n QPs (per core) - the enqueue/dequeue RegEx operations are interleaved as follows:

enqueue(QP #1)
enqueue(QP #2)
...
enqueue(QP #n)
dequeue(QP #1)
dequeue(QP #2)
...
dequeue(QP #n)

The test outputs the following data per QP and core:

  • Performance, in gigabit per second.
  • Matching results (rule id, position, length), for each job.
  • Matching results in absolute location (rule id, position , length), relative to the start of the input data.

12.1. Limitations

  • Supports only precompiled rules.

12.2. Application Options

--rules NAME
precompiled rule file
--data NAME
data file to use
--nb_jobs N
number of jobs to use
--nb_qps N
number of QPs to use
--nb_lcores N
number of cores to use
--perf N
only outputs the performance data
--nb_iter N
number of iteration to run
--nb_segs N
number of mbuf segment
--help
print application options

12.2.1. Running the Tool

Step 1: Compile a rule file

In order for the RegEx to work it must have a precompiled rule file. to generate this file there is a need to use a RegEx compiler that matches the RegEx PMD.

Step 2: Generate a data file

The data file, will be used as a source data for the RegEx to work on.

Step 3: Run the tool

The tool has a number of command line options. Here is the sample command line:

./dpdk-test-regex -a 83:00.0 -- --rules rule_file.rof2 --data data_file.txt --job 100 \
  --nb_qps 4 --nb_lcores 2