DPDK  18.11.11
rte_cryptodev_pmd.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2015-2016 Intel Corporation.
3  */
4 
5 #ifndef _RTE_CRYPTODEV_PMD_H_
6 #define _RTE_CRYPTODEV_PMD_H_
7 
16 #ifdef __cplusplus
17 extern "C" {
18 #endif
19 
20 #include <string.h>
21 
22 #include <rte_config.h>
23 #include <rte_dev.h>
24 #include <rte_malloc.h>
25 #include <rte_mbuf.h>
26 #include <rte_mempool.h>
27 #include <rte_log.h>
28 #include <rte_common.h>
29 
30 #include "rte_crypto.h"
31 #include "rte_cryptodev.h"
32 
33 
34 #define RTE_CRYPTODEV_PMD_DEFAULT_MAX_NB_QUEUE_PAIRS 8
35 
36 #define RTE_CRYPTODEV_PMD_NAME_ARG ("name")
37 #define RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG ("max_nb_queue_pairs")
38 #define RTE_CRYPTODEV_PMD_SOCKET_ID_ARG ("socket_id")
39 
40 
41 static const char * const cryptodev_pmd_valid_params[] = {
42  RTE_CRYPTODEV_PMD_NAME_ARG,
43  RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG,
44  RTE_CRYPTODEV_PMD_SOCKET_ID_ARG,
45  NULL
46 };
47 
52 struct rte_cryptodev_pmd_init_params {
53  char name[RTE_CRYPTODEV_NAME_MAX_LEN];
54  size_t private_data_size;
55  int socket_id;
56  unsigned int max_nb_queue_pairs;
57 };
58 
61  struct rte_cryptodev *devs;
62  struct rte_cryptodev_data *data[RTE_CRYPTO_MAX_DEVS];
64  uint8_t nb_devs;
65 };
66 
67 /* Cryptodev driver, containing the driver ID */
68 struct cryptodev_driver {
69  TAILQ_ENTRY(cryptodev_driver) next;
70  const struct rte_driver *driver;
71  uint8_t id;
72 };
73 
83 struct rte_cryptodev *
84 rte_cryptodev_pmd_get_dev(uint8_t dev_id);
85 
94 struct rte_cryptodev *
95 rte_cryptodev_pmd_get_named_dev(const char *name);
96 
105 unsigned int
106 rte_cryptodev_pmd_is_valid_dev(uint8_t dev_id);
107 
111 extern struct rte_cryptodev *rte_cryptodevs;
112 
113 
128 typedef int (*cryptodev_configure_t)(struct rte_cryptodev *dev,
129  struct rte_cryptodev_config *config);
130 
138 typedef int (*cryptodev_start_t)(struct rte_cryptodev *dev);
139 
145 typedef void (*cryptodev_stop_t)(struct rte_cryptodev *dev);
146 
155 typedef int (*cryptodev_close_t)(struct rte_cryptodev *dev);
156 
157 
164 typedef void (*cryptodev_stats_get_t)(struct rte_cryptodev *dev,
165  struct rte_cryptodev_stats *stats);
166 
167 
173 typedef void (*cryptodev_stats_reset_t)(struct rte_cryptodev *dev);
174 
175 
181 typedef void (*cryptodev_info_get_t)(struct rte_cryptodev *dev,
182  struct rte_cryptodev_info *dev_info);
183 
195 typedef int (*cryptodev_queue_pair_setup_t)(struct rte_cryptodev *dev,
196  uint16_t qp_id, const struct rte_cryptodev_qp_conf *qp_conf,
197  int socket_id, struct rte_mempool *session_pool);
198 
210  uint16_t qp_id);
211 
219 typedef uint32_t (*cryptodev_queue_pair_count_t)(struct rte_cryptodev *dev);
220 
234  struct rte_cryptodev *dev, unsigned nb_objs,
235  unsigned obj_cache_size, int socket_id);
236 
237 
248  struct rte_cryptodev *dev);
259  struct rte_cryptodev *dev);
260 
276  struct rte_crypto_sym_xform *xform,
277  struct rte_cryptodev_sym_session *session,
278  struct rte_mempool *mp);
294  struct rte_crypto_asym_xform *xform,
295  struct rte_cryptodev_asym_session *session,
296  struct rte_mempool *mp);
303 typedef void (*cryptodev_sym_free_session_t)(struct rte_cryptodev *dev,
304  struct rte_cryptodev_sym_session *sess);
311 typedef void (*cryptodev_asym_free_session_t)(struct rte_cryptodev *dev,
312  struct rte_cryptodev_asym_session *sess);
313 
347 };
348 
349 
361 struct rte_cryptodev *
362 rte_cryptodev_pmd_allocate(const char *name, int socket_id);
363 
374 extern int
376 
377 
395 int
396 rte_cryptodev_pmd_parse_input_args(
397  struct rte_cryptodev_pmd_init_params *params,
398  const char *args);
399 
414 struct rte_cryptodev *
415 rte_cryptodev_pmd_create(const char *name,
416  struct rte_device *device,
417  struct rte_cryptodev_pmd_init_params *params);
418 
431 int
432 rte_cryptodev_pmd_destroy(struct rte_cryptodev *cryptodev);
433 
445  enum rte_cryptodev_event_type event);
446 
451 int
452 rte_cryptodev_pmd_create_dev_name(char *name, const char *dev_name_prefix);
453 
466 uint8_t rte_cryptodev_allocate_driver(struct cryptodev_driver *crypto_drv,
467  const struct rte_driver *drv);
468 
469 
470 #define RTE_PMD_REGISTER_CRYPTO_DRIVER(crypto_drv, drv, driver_id)\
471 RTE_INIT(init_ ##driver_id)\
472 {\
473  driver_id = rte_cryptodev_allocate_driver(&crypto_drv, &(drv));\
474 }
475 
476 static inline void *
477 get_sym_session_private_data(const struct rte_cryptodev_sym_session *sess,
478  uint8_t driver_id) {
479  return sess->sess_private_data[driver_id];
480 }
481 
482 static inline void
483 set_sym_session_private_data(struct rte_cryptodev_sym_session *sess,
484  uint8_t driver_id, void *private_data)
485 {
486  sess->sess_private_data[driver_id] = private_data;
487 }
488 
489 static inline void *
490 get_asym_session_private_data(const struct rte_cryptodev_asym_session *sess,
491  uint8_t driver_id) {
492  return sess->sess_private_data[driver_id];
493 }
494 
495 static inline void
496 set_asym_session_private_data(struct rte_cryptodev_asym_session *sess,
497  uint8_t driver_id, void *private_data)
498 {
499  sess->sess_private_data[driver_id] = private_data;
500 }
501 
502 #ifdef __cplusplus
503 }
504 #endif
505 
506 #endif /* _RTE_CRYPTODEV_PMD_H_ */
void(* cryptodev_stop_t)(struct rte_cryptodev *dev)
__extension__ void * sess_private_data[0]
void(* cryptodev_info_get_t)(struct rte_cryptodev *dev, struct rte_cryptodev_info *dev_info)
int(* cryptodev_queue_pair_setup_t)(struct rte_cryptodev *dev, uint16_t qp_id, const struct rte_cryptodev_qp_conf *qp_conf, int socket_id, struct rte_mempool *session_pool)
cryptodev_close_t dev_close
unsigned int(* cryptodev_asym_get_session_private_size_t)(struct rte_cryptodev *dev)
int rte_cryptodev_pmd_release_device(struct rte_cryptodev *cryptodev)
struct rte_cryptodev_data * data[RTE_CRYPTO_MAX_DEVS]
void(* cryptodev_asym_free_session_t)(struct rte_cryptodev *dev, struct rte_cryptodev_asym_session *sess)
cryptodev_stop_t dev_stop
cryptodev_asym_get_session_private_size_t asym_session_get_size
struct rte_cryptodev * devs
cryptodev_sym_get_session_private_size_t sym_session_get_size
uint32_t(* cryptodev_queue_pair_count_t)(struct rte_cryptodev *dev)
int(* cryptodev_sym_configure_session_t)(struct rte_cryptodev *dev, struct rte_crypto_sym_xform *xform, struct rte_cryptodev_sym_session *session, struct rte_mempool *mp)
uint8_t driver_id
cryptodev_sym_configure_session_t sym_session_configure
__extension__ void * sess_private_data[0]
struct rte_cryptodev * rte_cryptodev_pmd_get_named_dev(const char *name)
#define RTE_CRYPTODEV_NAME_MAX_LEN
cryptodev_sym_free_session_t sym_session_clear
struct rte_cryptodev * rte_cryptodev_pmd_get_dev(uint8_t dev_id)
unsigned(* cryptodev_sym_get_session_private_size_t)(struct rte_cryptodev *dev)
cryptodev_queue_pair_count_t queue_pair_count
struct rte_cryptodev * rte_cryptodev_pmd_allocate(const char *name, int socket_id)
int(* cryptodev_configure_t)(struct rte_cryptodev *dev, struct rte_cryptodev_config *config)
void rte_cryptodev_pmd_callback_process(struct rte_cryptodev *dev, enum rte_cryptodev_event_type event)
unsigned int rte_cryptodev_pmd_is_valid_dev(uint8_t dev_id)
int(* cryptodev_queue_pair_release_t)(struct rte_cryptodev *dev, uint16_t qp_id)
cryptodev_stats_get_t stats_get
cryptodev_asym_configure_session_t asym_session_configure
int(* cryptodev_sym_create_session_pool_t)(struct rte_cryptodev *dev, unsigned nb_objs, unsigned obj_cache_size, int socket_id)
cryptodev_configure_t dev_configure
void(* cryptodev_stats_reset_t)(struct rte_cryptodev *dev)
cryptodev_info_get_t dev_infos_get
cryptodev_start_t dev_start
int(* cryptodev_close_t)(struct rte_cryptodev *dev)
struct rte_device * device
cryptodev_stats_reset_t stats_reset
rte_cryptodev_event_type
cryptodev_queue_pair_setup_t queue_pair_setup
void(* cryptodev_stats_get_t)(struct rte_cryptodev *dev, struct rte_cryptodev_stats *stats)
void(* cryptodev_sym_free_session_t)(struct rte_cryptodev *dev, struct rte_cryptodev_sym_session *sess)
cryptodev_queue_pair_release_t queue_pair_release
int(* cryptodev_asym_configure_session_t)(struct rte_cryptodev *dev, struct rte_crypto_asym_xform *xform, struct rte_cryptodev_asym_session *session, struct rte_mempool *mp)
cryptodev_asym_free_session_t asym_session_clear
struct rte_cryptodev * rte_cryptodevs
int(* cryptodev_start_t)(struct rte_cryptodev *dev)