f-stack/dpdk/drivers/common/cnxk/roc_sso_priv.h

67 lines
1.9 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_spinlock_t mbox_lock;
} __plt_cache_aligned;
enum sso_err_status {
SSO_ERR_PARAM = -4096,
SSO_ERR_DEVICE_NOT_BOUNDED = -4097,
};
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 LF ops */
int sso_lf_alloc(struct dev *dev, enum sso_lf_type lf_type, uint16_t nb_lf,
void **rsp);
int sso_lf_free(struct dev *dev, enum sso_lf_type lf_type, uint16_t nb_lf);
void sso_hws_link_modify(uint8_t hws, uintptr_t base, struct plt_bitmap *bmp,
uint16_t hwgrp[], uint16_t n, uint16_t enable);
int sso_hwgrp_alloc_xaq(struct dev *dev, uint32_t npa_aura_id, uint16_t hwgrps);
int sso_hwgrp_release_xaq(struct dev *dev, uint16_t hwgrps);
int sso_hwgrp_init_xaq_aura(struct dev *dev, struct roc_sso_xaq_data *xaq,
uint32_t nb_xae, uint32_t xae_waes,
uint32_t xaq_buf_size, uint16_t nb_hwgrp);
int sso_hwgrp_free_xaq_aura(struct dev *dev, struct roc_sso_xaq_data *xaq,
uint16_t nb_hwgrp);
/* 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_ */