DPDK  23.07.0
Data Structures | Macros | Typedefs | Enumerations | Functions
rte_dev.h File Reference
#include <stdio.h>
#include <rte_config.h>
#include <rte_common.h>
#include <rte_compat.h>
#include <rte_log.h>

Go to the source code of this file.

Data Structures

struct  rte_mem_resource
 
struct  rte_dev_iterator
 

Macros

#define RTE_PMD_REGISTER_KMOD_DEP(name, str)
 

Typedefs

typedef int(* rte_dev_cmp_t) (const struct rte_device *dev, const void *data)
 
typedef void *(* rte_dev_iterate_t) (const void *start, const char *devstr, const struct rte_dev_iterator *it)
 

Enumerations

enum  rte_dev_event_type { RTE_DEV_EVENT_ADD, RTE_DEV_EVENT_REMOVE, RTE_DEV_EVENT_MAX }
 
enum  rte_dev_policy
 

Functions

const char * rte_driver_name (const struct rte_driver *driver)
 
const struct rte_bus * rte_dev_bus (const struct rte_device *dev)
 
const char * rte_dev_bus_info (const struct rte_device *dev)
 
const struct rte_devargsrte_dev_devargs (const struct rte_device *dev)
 
const struct rte_driver * rte_dev_driver (const struct rte_device *dev)
 
const char * rte_dev_name (const struct rte_device *dev)
 
int rte_dev_numa_node (const struct rte_device *dev)
 
int rte_dev_is_probed (const struct rte_device *dev)
 
int rte_eal_hotplug_add (const char *busname, const char *devname, const char *drvargs)
 
int rte_dev_probe (const char *devargs)
 
int rte_eal_hotplug_remove (const char *busname, const char *devname)
 
int rte_dev_remove (struct rte_device *dev)
 
__rte_experimental int rte_dev_iterator_init (struct rte_dev_iterator *it, const char *str)
 
__rte_experimental struct rte_device * rte_dev_iterator_next (struct rte_dev_iterator *it)
 
__rte_experimental int rte_dev_event_callback_register (const char *device_name, rte_dev_event_cb_fn cb_fn, void *cb_arg)
 
__rte_experimental int rte_dev_event_callback_unregister (const char *device_name, rte_dev_event_cb_fn cb_fn, void *cb_arg)
 
__rte_experimental void rte_dev_event_callback_process (const char *device_name, enum rte_dev_event_type event)
 
__rte_experimental int rte_dev_event_monitor_start (void)
 
__rte_experimental int rte_dev_event_monitor_stop (void)
 
__rte_experimental int rte_dev_hotplug_handle_enable (void)
 
__rte_experimental int rte_dev_hotplug_handle_disable (void)
 
__rte_experimental int rte_dev_dma_map (struct rte_device *dev, void *addr, uint64_t iova, size_t len)
 
__rte_experimental int rte_dev_dma_unmap (struct rte_device *dev, void *addr, uint64_t iova, size_t len)
 

Detailed Description

RTE PMD Registration Interface

This file manages the list of device drivers.

Definition in file rte_dev.h.

Macro Definition Documentation

◆ RTE_PMD_REGISTER_KMOD_DEP

#define RTE_PMD_REGISTER_KMOD_DEP (   name,
  str 
)
Value:
static const char DRV_EXP_TAG(name, kmod_dep_export)[] \
__rte_used = str

Advertise the list of kernel modules required to run this driver

This string lists the kernel modules required for the devices associated to a PMD. The format of each line of the string is: "<device-pattern> <kmod-expression>".

The possible formats for the device pattern are: "*" all devices supported by this driver "pci:*" all PCI devices supported by this driver "pci:v8086:d*:sv*:sd*" all PCI devices supported by this driver whose vendor id is 0x8086.

The format of the kernel modules list is a parenthesized expression containing logical-and (&) and logical-or (|).

The device pattern and the kmod expression are separated by a space.

Example:

  • "* igb_uio | uio_pci_generic | vfio"

Definition at line 286 of file rte_dev.h.

Typedef Documentation

◆ rte_dev_cmp_t

typedef int(* rte_dev_cmp_t) (const struct rte_device *dev, const void *data)

Device comparison function.

This type of function is used to compare an rte_device with arbitrary data.

Parameters
devDevice handle.
dataData to compare against. The type of this parameter is determined by the kind of comparison performed by the function.
Returns
0 if the device matches the data. !0 if the device does not match. <0 if ordering is possible and the device is lower than the data. >0 if ordering is possible and the device is greater than the data.

Definition at line 247 of file rte_dev.h.

◆ rte_dev_iterate_t

typedef void*(* rte_dev_iterate_t) (const void *start, const char *devstr, const struct rte_dev_iterator *it)

