32 #ifndef _RTE_CRYPTODEV_H_
33 #define _RTE_CRYPTODEV_H_
56 #define CRYPTODEV_NAME_NULL_PMD ("cryptodev_null_pmd")
58 #define CRYPTODEV_NAME_AESNI_MB_PMD ("cryptodev_aesni_mb_pmd")
60 #define CRYPTODEV_NAME_QAT_PMD ("cryptodev_qat_pmd")
72 #define CDEV_LOG_ERR(fmt, args...) \
73 RTE_LOG(ERR, CRYPTODEV, "%s() line %u: " fmt "\n", \
74 __func__, __LINE__, ## args)
76 #define CDEV_PMD_LOG_ERR(dev, fmt, args...) \
77 RTE_LOG(ERR, CRYPTODEV, "[%s] %s() line %u: " fmt "\n", \
78 dev, __func__, __LINE__, ## args)
80 #ifdef RTE_LIBRTE_CRYPTODEV_DEBUG
81 #define CDEV_LOG_DEBUG(fmt, args...) \
82 RTE_LOG(DEBUG, CRYPTODEV, "%s() line %u: " fmt "\n", \
83 __func__, __LINE__, ## args) \
85 #define CDEV_PMD_TRACE(fmt, args...) \
86 RTE_LOG(DEBUG, CRYPTODEV, "[%s] %s: " fmt "\n", \
87 dev, __func__, ## args)
90 #define CDEV_LOG_DEBUG(fmt, args...)
91 #define CDEV_PMD_TRACE(fmt, args...)
106 #define RTE_CRYPTODEV_DETACHED (0)
107 #define RTE_CRYPTODEV_ATTACHED (1)
133 #ifdef RTE_CRYPTODEV_PERF
138 struct rte_cryptodev_perf_stats {
139 uint64_t t_accumlated;
157 #ifdef RTE_CRYPTODEV_DETAILED_STATS
159 uint64_t encrypt_ops;
160 uint64_t encrypt_bytes;
162 uint64_t decrypt_ops;
163 uint64_t decrypt_bytes;
167 uint64_t generate_ops;
168 uint64_t bytes_hashed;
171 uint64_t bytes_verified;
175 #ifdef RTE_CRYPTODEV_PERF
176 struct rte_cryptodev_perf_stats op_perf;
229 rte_cryptodev_socket_id(uint8_t dev_id);
452 struct rte_cryptodev_callback;
455 TAILQ_HEAD(rte_cryptodev_cb_list, rte_cryptodev_callback);
486 #define RTE_CRYPTODEV_NAME_MAX_LEN (64)
554 static inline uint16_t
556 struct rte_mbuf **pkts, uint16_t nb_pkts)
599 static inline uint16_t
601 struct rte_mbuf **pkts, uint16_t nb_pkts)
631 extern struct rte_cryptodev_session *
647 extern struct rte_cryptodev_session *
649 struct rte_cryptodev_session *session);
void rte_cryptodev_info_get(uint8_t dev_id, struct rte_cryptodev_info *dev_info)
struct rte_pci_device * pci_dev
uint16_t(* dequeue_pkt_burst_t)(void *qp, struct rte_mbuf **pkts, uint16_t nb_pkts)
int rte_cryptodev_queue_pair_setup(uint8_t dev_id, uint16_t queue_pair_id, const struct rte_cryptodev_qp_conf *qp_conf, int socket_id)
int rte_cryptodev_queue_pair_start(uint8_t dev_id, uint16_t queue_pair_id)
TAILQ_HEAD(rte_cryptodev_cb_list, rte_cryptodev_callback)
struct rte_mempool * session_pool
uint64_t dequeue_err_count
struct rte_cryptodev_session * rte_cryptodev_session_create(uint8_t dev_id, struct rte_crypto_xform *xform)
dequeue_pkt_burst_t dequeue_burst
int rte_cryptodev_configure(uint8_t dev_id, struct rte_cryptodev_config *config)
char name[RTE_CRYPTODEV_NAME_MAX_LEN]
int rte_cryptodev_callback_unregister(uint8_t dev_id, enum rte_cryptodev_event_type event, rte_cryptodev_cb_fn cb_fn, void *cb_arg)
void rte_cryptodev_stop(uint8_t dev_id)
int rte_cryptodev_close(uint8_t dev_id)
int rte_cryptodev_callback_register(uint8_t dev_id, enum rte_cryptodev_event_type event, rte_cryptodev_cb_fn cb_fn, void *cb_arg)
static uint16_t rte_cryptodev_enqueue_burst(uint8_t dev_id, uint16_t qp_id, struct rte_mbuf **pkts, uint16_t nb_pkts)
int rte_cryptodev_queue_pair_stop(uint8_t dev_id, uint16_t queue_pair_id)
#define RTE_CRYPTODEV_NAME_MAX_LEN
enqueue_pkt_burst_t enqueue_burst
int rte_cryptodev_stats_get(uint8_t dev_id, struct rte_cryptodev_stats *stats)
struct rte_cryptodev_data * data
struct rte_cryptodev_config::@23 session_mp
struct rte_cryptodev_cb_list link_intr_cbs
void(* rte_cryptodev_cb_fn)(uint8_t dev_id, enum rte_cryptodev_event_type event, void *cb_arg)
enum rte_cryptodev_type dev_type
uint8_t rte_cryptodev_count(void)
struct rte_cryptodev_ops * dev_ops
enum rte_cryptodev_type dev_type
struct rte_cryptodev_session * rte_cryptodev_session_free(uint8_t dev_id, struct rte_cryptodev_session *session)
int rte_cryptodev_start(uint8_t dev_id)
uint64_t enqueue_err_count
uint16_t rte_cryptodev_queue_pair_count(uint8_t dev_id)
uint16_t(* enqueue_pkt_burst_t)(void *qp, struct rte_mbuf **pkts, uint16_t nb_pkts)
struct rte_pci_device * pci_dev
int rte_cryptodev_create_vdev(const char *name, const char *args)
const struct rte_cryptodev_driver * driver
void rte_cryptodev_stats_reset(uint8_t dev_id)
int rte_cryptodev_get_dev_id(const char *name)
unsigned max_nb_queue_pairs
static uint16_t rte_cryptodev_dequeue_burst(uint8_t dev_id, uint16_t qp_id, struct rte_mbuf **pkts, uint16_t nb_pkts)
struct rte_cryptodev * rte_cryptodevs
#define __rte_cache_aligned