xref: /dpdk/lib/eventdev/rte_eventdev_core.h (revision c1bdd86d04d161c07c61ec1be8ef081108d29d2a)
126f14535SPavan Nikhilesh /* SPDX-License-Identifier: BSD-3-Clause
226f14535SPavan Nikhilesh  * Copyright(c) 2016-2018 Intel Corporation.
326f14535SPavan Nikhilesh  * Copyright(C) 2021 Marvell.
426f14535SPavan Nikhilesh  * Copyright 2016 NXP
526f14535SPavan Nikhilesh  * All rights reserved.
626f14535SPavan Nikhilesh  */
726f14535SPavan Nikhilesh 
826f14535SPavan Nikhilesh #ifndef _RTE_EVENTDEV_CORE_H_
926f14535SPavan Nikhilesh #define _RTE_EVENTDEV_CORE_H_
1026f14535SPavan Nikhilesh 
1126f14535SPavan Nikhilesh #ifdef __cplusplus
1226f14535SPavan Nikhilesh extern "C" {
1326f14535SPavan Nikhilesh #endif
1426f14535SPavan Nikhilesh 
1526f14535SPavan Nikhilesh typedef uint16_t (*event_enqueue_t)(void *port, const struct rte_event *ev);
1626f14535SPavan Nikhilesh /**< @internal Enqueue event on port of a device */
1726f14535SPavan Nikhilesh 
1826f14535SPavan Nikhilesh typedef uint16_t (*event_enqueue_burst_t)(void *port,
1926f14535SPavan Nikhilesh 					  const struct rte_event ev[],
2026f14535SPavan Nikhilesh 					  uint16_t nb_events);
2126f14535SPavan Nikhilesh /**< @internal Enqueue burst of events on port of a device */
2226f14535SPavan Nikhilesh 
2326f14535SPavan Nikhilesh typedef uint16_t (*event_dequeue_t)(void *port, struct rte_event *ev,
2426f14535SPavan Nikhilesh 				    uint64_t timeout_ticks);
2526f14535SPavan Nikhilesh /**< @internal Dequeue event from port of a device */
2626f14535SPavan Nikhilesh 
2726f14535SPavan Nikhilesh typedef uint16_t (*event_dequeue_burst_t)(void *port, struct rte_event ev[],
2826f14535SPavan Nikhilesh 					  uint16_t nb_events,
2926f14535SPavan Nikhilesh 					  uint64_t timeout_ticks);
3026f14535SPavan Nikhilesh /**< @internal Dequeue burst of events from port of a device */
3126f14535SPavan Nikhilesh 
3254f17843SMattias Rönnblom typedef void (*event_maintain_t)(void *port, int op);
3354f17843SMattias Rönnblom /**< @internal Maintains a port */
3454f17843SMattias Rönnblom 
3526f14535SPavan Nikhilesh typedef uint16_t (*event_tx_adapter_enqueue_t)(void *port,
3626f14535SPavan Nikhilesh 					       struct rte_event ev[],
3726f14535SPavan Nikhilesh 					       uint16_t nb_events);
3826f14535SPavan Nikhilesh /**< @internal Enqueue burst of events on port of a device */
3926f14535SPavan Nikhilesh 
4026f14535SPavan Nikhilesh typedef uint16_t (*event_crypto_adapter_enqueue_t)(void *port,
4126f14535SPavan Nikhilesh 						   struct rte_event ev[],
4226f14535SPavan Nikhilesh 						   uint16_t nb_events);
4326f14535SPavan Nikhilesh /**< @internal Enqueue burst of events on crypto adapter */
4426f14535SPavan Nikhilesh 
4566a30a29SAmit Prakash Shukla typedef uint16_t (*event_dma_adapter_enqueue_t)(void *port, struct rte_event ev[],
4666a30a29SAmit Prakash Shukla 						uint16_t nb_events);
4766a30a29SAmit Prakash Shukla /**< @internal Enqueue burst of events on DMA adapter */
4866a30a29SAmit Prakash Shukla 
49d007a7f3SPavan Nikhilesh typedef int (*event_profile_switch_t)(void *port, uint8_t profile);
50d007a7f3SPavan Nikhilesh /**< @internal Switch active link profile on the event port. */
51d007a7f3SPavan Nikhilesh 
52*c1bdd86dSPavan Nikhilesh typedef int (*event_preschedule_modify_t)(void *port,
53*c1bdd86dSPavan Nikhilesh 					  enum rte_event_dev_preschedule_type preschedule_type);
54*c1bdd86dSPavan Nikhilesh /**< @internal Modify pre-schedule type on the event port. */
55*c1bdd86dSPavan Nikhilesh 
56c6552d9aSTyler Retzlaff struct __rte_cache_aligned rte_event_fp_ops {
57d35e6132SPavan Nikhilesh 	void **data;
58d35e6132SPavan Nikhilesh 	/**< points to array of internal port data pointers */
59d35e6132SPavan Nikhilesh 	event_enqueue_t enqueue;
60d35e6132SPavan Nikhilesh 	/**< PMD enqueue function. */
61d35e6132SPavan Nikhilesh 	event_enqueue_burst_t enqueue_burst;
62d35e6132SPavan Nikhilesh 	/**< PMD enqueue burst function. */
63d35e6132SPavan Nikhilesh 	event_enqueue_burst_t enqueue_new_burst;
64d35e6132SPavan Nikhilesh 	/**< PMD enqueue burst new function. */
65d35e6132SPavan Nikhilesh 	event_enqueue_burst_t enqueue_forward_burst;
66d35e6132SPavan Nikhilesh 	/**< PMD enqueue burst fwd function. */
67d35e6132SPavan Nikhilesh 	event_dequeue_t dequeue;
68d35e6132SPavan Nikhilesh 	/**< PMD dequeue function. */
69d35e6132SPavan Nikhilesh 	event_dequeue_burst_t dequeue_burst;
70d35e6132SPavan Nikhilesh 	/**< PMD dequeue burst function. */
7154f17843SMattias Rönnblom 	event_maintain_t maintain;
7254f17843SMattias Rönnblom 	/**< PMD port maintenance function. */
73d35e6132SPavan Nikhilesh 	event_tx_adapter_enqueue_t txa_enqueue;
74d35e6132SPavan Nikhilesh 	/**< PMD Tx adapter enqueue function. */
75d35e6132SPavan Nikhilesh 	event_tx_adapter_enqueue_t txa_enqueue_same_dest;
76d35e6132SPavan Nikhilesh 	/**< PMD Tx adapter enqueue same destination function. */
77d35e6132SPavan Nikhilesh 	event_crypto_adapter_enqueue_t ca_enqueue;
78d35e6132SPavan Nikhilesh 	/**< PMD Crypto adapter enqueue function. */
7966a30a29SAmit Prakash Shukla 	event_dma_adapter_enqueue_t dma_enqueue;
8066a30a29SAmit Prakash Shukla 	/**< PMD DMA adapter enqueue function. */
81d007a7f3SPavan Nikhilesh 	event_profile_switch_t profile_switch;
82d007a7f3SPavan Nikhilesh 	/**< PMD Event switch profile function. */
83*c1bdd86dSPavan Nikhilesh 	event_preschedule_modify_t preschedule_modify;
84*c1bdd86dSPavan Nikhilesh 	/**< PMD Event port pre-schedule switch. */
85*c1bdd86dSPavan Nikhilesh 	uintptr_t reserved[3];
86c6552d9aSTyler Retzlaff };
87d35e6132SPavan Nikhilesh 
88d35e6132SPavan Nikhilesh extern struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS];
89d35e6132SPavan Nikhilesh 
9026f14535SPavan Nikhilesh #ifdef __cplusplus
9126f14535SPavan Nikhilesh }
9226f14535SPavan Nikhilesh #endif
9326f14535SPavan Nikhilesh 
9426f14535SPavan Nikhilesh #endif /*_RTE_EVENTDEV_CORE_H_*/
95