Device iteration function.

Find the next device matching properties passed in parameters. The function takes an additional start parameter, that is used as starting context when relevant.

The function returns the current element in the iteration. This return value will potentially be used as a start parameter in subsequent calls to the function.

The additional iterator parameter is only there if a specific implementation needs additional context. It must not be modified by the iteration function itself.

Parameters
startStarting iteration context.
devstrDevice description string.
itDevice iterator.
Returns
The address of the current element matching the device description string.

Definition at line 333 of file rte_dev.h.

Enumeration Type Documentation

◆ rte_dev_event_type

The device event type.

Enumerator
RTE_DEV_EVENT_ADD 

device being added

RTE_DEV_EVENT_REMOVE 

device being removed

RTE_DEV_EVENT_MAX 

max value of this enum

Definition at line 35 of file rte_dev.h.

◆ rte_dev_policy

Device policies.

Definition at line 61 of file rte_dev.h.

Function Documentation

◆ rte_driver_name()

const char* rte_driver_name ( const struct rte_driver *  driver)

Retrieve a driver name.

Parameters
driverA pointer to a driver structure.
Returns
A pointer to the driver name string.

◆ rte_dev_bus()

const struct rte_bus* rte_dev_bus ( const struct rte_device *  dev)

Retrieve a device bus.

Parameters
devA pointer to a device structure.
Returns
A pointer to this device bus.

◆ rte_dev_bus_info()

const char* rte_dev_bus_info ( const struct rte_device *  dev)

Retrieve bus specific information for a device.

Parameters
devA pointer to a device structure.
Returns
A string describing this device or NULL if none is available.

◆ rte_dev_devargs()

const struct rte_devargs* rte_dev_devargs ( const struct rte_device *  dev)

Retrieve a device arguments.

Parameters
devA pointer to a device structure.
Returns
A pointer to this device devargs.

◆ rte_dev_driver()

const struct rte_driver* rte_dev_driver ( const struct rte_device *  dev)

Retrieve a device driver.

Parameters
devA pointer to a device structure.
Returns
A pointer to this device driver.

◆ rte_dev_name()

const char* rte_dev_name ( const struct rte_device *  dev)

Retrieve a device name.

Parameters
devA pointer to a device structure.
Returns
A pointer to this device name.
Examples:
examples/ethtool/lib/rte_ethtool.c, examples/l3fwd/l3fwd_em.c, examples/l3fwd/l3fwd_fib.c, examples/l3fwd/l3fwd_lpm.c, and examples/vdpa/main.c.

◆ rte_dev_numa_node()

int rte_dev_numa_node ( const struct rte_device *  dev)

Retrieve a device numa node.

Parameters
devA pointer to a device structure.
Returns
A pointer to this device numa node.

◆ rte_dev_is_probed()

int rte_dev_is_probed ( const struct rte_device *  dev)

Query status of a device.

Parameters
devGeneric device pointer.
Returns
(int)true if already probed successfully, 0 otherwise.

◆ rte_eal_hotplug_add()

int rte_eal_hotplug_add ( const char *  busname,
const char *  devname,
const char *  drvargs 
)

Hotplug add a given device to a specific bus.

In multi-process, it will request other processes to add the same device. A failure, in any process, will rollback the action

Parameters
busnameThe bus name the device is added to.
devnameThe device name. Based on this device name, eal will identify a driver capable of handling it and pass it to the driver probing function.
drvargsDevice arguments to be passed to the driver.
Returns
0 on success, negative on error.
Examples:
examples/multi_process/hotplug_mp/commands.c.

◆ rte_dev_probe()

int rte_dev_probe ( const char *  devargs)

Add matching devices.

In multi-process, it will request other processes to add the same device. A failure, in any process, will rollback the action

Parameters
devargsDevice arguments including bus, class and driver properties.
Returns
0 on success, negative on error.

◆ rte_eal_hotplug_remove()

int rte_eal_hotplug_remove ( const char *  busname,
const char *  devname 
)

Hotplug remove a given device from a specific bus.

In multi-process, it will request other processes to remove the same device. A failure, in any process, will rollback the action

Parameters
busnameThe bus name the device is removed from.
devnameThe device name being removed.
Returns
0 on success, negative on error.
Examples:
examples/multi_process/hotplug_mp/commands.c.

◆ rte_dev_remove()

int rte_dev_remove ( struct rte_device *  dev)

Remove one device.

In multi-process, it will request other processes to remove the same device. A failure, in any process, will rollback the action

Parameters
devData structure of the device to remove.
Returns
0 on success, negative on error.

◆ rte_dev_iterator_init()

