mirror of https://github.com/F-Stack/f-stack.git
264 lines
9.6 KiB
C
264 lines
9.6 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(C) 2021 Marvell.
|
|
*/
|
|
#ifndef _ROC_NIX_INL_H_
|
|
#define _ROC_NIX_INL_H_
|
|
|
|
/* ONF INB HW area */
|
|
#define ROC_NIX_INL_ONF_IPSEC_INB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_onf_ipsec_inb_sa), ROC_ALIGN)
|
|
/* ONF INB SW reserved area */
|
|
#define ROC_NIX_INL_ONF_IPSEC_INB_SW_RSVD 384
|
|
#define ROC_NIX_INL_ONF_IPSEC_INB_SA_SZ \
|
|
(ROC_NIX_INL_ONF_IPSEC_INB_HW_SZ + ROC_NIX_INL_ONF_IPSEC_INB_SW_RSVD)
|
|
#define ROC_NIX_INL_ONF_IPSEC_INB_SA_SZ_LOG2 9
|
|
|
|
/* ONF OUTB HW area */
|
|
#define ROC_NIX_INL_ONF_IPSEC_OUTB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_onf_ipsec_outb_sa), ROC_ALIGN)
|
|
/* ONF OUTB SW reserved area */
|
|
#define ROC_NIX_INL_ONF_IPSEC_OUTB_SW_RSVD 128
|
|
#define ROC_NIX_INL_ONF_IPSEC_OUTB_SA_SZ \
|
|
(ROC_NIX_INL_ONF_IPSEC_OUTB_HW_SZ + ROC_NIX_INL_ONF_IPSEC_OUTB_SW_RSVD)
|
|
#define ROC_NIX_INL_ONF_IPSEC_OUTB_SA_SZ_LOG2 8
|
|
|
|
/* ON INB HW area */
|
|
#define ROC_NIX_INL_ON_IPSEC_INB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_ie_on_inb_sa), ROC_ALIGN)
|
|
/* ON INB SW reserved area */
|
|
#define ROC_NIX_INL_ON_IPSEC_INB_SW_RSVD 640
|
|
#define ROC_NIX_INL_ON_IPSEC_INB_SA_SZ \
|
|
(ROC_NIX_INL_ON_IPSEC_INB_HW_SZ + ROC_NIX_INL_ON_IPSEC_INB_SW_RSVD)
|
|
#define ROC_NIX_INL_ON_IPSEC_INB_SA_SZ_LOG2 10
|
|
|
|
/* ONF OUTB HW area */
|
|
#define ROC_NIX_INL_ON_IPSEC_OUTB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_ie_on_outb_sa), ROC_ALIGN)
|
|
/* ONF OUTB SW reserved area */
|
|
#define ROC_NIX_INL_ON_IPSEC_OUTB_SW_RSVD 256
|
|
#define ROC_NIX_INL_ON_IPSEC_OUTB_SA_SZ \
|
|
(ROC_NIX_INL_ON_IPSEC_OUTB_HW_SZ + ROC_NIX_INL_ON_IPSEC_OUTB_SW_RSVD)
|
|
#define ROC_NIX_INL_ON_IPSEC_OUTB_SA_SZ_LOG2 9
|
|
|
|
/* OT INB HW area */
|
|
#define ROC_NIX_INL_OT_IPSEC_INB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_ot_ipsec_inb_sa), ROC_ALIGN)
|
|
/* OT INB SW reserved area */
|
|
#define ROC_NIX_INL_OT_IPSEC_INB_SW_RSVD 128
|
|
#define ROC_NIX_INL_OT_IPSEC_INB_SA_SZ \
|
|
(ROC_NIX_INL_OT_IPSEC_INB_HW_SZ + ROC_NIX_INL_OT_IPSEC_INB_SW_RSVD)
|
|
#define ROC_NIX_INL_OT_IPSEC_INB_SA_SZ_LOG2 10
|
|
|
|
/* OT OUTB HW area */
|
|
#define ROC_NIX_INL_OT_IPSEC_OUTB_HW_SZ \
|
|
PLT_ALIGN(sizeof(struct roc_ot_ipsec_outb_sa), ROC_ALIGN)
|
|
/* OT OUTB SW reserved area */
|
|
#define ROC_NIX_INL_OT_IPSEC_OUTB_SW_RSVD 128
|
|
#define ROC_NIX_INL_OT_IPSEC_OUTB_SA_SZ \
|
|
(ROC_NIX_INL_OT_IPSEC_OUTB_HW_SZ + ROC_NIX_INL_OT_IPSEC_OUTB_SW_RSVD)
|
|
#define ROC_NIX_INL_OT_IPSEC_OUTB_SA_SZ_LOG2 9
|
|
|
|
/* Alignment of SA Base */
|
|
#define ROC_NIX_INL_SA_BASE_ALIGN BIT_ULL(16)
|
|
|
|
#define ROC_NIX_INL_SA_SOFT_EXP_ERR_MAX_POLL_COUNT 25
|
|
|
|
#define ROC_NIX_SOFT_EXP_ERR_RING_MAX_ENTRY_LOG2 16
|
|
|
|
#define ROC_NIX_SOFT_EXP_PER_PORT_MAX_RINGS 4
|
|
|
|
#define ROC_NIX_MAX_TOTAL_OUTB_IPSEC_SA \
|
|
(ROC_IPSEC_ERR_RING_MAX_ENTRY * ROC_NIX_SOFT_EXP_PER_PORT_MAX_RINGS)
|
|
|
|
#define ROC_NIX_INL_MAX_SOFT_EXP_RNGS \
|
|
(PLT_MAX_ETHPORTS * ROC_NIX_SOFT_EXP_PER_PORT_MAX_RINGS)
|
|
|
|
/* Reassembly configuration */
|
|
#define ROC_NIX_INL_REAS_ACTIVE_LIMIT 0xFFF
|
|
#define ROC_NIX_INL_REAS_ACTIVE_THRESHOLD 10
|
|
#define ROC_NIX_INL_REAS_ZOMBIE_LIMIT 0xFFF
|
|
#define ROC_NIX_INL_REAS_ZOMBIE_THRESHOLD 10
|
|
|
|
static inline struct roc_ie_on_inb_sa *
|
|
roc_nix_inl_on_ipsec_inb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_ON_IPSEC_INB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline struct roc_ie_on_outb_sa *
|
|
roc_nix_inl_on_ipsec_outb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_ON_IPSEC_OUTB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_on_ipsec_inb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_ON_IPSEC_INB_HW_SZ);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_on_ipsec_outb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_ON_IPSEC_OUTB_HW_SZ);
|
|
}
|
|
|
|
static inline struct roc_onf_ipsec_inb_sa *
|
|
roc_nix_inl_onf_ipsec_inb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_ONF_IPSEC_INB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline struct roc_onf_ipsec_outb_sa *
|
|
roc_nix_inl_onf_ipsec_outb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_ONF_IPSEC_OUTB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_onf_ipsec_inb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_ONF_IPSEC_INB_HW_SZ);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_onf_ipsec_outb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_ONF_IPSEC_OUTB_HW_SZ);
|
|
}
|
|
|
|
static inline struct roc_ot_ipsec_inb_sa *
|
|
roc_nix_inl_ot_ipsec_inb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_OT_IPSEC_INB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline struct roc_ot_ipsec_outb_sa *
|
|
roc_nix_inl_ot_ipsec_outb_sa(uintptr_t base, uint64_t idx)
|
|
{
|
|
uint64_t off = idx << ROC_NIX_INL_OT_IPSEC_OUTB_SA_SZ_LOG2;
|
|
|
|
return PLT_PTR_ADD(base, off);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_ot_ipsec_inb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_OT_IPSEC_INB_HW_SZ);
|
|
}
|
|
|
|
static inline void *
|
|
roc_nix_inl_ot_ipsec_outb_sa_sw_rsvd(void *sa)
|
|
{
|
|
return PLT_PTR_ADD(sa, ROC_NIX_INL_OT_IPSEC_OUTB_HW_SZ);
|
|
}
|
|
|
|
/* Inline device SSO Work callback */
|
|
typedef void (*roc_nix_inl_sso_work_cb_t)(uint64_t *gw, void *args,
|
|
uint32_t soft_exp_event);
|
|
|
|
typedef int (*roc_nix_inl_meta_pool_cb_t)(uint64_t *aura_handle, uint32_t blk_sz, uint32_t nb_bufs,
|
|
bool destroy);
|
|
|
|
struct roc_nix_inl_dev {
|
|
/* Input parameters */
|
|
struct plt_pci_device *pci_dev;
|
|
uint32_t ipsec_in_min_spi;
|
|
uint32_t ipsec_in_max_spi;
|
|
bool selftest;
|
|
bool is_multi_channel;
|
|
uint16_t channel;
|
|
uint16_t chan_mask;
|
|
bool attach_cptlf;
|
|
uint16_t wqe_skip;
|
|
uint8_t spb_drop_pc;
|
|
uint8_t lpb_drop_pc;
|
|
uint32_t soft_exp_poll_freq; /* Polling disabled if 0 */
|
|
uint32_t nb_meta_bufs;
|
|
uint32_t meta_buf_sz;
|
|
/* End of input parameters */
|
|
|
|
#define ROC_NIX_INL_MEM_SZ (1280)
|
|
uint8_t reserved[ROC_NIX_INL_MEM_SZ] __plt_cache_aligned;
|
|
} __plt_cache_aligned;
|
|
|
|
/* NIX Inline Device API */
|
|
int __roc_api roc_nix_inl_dev_init(struct roc_nix_inl_dev *roc_inl_dev);
|
|
int __roc_api roc_nix_inl_dev_fini(struct roc_nix_inl_dev *roc_inl_dev);
|
|
void __roc_api roc_nix_inl_dev_dump(struct roc_nix_inl_dev *roc_inl_dev, FILE *file);
|
|
bool __roc_api roc_nix_inl_dev_is_probed(void);
|
|
void __roc_api roc_nix_inl_dev_lock(void);
|
|
void __roc_api roc_nix_inl_dev_unlock(void);
|
|
int __roc_api roc_nix_inl_dev_xaq_realloc(uint64_t aura_handle);
|
|
uint16_t __roc_api roc_nix_inl_dev_pffunc_get(void);
|
|
|
|
/* NIX Inline Inbound API */
|
|
int __roc_api roc_nix_inl_inb_init(struct roc_nix *roc_nix);
|
|
int __roc_api roc_nix_inl_inb_fini(struct roc_nix *roc_nix);
|
|
bool __roc_api roc_nix_inl_inb_is_enabled(struct roc_nix *roc_nix);
|
|
uintptr_t __roc_api roc_nix_inl_inb_sa_base_get(struct roc_nix *roc_nix,
|
|
bool inl_dev_sa);
|
|
uint32_t __roc_api roc_nix_inl_inb_spi_range(struct roc_nix *roc_nix,
|
|
bool inl_dev_sa, uint32_t *min,
|
|
uint32_t *max);
|
|
uint32_t __roc_api roc_nix_inl_inb_sa_sz(struct roc_nix *roc_nix,
|
|
bool inl_dev_sa);
|
|
uintptr_t __roc_api roc_nix_inl_inb_sa_get(struct roc_nix *roc_nix,
|
|
bool inl_dev_sa, uint32_t spi);
|
|
void __roc_api roc_nix_inb_mode_set(struct roc_nix *roc_nix, bool use_inl_dev);
|
|
void __roc_api roc_nix_inl_inb_set(struct roc_nix *roc_nix, bool ena);
|
|
int __roc_api roc_nix_inl_dev_rq_get(struct roc_nix_rq *rq, bool ena);
|
|
int __roc_api roc_nix_inl_dev_rq_put(struct roc_nix_rq *rq);
|
|
bool __roc_api roc_nix_inb_is_with_inl_dev(struct roc_nix *roc_nix);
|
|
struct roc_nix_rq *__roc_api roc_nix_inl_dev_rq(struct roc_nix *roc_nix);
|
|
int __roc_api roc_nix_inl_inb_tag_update(struct roc_nix *roc_nix,
|
|
uint32_t tag_const, uint8_t tt);
|
|
int __roc_api roc_nix_reassembly_configure(uint32_t max_wait_time,
|
|
uint16_t max_frags);
|
|
int __roc_api roc_nix_inl_ts_pkind_set(struct roc_nix *roc_nix, bool ts_ena,
|
|
bool inb_inl_dev);
|
|
int __roc_api roc_nix_inl_rq_ena_dis(struct roc_nix *roc_nix, bool ena);
|
|
int __roc_api roc_nix_inl_meta_aura_check(struct roc_nix_rq *rq);
|
|
bool __roc_api roc_nix_has_reass_support(struct roc_nix *nix);
|
|
|
|
/* NIX Inline Outbound API */
|
|
int __roc_api roc_nix_inl_outb_init(struct roc_nix *roc_nix);
|
|
int __roc_api roc_nix_inl_outb_fini(struct roc_nix *roc_nix);
|
|
bool __roc_api roc_nix_inl_outb_is_enabled(struct roc_nix *roc_nix);
|
|
uintptr_t __roc_api roc_nix_inl_outb_sa_base_get(struct roc_nix *roc_nix);
|
|
struct roc_cpt_lf *__roc_api
|
|
roc_nix_inl_outb_lf_base_get(struct roc_nix *roc_nix);
|
|
uint16_t __roc_api roc_nix_inl_outb_sso_pffunc_get(struct roc_nix *roc_nix);
|
|
int __roc_api roc_nix_inl_cb_register(roc_nix_inl_sso_work_cb_t cb, void *args);
|
|
int __roc_api roc_nix_inl_cb_unregister(roc_nix_inl_sso_work_cb_t cb,
|
|
void *args);
|
|
int __roc_api roc_nix_inl_outb_soft_exp_poll_switch(struct roc_nix *roc_nix,
|
|
bool poll);
|
|
uint64_t *__roc_api roc_nix_inl_outb_ring_base_get(struct roc_nix *roc_nix);
|
|
void __roc_api roc_nix_inl_meta_pool_cb_register(roc_nix_inl_meta_pool_cb_t cb);
|
|
|
|
/* NIX Inline/Outbound API */
|
|
enum roc_nix_inl_sa_sync_op {
|
|
ROC_NIX_INL_SA_OP_FLUSH,
|
|
ROC_NIX_INL_SA_OP_FLUSH_INVAL,
|
|
ROC_NIX_INL_SA_OP_RELOAD,
|
|
};
|
|
|
|
int __roc_api roc_nix_inl_sa_sync(struct roc_nix *roc_nix, void *sa, bool inb,
|
|
enum roc_nix_inl_sa_sync_op op);
|
|
int __roc_api roc_nix_inl_ctx_write(struct roc_nix *roc_nix, void *sa_dptr,
|
|
void *sa_cptr, bool inb, uint16_t sa_len);
|
|
void __roc_api roc_nix_inl_outb_cpt_lfs_dump(struct roc_nix *roc_nix, FILE *file);
|
|
|
|
#endif /* _ROC_NIX_INL_H_ */
|