numam-dpdk/drivers/common/cnxk/roc_sso_priv.h
Pavan Nikhilesh 84ed1a5b4b common/cnxk: support SSO IRQ
Add support to registering and un-registering SSO HWS and
HWGRP IRQs.

Signed-off-by: Pavan Nikhilesh <pbhagavatula@marvell.com>
Acked-by: Nithin Dabilpuram <ndabilpuram@marvell.com>
2021-04-09 08:32:24 +02:00

51 lines
1.1 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(C) 2021 Marvell.
*/
#ifndef _ROC_SSO_PRIV_H_
#define _ROC_SSO_PRIV_H_
struct sso_rsrc {
uint16_t rsrc_id;
uint64_t base;
};
struct sso {
struct plt_pci_device *pci_dev;
struct dev dev;
/* Interrupt handler args. */
struct sso_rsrc hws_rsrc[MAX_RVU_BLKLF_CNT];
struct sso_rsrc hwgrp_rsrc[MAX_RVU_BLKLF_CNT];
/* MSIX offsets */
uint16_t hws_msix_offset[MAX_RVU_BLKLF_CNT];
uint16_t hwgrp_msix_offset[MAX_RVU_BLKLF_CNT];
/* SSO link mapping. */
struct plt_bitmap **link_map;
void *link_map_mem;
} __plt_cache_aligned;
enum sso_err_status {
SSO_ERR_PARAM = -4096,
};
enum sso_lf_type {
SSO_LF_TYPE_HWS,
SSO_LF_TYPE_HWGRP,
};
static inline struct sso *
roc_sso_to_sso_priv(struct roc_sso *roc_sso)
{
return (struct sso *)&roc_sso->reserved[0];
}
/* SSO IRQ */
int sso_register_irqs_priv(struct roc_sso *roc_sso,
struct plt_intr_handle *handle, uint16_t nb_hws,
uint16_t nb_hwgrp);
void sso_unregister_irqs_priv(struct roc_sso *roc_sso,
struct plt_intr_handle *handle, uint16_t nb_hws,
uint16_t nb_hwgrp);
#endif /* _ROC_SSO_PRIV_H_ */