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 52c1bdd86dSPavan Nikhilesh typedef int (*event_preschedule_modify_t)(void *port, 53c1bdd86dSPavan Nikhilesh enum rte_event_dev_preschedule_type preschedule_type); 54c1bdd86dSPavan Nikhilesh /**< @internal Modify pre-schedule type on the event port. */ 55c1bdd86dSPavan Nikhilesh 56*4ade669cSPavan Nikhilesh typedef void (*event_preschedule_t)(void *port, 57*4ade669cSPavan Nikhilesh enum rte_event_dev_preschedule_type preschedule_type); 58*4ade669cSPavan Nikhilesh /**< @internal Issue pre-schedule on an event port. */ 59*4ade669cSPavan Nikhilesh 60c6552d9aSTyler Retzlaff struct __rte_cache_aligned rte_event_fp_ops { 61d35e6132SPavan Nikhilesh void **data; 62d35e6132SPavan Nikhilesh /**< points to array of internal port data pointers */ 63d35e6132SPavan Nikhilesh event_enqueue_t enqueue; 64d35e6132SPavan Nikhilesh /**< PMD enqueue function. */ 65d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_burst; 66d35e6132SPavan Nikhilesh /**< PMD enqueue burst function. */ 67d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_new_burst; 68d35e6132SPavan Nikhilesh /**< PMD enqueue burst new function. */ 69d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_forward_burst; 70d35e6132SPavan Nikhilesh /**< PMD enqueue burst fwd function. */ 71d35e6132SPavan Nikhilesh event_dequeue_t dequeue; 72d35e6132SPavan Nikhilesh /**< PMD dequeue function. */ 73d35e6132SPavan Nikhilesh event_dequeue_burst_t dequeue_burst; 74d35e6132SPavan Nikhilesh /**< PMD dequeue burst function. */ 7554f17843SMattias Rönnblom event_maintain_t maintain; 7654f17843SMattias Rönnblom /**< PMD port maintenance function. */ 77d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue; 78d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue function. */ 79d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue_same_dest; 80d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue same destination function. */ 81d35e6132SPavan Nikhilesh event_crypto_adapter_enqueue_t ca_enqueue; 82d35e6132SPavan Nikhilesh /**< PMD Crypto adapter enqueue function. */ 8366a30a29SAmit Prakash Shukla event_dma_adapter_enqueue_t dma_enqueue; 8466a30a29SAmit Prakash Shukla /**< PMD DMA adapter enqueue function. */ 85d007a7f3SPavan Nikhilesh event_profile_switch_t profile_switch; 86d007a7f3SPavan Nikhilesh /**< PMD Event switch profile function. */ 87c1bdd86dSPavan Nikhilesh event_preschedule_modify_t preschedule_modify; 88c1bdd86dSPavan Nikhilesh /**< PMD Event port pre-schedule switch. */ 89*4ade669cSPavan Nikhilesh event_preschedule_t preschedule; 90*4ade669cSPavan Nikhilesh /**< PMD Event port pre-schedule. */ 91*4ade669cSPavan Nikhilesh uintptr_t reserved[2]; 92c6552d9aSTyler Retzlaff }; 93d35e6132SPavan Nikhilesh 94d35e6132SPavan Nikhilesh extern struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS]; 95d35e6132SPavan Nikhilesh 9626f14535SPavan Nikhilesh #ifdef __cplusplus 9726f14535SPavan Nikhilesh } 9826f14535SPavan Nikhilesh #endif 9926f14535SPavan Nikhilesh 10026f14535SPavan Nikhilesh #endif /*_RTE_EVENTDEV_CORE_H_*/ 101