mirror of https://github.com/F-Stack/f-stack.git
189 lines
4.6 KiB
C
189 lines
4.6 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(c) 2014-2021 Broadcom
|
|
* All rights reserved.
|
|
*/
|
|
|
|
#ifndef _ULP_FC_MGR_H_
|
|
#define _ULP_FC_MGR_H_
|
|
|
|
#include "bnxt_ulp.h"
|
|
#include "tf_core.h"
|
|
|
|
#define ULP_FLAG_FC_THREAD BIT(0)
|
|
#define ULP_FC_TIMER 1/* Timer freq in Sec Flow Counters */
|
|
|
|
/* Macros to extract packet/byte counters from a 64-bit flow counter. */
|
|
#define FLOW_CNTR_BYTE_WIDTH 36
|
|
#define FLOW_CNTR_BYTE_MASK (((uint64_t)1 << FLOW_CNTR_BYTE_WIDTH) - 1)
|
|
|
|
#define FLOW_CNTR_PKTS(v, d) (((v) & (d)->packet_count_mask) >> \
|
|
(d)->packet_count_shift)
|
|
#define FLOW_CNTR_BYTES(v, d) (((v) & (d)->byte_count_mask) >> \
|
|
(d)->byte_count_shift)
|
|
|
|
#define FLOW_CNTR_PC_FLOW_VALID 0x1000000
|
|
|
|
struct sw_acc_counter {
|
|
uint64_t pkt_count;
|
|
uint64_t byte_count;
|
|
bool valid;
|
|
uint32_t hw_cntr_id;
|
|
uint32_t pc_flow_idx;
|
|
};
|
|
|
|
struct hw_fc_mem_info {
|
|
/*
|
|
* [out] mem_va, pointer to the allocated memory.
|
|
*/
|
|
void *mem_va;
|
|
/*
|
|
* [out] mem_pa, physical address of the allocated memory.
|
|
*/
|
|
void *mem_pa;
|
|
uint32_t start_idx;
|
|
bool start_idx_is_set;
|
|
};
|
|
|
|
struct bnxt_ulp_fc_info {
|
|
struct sw_acc_counter *sw_acc_tbl[TF_DIR_MAX];
|
|
struct hw_fc_mem_info shadow_hw_tbl[TF_DIR_MAX];
|
|
uint32_t flags;
|
|
uint32_t num_entries;
|
|
pthread_mutex_t fc_lock;
|
|
uint32_t num_counters;
|
|
};
|
|
|
|
int32_t
|
|
ulp_fc_mgr_init(struct bnxt_ulp_context *ctxt);
|
|
|
|
/*
|
|
* Release all resources in the flow counter manager for this ulp context
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*/
|
|
int32_t
|
|
ulp_fc_mgr_deinit(struct bnxt_ulp_context *ctxt);
|
|
|
|
/*
|
|
* Setup the Flow counter timer thread that will fetch/accumulate raw counter
|
|
* data from the chip's internal flow counters
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*/
|
|
int32_t
|
|
ulp_fc_mgr_thread_start(struct bnxt_ulp_context *ctxt);
|
|
|
|
/*
|
|
* Alarm handler that will issue the TF-Core API to fetch
|
|
* data from the chip's internal flow counters
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*/
|
|
void
|
|
ulp_fc_mgr_alarm_cb(void *arg);
|
|
|
|
/*
|
|
* Cancel the alarm handler
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
*/
|
|
void ulp_fc_mgr_thread_cancel(struct bnxt_ulp_context *ctxt);
|
|
|
|
/*
|
|
* Set the starting index that indicates the first HW flow
|
|
* counter ID
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* dir [in] The direction of the flow
|
|
*
|
|
* start_idx [in] The HW flow counter ID
|
|
*
|
|
*/
|
|
int ulp_fc_mgr_start_idx_set(struct bnxt_ulp_context *ctxt, enum tf_dir dir,
|
|
uint32_t start_idx);
|
|
|
|
/*
|
|
* Set the corresponding SW accumulator table entry based on
|
|
* the difference between this counter ID and the starting
|
|
* counter ID. Also, keep track of num of active counter enabled
|
|
* flows.
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* dir [in] The direction of the flow
|
|
*
|
|
* hw_cntr_id [in] The HW flow counter ID
|
|
*
|
|
*/
|
|
int ulp_fc_mgr_cntr_set(struct bnxt_ulp_context *ctxt, enum tf_dir dir,
|
|
uint32_t hw_cntr_id);
|
|
/*
|
|
* Reset the corresponding SW accumulator table entry based on
|
|
* the difference between this counter ID and the starting
|
|
* counter ID.
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* dir [in] The direction of the flow
|
|
*
|
|
* hw_cntr_id [in] The HW flow counter ID
|
|
*
|
|
*/
|
|
int ulp_fc_mgr_cntr_reset(struct bnxt_ulp_context *ctxt, enum tf_dir dir,
|
|
uint32_t hw_cntr_id);
|
|
/*
|
|
* Check if the starting HW counter ID value is set in the
|
|
* flow counter manager.
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* dir [in] The direction of the flow
|
|
*
|
|
*/
|
|
bool ulp_fc_mgr_start_idx_isset(struct bnxt_ulp_context *ctxt, enum tf_dir dir);
|
|
|
|
/*
|
|
* Check if the alarm thread that walks through the flows is started
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
*/
|
|
bool ulp_fc_mgr_thread_isstarted(struct bnxt_ulp_context *ctxt);
|
|
|
|
/*
|
|
* Fill the rte_flow_query_count 'data' argument passed
|
|
* in the rte_flow_query() with the values obtained and
|
|
* accumulated locally.
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* flow_id [in] The HW flow ID
|
|
*
|
|
* count [out] The rte_flow_query_count 'data' that is set
|
|
*
|
|
*/
|
|
int ulp_fc_mgr_query_count_get(struct bnxt_ulp_context *ulp_ctx,
|
|
uint32_t flow_id,
|
|
struct rte_flow_query_count *count);
|
|
|
|
/*
|
|
* Set the parent flow if in the SW accumulator table entry
|
|
*
|
|
* ctxt [in] The ulp context for the flow counter manager
|
|
*
|
|
* dir [in] The direction of the flow
|
|
*
|
|
* hw_cntr_id [in] The HW flow counter ID
|
|
*
|
|
* pc_idx [in] parent child db index
|
|
*
|
|
*/
|
|
int32_t ulp_fc_mgr_cntr_parent_flow_set(struct bnxt_ulp_context *ctxt,
|
|
enum tf_dir dir,
|
|
uint32_t hw_cntr_id,
|
|
uint32_t pc_idx);
|
|
|
|
#endif /* _ULP_FC_MGR_H_ */
|