DPDK
1.8.0
|
Data Structures | |
struct | rte_kni_ops |
struct | rte_kni_conf |
Functions | |
void | rte_kni_init (unsigned int max_kni_ifaces) |
struct rte_kni * | rte_kni_alloc (struct rte_mempool *pktmbuf_pool, const struct rte_kni_conf *conf, struct rte_kni_ops *ops) |
struct rte_kni * | rte_kni_create (uint8_t port_id, unsigned mbuf_size, struct rte_mempool *pktmbuf_pool, struct rte_kni_ops *ops) |
int | rte_kni_release (struct rte_kni *kni) |
int | rte_kni_handle_request (struct rte_kni *kni) |
unsigned | rte_kni_rx_burst (struct rte_kni *kni, struct rte_mbuf **mbufs, unsigned num) |
unsigned | rte_kni_tx_burst (struct rte_kni *kni, struct rte_mbuf **mbufs, unsigned num) |
uint8_t | rte_kni_get_port_id (struct rte_kni *kni) |
struct rte_kni * | rte_kni_get (const char *name) |
struct rte_kni * | rte_kni_info_get (uint8_t port_id) |
int | rte_kni_register_handlers (struct rte_kni *kni, struct rte_kni_ops *ops) |
int | rte_kni_unregister_handlers (struct rte_kni *kni) |
void | rte_kni_close (void) |
RTE KNI
The KNI library provides the ability to create and destroy kernel NIC interfaces that may be used by the RTE application to receive/transmit packets from/to Linux kernel net interfaces.
This library provide two APIs to burst receive packets from KNI interfaces, and burst transmit packets to KNI interfaces.
|
read |
Allocate KNI interface according to the port id, mbuf size, mbuf pool, configurations and callbacks for kernel requests.The KNI interface created in the kernel space is the net interface the traditional Linux application talking to.
The rte_kni_alloc shall not be called before rte_kni_init() has been called. rte_kni_alloc is thread safe.
pktmbuf_pool | The mempool for allocting mbufs for packets. |
conf | The pointer to the configurations of the KNI device. |
ops | The pointer to the callbacks for the KNI kernel requests. |
void rte_kni_close | ( | void | ) |
close KNI device.
void |
|
read |
It create a KNI device for specific port.
Note: It is deprecated and just for backward compatibility.
port_id | Port ID. |
mbuf_size | mbuf size. |
pktmbuf_pool | The mempool for allocting mbufs for packets. |
ops | The pointer to the callbacks for the KNI kernel requests. |
|
read |
Get the KNI context of its name.
name | pointer to the KNI device name. |
uint8_t rte_kni_get_port_id | ( | struct rte_kni * | kni | ) |
Get the port id from KNI interface.
Note: It is deprecated and just for backward compatibility.
kni | The KNI interface context. |
int rte_kni_handle_request | ( | struct rte_kni * | kni | ) |
It is used to handle the request mbufs sent from kernel space. Then analyzes it and calls the specific actions for the specific requests. Finally constructs the response mbuf and puts it back to the resp_q.
kni | The pointer to the context of an existent KNI interface. |
|
read |
Get the KNI context of the specific port.
Note: It is deprecated and just for backward compatibility.
port_id | the port id. |
void rte_kni_init | ( | unsigned int | max_kni_ifaces | ) |
Initialize and preallocate KNI subsystem
This function is to be executed on the MASTER lcore only, after EAL initialization and before any KNI interface is attempted to be allocated
max_kni_ifaces | The maximum number of KNI interfaces that can coexist concurrently |
int rte_kni_register_handlers | ( | struct rte_kni * | kni, |
struct rte_kni_ops * | ops | ||
) |
Register KNI request handling for a specified port,and it can be called by master process or slave process.
kni | pointer to struct rte_kni. |
ops | ponter to struct rte_kni_ops. |
int rte_kni_release | ( | struct rte_kni * | kni | ) |
Release KNI interface according to the context. It will also release the paired KNI interface in kernel space. All processing on the specific KNI context need to be stopped before calling this interface.
rte_kni_release is thread safe.
kni | The pointer to the context of an existent KNI interface. |
unsigned rte_kni_rx_burst | ( | struct rte_kni * | kni, |
struct rte_mbuf ** | mbufs, | ||
unsigned | num | ||
) |
Retrieve a burst of packets from a KNI interface. The retrieved packets are stored in rte_mbuf structures whose pointers are supplied in the array of mbufs, and the maximum number is indicated by num. It handles the freeing of the mbufs in the free queue of KNI interface.
kni | The KNI interface context. |
mbufs | The array to store the pointers of mbufs. |
num | The maximum number per burst. |
unsigned rte_kni_tx_burst | ( | struct rte_kni * | kni, |
struct rte_mbuf ** | mbufs, | ||
unsigned | num | ||
) |
Send a burst of packets to a KNI interface. The packets to be sent out are stored in rte_mbuf structures whose pointers are supplied in the array of mbufs, and the maximum number is indicated by num. It handles allocating the mbufs for KNI interface alloc queue.
kni | The KNI interface context. |
mbufs | The array to store the pointers of mbufs. |
num | The maximum number per burst. |
int rte_kni_unregister_handlers | ( | struct rte_kni * | kni | ) |
Unregister KNI request handling for a specified port.
kni | pointer to struct rte_kni. |