aboutsummaryrefslogtreecommitdiffstats
path: root/docs/gettingstarted/developers/plugins.rst
blob: 09db1d3459f1cabc3bd214a14321d99dde2c6094 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
.. _dplugins:

Plugins
=======

vlib implements a straightforward plug-in DLL mechanism. VLIB client
applications specify a directory to search for plug-in .DLLs, and a name
filter to apply (if desired). VLIB needs to load plug-ins very early.

Once loaded, the plug-in DLL mechanism uses dlsym to find and verify a
vlib\_plugin\_registration data structure in the newly-loaded plug-in.

For more on plugins please refer to :ref:`add_plugin`.
fcc } .highlight .c { color: #888888 } /* Comment */ .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .highlight .k { color: #008800; font-weight: bold } /* Keyword */ .highlight .ch { color: #888888 } /* Comment.Hashbang */ .highlight .cm { color: #888888 } /* Comment.Multiline */ .highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
TRex JSON Template
==================

Whenever TRex is publishing live data, it uses JSON notation to describe the data-object.

Each client may parse it differently, however this page will describe the values meaning when published by TRex server.


Main Fields
-----------

Each TRex server-published JSON object contains data divided to main fields under which the actual data lays.

These main fields are:

+-----------------------------+----------------------------------------------------+---------------------------+
| Main field                  | Contains                                           | Comments                  |
+=============================+====================================================+===========================+
| :ref:`trex-global-field`    | Must-have data on TRex run,                        |                           |
|                             | mainly regarding Tx/Rx and packet drops            |                           |
+-----------------------------+----------------------------------------------------+---------------------------+
| :ref:`tx-gen-field`         | Data indicate the quality of the transmit process. |                           |
|                             | In case histogram is zero it means that all packets|                           |
|                             | were injected in the right time.                   |                           |
+-----------------------------+----------------------------------------------------+---------------------------+
| :ref:`trex-latecny-field`   | Latency reports, containing latency data on        | - Generated when latency  |
|                             | generated data and on response traffic             |   test is enabled (``l``  |
|                             |                                                    |   param)                  |
|                             |                                                    | - *typo* on field key:    |
+-----------------------------+----------------------------------------------------+   will be fixed on next   |   
| :ref:`trex-latecny-v2-field`| Extended latency information                       |   release                 |
+-----------------------------+----------------------------------------------------+---------------------------+


Each of these fields contains keys for field general data (such as its name) and its actual data, which is always stored under the **"data"** key.

For example, in order to access some trex-global data, the access path would look like::

   AllData -> trex-global -> data -> desired_info

   


Detailed explanation
--------------------

.. _trex-global-field:

trex-global field
~~~~~~~~~~~~~~~~~


+--------------------------------+-------+-----------------------------------------------------------+
|      Sub-key                   | Type  |                          Meaning                          |
+================================+=======+===========================================================+
| m_cpu_util                     | float | CPU utilization (0-100)                                   |
+--------------------------------+-------+-----------------------------------------------------------+
| m_platform_factor              | float | multiplier factor                                         |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_bps                       | float | total tx bit per second                                   |
+--------------------------------+-------+-----------------------------------------------------------+
| m_rx_bps                       | float | total rx bit per second                                   |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_pps                       | float | total tx packet per second                                |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_cps                       | float | total tx connection per second                            |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_expected_cps              | float | expected tx connection per second                         |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_expected_pps              | float | expected tx packet per second                             |
+--------------------------------+-------+-----------------------------------------------------------+
| m_tx_expected_bps              | float | expected tx bit per second                                |
+--------------------------------+-------+-----------------------------------------------------------+
| m_rx_drop_bps                  | float | drop rate in bit per second                               |
+--------------------------------+-------+-----------------------------------------------------------+
| m_active_flows                 | float | active trex flows                                         |
+--------------------------------+-------+-----------------------------------------------------------+
| m_open_flows                   | float | open trex flows from startup (monotonically incrementing) |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_tx_pkts                |  int  | total tx in packets                                       |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_rx_pkts                |  int  | total rx in packets                                       |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_tx_bytes               |  int  | total tx in bytes                                         |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_rx_bytes               |  int  | total rx in bytes                                         |
+--------------------------------+-------+-----------------------------------------------------------+
| opackets-#                     |  int  | output packets (per interface)                            |
+--------------------------------+-------+-----------------------------------------------------------+
| obytes-#                       |  int  | output bytes (per interface)                              |
+--------------------------------+-------+-----------------------------------------------------------+
| ipackets-#                     |  int  | input packet (per interface)                              |
+--------------------------------+-------+-----------------------------------------------------------+
| ibytes-#                       |  int  | input bytes (per interface)                               |
+--------------------------------+-------+-----------------------------------------------------------+
| ierrors-#                      |  int  | input errors (per interface)                              |
+--------------------------------+-------+-----------------------------------------------------------+
| oerrors-#                      |  int  | input errors (per interface)                              |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_tx_bps-#               | float | total transmitted data in bit per second                  |
+--------------------------------+-------+-----------------------------------------------------------+
| unknown                        |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_nat_learn_error [#f1]_ |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_nat_active [#f2]_      |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_nat_no_fid [#f2]_      |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_nat_time_out [#f2]_    |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+
| m_total_nat_open [#f2]_    	 |  int  |                                                           |
+--------------------------------+-------+-----------------------------------------------------------+


.. _tx-gen-field:

tx-gen field
~~~~~~~~~~~~

+-------------------+-------+-----------------------------------------------------------+
|      Sub-key      | Type  |                          Meaning                          |
+===================+=======+===========================================================+
| realtime-hist     | dict  | histogram of transmission. See extended information about |
|                   |       | histogram object under :ref:`histogram-object-fields`.    |
|                   |       | The attribute analyzed is time packet has been sent       |
|                   |       | before/after it was intended to be                        |
+-------------------+-------+-----------------------------------------------------------+
| unknown           | int   |                                                           |
+-------------------+-------+-----------------------------------------------------------+

.. _trex-latecny-field:

trex-latecny field
~~~~~~~~~~~~~~~~~~

+---------+-------+---------------------------------------------------------+
| Sub-key | Type  |                         Meaning                         |
+=========+=======+=========================================================+
| avg-#   | float | average latency in usec (per interface)                 |
+---------+-------+---------------------------------------------------------+
| max-#   | float | max latency in usec from the test start (per interface) |
+---------+-------+---------------------------------------------------------+
| c-max-# | float | max in the last 1 sec window (per interface)            |
+---------+-------+---------------------------------------------------------+
| error-# | float | errors in latency packets (per interface)               |
+---------+-------+---------------------------------------------------------+
| unknown |  int  |                                                         |
+---------+-------+---------------------------------------------------------+

.. _trex-latecny-v2-field:

trex-latecny-v2 field
~~~~~~~~~~~~~~~~~~~~~

+--------------------------------------+-------+--------------------------------------+
|               Sub-key                | Type  |               Meaning                |
+======================================+=======+======================================+
| cpu_util                             | float | rx thread cpu % (this is not trex DP |
|                                      |       | threads cpu%%)                       |
+--------------------------------------+-------+--------------------------------------+
| port-#                               |       | Containing per interface             |
|                                      | dict  | information. See extended            |
|                                      |       | information under ``port-# ->        |
|                                      |       | key_name -> sub_key``                |
+--------------------------------------+-------+--------------------------------------+
| port-#->hist                         | dict  | histogram of latency. See extended   |
|                                      |       | information about histogram object   |
|                                      |       | under :ref:`histogram-object-fields`.|
+--------------------------------------+-------+--------------------------------------+
| port-#->stats                        |       | Containing per interface             |
|                                      | dict  | information. See extended            |
|                                      |       | information under ``port-# ->        |
|                                      |       | key_name -> sub_key``                |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_tx_pkt_ok           | int   | total of try sent packets            |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_pkt_ok              | int   | total of packets sent from hardware  |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_no_magic            | int   | rx error with no magic               |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_no_id               | int   | rx errors with no id                 |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_seq_error           | int   | error in seq number                  |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_length_error        | int   |                                      |
+--------------------------------------+-------+--------------------------------------+
| port-#->stats->m_rx_check            | int   | packets tested in rx                 |
+--------------------------------------+-------+--------------------------------------+
| unknown                              | int   |                                      |
+--------------------------------------+-------+--------------------------------------+



.. _histogram-object-fields:

Histogram object fields
~~~~~~~~~~~~~~~~~~~~~~~

The histogram object is being used in number of place throughout the JSON object.
The following section describes its fields in detail.


+-----------+-------+-----------------------------------------------------------------------------------+
|  Sub-key  | Type  |                                      Meaning                                      |
+===========+=======+===================================================================================+
| min_usec  |  int  | min attribute value in usec. pkt with latency less than this value is not counted |
+-----------+-------+-----------------------------------------------------------------------------------+
| max_usec  |  int  | max attribute value in usec                                                       |
+-----------+-------+-----------------------------------------------------------------------------------+
| high_cnt  |  int  | how many packets on which its attribute > min_usec                                |
+-----------+-------+-----------------------------------------------------------------------------------+
| cnt       |  int  | total packets from test startup                                                   |
+-----------+-------+-----------------------------------------------------------------------------------+
| s_avg     | float | average value from test startup                                                   |
+-----------+-------+-----------------------------------------------------------------------------------+
| histogram |       | histogram of relevant object by the following keys:                               |
|           | array |  - key: value in usec                                                             |
|           |       |  - val: number of packets                                                         |
+-----------+-------+-----------------------------------------------------------------------------------+


Access Examples
---------------



.. rubric:: Footnotes

.. [#f1] Available only in NAT and NAT learning operation (``learn`` and ``learn-verify`` flags)

.. [#f2] Available only in NAT operation (``learn`` flag)