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 32*54f17843SMattias Rönnblom typedef void (*event_maintain_t)(void *port, int op); 33*54f17843SMattias Rönnblom /**< @internal Maintains a port */ 34*54f17843SMattias 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 45d35e6132SPavan Nikhilesh struct rte_event_fp_ops { 46d35e6132SPavan Nikhilesh void **data; 47d35e6132SPavan Nikhilesh /**< points to array of internal port data pointers */ 48d35e6132SPavan Nikhilesh event_enqueue_t enqueue; 49d35e6132SPavan Nikhilesh /**< PMD enqueue function. */ 50d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_burst; 51d35e6132SPavan Nikhilesh /**< PMD enqueue burst function. */ 52d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_new_burst; 53d35e6132SPavan Nikhilesh /**< PMD enqueue burst new function. */ 54d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_forward_burst; 55d35e6132SPavan Nikhilesh /**< PMD enqueue burst fwd function. */ 56d35e6132SPavan Nikhilesh event_dequeue_t dequeue; 57d35e6132SPavan Nikhilesh /**< PMD dequeue function. */ 58d35e6132SPavan Nikhilesh event_dequeue_burst_t dequeue_burst; 59d35e6132SPavan Nikhilesh /**< PMD dequeue burst function. */ 60*54f17843SMattias Rönnblom event_maintain_t maintain; 61*54f17843SMattias Rönnblom /**< PMD port maintenance function. */ 62d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue; 63d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue function. */ 64d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue_same_dest; 65d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue same destination function. */ 66d35e6132SPavan Nikhilesh event_crypto_adapter_enqueue_t ca_enqueue; 67d35e6132SPavan Nikhilesh /**< PMD Crypto adapter enqueue function. */ 68d35e6132SPavan Nikhilesh uintptr_t reserved[6]; 69d35e6132SPavan Nikhilesh } __rte_cache_aligned; 70d35e6132SPavan Nikhilesh 71d35e6132SPavan Nikhilesh extern struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS]; 72d35e6132SPavan Nikhilesh 7326f14535SPavan Nikhilesh #ifdef __cplusplus 7426f14535SPavan Nikhilesh } 7526f14535SPavan Nikhilesh #endif 7626f14535SPavan Nikhilesh 7726f14535SPavan Nikhilesh #endif /*_RTE_EVENTDEV_CORE_H_*/ 78