/* Constants */
#define ROC_NIX_BPF_PER_PFFUNC 64
+#define ROC_NIX_BPF_ID_INVALID 0xFFFF
#define ROC_NIX_BPF_LEVEL_IDX_INVALID 0xFF
#define ROC_NIX_BPF_LEVEL_MAX 3
+#define ROC_NIX_BPF_STATS_MAX 12
enum roc_nix_rss_reta_sz {
ROC_NIX_RSS_RETA_SZ_64 = 64,
ROC_NIX_BPF_ACTION_RED
};
+enum roc_nix_bpf_stats {
+ ROC_NIX_BPF_GREEN_PKT_F_PASS = BIT_ULL(0),
+ ROC_NIX_BPF_GREEN_OCTS_F_PASS = BIT_ULL(1),
+ ROC_NIX_BPF_GREEN_PKT_F_DROP = BIT_ULL(2),
+ ROC_NIX_BPF_GREEN_OCTS_F_DROP = BIT_ULL(3),
+ ROC_NIX_BPF_YELLOW_PKT_F_PASS = BIT_ULL(4),
+ ROC_NIX_BPF_YELLOW_OCTS_F_PASS = BIT_ULL(5),
+ ROC_NIX_BPF_YELLOW_PKT_F_DROP = BIT_ULL(6),
+ ROC_NIX_BPF_YELLOW_OCTS_F_DROP = BIT_ULL(7),
+ ROC_NIX_BPF_RED_PKT_F_PASS = BIT_ULL(8),
+ ROC_NIX_BPF_RED_OCTS_F_PASS = BIT_ULL(9),
+ ROC_NIX_BPF_RED_PKT_F_DROP = BIT_ULL(10),
+ ROC_NIX_BPF_RED_OCTS_F_DROP = BIT_ULL(11),
+};
+
struct roc_nix_bpf_cfg {
enum roc_nix_bpf_algo alg;
enum roc_nix_bpf_lmode lmode;
uint16_t ids[ROC_NIX_BPF_PER_PFFUNC];
};
+struct roc_nix_bpf_precolor {
+#define ROC_NIX_BPF_PRE_COLOR_MAX 64
+ uint8_t count;
+ enum roc_nix_bpf_pc_mode mode;
+ enum roc_nix_bpf_color color[ROC_NIX_BPF_PRE_COLOR_MAX];
+};
+
struct roc_nix_vlan_config {
uint32_t type;
union {
int __roc_api roc_nix_lf_free(struct roc_nix *roc_nix);
int __roc_api roc_nix_lf_inl_ipsec_cfg(struct roc_nix *roc_nix,
struct roc_nix_ipsec_cfg *cfg, bool enb);
+int __roc_api roc_nix_cpt_ctx_cache_sync(struct roc_nix *roc_nix);
/* Debug */
int __roc_api roc_nix_lf_get_reg_count(struct roc_nix *roc_nix);
int __roc_api roc_nix_bpf_ena_dis(struct roc_nix *roc_nix, uint16_t id,
struct roc_nix_rq *rq, bool enable);
+int __roc_api roc_nix_bpf_dump(struct roc_nix *roc_nix, uint16_t id,
+ enum roc_nix_bpf_level_flag lvl_flag);
+
+int __roc_api roc_nix_bpf_pre_color_tbl_setup(
+ struct roc_nix *roc_nix, uint16_t id,
+ enum roc_nix_bpf_level_flag lvl_flag, struct roc_nix_bpf_precolor *tbl);
+
+/* Use ROC_NIX_BPF_ID_INVALID as dst_id to disconnect */
+int __roc_api roc_nix_bpf_connect(struct roc_nix *roc_nix,
+ enum roc_nix_bpf_level_flag lvl_flag,
+ uint16_t src_id, uint16_t dst_id);
+
+int __roc_api
+roc_nix_bpf_stats_read(struct roc_nix *roc_nix, uint16_t id, uint64_t mask,
+ enum roc_nix_bpf_level_flag lvl_flag,
+ uint64_t stats[ROC_NIX_BPF_STATS_MAX] /* Out */);
+
+int __roc_api roc_nix_bpf_stats_reset(struct roc_nix *roc_nix, uint16_t id,
+ uint64_t mask,
+ enum roc_nix_bpf_level_flag lvl_flag);
+
+int __roc_api
+roc_nix_bpf_lf_stats_read(struct roc_nix *roc_nix, uint64_t mask,
+ uint64_t stats[ROC_NIX_BPF_STATS_MAX] /* Out */);
+
+int __roc_api roc_nix_bpf_lf_stats_reset(struct roc_nix *roc_nix,
+ uint64_t mask);
+
uint8_t __roc_api
roc_nix_bpf_level_to_idx(enum roc_nix_bpf_level_flag lvl_flag);
+uint8_t __roc_api roc_nix_bpf_stats_to_idx(enum roc_nix_bpf_stats lvl_flag);
+
/* MAC */
int __roc_api roc_nix_mac_rxtx_start_stop(struct roc_nix *roc_nix, bool start);
int __roc_api roc_nix_mac_link_event_start_stop(struct roc_nix *roc_nix,