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 49*d007a7f3SPavan Nikhilesh typedef int (*event_profile_switch_t)(void *port, uint8_t profile); 50*d007a7f3SPavan Nikhilesh /**< @internal Switch active link profile on the event port. */ 51*d007a7f3SPavan Nikhilesh 52d35e6132SPavan Nikhilesh struct rte_event_fp_ops { 53d35e6132SPavan Nikhilesh void **data; 54d35e6132SPavan Nikhilesh /**< points to array of internal port data pointers */ 55d35e6132SPavan Nikhilesh event_enqueue_t enqueue; 56d35e6132SPavan Nikhilesh /**< PMD enqueue function. */ 57d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_burst; 58d35e6132SPavan Nikhilesh /**< PMD enqueue burst function. */ 59d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_new_burst; 60d35e6132SPavan Nikhilesh /**< PMD enqueue burst new function. */ 61d35e6132SPavan Nikhilesh event_enqueue_burst_t enqueue_forward_burst; 62d35e6132SPavan Nikhilesh /**< PMD enqueue burst fwd function. */ 63d35e6132SPavan Nikhilesh event_dequeue_t dequeue; 64d35e6132SPavan Nikhilesh /**< PMD dequeue function. */ 65d35e6132SPavan Nikhilesh event_dequeue_burst_t dequeue_burst; 66d35e6132SPavan Nikhilesh /**< PMD dequeue burst function. */ 6754f17843SMattias Rönnblom event_maintain_t maintain; 6854f17843SMattias Rönnblom /**< PMD port maintenance function. */ 69d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue; 70d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue function. */ 71d35e6132SPavan Nikhilesh event_tx_adapter_enqueue_t txa_enqueue_same_dest; 72d35e6132SPavan Nikhilesh /**< PMD Tx adapter enqueue same destination function. */ 73d35e6132SPavan Nikhilesh event_crypto_adapter_enqueue_t ca_enqueue; 74d35e6132SPavan Nikhilesh /**< PMD Crypto adapter enqueue function. */ 7566a30a29SAmit Prakash Shukla event_dma_adapter_enqueue_t dma_enqueue; 7666a30a29SAmit Prakash Shukla /**< PMD DMA adapter enqueue function. */ 77*d007a7f3SPavan Nikhilesh event_profile_switch_t profile_switch; 78*d007a7f3SPavan Nikhilesh /**< PMD Event switch profile function. */ 7966a30a29SAmit Prakash Shukla uintptr_t reserved[4]; 80d35e6132SPavan Nikhilesh } __rte_cache_aligned; 81d35e6132SPavan Nikhilesh 82d35e6132SPavan Nikhilesh extern struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS]; 83d35e6132SPavan Nikhilesh 8426f14535SPavan Nikhilesh #ifdef __cplusplus 8526f14535SPavan Nikhilesh } 8626f14535SPavan Nikhilesh #endif 8726f14535SPavan Nikhilesh 8826f14535SPavan Nikhilesh #endif /*_RTE_EVENTDEV_CORE_H_*/ 89