/* SPDX-License-Identifier: GPL-2.0 */ /* Copyright (C) 2023, Intel Corporation. */ #ifndef _ICE_IRQ_H_ #define _ICE_IRQ_H_ struct ice_irq_entry { unsigned int index; bool dynamic; /* allocation type flag */ }; struct ice_irq_tracker { struct xarray entries; u16 num_entries; /* total vectors available */ u16 num_static; /* preallocated entries */ }; int ice_init_interrupt_scheme(struct ice_pf *pf); void ice_clear_interrupt_scheme(struct ice_pf *pf); struct msi_map ice_alloc_irq(struct ice_pf *pf, bool dyn_only); void ice_free_irq(struct ice_pf *pf, struct msi_map map); int ice_get_max_used_msix_vector(struct ice_pf *pf); #endif