mirror of https://github.com/F-Stack/f-stack.git
62 lines
1.8 KiB
C
62 lines
1.8 KiB
C
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||
|
*
|
||
|
* Copyright(c) 2020-2021 Xilinx, Inc.
|
||
|
*/
|
||
|
|
||
|
#ifndef _SFC_MAE_COUNTER_H
|
||
|
#define _SFC_MAE_COUNTER_H
|
||
|
|
||
|
#include "sfc.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/* Default values for a user of counter RxQ */
|
||
|
#define SFC_MAE_COUNTER_RX_BURST 32
|
||
|
#define SFC_COUNTER_RXQ_RX_DESC_COUNT 256
|
||
|
|
||
|
/*
|
||
|
* The refill level is chosen based on requirement to keep number
|
||
|
* of give credits operations low.
|
||
|
*/
|
||
|
#define SFC_COUNTER_RXQ_REFILL_LEVEL (SFC_COUNTER_RXQ_RX_DESC_COUNT / 4)
|
||
|
|
||
|
/*
|
||
|
* SF-122415-TC states that the packetiser that generates packets for
|
||
|
* counter stream must support 9k frames. Set it to the maximum supported
|
||
|
* size since in case of huge flow of counters, having fewer packets in counter
|
||
|
* updates is better.
|
||
|
*/
|
||
|
#define SFC_MAE_COUNTER_STREAM_PACKET_SIZE 9216
|
||
|
|
||
|
bool sfc_mae_counter_rxq_required(struct sfc_adapter *sa);
|
||
|
|
||
|
int sfc_mae_counter_rxq_attach(struct sfc_adapter *sa);
|
||
|
void sfc_mae_counter_rxq_detach(struct sfc_adapter *sa);
|
||
|
|
||
|
int sfc_mae_counter_rxq_init(struct sfc_adapter *sa);
|
||
|
void sfc_mae_counter_rxq_fini(struct sfc_adapter *sa);
|
||
|
|
||
|
int sfc_mae_counters_init(struct sfc_mae_counters *counters,
|
||
|
uint32_t nb_counters_max);
|
||
|
void sfc_mae_counters_fini(struct sfc_mae_counters *counters);
|
||
|
int sfc_mae_counter_enable(struct sfc_adapter *sa,
|
||
|
struct sfc_mae_counter_id *counterp);
|
||
|
int sfc_mae_counter_disable(struct sfc_adapter *sa,
|
||
|
struct sfc_mae_counter_id *counter);
|
||
|
int sfc_mae_counter_get(struct sfc_mae_counters *counters,
|
||
|
const struct sfc_mae_counter_id *counter,
|
||
|
struct rte_flow_query_count *data);
|
||
|
|
||
|
int sfc_mae_counter_start(struct sfc_adapter *sa);
|
||
|
void sfc_mae_counter_stop(struct sfc_adapter *sa);
|
||
|
|
||
|
/* Check whether MAE Counter-on-Queue (CoQ) prerequisites are satisfied */
|
||
|
bool sfc_mae_counter_stream_enabled(struct sfc_adapter *sa);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
#endif /* _SFC_MAE_COUNTER_H */
|