mirror of https://github.com/F-Stack/f-stack.git
122 lines
3.4 KiB
C
122 lines
3.4 KiB
C
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||
|
* Copyright(C) 2021 Marvell.
|
||
|
*/
|
||
|
|
||
|
#ifndef _ROC_SSO_H_
|
||
|
#define _ROC_SSO_H_
|
||
|
|
||
|
struct roc_sso_hwgrp_qos {
|
||
|
uint16_t hwgrp;
|
||
|
uint8_t xaq_prcnt;
|
||
|
uint8_t iaq_prcnt;
|
||
|
uint8_t taq_prcnt;
|
||
|
};
|
||
|
|
||
|
struct roc_sso_hws_stats {
|
||
|
uint64_t arbitration;
|
||
|
};
|
||
|
|
||
|
struct roc_sso_hwgrp_stats {
|
||
|
uint64_t ws_pc;
|
||
|
uint64_t ext_pc;
|
||
|
uint64_t wa_pc;
|
||
|
uint64_t ts_pc;
|
||
|
uint64_t ds_pc;
|
||
|
uint64_t dq_pc;
|
||
|
uint64_t aw_status;
|
||
|
uint64_t page_cnt;
|
||
|
};
|
||
|
|
||
|
struct roc_sso_xaq_data {
|
||
|
uint32_t nb_xaq;
|
||
|
uint32_t nb_xae;
|
||
|
uint32_t xaq_lmt;
|
||
|
uint64_t aura_handle;
|
||
|
void *fc;
|
||
|
void *mem;
|
||
|
};
|
||
|
|
||
|
struct roc_sso {
|
||
|
struct plt_pci_device *pci_dev;
|
||
|
/* Public data. */
|
||
|
uint16_t max_hwgrp;
|
||
|
uint16_t max_hws;
|
||
|
uint16_t nb_hwgrp;
|
||
|
uint8_t nb_hws;
|
||
|
uintptr_t lmt_base;
|
||
|
struct roc_sso_xaq_data xaq;
|
||
|
/* HW Const. */
|
||
|
uint32_t xae_waes;
|
||
|
uint32_t xaq_buf_size;
|
||
|
uint32_t iue;
|
||
|
/* Private data. */
|
||
|
#define ROC_SSO_MEM_SZ (16 * 1024)
|
||
|
uint8_t reserved[ROC_SSO_MEM_SZ] __plt_cache_aligned;
|
||
|
} __plt_cache_aligned;
|
||
|
|
||
|
static __plt_always_inline void
|
||
|
roc_sso_hws_head_wait(uintptr_t tag_op)
|
||
|
{
|
||
|
#ifdef RTE_ARCH_ARM64
|
||
|
uint64_t tag;
|
||
|
|
||
|
asm volatile(PLT_CPU_FEATURE_PREAMBLE
|
||
|
" ldr %[tag], [%[tag_op]] \n"
|
||
|
" tbnz %[tag], 35, done%= \n"
|
||
|
" sevl \n"
|
||
|
"rty%=: wfe \n"
|
||
|
" ldr %[tag], [%[tag_op]] \n"
|
||
|
" tbz %[tag], 35, rty%= \n"
|
||
|
"done%=: \n"
|
||
|
: [tag] "=&r"(tag)
|
||
|
: [tag_op] "r"(tag_op));
|
||
|
#else
|
||
|
/* Wait for the SWTAG/SWTAG_FULL operation */
|
||
|
while (!(plt_read64(tag_op) & BIT_ULL(35)))
|
||
|
;
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
/* SSO device initialization */
|
||
|
int __roc_api roc_sso_dev_init(struct roc_sso *roc_sso);
|
||
|
int __roc_api roc_sso_dev_fini(struct roc_sso *roc_sso);
|
||
|
|
||
|
/* SSO device configuration */
|
||
|
int __roc_api roc_sso_rsrc_init(struct roc_sso *roc_sso, uint8_t nb_hws,
|
||
|
uint16_t nb_hwgrp);
|
||
|
void __roc_api roc_sso_rsrc_fini(struct roc_sso *roc_sso);
|
||
|
int __roc_api roc_sso_hwgrp_qos_config(struct roc_sso *roc_sso,
|
||
|
struct roc_sso_hwgrp_qos *qos,
|
||
|
uint8_t nb_qos, uint32_t nb_xaq);
|
||
|
int __roc_api roc_sso_hwgrp_alloc_xaq(struct roc_sso *roc_sso,
|
||
|
uint32_t npa_aura_id, uint16_t hwgrps);
|
||
|
int __roc_api roc_sso_hwgrp_release_xaq(struct roc_sso *roc_sso,
|
||
|
uint16_t hwgrps);
|
||
|
int __roc_api roc_sso_hwgrp_set_priority(struct roc_sso *roc_sso,
|
||
|
uint16_t hwgrp, uint8_t weight,
|
||
|
uint8_t affinity, uint8_t priority);
|
||
|
uint64_t __roc_api roc_sso_ns_to_gw(struct roc_sso *roc_sso, uint64_t ns);
|
||
|
int __roc_api roc_sso_hws_link(struct roc_sso *roc_sso, uint8_t hws,
|
||
|
uint16_t hwgrp[], uint16_t nb_hwgrp);
|
||
|
int __roc_api roc_sso_hws_unlink(struct roc_sso *roc_sso, uint8_t hws,
|
||
|
uint16_t hwgrp[], uint16_t nb_hwgrp);
|
||
|
int __roc_api roc_sso_hwgrp_hws_link_status(struct roc_sso *roc_sso,
|
||
|
uint8_t hws, uint16_t hwgrp);
|
||
|
uintptr_t __roc_api roc_sso_hws_base_get(struct roc_sso *roc_sso, uint8_t hws);
|
||
|
uintptr_t __roc_api roc_sso_hwgrp_base_get(struct roc_sso *roc_sso,
|
||
|
uint16_t hwgrp);
|
||
|
int __roc_api roc_sso_hwgrp_init_xaq_aura(struct roc_sso *roc_sso,
|
||
|
uint32_t nb_xae);
|
||
|
int __roc_api roc_sso_hwgrp_free_xaq_aura(struct roc_sso *roc_sso,
|
||
|
uint16_t nb_hwgrp);
|
||
|
|
||
|
/* Debug */
|
||
|
void __roc_api roc_sso_dump(struct roc_sso *roc_sso, uint8_t nb_hws,
|
||
|
uint16_t hwgrp, FILE *f);
|
||
|
int __roc_api roc_sso_hwgrp_stats_get(struct roc_sso *roc_sso, uint8_t hwgrp,
|
||
|
struct roc_sso_hwgrp_stats *stats);
|
||
|
int __roc_api roc_sso_hws_stats_get(struct roc_sso *roc_sso, uint8_t hws,
|
||
|
struct roc_sso_hws_stats *stats);
|
||
|
|
||
|
#endif /* _ROC_SSOW_H_ */
|