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