:orphan: .. index:: pair: group; PCI devices configuration of Test Agents .. _doxid-group__tapi__conf__pci: PCI devices configuration of Test Agents ======================================== .. toctree:: :hidden: enum_tapi_cfg_driver_type.rst enum_tapi_cfg_pci_param_cmode.rst Overview ~~~~~~~~ .. ref-code-block:: cpp :class: doxyrest-overview-code-block // typedefs typedef enum :ref:`tapi_cfg_pci_param_cmode` :ref:`tapi_cfg_pci_param_cmode`; // enums enum :ref:`tapi_cfg_driver_type`; enum :ref:`tapi_cfg_pci_param_cmode`; // global functions :ref:`te_errno` :ref:`tapi_cfg_pci_get_pci_vendor_device`(const char* ta, const char* pci_addr, char** vendor, char** device); :ref:`te_errno` :ref:`tapi_cfg_pci_resolve_device_oid`(char** pci_dev_oid, const char* pci_inst_fmt, ...); :ref:`te_errno` :ref:`te_errno` :ref:`tapi_cfg_pci_devices_by_vendor_device`(const char* ta, const char* vendor, const char* device, unsigned int* size, char*** pci_oids); :ref:`te_errno` :ref:`tapi_cfg_pci_get_max_vfs_of_pf`(const char* pf_oid, unsigned int* n_vfs); :ref:`te_errno` :ref:`tapi_cfg_pci_get_vfs_of_pf`(const char* pf_oid, bool pci_device, unsigned int* n_pci_vfs, :ref:`cfg_oid`*** pci_vfs, unsigned int** pci_vf_ids); :ref:`te_errno` :ref:`tapi_cfg_pci_enable_vfs_of_pf`(const char* pf_oid, unsigned int n_vfs); :ref:`te_errno` :ref:`tapi_cfg_pci_addr_by_oid`(const :ref:`cfg_oid`* pci_device, char** pci_addr); :ref:`te_errno` :ref:`tapi_cfg_pci_addr_by_oid_array`(unsigned int n_devices, const :ref:`cfg_oid`** pci_devices, char*** pci_addrs); char* :ref:`tapi_cfg_pci_rsrc_name`(const :ref:`cfg_oid`* pci_instance); char* :ref:`tapi_cfg_pci_fn_netdev_rsrc_name`(const :ref:`cfg_oid`* oid); :ref:`te_errno` :ref:`tapi_cfg_pci_grab`(const :ref:`cfg_oid`* pci_instance); :ref:`te_errno` :ref:`tapi_cfg_pci_oid_by_addr`(const char* ta, const char* pci_addr, char** pci_oid); :ref:`te_errno` :ref:`tapi_cfg_pci_instance_by_addr`(const char* ta, const char* pci_addr, char** pci_inst); :ref:`te_errno` :ref:`tapi_cfg_pci_get_ta_driver`(const char* ta, enum :ref:`tapi_cfg_driver_type` type, char** driver); :ref:`te_errno` :ref:`tapi_cfg_pci_get_devices`(const char* pci_oid, unsigned int* count, char*** device_names); :ref:`te_errno` :ref:`tapi_cfg_pci_get_driver`(const char* pci_oid, char** driver); :ref:`te_errno` :ref:`tapi_cfg_pci_bind_driver`(const char* pci_oid, const char* driver); :ref:`te_errno` :ref:`tapi_cfg_pci_bind_ta_driver_on_device`(const char* ta, enum :ref:`tapi_cfg_driver_type` type, const char* pci_addr); :ref:`te_errno` :ref:`tapi_cfg_pci_fn_netdev_get_net_if`(const char* pci_fn_oid, const char* netdev, char** interface); :ref:`te_errno` :ref:`tapi_cfg_pci_get_net_if`(const char* pci_oid, char** interface); :ref:`te_errno` :ref:`tapi_cfg_pci_oid_by_net_if`(const char* ta, const char* if_name, char** pci_oid); :ref:`te_errno` :ref:`tapi_cfg_pci_get_numa_node`(const char* pci_oid, char** numa_node); :ref:`te_errno` :ref:`tapi_cfg_pci_get_numa_node_id`(const char* pci_oid, int* numa_node); :ref:`te_errno` :ref:`tapi_cfg_pci_bind_driver_by_vend_dev_inst`(const char* ta, const char* vendor, const char* device, unsigned int instance, const char* driver); :ref:`te_errno` :ref:`tapi_cfg_pci_unbind_driver_by_vend_dev_inst`(const char* ta, const char* vendor, const char* device, unsigned int instance); :ref:`te_errno` :ref:`tapi_cfg_pci_get_driver_by_vend_dev_inst`(const char* ta, const char* vendor, const char* device, unsigned int instance, char** driver); :ref:`te_errno` :ref:`tapi_cfg_pci_get_serialno`(const char* pci_oid, char** serialno); :ref:`te_errno` :ref:`tapi_cfg_pci_get_class`(const char* pci_oid, unsigned int* class_id, unsigned int* subclass_id, unsigned int* intf_id); :ref:`te_errno` :ref:`tapi_cfg_pci_param_is_present`(const char* pci_oid, const char* param_name, bool* present); :ref:`te_errno` :ref:`tapi_cfg_pci_get_param_str`(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, char** value); :ref:`te_errno` :ref:`tapi_cfg_pci_get_param_uint`(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, uint64_t* value); :ref:`te_errno` :ref:`tapi_cfg_pci_set_param_str`(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, const char* value); :ref:`te_errno` :ref:`tapi_cfg_pci_set_param_uint`(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, uint64_t value); :ref:`te_errno` :ref:`tapi_cfg_pci_get_vendor_dev_ids`(const char* pci_oid, unsigned int* vendor_id, unsigned int* device_id, unsigned int* subsystem_vendor_id, unsigned int* subsystem_device_id); :ref:`te_errno` :ref:`tapi_cfg_pci_get_spdk_config_filename`(const char* pci_oid, const char* cfg_name, bool create, char** filename); .. _details-group__tapi__conf__pci: Detailed Documentation ~~~~~~~~~~~~~~~~~~~~~~ Typedefs -------- .. index:: pair: typedef; tapi_cfg_pci_param_cmode .. _doxid-group__tapi__conf__pci_1ga2c80635d0849ab3d0ac069e740f52b4d: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef enum :ref:`tapi_cfg_pci_param_cmode` tapi_cfg_pci_param_cmode Device parameter configuration mode Global Functions ---------------- .. index:: pair: function; tapi_cfg_pci_get_pci_vendor_device .. _doxid-group__tapi__conf__pci_1ga3e9e34bcc2804f8dd4af4318100d5b2d: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_pci_vendor_device(const char* ta, const char* pci_addr, char** vendor, char** device) Get vendor and device identifiers of a PCI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - pci_addr - PCI device address (BDF notation) * - vendor - Vendor identifier (may be ``NULL`` to ignore) * - device - Device identifier (may be ``NULL`` to ignore) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_resolve_device_oid .. _doxid-group__tapi__conf__pci_1ga4f305ef9c8512335d764518cda0d8be7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_resolve_device_oid(char** pci_dev_oid, const char* pci_inst_fmt, ...) Get a PCI device OID (/agent/hardware/pci/device) by PCI instance OID (/agent/hardware/pci/vendor/device/instance). If a PCI device OID is provided, a copy of it is returned. The OID is constructed from a format string ``fmt`` and arguments. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_dev_oid - PCI device OID (should be free()'d) * - pci_inst_fmt - A printf() format for a PCI instance OID * - ... - Arguments .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_devices_by_vendor_device .. _doxid-group__tapi__conf__pci_1ga052c534aa8f71fabe23877b36fd8e066: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` :ref:`te_errno` tapi_cfg_pci_devices_by_vendor_device(const char* ta, const char* vendor, const char* device, unsigned int* size, char*** pci_oids) Get PCI addresses of PCI functions with specified vendor and device identifiers. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - vendor - Vendor identifier * - device - Device identifier * - size - Count of ``pci_addrs`` * - pci_oids - OIDs of found devices (/agent/hardware/pci/device). Might be ``NULL`` to only get the count. .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_max_vfs_of_pf .. _doxid-group__tapi__conf__pci_1ga4580a429cdcfc9778877e631dfcd8197: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_max_vfs_of_pf(const char* pf_oid, unsigned int* n_vfs) Get maximum possible number of VFs by a PCI PF object identifier. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pf_oid - PF OID in string representation * - n_vfs - Number of discovered VFs (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_vfs_of_pf .. _doxid-group__tapi__conf__pci_1ga0f13c6626e74cc532dfd4ecedd052a86: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_vfs_of_pf(const char* pf_oid, bool pci_device, unsigned int* n_pci_vfs, :ref:`cfg_oid`*** pci_vfs, unsigned int** pci_vf_ids) Get VFs by a PCI PF object identifier. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pf_oid - PF OID in string representation * - pci_device - ``true`` - get PCI device OID (/agent/hardware/pci/device), ``false`` - get PCI instance OID (/agent/hardware/pci/vendor/device/instance) * - n_pci_vfs - Number of discovered VFs (must not be ``NULL``) * - pci_vfs - VF object identifiers (may be ``NULL`` to ignore) * - pci_vf_ids - Indices of the VFs (may be ``NULL`` to ignore) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_enable_vfs_of_pf .. _doxid-group__tapi__conf__pci_1gaeadb04fbea99c8935f145250cbad8830: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_enable_vfs_of_pf(const char* pf_oid, unsigned int n_vfs) Set number of VFs by a PCI PF object identifier. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pf_oid - PF OID in string representation * - n_vfs - Requested number of VFs .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_addr_by_oid .. _doxid-group__tapi__conf__pci_1ga00f13e859cfb149cb8a9000a1d5e9bd8: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_addr_by_oid(const :ref:`cfg_oid`* pci_device, char** pci_addr) Get PCI address (BDF notation) by PCI device OID (/agent/hardware/pci/device) .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_device - PCI device * - pci_addr - PCI address (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_addr_by_oid_array .. _doxid-group__tapi__conf__pci_1ga887c9c32d218037112d4d54ec9073d78: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_addr_by_oid_array(unsigned int n_devices, const :ref:`cfg_oid`** pci_devices, char*** pci_addrs) Call :ref:`tapi_cfg_pci_addr_by_oid() ` on an array of PCI device OIDs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - n_devices - Number of PCI devices * - pci_devices - PCI device OIDs * - pci_addrs - PCI addresses (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_rsrc_name .. _doxid-group__tapi__conf__pci_1gad285733aae6a9f8326ee74473b532822: .. ref-code-block:: cpp :class: doxyrest-title-code-block char* tapi_cfg_pci_rsrc_name(const :ref:`cfg_oid`* pci_instance) Allocate a string with resource name for grabbing a PCI instance. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_instance - PCI instance OID (/agent/hardware/pci/vendor/device/instance) .. rubric:: Returns: Allocated resource name string .. index:: pair: function; tapi_cfg_pci_fn_netdev_rsrc_name .. _doxid-group__tapi__conf__pci_1ga39becf98453e7cbde248303de38460ee: .. ref-code-block:: cpp :class: doxyrest-title-code-block char* tapi_cfg_pci_fn_netdev_rsrc_name(const :ref:`cfg_oid`* oid) Allocate a string with resource name for grabbing a PCI instance with netdev. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_instance - PCI instance OID (/agent/hardware/pci/vendor/device/instance/netdev) .. rubric:: Returns: Allocated resource name string .. index:: pair: function; tapi_cfg_pci_grab .. _doxid-group__tapi__conf__pci_1ga1f383ad2d3336abf11be8c84b8074a3c: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_grab(const :ref:`cfg_oid`* pci_instance) Grab a PCI device as a resource. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_instance - PCI instance OID (/agent/hardware/pci/vendor/device/instance) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_oid_by_addr .. _doxid-group__tapi__conf__pci_1ga0a49774c3f5c1efdfb5ec2fc3f91379c: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_oid_by_addr(const char* ta, const char* pci_addr, char** pci_oid) Get PCI device OID by the PCI address .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - pci_addr - PCI device address (BDF notation) * - pci_oid - PCI device OID (/agent/hardware/pci/device) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_instance_by_addr .. _doxid-group__tapi__conf__pci_1ga8d578db17b8b26ef45e631e0c6e75e9f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_instance_by_addr(const char* ta, const char* pci_addr, char** pci_inst) Get PCI instance OID (used in network model resources) by PCI address. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - test agent name * - pci_addr - PCI device address (BDF notation) * - pci_inst - location for PCI instance OID .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_ta_driver .. _doxid-group__tapi__conf__pci_1gabf4849dae2dc05dca96948bb1326c05a: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_ta_driver(const char* ta, enum :ref:`tapi_cfg_driver_type` type, char** driver) Get PCI device driver assigned to a Test Agent .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - type - Driver type * - driver - Driver name (on success, if no driver is assigned, the pointed data becomes ``NULL``). The argument itself must not be ``NULL``. .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_devices .. _doxid-group__tapi__conf__pci_1ga00e42dfbd0ee756ca66205aac06f5c93: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_devices(const char* pci_oid, unsigned int* count, char*** device_names) Get character or block devices names list of a PCI device .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - count - Count of ``device_names`` * - device_names - Character or block devices names .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_driver .. _doxid-group__tapi__conf__pci_1ga1f44ac3b84f56af9b3c125e28cb3bca1: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_driver(const char* pci_oid, char** driver) Get driver of a PCI device .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device or /agent/hardware/pci/vendor/device/instance) * - driver - Driver name (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_bind_driver .. _doxid-group__tapi__conf__pci_1ga1866042166fb8beaa64a450c3e58847e: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_bind_driver(const char* pci_oid, const char* driver) Bind driver to a PCI device .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device or /agent/hardware/pci/vendor/device/instance) * - driver - Driver name .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_bind_ta_driver_on_device .. _doxid-group__tapi__conf__pci_1ga87845029b812ab2611035f20947e9466: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_bind_ta_driver_on_device(const char* ta, enum :ref:`tapi_cfg_driver_type` type, const char* pci_addr) Bind driver associated with a Test Agent on a PCI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - type - Driver type * - pci_addr - PCI address of the device to which the driver will be bound .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_fn_netdev_get_net_if .. _doxid-group__tapi__conf__pci_1gae7b10fd7a60bed92ad2d50a98bbad01a: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_fn_netdev_get_net_if(const char* pci_fn_oid, const char* netdev, char** interface) Get the network interface associated with a PCI device with port. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_fn_oid - PCI device OID (/agent/hardware/pci/device/net) * - netdev - Port (net) instance name * - interface - Network interface name (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_net_if .. _doxid-group__tapi__conf__pci_1gad93257815a60253011e4b7297e7988a7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_net_if(const char* pci_oid, char** interface) Get the first network interface associated with a PCI device. In theory, more than one interface can be associated, in that case the function produces a warning. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - interface - Network interface name (must not be ``NULL``) .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_oid_by_net_if .. _doxid-group__tapi__conf__pci_1ga52142fa92d86fd77bc6136691c313f63: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_oid_by_net_if(const char* ta, const char* if_name, char** pci_oid) Find out PCI device for a given network interface. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - if_name - Interface name * - pci_oid - Where to save pointer to OID of PCI device (should be released by caller) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_numa_node .. _doxid-group__tapi__conf__pci_1ga6d4ae9ed673dd8b8e367deb94d46a1b3: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_numa_node(const char* pci_oid, char** numa_node) Get assigned NUMA node of a PCI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - numa_node - OID (/agent/hardware/node) of a NUMA node where the device is local. Returns empty value if NUMA node is not assigned. .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_numa_node_id .. _doxid-group__tapi__conf__pci_1ga2c1b04685620f6c30bf297a2db20cc44: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_numa_node_id(const char* pci_oid, int* numa_node) Get assigned NUMA node of a PCI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - numa_node - Index of a NUMA node assigned to a PCI device. Returns ``-1`` if NUMA node is not assigned. .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_bind_driver_by_vend_dev_inst .. _doxid-group__tapi__conf__pci_1gabb65e27ec05acc9f561fdc4d2e5de017: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_bind_driver_by_vend_dev_inst(const char* ta, const char* vendor, const char* device, unsigned int instance, const char* driver) Wrapper for **tapi_cfg_pci_bind_driver** to binding a driver by vendor, device and instance. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - vendor - Vendor identifier * - device - Device identifier * - instance - Index of a PCI device with specified vendir/device IDs * - driver - Driver to bind .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_unbind_driver_by_vend_dev_inst .. _doxid-group__tapi__conf__pci_1ga49d3bd76735bdf0129d8594bd0e199f7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_unbind_driver_by_vend_dev_inst(const char* ta, const char* vendor, const char* device, unsigned int instance) Wrapper for **tapi_cfg_pci_bind_driver** to unbinding a driver by vendor, device and instance. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - vendor - Vendor identifier * - device - Device identifier * - instance - Index of a PCI device with specified vendir/device IDs .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_driver_by_vend_dev_inst .. _doxid-group__tapi__conf__pci_1gacecf59f35f37d70a8e9c865d1dfd9746: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_driver_by_vend_dev_inst(const char* ta, const char* vendor, const char* device, unsigned int instance, char** driver) Wrapper for **tapi_cfg_pci_get_driver** to getiing a driver by vendor, device and instance. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta - Test Agent name * - vendor - Vendor identifier * - device - Device identifier * - instance - Index of a PCI device with specified vendir/device IDs * - driver - Driver .. rubric:: Returns: Status code .. index:: pair: function; tapi_cfg_pci_get_serialno .. _doxid-group__tapi__conf__pci_1gaef56ae0a0f43ce5c489a2ade7bb7b4b7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_serialno(const char* pci_oid, char** serialno) Get PCI serial number. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - serialno - Where to save PCI serial number (should be released by the caller) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_class .. _doxid-group__tapi__conf__pci_1gae5dc84f3a2a835b180ea0b909a5bb203: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_class(const char* pci_oid, unsigned int* class_id, unsigned int* subclass_id, unsigned int* intf_id) Get PCI class, subclass and prog. interface of a device. All output parameters may be passed ``NULL``, then they are ignored. The output parameters are all ``unsigned``, not the corresponding enum types, because the enums above may not be exhaustive the caller must be prepared to deal with unlisted values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID or instance OID (/agent/hardware/pci/device or /agent/hardware/pci/vendor/device/instance, see :ref:`tapi_cfg_pci_resolve_device_oid() `) * - class_id - Class ID (see tapi_cfg_pci_class) * - subclass_id - Subclass ID (see tapi_cfg_pci_subclass) * - intf_id - Prog. interface ID (see tapi_cfg_pci_prog_interface) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_param_is_present .. _doxid-group__tapi__conf__pci_1gaefcfef33ebee367d228bf4b14cb60c88: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_param_is_present(const char* pci_oid, const char* param_name, bool* present) Check whether device parameter is present. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - param_name - Parameter name * - present - Will be set to ``true`` if device parameter is present, to ``false`` otherwise .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_param_str .. _doxid-group__tapi__conf__pci_1ga4354a537769584b0a60c8390ac3e2b9f: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_param_str(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, char** value) Get device parameter value of string type. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - param_name - Parameter name * - cmode - Configuration mode of the value of interest * - value - Where to save obtained value (should be released by the caller) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_param_uint .. _doxid-group__tapi__conf__pci_1gaeebfadcc965e223f48856462d76862eb: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_param_uint(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, uint64_t* value) Get device parameter value of unsigned integer type (this includes u8, u16, u32, u64 and flag parameters). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - param_name - Parameter name * - cmode - Configuration mode of the value of interest * - value - Where to save obtained value .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_set_param_str .. _doxid-group__tapi__conf__pci_1ga004b17ca6270d133e8c7d974dfd6687e: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_set_param_str(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, const char* value) Set device parameter value of string type. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - param_name - Parameter name * - cmode - Configuration mode of the value of interest * - value - Value to set .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_set_param_uint .. _doxid-group__tapi__conf__pci_1ga3a255fc4f37a3673ee1d467e05bb7e27: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_set_param_uint(const char* pci_oid, const char* param_name, :ref:`tapi_cfg_pci_param_cmode` cmode, uint64_t value) Set device parameter value of unsigned integer type (can be used for any unsigned integer type, including flag type, it will fail if provided value is too big for the actual parameter type). .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device) * - param_name - Parameter name * - cmode - Configuration mode of the value of interest * - value - Value to set .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_vendor_dev_ids .. _doxid-group__tapi__conf__pci_1gafb1443cd4a23fbe0bf06ae00eba1e680: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_vendor_dev_ids(const char* pci_oid, unsigned int* vendor_id, unsigned int* device_id, unsigned int* subsystem_vendor_id, unsigned int* subsystem_device_id) Get vendor/device IDs of PCI device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID * - vendor_id - Where to save vendor ID (may be ``NULL``) * - device_id - Where to save device ID (may be ``NULL``) * - subsystem_vendor_id - Where to save subsystem vendor ID (may be ``NULL``) * - subsystem_device_id - Where to save subsystem device ID (may be ``NULL``) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_cfg_pci_get_spdk_config_filename .. _doxid-group__tapi__conf__pci_1ga41582fa26f336815081b13d369809f52: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_cfg_pci_get_spdk_config_filename(const char* pci_oid, const char* cfg_name, bool create, char** filename) Get the name of a SPDK JSON config file associated with the device. The PCI OID must refer to a NVME device. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pci_oid - PCI device OID (/agent/hardware/pci/device or /agent/hardware/pci/vendor/device/instance) * - cfg_name - SPDK configuration name * - create - if ``true``, create the requested configuration * - filename - JSON file name (at the agent) * - TE_ENOTBLK - The device is not NVME. * - TE_ENOENT - The configuration or the device do not exist. * - TE_EEXIST - The configuration already exists (if ``create`` is ``true``). .. rubric:: Returns: status code