DPDK  18.02.2
rte_bbdev.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2017 Intel Corporation
3  */
4 
5 #ifndef _RTE_BBDEV_H_
6 #define _RTE_BBDEV_H_
7 
26 #ifdef __cplusplus
27 extern "C" {
28 #endif
29 
30 #include <stdint.h>
31 #include <stdbool.h>
32 #include <string.h>
33 
34 #include <rte_compat.h>
35 #include <rte_atomic.h>
36 #include <rte_bus.h>
37 #include <rte_cpuflags.h>
38 #include <rte_memory.h>
39 
40 #include "rte_bbdev_op.h"
41 
42 #ifndef RTE_BBDEV_MAX_DEVS
43 #define RTE_BBDEV_MAX_DEVS 128
44 #endif
45 
48  RTE_BBDEV_UNUSED,
49  RTE_BBDEV_INITIALIZED
50 };
51 
58 uint16_t __rte_experimental
59 rte_bbdev_count(void);
60 
70 bool __rte_experimental
71 rte_bbdev_is_valid(uint16_t dev_id);
72 
83 uint16_t __rte_experimental
84 rte_bbdev_find_next(uint16_t dev_id);
85 
87 #define RTE_BBDEV_FOREACH(i) for (i = rte_bbdev_find_next(-1); \
88  i < RTE_BBDEV_MAX_DEVS; \
89  i = rte_bbdev_find_next(i))
90 
112 int __rte_experimental
113 rte_bbdev_setup_queues(uint16_t dev_id, uint16_t num_queues, int socket_id);
114 
129 int __rte_experimental
130 rte_bbdev_intr_enable(uint16_t dev_id);
131 
134  int socket;
135  uint32_t queue_size;
136  uint8_t priority;
139 };
140 
158 int __rte_experimental
159 rte_bbdev_queue_configure(uint16_t dev_id, uint16_t queue_id,
160  const struct rte_bbdev_queue_conf *conf);
161 
173 int __rte_experimental
174 rte_bbdev_start(uint16_t dev_id);
175 
186 int __rte_experimental
187 rte_bbdev_stop(uint16_t dev_id);
188 
199 int __rte_experimental
200 rte_bbdev_close(uint16_t dev_id);
201 
216 int __rte_experimental
217 rte_bbdev_queue_start(uint16_t dev_id, uint16_t queue_id);
218 
231 int __rte_experimental
232 rte_bbdev_queue_stop(uint16_t dev_id, uint16_t queue_id);
233 
236  uint64_t enqueued_count;
237  uint64_t dequeued_count;
242 };
243 
257 int __rte_experimental
258 rte_bbdev_stats_get(uint16_t dev_id, struct rte_bbdev_stats *stats);
259 
268 int __rte_experimental
269 rte_bbdev_stats_reset(uint16_t dev_id);
270 
274  const char *driver_name;
275 
277  unsigned int max_num_queues;
279  uint32_t queue_size_lim;
287  uint16_t min_alignment;
291  const struct rte_bbdev_op_cap *capabilities;
293  const enum rte_cpu_flag_t *cpu_flag_reqs;
294 };
295 
297 #define RTE_BBDEV_END_OF_CAPABILITIES_LIST() \
298  { RTE_BBDEV_OP_NONE }
299 
305  int socket_id;
306  const char *dev_name;
307  const struct rte_bus *bus;
308  uint16_t num_queues;
309  bool started;
311 };
312 
326 int __rte_experimental
327 rte_bbdev_info_get(uint16_t dev_id, struct rte_bbdev_info *dev_info);
328 
334  bool started;
335 };
336 
352 int __rte_experimental
353 rte_bbdev_queue_info_get(uint16_t dev_id, uint16_t queue_id,
354  struct rte_bbdev_queue_info *queue_info);
355 
357 struct rte_bbdev_queue_data {
358  void *queue_private;
359  struct rte_bbdev_queue_conf conf;
360  struct rte_bbdev_stats queue_stats;
361  bool started;
362 };
363 
365 typedef uint16_t (*rte_bbdev_enqueue_enc_ops_t)(
366  struct rte_bbdev_queue_data *q_data,
367  struct rte_bbdev_enc_op **ops,
368  uint16_t num);
369 
371 typedef uint16_t (*rte_bbdev_enqueue_dec_ops_t)(
372  struct rte_bbdev_queue_data *q_data,
373  struct rte_bbdev_dec_op **ops,
374  uint16_t num);
375 
377 typedef uint16_t (*rte_bbdev_dequeue_enc_ops_t)(
378  struct rte_bbdev_queue_data *q_data,
379  struct rte_bbdev_enc_op **ops, uint16_t num);
380 
382 typedef uint16_t (*rte_bbdev_dequeue_dec_ops_t)(
383  struct rte_bbdev_queue_data *q_data,
384  struct rte_bbdev_dec_op **ops, uint16_t num);
385 
386 #define RTE_BBDEV_NAME_MAX_LEN 64
394 struct rte_bbdev_data {
395  char name[RTE_BBDEV_NAME_MAX_LEN];
396  void *dev_private;
397  uint16_t num_queues;
398  struct rte_bbdev_queue_data *queues;
399  uint16_t dev_id;
400  int socket_id;
401  bool started;
403  rte_atomic16_t process_cnt;
404 };
405 
406 /* Forward declarations */
407 struct rte_bbdev_ops;
408 struct rte_bbdev_callback;
409 struct rte_intr_handle;
410 
412 TAILQ_HEAD(rte_bbdev_cb_list, rte_bbdev_callback);
413 
418 struct __rte_cache_aligned rte_bbdev {
420  rte_bbdev_enqueue_enc_ops_t enqueue_enc_ops;
422  rte_bbdev_enqueue_dec_ops_t enqueue_dec_ops;
424  rte_bbdev_dequeue_enc_ops_t dequeue_enc_ops;
426  rte_bbdev_dequeue_dec_ops_t dequeue_dec_ops;
427  const struct rte_bbdev_ops *dev_ops;
428  struct rte_bbdev_data *data;
429  enum rte_bbdev_state state;
430  struct rte_device *device;
432  struct rte_bbdev_cb_list list_cbs;
433  struct rte_intr_handle *intr_handle;
434 };
435 
437 extern struct rte_bbdev rte_bbdev_devices[];
438 
460 static inline uint16_t
461 rte_bbdev_enqueue_enc_ops(uint16_t dev_id, uint16_t queue_id,
462  struct rte_bbdev_enc_op **ops, uint16_t num_ops)
463 {
464  struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
465  struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
466  return dev->enqueue_enc_ops(q_data, ops, num_ops);
467 }
468 
490 static inline uint16_t
491 rte_bbdev_enqueue_dec_ops(uint16_t dev_id, uint16_t queue_id,
492  struct rte_bbdev_dec_op **ops, uint16_t num_ops)
493 {
494  struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
495  struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
496  return dev->enqueue_dec_ops(q_data, ops, num_ops);
497 }
498 
520 static inline uint16_t
521 rte_bbdev_dequeue_enc_ops(uint16_t dev_id, uint16_t queue_id,
522  struct rte_bbdev_enc_op **ops, uint16_t num_ops)
523 {
524  struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
525  struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
526  return dev->dequeue_enc_ops(q_data, ops, num_ops);
527 }
528 
551 static inline uint16_t
552 rte_bbdev_dequeue_dec_ops(uint16_t dev_id, uint16_t queue_id,
553  struct rte_bbdev_dec_op **ops, uint16_t num_ops)
554 {
555  struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
556  struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
557  return dev->dequeue_dec_ops(q_data, ops, num_ops);
558 }
559 
566 };
567 
581 typedef void (*rte_bbdev_cb_fn)(uint16_t dev_id,
582  enum rte_bbdev_event_type event, void *cb_arg,
583  void *ret_param);
584 
602 int __rte_experimental
603 rte_bbdev_callback_register(uint16_t dev_id, enum rte_bbdev_event_type event,
604  rte_bbdev_cb_fn cb_fn, void *cb_arg);
605 
625 int __rte_experimental
626 rte_bbdev_callback_unregister(uint16_t dev_id, enum rte_bbdev_event_type event,
627  rte_bbdev_cb_fn cb_fn, void *cb_arg);
628 
645 int __rte_experimental
646 rte_bbdev_queue_intr_enable(uint16_t dev_id, uint16_t queue_id);
647 
661 int __rte_experimental
662 rte_bbdev_queue_intr_disable(uint16_t dev_id, uint16_t queue_id);
663 
688 int __rte_experimental
689 rte_bbdev_queue_intr_ctl(uint16_t dev_id, uint16_t queue_id, int epfd, int op,
690  void *data);
691 
692 #ifdef __cplusplus
693 }
694 #endif
695 
696 #endif /* _RTE_BBDEV_H_ */