numam-dpdk/lib/vhost/rte_vhost_async.h

197 lines
5.3 KiB
C
Raw Normal View History

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2020 Intel Corporation
*/
#ifndef _RTE_VHOST_ASYNC_H_
#define _RTE_VHOST_ASYNC_H_
#include "rte_vhost.h"
/**
* iovec iterator
*/
struct rte_vhost_iov_iter {
/** offset to the first byte of interesting data */
size_t offset;
/** total bytes of data in this iterator */
size_t count;
/** pointer to the iovec array */
struct iovec *iov;
/** number of iovec in this iterator */
unsigned long nr_segs;
};
/**
* dma transfer descriptor pair
*/
struct rte_vhost_async_desc {
/** source memory iov_iter */
struct rte_vhost_iov_iter *src;
/** destination memory iov_iter */
struct rte_vhost_iov_iter *dst;
};
/**
* dma transfer status
*/
struct rte_vhost_async_status {
/** An array of application specific data for source memory */
uintptr_t *src_opaque_data;
/** An array of application specific data for destination memory */
uintptr_t *dst_opaque_data;
};
/**
* dma operation callbacks to be implemented by applications
*/
struct rte_vhost_async_channel_ops {
/**
* instruct async engines to perform copies for a batch of packets
*
* @param vid
* id of vhost device to perform data copies
* @param queue_id
* queue id to perform data copies
* @param descs
* an array of DMA transfer memory descriptors
* @param opaque_data
* opaque data pair sending to DMA engine
* @param count
* number of elements in the "descs" array
* @return
* number of descs processed
*/
uint32_t (*transfer_data)(int vid, uint16_t queue_id,
struct rte_vhost_async_desc *descs,
struct rte_vhost_async_status *opaque_data,
uint16_t count);
/**
* check copy-completed packets from the async engine
* @param vid
* id of vhost device to check copy completion
* @param queue_id
* queue id to check copy completion
* @param opaque_data
* buffer to receive the opaque data pair from DMA engine
* @param max_packets
* max number of packets could be completed
* @return
* number of async descs completed
*/
uint32_t (*check_completed_copies)(int vid, uint16_t queue_id,
struct rte_vhost_async_status *opaque_data,
uint16_t max_packets);
};
/**
* inflight async packet information
*/
struct async_inflight_info {
struct rte_mbuf *mbuf;
uint16_t descs; /* num of descs inflight */
uint16_t nr_buffers; /* num of buffers inflight for packed ring */
};
/**
* dma channel feature bit definition
*/
struct rte_vhost_async_features {
union {
uint32_t intval;
struct {
uint32_t async_inorder:1;
uint32_t resvd_0:15;
uint32_t async_threshold:12;
uint32_t resvd_1:4;
};
};
};
/**
* register an async channel for vhost
*
* @param vid
* vhost device id async channel to be attached to
* @param queue_id
* vhost queue id async channel to be attached to
* @param features
* DMA channel feature bit
* b0 : DMA supports inorder data transfer
* b1 - b15: reserved
* b16 - b27: Packet length threshold for DMA transfer
* b28 - b31: reserved
* @param ops
* DMA operation callbacks
* @return
* 0 on success, -1 on failures
*/
__rte_experimental
int rte_vhost_async_channel_register(int vid, uint16_t queue_id,
uint32_t features, struct rte_vhost_async_channel_ops *ops);
/**
* unregister a dma channel for vhost
*
* @param vid
* vhost device id DMA channel to be detached
* @param queue_id
* vhost queue id DMA channel to be detached
* @return
* 0 on success, -1 on failures
*/
__rte_experimental
int rte_vhost_async_channel_unregister(int vid, uint16_t queue_id);
/**
* This function submits enqueue data to async engine. Successfully
* enqueued packets can be transfer completed or being occupied by DMA
* engines, when this API returns. Transfer completed packets are returned
* in comp_pkts, so users need to guarantee its size is greater than or
* equal to the size of pkts; for packets that are successfully enqueued
* but not transfer completed, users should poll transfer status by
* rte_vhost_poll_enqueue_completed().
*
* @param vid
* id of vhost device to enqueue data
* @param queue_id
* queue id to enqueue data
* @param pkts
* array of packets to be enqueued
* @param count
* packets num to be enqueued
* @param comp_pkts
* empty array to get transfer completed packets. Users need to
* guarantee its size is greater than or equal to that of pkts
* @param comp_count
* num of packets that are transfer completed, when this API returns.
* If no packets are transfer completed, its value is set to 0.
* @return
* num of packets enqueued, including in-flight and transfer completed
*/
__rte_experimental
uint16_t rte_vhost_submit_enqueue_burst(int vid, uint16_t queue_id,
struct rte_mbuf **pkts, uint16_t count,
struct rte_mbuf **comp_pkts, uint32_t *comp_count);
/**
* This function checks async completion status for a specific vhost
* device queue. Packets which finish copying (enqueue) operation
* will be returned in an array.
*
* @param vid
* id of vhost device to enqueue data
* @param queue_id
* queue id to enqueue data
* @param pkts
* blank array to get return packet pointer
* @param count
* size of the packet array
* @return
* num of packets returned
*/
__rte_experimental
uint16_t rte_vhost_poll_enqueue_completed(int vid, uint16_t queue_id,
struct rte_mbuf **pkts, uint16_t count);
#endif /* _RTE_VHOST_ASYNC_H_ */