2021-02-05 08:48:47 +00:00
|
|
|
.. SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
Copyright 2020 Mellanox Technologies, Ltd
|
|
|
|
|
|
|
|
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.
|
2022-09-06 04:00:10 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
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.
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
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:
|
2021-02-05 08:48:47 +00:00
|
|
|
|
|
|
|
* 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.
|
|
|
|
|
|
|
|
|
|
|
|
Limitations
|
|
|
|
~~~~~~~~~~~
|
|
|
|
|
|
|
|
* Supports only precompiled rules.
|
|
|
|
|
|
|
|
|
|
|
|
Application Options
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
``--rules NAME``
|
|
|
|
precompiled rule file
|
|
|
|
|
|
|
|
``--data NAME``
|
|
|
|
data file to use
|
|
|
|
|
|
|
|
``--nb_jobs N``
|
|
|
|
number of jobs to use
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
``--nb_qps N``
|
|
|
|
number of QPs to use
|
|
|
|
|
|
|
|
``--nb_lcores N``
|
|
|
|
number of cores to use
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
``--perf N``
|
|
|
|
only outputs the performance data
|
|
|
|
|
|
|
|
``--nb_iter N``
|
|
|
|
number of iteration to run
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
``--nb_segs N``
|
|
|
|
number of mbuf segment
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
``--help``
|
|
|
|
print application options
|
|
|
|
|
|
|
|
|
|
|
|
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::
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
./dpdk-test-regex -a 83:00.0 -- --rules rule_file.rof2 --data data_file.txt --job 100 \
|
|
|
|
--nb_qps 4 --nb_lcores 2
|