:orphan: .. index:: pair: group; ethtool tool TAPI (tapi_ethtool) .. _doxid-group__tapi__ethtool: ethtool tool TAPI (tapi_ethtool) ================================ .. toctree:: :hidden: enum_tapi_ethtool_cmd.rst struct_tapi_ethtool_if_props.rst struct_tapi_ethtool_opt.rst struct_tapi_ethtool_pause.rst struct_tapi_ethtool_report.rst struct_tapi_ethtool_ring.rst Overview ~~~~~~~~ Declarations for TAPI to handle ethtool tool. :ref:`More...` .. ref-code-block:: cpp :class: doxyrest-overview-code-block // typedefs typedef enum :ref:`tapi_ethtool_cmd` :ref:`tapi_ethtool_cmd`; typedef struct :ref:`tapi_ethtool_opt` :ref:`tapi_ethtool_opt`; typedef struct :ref:`tapi_ethtool_if_props` :ref:`tapi_ethtool_if_props`; typedef struct :ref:`tapi_ethtool_pause` :ref:`tapi_ethtool_pause`; typedef struct :ref:`tapi_ethtool_ring` :ref:`tapi_ethtool_ring`; typedef struct :ref:`tapi_ethtool_report` :ref:`tapi_ethtool_report`; // enums enum :ref:`tapi_ethtool_cmd`; // structs struct :ref:`tapi_ethtool_if_props`; struct :ref:`tapi_ethtool_opt`; struct :ref:`tapi_ethtool_pause`; struct :ref:`tapi_ethtool_report`; struct :ref:`tapi_ethtool_ring`; // global variables const :ref:`tapi_ethtool_opt` :ref:`tapi_ethtool_default_opt`; const :ref:`tapi_ethtool_report` :ref:`tapi_ethtool_default_report`; // global functions :ref:`te_errno` :ref:`tapi_ethtool`(:ref:`tapi_job_factory_t`* factory, const :ref:`tapi_ethtool_opt`* opt, :ref:`tapi_ethtool_report`* report); :ref:`te_errno` :ref:`tapi_ethtool_get_stat`(:ref:`tapi_ethtool_report`* report, const char* name, long int* value); void :ref:`tapi_ethtool_destroy_report`(:ref:`tapi_ethtool_report`* report); // macros #define :ref:`TAPI_ETHTOOL_MAX_STR` .. _details-group__tapi__ethtool: Detailed Documentation ~~~~~~~~~~~~~~~~~~~~~~ Declarations for TAPI to handle ethtool tool. WARNING: do not use this TAPI unless you really need to check ethtool application itself. Normally configuration tree should be used to read and change network interface settings. It is strictly prohibited to use this TAPI for changing configuration. Copyright (C) 2021-2022 OKTET Labs Ltd. All rights reserved. Typedefs -------- .. index:: pair: typedef; tapi_ethtool_cmd .. _doxid-group__tapi__ethtool_1ga1f82620f5abbc2e1ffdc312a355acba9: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef enum :ref:`tapi_ethtool_cmd` tapi_ethtool_cmd Supported ethtool commands .. index:: pair: typedef; tapi_ethtool_opt .. _doxid-group__tapi__ethtool_1gacedc32417fa45a9e029df8ef1f71f025: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_ethtool_opt` tapi_ethtool_opt Command line options for ethtool .. index:: pair: typedef; tapi_ethtool_if_props .. _doxid-group__tapi__ethtool_1ga80e1b7c070c40fb36a113bee622dced0: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_ethtool_if_props` tapi_ethtool_if_props Interface properties parsed in case of ``TAPI_ETHTOOL_CMD_NONE`` .. index:: pair: typedef; tapi_ethtool_pause .. _doxid-group__tapi__ethtool_1ga5c94e67500b9855f97a5616943b30901: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_ethtool_pause` tapi_ethtool_pause Pause parameters parsed in case of ``TAPI_ETHTOOL_CMD_SHOW_PAUSE`` .. index:: pair: typedef; tapi_ethtool_ring .. _doxid-group__tapi__ethtool_1ga51d6f2ebc738e6ca5d29b029f7e538a3: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_ethtool_ring` tapi_ethtool_ring Ring parameters parsed in case of ``TAPI_ETHTOOL_CMD_SHOW_RING`` .. index:: pair: typedef; tapi_ethtool_report .. _doxid-group__tapi__ethtool_1ga734ade30553a7ae10cb9205da6f99d6d: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef struct :ref:`tapi_ethtool_report` tapi_ethtool_report Structure for storing parsed data from ethtool output Global Variables ---------------- .. index:: pair: variable; tapi_ethtool_default_opt .. _doxid-group__tapi__ethtool_1gadb4034788bb37a560aba5dc8ba72ddae: .. ref-code-block:: cpp :class: doxyrest-title-code-block const :ref:`tapi_ethtool_opt` tapi_ethtool_default_opt Default options initializer .. index:: pair: variable; tapi_ethtool_default_report .. _doxid-group__tapi__ethtool_1ga0f2603f455f35cb87e9559a526cc98f3: .. ref-code-block:: cpp :class: doxyrest-title-code-block const :ref:`tapi_ethtool_report` tapi_ethtool_default_report Default report initializer Global Functions ---------------- .. index:: pair: function; tapi_ethtool .. _doxid-group__tapi__ethtool_1gaa2d26661cc494c1835588625787e1a62: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_ethtool(:ref:`tapi_job_factory_t`* factory, const :ref:`tapi_ethtool_opt`* opt, :ref:`tapi_ethtool_report`* report) Run ethtool command, parse its output if required. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - factory - Job factory * - opt - Ethtool command options * - report - If not ``NULL``, parsed data from output will be saved here .. rubric:: Returns: Status code. .. index:: pair: function; tapi_ethtool_get_stat .. _doxid-group__tapi__ethtool_1ga5bf7151661b68cd1f2a2f64e017ec9e2: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_ethtool_get_stat(:ref:`tapi_ethtool_report`* report, const char* name, long int* value) Get a single statistic from parsed ethtool output. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - report - Pointer to parsed data storage * - name - Name of the statistic * - value - Where to save parsed value .. rubric:: Returns: Status code. .. index:: pair: function; tapi_ethtool_destroy_report .. _doxid-group__tapi__ethtool_1gab967806ee69740e36d73506522b5ad24: .. ref-code-block:: cpp :class: doxyrest-title-code-block void tapi_ethtool_destroy_report(:ref:`tapi_ethtool_report`* report) Release resources allocated for ethtool output data. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - report - Structure storing parsed data Macros ------ .. index:: pair: define; TAPI_ETHTOOL_MAX_STR .. _doxid-group__tapi__ethtool_1ga6148603f11ec7155ac3b86a69f59274c: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TAPI_ETHTOOL_MAX_STR Maximum string length in ethtool output