mirror of https://github.com/F-Stack/f-stack.git
124 lines
3.5 KiB
C
124 lines
3.5 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 uint64_t
|
|
roc_sso_hws_head_wait(uintptr_t base)
|
|
{
|
|
uintptr_t tag_op = base + SSOW_LF_GWS_TAG;
|
|
uint64_t tag;
|
|
|
|
#if defined(__aarch64__)
|
|
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
|
|
do {
|
|
tag = plt_read64(tag_op);
|
|
} while (!(tag & BIT_ULL(35)));
|
|
#endif
|
|
return tag;
|
|
}
|
|
|
|
/* 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);
|
|
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_ */
|