__rte_experimental int rte_dev_iterator_init ( struct rte_dev_iterator it,
const char *  str 
)

Initializes a device iterator.

This iterator allows accessing a list of devices matching a criteria. The device matching is made among all buses and classes currently registered, filtered by the device description given as parameter.

This function will not allocate any memory. It is safe to stop the iteration at any moment and let the iterator go out of context.

Parameters
itDevice iterator handle.
strDevice description string.
Returns
0 on successful initialization. <0 on error.

◆ rte_dev_iterator_next()

__rte_experimental struct rte_device* rte_dev_iterator_next ( struct rte_dev_iterator it)

Iterates on a device iterator.

Generates a new rte_device handle corresponding to the next element in the list described in comprehension by the iterator.

The next object is returned, and the iterator is updated.

Parameters
itDevice iterator handle.
Returns
An rte_device handle if found. NULL if an error occurred (rte_errno is set). NULL if no device could be found (rte_errno is not set).

◆ rte_dev_event_callback_register()

__rte_experimental int rte_dev_event_callback_register ( const char *  device_name,
rte_dev_event_cb_fn  cb_fn,
void *  cb_arg 
)
Warning
EXPERIMENTAL: this API may change without prior notice

It registers the callback for the specific device. Multiple callbacks can be registered at the same time.

Parameters
device_nameThe device name, that is the param name of the struct rte_device, null value means for all devices.
cb_fncallback address.
cb_argaddress of parameter for callback.
Returns
  • On success, zero.
  • On failure, a negative value.

◆ rte_dev_event_callback_unregister()

__rte_experimental int rte_dev_event_callback_unregister ( const char *  device_name,
rte_dev_event_cb_fn  cb_fn,
void *  cb_arg 
)
Warning
EXPERIMENTAL: this API may change without prior notice

It unregisters the callback according to the specified device.

Parameters
device_nameThe device name, that is the param name of the struct rte_device, null value means for all devices and their callbacks.
cb_fncallback address.
cb_argaddress of parameter for callback, (void *)-1 means to remove all registered which has the same callback address.
Returns
  • On success, return the number of callback entities removed.
  • On failure, a negative value.

◆ rte_dev_event_callback_process()

__rte_experimental void rte_dev_event_callback_process ( const char *  device_name,
enum rte_dev_event_type  event 
)
Warning
EXPERIMENTAL: this API may change without prior notice

Executes all the user application registered callbacks for the specific device.

Parameters
device_nameThe device name.
eventthe device event type.

◆ rte_dev_event_monitor_start()

__rte_experimental int rte_dev_event_monitor_start ( void  )
Warning
EXPERIMENTAL: this API may change without prior notice

Start the device event monitoring.

Returns
  • On success, zero.
  • On failure, a negative value.

◆ rte_dev_event_monitor_stop()

__rte_experimental int rte_dev_event_monitor_stop ( void  )
Warning
EXPERIMENTAL: this API may change without prior notice

Stop the device event monitoring.

Returns
  • On success, zero.
  • On failure, a negative value.

◆ rte_dev_hotplug_handle_enable()

__rte_experimental int rte_dev_hotplug_handle_enable ( void  )
Warning
EXPERIMENTAL: this API may change without prior notice

Enable hotplug handling for devices.

Returns
  • On success, zero.
  • On failure, a negative value.

◆ rte_dev_hotplug_handle_disable()

__rte_experimental int rte_dev_hotplug_handle_disable ( void  )
Warning
EXPERIMENTAL: this API may change without prior notice

Disable hotplug handling for devices.

Returns
  • On success, zero.
  • On failure, a negative value.

◆ rte_dev_dma_map()

__rte_experimental int rte_dev_dma_map ( struct rte_device *  dev,
void *  addr,
uint64_t  iova,
size_t  len 
)

Device level DMA map function. After a successful call, the memory segment will be mapped to the given device.

Note
: Memory must be registered in advance using rte_extmem_* APIs.
Parameters
devDevice pointer.
addrVirtual address to map.
iovaIOVA address to map.
lenLength of the memory segment being mapped.
Returns
0 if mapping was successful. Negative value and rte_errno is set otherwise.

◆ rte_dev_dma_unmap()

__rte_experimental int rte_dev_dma_unmap ( struct rte_device *  dev,
void *  addr,
uint64_t  iova,
size_t  len 
)

Device level DMA unmap function. After a successful call, the memory segment will no longer be accessible by the given device.

Note
: Memory must be registered in advance using rte_extmem_* APIs.
Parameters
devDevice pointer.
addrVirtual address to unmap.
iovaIOVA address to unmap.
lenLength of the memory segment being mapped.
Returns
0 if un-mapping was successful. Negative value and rte_errno is set otherwise.