mirror of https://github.com/F-Stack/f-stack.git
67 lines
1.9 KiB
C
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_ */
|