DPDK 25.03.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
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
23#include <stdint.h>
24#include <stdbool.h>
25
26#include <rte_compat.h>
27#include <rte_cpuflags.h>
28
29#include "rte_bbdev_op.h"
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
35#include "rte_bbdev_trace_fp.h"
36
37#ifndef RTE_BBDEV_MAX_DEVS
38#define RTE_BBDEV_MAX_DEVS 128
39#endif
40
41/*
42 * Maximum size to be used to manage the enum rte_bbdev_enqueue_status
43 * including padding for future enum insertion.
44 * The enum values must be explicitly kept smaller or equal to this padded maximum size.
45 */
46#define RTE_BBDEV_ENQ_STATUS_SIZE_MAX 6
47
50 RTE_BBDEV_UNUSED,
51 RTE_BBDEV_INITIALIZED
52};
53
60uint16_t
62
72bool
73rte_bbdev_is_valid(uint16_t dev_id);
74
85uint16_t
86rte_bbdev_find_next(uint16_t dev_id);
87
89#define RTE_BBDEV_FOREACH(i) for (i = rte_bbdev_find_next(-1); \
90 i < RTE_BBDEV_MAX_DEVS; \
91 i = rte_bbdev_find_next(i))
92
114int
115rte_bbdev_setup_queues(uint16_t dev_id, uint16_t num_queues, int socket_id);
116
131int
132rte_bbdev_intr_enable(uint16_t dev_id);
133
136 int socket;
137 uint32_t queue_size;
138 uint8_t priority;
141};
142
160int
161rte_bbdev_queue_configure(uint16_t dev_id, uint16_t queue_id,
162 const struct rte_bbdev_queue_conf *conf);
163
175int
176rte_bbdev_start(uint16_t dev_id);
177
188int
189rte_bbdev_stop(uint16_t dev_id);
190
201int
202rte_bbdev_close(uint16_t dev_id);
203
218int
219rte_bbdev_queue_start(uint16_t dev_id, uint16_t queue_id);
220
233int
234rte_bbdev_queue_stop(uint16_t dev_id, uint16_t queue_id);
235
249 /* Note: RTE_BBDEV_ENQ_STATUS_SIZE_MAX must be larger or equal to maximum enum value. */
250};
251
265};
266
269 uint64_t enqueued_count;
270 uint64_t dequeued_count;
280 uint64_t enqueue_status_count[RTE_BBDEV_ENQ_STATUS_SIZE_MAX];
290};
291
305int
306rte_bbdev_stats_get(uint16_t dev_id, struct rte_bbdev_stats *stats);
307
316int
317rte_bbdev_stats_reset(uint16_t dev_id);
318
321/* Structure rte_bbdev_driver_info 8< */
324 const char *driver_name;
325
327 unsigned int max_num_queues;
329 unsigned int num_queues[RTE_BBDEV_OP_TYPE_SIZE_MAX];
331 unsigned int queue_priority[RTE_BBDEV_OP_TYPE_SIZE_MAX];
357 const enum rte_cpu_flag_t *cpu_flag_reqs;
360};
361/* >8 End of structure rte_bbdev_driver_info. */
362
364#define RTE_BBDEV_END_OF_CAPABILITIES_LIST() \
365 { RTE_BBDEV_OP_NONE }
366
372/* Structure rte_bbdev_info 8< */
375 const char *dev_name;
376 const struct rte_device *device;
377 uint16_t num_queues;
378 bool started;
380};
381/* >8 End of structure rte_bbdev_info. */
382
396int
397rte_bbdev_info_get(uint16_t dev_id, struct rte_bbdev_info *dev_info);
398
405};
406
422int
423rte_bbdev_queue_info_get(uint16_t dev_id, uint16_t queue_id,
424 struct rte_bbdev_queue_info *queue_info);
425
427struct rte_bbdev_queue_data {
428 void *queue_private;
429 struct rte_bbdev_queue_conf conf;
430 struct rte_bbdev_stats queue_stats;
431 enum rte_bbdev_enqueue_status enqueue_status;
432 bool started;
433};
434
436typedef uint16_t (*rte_bbdev_enqueue_enc_ops_t)(
437 struct rte_bbdev_queue_data *q_data,
438 struct rte_bbdev_enc_op **ops,
439 uint16_t num);
440
442typedef uint16_t (*rte_bbdev_enqueue_dec_ops_t)(
443 struct rte_bbdev_queue_data *q_data,
444 struct rte_bbdev_dec_op **ops,
445 uint16_t num);
446
448typedef uint16_t (*rte_bbdev_enqueue_fft_ops_t)(
449 struct rte_bbdev_queue_data *q_data,
450 struct rte_bbdev_fft_op **ops,
451 uint16_t num);
452
454typedef uint16_t (*rte_bbdev_enqueue_mldts_ops_t)(
455 struct rte_bbdev_queue_data *q_data,
456 struct rte_bbdev_mldts_op **ops,
457 uint16_t num);
458
460typedef uint16_t (*rte_bbdev_dequeue_enc_ops_t)(
461 struct rte_bbdev_queue_data *q_data,
462 struct rte_bbdev_enc_op **ops, uint16_t num);
463
465typedef uint16_t (*rte_bbdev_dequeue_dec_ops_t)(
466 struct rte_bbdev_queue_data *q_data,
467 struct rte_bbdev_dec_op **ops, uint16_t num);
468
470typedef uint16_t (*rte_bbdev_dequeue_fft_ops_t)(
471 struct rte_bbdev_queue_data *q_data,
472 struct rte_bbdev_fft_op **ops, uint16_t num);
473
475typedef uint16_t (*rte_bbdev_dequeue_mldts_ops_t)(
476 struct rte_bbdev_queue_data *q_data,
477 struct rte_bbdev_mldts_op **ops, uint16_t num);
478
479#define RTE_BBDEV_NAME_MAX_LEN 64
487struct rte_bbdev_data {
488 char name[RTE_BBDEV_NAME_MAX_LEN];
489 void *dev_private;
490 uint16_t num_queues;
491 struct rte_bbdev_queue_data *queues;
492 uint16_t dev_id;
493 int socket_id;
494 bool started;
495 RTE_ATOMIC(uint16_t) process_cnt;
496};
497
498/* Forward declarations */
499struct rte_bbdev_ops;
500struct rte_bbdev_callback;
501struct rte_intr_handle;
502
504RTE_TAILQ_HEAD(rte_bbdev_cb_list, rte_bbdev_callback);
505
510struct __rte_cache_aligned rte_bbdev {
512 rte_bbdev_enqueue_enc_ops_t enqueue_enc_ops;
514 rte_bbdev_enqueue_dec_ops_t enqueue_dec_ops;
516 rte_bbdev_dequeue_enc_ops_t dequeue_enc_ops;
518 rte_bbdev_dequeue_dec_ops_t dequeue_dec_ops;
520 rte_bbdev_enqueue_enc_ops_t enqueue_ldpc_enc_ops;
522 rte_bbdev_enqueue_dec_ops_t enqueue_ldpc_dec_ops;
524 rte_bbdev_dequeue_enc_ops_t dequeue_ldpc_enc_ops;
526 rte_bbdev_dequeue_dec_ops_t dequeue_ldpc_dec_ops;
528 rte_bbdev_enqueue_fft_ops_t enqueue_fft_ops;
530 rte_bbdev_dequeue_fft_ops_t dequeue_fft_ops;
531 const struct rte_bbdev_ops *dev_ops;
532 struct rte_bbdev_data *data;
533 enum rte_bbdev_state state;
534 struct rte_device *device;
536 struct rte_bbdev_cb_list list_cbs;
537 struct rte_intr_handle *intr_handle;
539 rte_bbdev_enqueue_mldts_ops_t enqueue_mldts_ops;
541 rte_bbdev_dequeue_mldts_ops_t dequeue_mldts_ops;
542};
543
545extern struct rte_bbdev rte_bbdev_devices[];
546
568static inline uint16_t
569rte_bbdev_enqueue_enc_ops(uint16_t dev_id, uint16_t queue_id,
570 struct rte_bbdev_enc_op **ops, uint16_t num_ops)
571{
572 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
573 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
574 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
576 return dev->enqueue_enc_ops(q_data, ops, num_ops);
577}
578
600static inline uint16_t
601rte_bbdev_enqueue_dec_ops(uint16_t dev_id, uint16_t queue_id,
602 struct rte_bbdev_dec_op **ops, uint16_t num_ops)
603{
604 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
605 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
606 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
608 return dev->enqueue_dec_ops(q_data, ops, num_ops);
609}
610
632static inline uint16_t
633rte_bbdev_enqueue_ldpc_enc_ops(uint16_t dev_id, uint16_t queue_id,
634 struct rte_bbdev_enc_op **ops, uint16_t num_ops)
635{
636 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
637 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
638 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
640 return dev->enqueue_ldpc_enc_ops(q_data, ops, num_ops);
641}
642
664static inline uint16_t
665rte_bbdev_enqueue_ldpc_dec_ops(uint16_t dev_id, uint16_t queue_id,
666 struct rte_bbdev_dec_op **ops, uint16_t num_ops)
667{
668 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
669 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
670 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
672 return dev->enqueue_ldpc_dec_ops(q_data, ops, num_ops);
673}
674
696static inline uint16_t
697rte_bbdev_enqueue_fft_ops(uint16_t dev_id, uint16_t queue_id,
698 struct rte_bbdev_fft_op **ops, uint16_t num_ops)
699{
700 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
701 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
702 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
704 return dev->enqueue_fft_ops(q_data, ops, num_ops);
705}
706
728static inline uint16_t
729rte_bbdev_enqueue_mldts_ops(uint16_t dev_id, uint16_t queue_id,
730 struct rte_bbdev_mldts_op **ops, uint16_t num_ops)
731{
732 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
733 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
734 rte_bbdev_trace_enqueue(dev_id, queue_id, (void **)ops, num_ops,
736 return dev->enqueue_mldts_ops(q_data, ops, num_ops);
737}
738
761static inline uint16_t
762rte_bbdev_dequeue_enc_ops(uint16_t dev_id, uint16_t queue_id,
763 struct rte_bbdev_enc_op **ops, uint16_t num_ops)
764{
765 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
766 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
767 uint16_t num_ops_dequeued = dev->dequeue_enc_ops(q_data, ops, num_ops);
768 if (num_ops_dequeued > 0)
769 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
771 return num_ops_dequeued;
772}
773
797static inline uint16_t
798rte_bbdev_dequeue_dec_ops(uint16_t dev_id, uint16_t queue_id,
799 struct rte_bbdev_dec_op **ops, uint16_t num_ops)
800{
801 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
802 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
803 uint16_t num_ops_dequeued = dev->dequeue_dec_ops(q_data, ops, num_ops);
804 if (num_ops_dequeued > 0)
805 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
807 return num_ops_dequeued;
808}
809
810
832static inline uint16_t
833rte_bbdev_dequeue_ldpc_enc_ops(uint16_t dev_id, uint16_t queue_id,
834 struct rte_bbdev_enc_op **ops, uint16_t num_ops)
835{
836 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
837 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
838 uint16_t num_ops_dequeued = dev->dequeue_ldpc_enc_ops(q_data, ops, num_ops);
839 if (num_ops_dequeued > 0)
840 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
842 return num_ops_dequeued;
843}
844
866static inline uint16_t
867rte_bbdev_dequeue_ldpc_dec_ops(uint16_t dev_id, uint16_t queue_id,
868 struct rte_bbdev_dec_op **ops, uint16_t num_ops)
869{
870 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
871 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
872 uint16_t num_ops_dequeued = dev->dequeue_ldpc_dec_ops(q_data, ops, num_ops);
873 if (num_ops_dequeued > 0)
874 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
876 return num_ops_dequeued;
877}
878
900static inline uint16_t
901rte_bbdev_dequeue_fft_ops(uint16_t dev_id, uint16_t queue_id,
902 struct rte_bbdev_fft_op **ops, uint16_t num_ops)
903{
904 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
905 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
906 uint16_t num_ops_dequeued = dev->dequeue_fft_ops(q_data, ops, num_ops);
907 if (num_ops_dequeued > 0)
908 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
909 num_ops_dequeued, rte_bbdev_op_type_str(RTE_BBDEV_OP_FFT));
910 return num_ops_dequeued;
911}
912
934static inline uint16_t
935rte_bbdev_dequeue_mldts_ops(uint16_t dev_id, uint16_t queue_id,
936 struct rte_bbdev_mldts_op **ops, uint16_t num_ops)
937{
938 struct rte_bbdev *dev = &rte_bbdev_devices[dev_id];
939 struct rte_bbdev_queue_data *q_data = &dev->data->queues[queue_id];
940 uint16_t num_ops_dequeued = dev->dequeue_mldts_ops(q_data, ops, num_ops);
941 if (num_ops_dequeued > 0)
942 rte_bbdev_trace_dequeue(dev_id, queue_id, (void **)ops, num_ops,
943 num_ops_dequeued, rte_bbdev_op_type_str(RTE_BBDEV_OP_MLDTS));
944 return num_ops_dequeued;
945}
946
954
968typedef void (*rte_bbdev_cb_fn)(uint16_t dev_id,
969 enum rte_bbdev_event_type event, void *cb_arg,
970 void *ret_param);
971
989int
991 rte_bbdev_cb_fn cb_fn, void *cb_arg);
992
1012int
1014 rte_bbdev_cb_fn cb_fn, void *cb_arg);
1015
1032int
1033rte_bbdev_queue_intr_enable(uint16_t dev_id, uint16_t queue_id);
1034
1048int
1049rte_bbdev_queue_intr_disable(uint16_t dev_id, uint16_t queue_id);
1050
1075int
1076rte_bbdev_queue_intr_ctl(uint16_t dev_id, uint16_t queue_id, int epfd, int op,
1077 void *data);
1078
1088const char*
1090
1100const char*
1102
1122__rte_experimental
1123int
1124rte_bbdev_queue_ops_dump(uint16_t dev_id, uint16_t queue_index, FILE *file);
1125
1126
1146__rte_experimental
1147char *
1148rte_bbdev_ops_param_string(void *op, enum rte_bbdev_op_type op_type, char *str, uint32_t len);
1149
1150#ifdef __cplusplus
1151}
1152#endif
1153
1154#endif /* _RTE_BBDEV_H_ */
int rte_bbdev_start(uint16_t dev_id)
rte_bbdev_device_status
Definition: rte_bbdev.h:255
@ RTE_BBDEV_DEV_FATAL_ERR
Definition: rte_bbdev.h:261
@ RTE_BBDEV_DEV_CORRECT_ERR
Definition: rte_bbdev.h:264
@ RTE_BBDEV_DEV_NOT_SUPPORTED
Definition: rte_bbdev.h:257
@ RTE_BBDEV_DEV_RECONFIG_REQ
Definition: rte_bbdev.h:263
@ RTE_BBDEV_DEV_CONFIGURED
Definition: rte_bbdev.h:259
@ RTE_BBDEV_DEV_RESTART_REQ
Definition: rte_bbdev.h:262
@ RTE_BBDEV_DEV_RESET
Definition: rte_bbdev.h:258
@ RTE_BBDEV_DEV_ACTIVE
Definition: rte_bbdev.h:260
@ RTE_BBDEV_DEV_NOSTATUS
Definition: rte_bbdev.h:256
int rte_bbdev_queue_intr_enable(uint16_t dev_id, uint16_t queue_id)
rte_bbdev_enqueue_status
Definition: rte_bbdev.h:244
@ RTE_BBDEV_ENQ_STATUS_INVALID_OP
Definition: rte_bbdev.h:248
@ RTE_BBDEV_ENQ_STATUS_RING_FULL
Definition: rte_bbdev.h:247
@ RTE_BBDEV_ENQ_STATUS_QUEUE_FULL
Definition: rte_bbdev.h:246
@ RTE_BBDEV_ENQ_STATUS_NONE
Definition: rte_bbdev.h:245
int rte_bbdev_setup_queues(uint16_t dev_id, uint16_t num_queues, int socket_id)
__rte_experimental int rte_bbdev_queue_ops_dump(uint16_t dev_id, uint16_t queue_index, FILE *file)
RTE_TAILQ_HEAD(rte_bbdev_cb_list, rte_bbdev_callback)
static uint16_t rte_bbdev_dequeue_fft_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_fft_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:901
int rte_bbdev_callback_register(uint16_t dev_id, enum rte_bbdev_event_type event, rte_bbdev_cb_fn cb_fn, void *cb_arg)
static uint16_t rte_bbdev_dequeue_mldts_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_mldts_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:935
int rte_bbdev_stop(uint16_t dev_id)
int rte_bbdev_close(uint16_t dev_id)
rte_bbdev_state
Definition: rte_bbdev.h:49
uint16_t rte_bbdev_find_next(uint16_t dev_id)
__rte_experimental char * rte_bbdev_ops_param_string(void *op, enum rte_bbdev_op_type op_type, char *str, uint32_t len)
static uint16_t rte_bbdev_dequeue_ldpc_dec_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_dec_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:867
static uint16_t rte_bbdev_enqueue_mldts_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_mldts_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:729
int rte_bbdev_info_get(uint16_t dev_id, struct rte_bbdev_info *dev_info)
uint16_t rte_bbdev_count(void)
int rte_bbdev_stats_reset(uint16_t dev_id)
static uint16_t rte_bbdev_enqueue_enc_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_enc_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:569
rte_bbdev_event_type
Definition: rte_bbdev.h:948
@ RTE_BBDEV_EVENT_ERROR
Definition: rte_bbdev.h:950
@ RTE_BBDEV_EVENT_DEQUEUE
Definition: rte_bbdev.h:951
@ RTE_BBDEV_EVENT_UNKNOWN
Definition: rte_bbdev.h:949
@ RTE_BBDEV_EVENT_MAX
Definition: rte_bbdev.h:952
int rte_bbdev_queue_configure(uint16_t dev_id, uint16_t queue_id, const struct rte_bbdev_queue_conf *conf)
const char * rte_bbdev_device_status_str(enum rte_bbdev_device_status status)
static uint16_t rte_bbdev_enqueue_fft_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_fft_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:697
void(* rte_bbdev_cb_fn)(uint16_t dev_id, enum rte_bbdev_event_type event, void *cb_arg, void *ret_param)
Definition: rte_bbdev.h:968
static uint16_t rte_bbdev_dequeue_ldpc_enc_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_enc_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:833
int rte_bbdev_queue_info_get(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_queue_info *queue_info)
static uint16_t rte_bbdev_dequeue_dec_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_dec_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:798
static uint16_t rte_bbdev_dequeue_enc_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_enc_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:762
static uint16_t rte_bbdev_enqueue_ldpc_enc_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_enc_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:633
bool rte_bbdev_is_valid(uint16_t dev_id)
int rte_bbdev_queue_start(uint16_t dev_id, uint16_t queue_id)
const char * rte_bbdev_enqueue_status_str(enum rte_bbdev_enqueue_status status)
static uint16_t rte_bbdev_enqueue_ldpc_dec_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_dec_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:665
int rte_bbdev_stats_get(uint16_t dev_id, struct rte_bbdev_stats *stats)
int rte_bbdev_callback_unregister(uint16_t dev_id, enum rte_bbdev_event_type event, rte_bbdev_cb_fn cb_fn, void *cb_arg)
int rte_bbdev_intr_enable(uint16_t dev_id)
int rte_bbdev_queue_intr_disable(uint16_t dev_id, uint16_t queue_id)
int rte_bbdev_queue_intr_ctl(uint16_t dev_id, uint16_t queue_id, int epfd, int op, void *data)
static uint16_t rte_bbdev_enqueue_dec_ops(uint16_t dev_id, uint16_t queue_id, struct rte_bbdev_dec_op **ops, uint16_t num_ops)
Definition: rte_bbdev.h:601
int rte_bbdev_queue_stop(uint16_t dev_id, uint16_t queue_id)
#define RTE_BBDEV_NAME_MAX_LEN
Definition: rte_bbdev.h:479
rte_bbdev_op_type
Definition: rte_bbdev_op.h:930
@ RTE_BBDEV_OP_FFT
Definition: rte_bbdev_op.h:936
@ RTE_BBDEV_OP_TURBO_DEC
Definition: rte_bbdev_op.h:932
@ RTE_BBDEV_OP_LDPC_DEC
Definition: rte_bbdev_op.h:934
@ RTE_BBDEV_OP_TURBO_ENC
Definition: rte_bbdev_op.h:933
@ RTE_BBDEV_OP_MLDTS
Definition: rte_bbdev_op.h:937
@ RTE_BBDEV_OP_LDPC_ENC
Definition: rte_bbdev_op.h:935
const char * rte_bbdev_op_type_str(enum rte_bbdev_op_type op_type)
#define __rte_cache_aligned
Definition: rte_common.h:705
unsigned int max_num_queues
Definition: rte_bbdev.h:327
uint8_t max_dl_queue_priority
Definition: rte_bbdev.h:337
struct rte_bbdev_queue_conf default_queue_conf
Definition: rte_bbdev.h:353
unsigned int num_queues[RTE_BBDEV_OP_TYPE_SIZE_MAX]
Definition: rte_bbdev.h:329
uint16_t min_alignment
Definition: rte_bbdev.h:347
unsigned int queue_priority[RTE_BBDEV_OP_TYPE_SIZE_MAX]
Definition: rte_bbdev.h:331
enum rte_cpu_flag_t * cpu_flag_reqs
Definition: rte_bbdev.h:357
uint32_t harq_buffer_size
Definition: rte_bbdev.h:345
const struct rte_bbdev_op_cap * capabilities
Definition: rte_bbdev.h:355
const char * driver_name
Definition: rte_bbdev.h:324
uint32_t queue_size_lim
Definition: rte_bbdev.h:333
enum rte_bbdev_device_status device_status
Definition: rte_bbdev.h:343
uint8_t max_ul_queue_priority
Definition: rte_bbdev.h:339
uint16_t * fft_window_width
Definition: rte_bbdev.h:359
struct rte_bbdev_driver_info drv
Definition: rte_bbdev.h:379
const char * dev_name
Definition: rte_bbdev.h:375
uint16_t num_queues
Definition: rte_bbdev.h:377
const struct rte_device * device
Definition: rte_bbdev.h:376
enum rte_bbdev_op_type op_type
Definition: rte_bbdev.h:140
struct rte_bbdev_queue_conf conf
Definition: rte_bbdev.h:402
uint64_t enqueue_status_count[RTE_BBDEV_ENQ_STATUS_SIZE_MAX]
Definition: rte_bbdev.h:280
uint64_t acc_offload_cycles
Definition: rte_bbdev.h:287
uint64_t enqueue_err_count
Definition: rte_bbdev.h:272
uint64_t enqueued_count
Definition: rte_bbdev.h:269
uint64_t enqueue_warn_count
Definition: rte_bbdev.h:276
uint64_t dequeue_err_count
Definition: rte_bbdev.h:274
uint16_t enqueue_depth_avail
Definition: rte_bbdev.h:289
uint64_t dequeued_count
Definition: rte_bbdev.h:270
uint64_t dequeue_warn_count
Definition: rte_bbdev.h:278