1 /* SPDX-License-Identifier: GPL-2.0 2 * Marvell OcteonTx2 RVU Ethernet driver 3 * 4 * Copyright (C) 2020 Marvell. 5 */ 6 7 #ifndef CN10K_H 8 #define CN10K_H 9 10 #include "otx2_common.h" 11 12 void cn10k_refill_pool_ptrs(void *dev, struct otx2_cq_queue *cq); 13 void cn10k_sqe_flush(void *dev, struct otx2_snd_queue *sq, int size, int qidx); 14 int cn10k_sq_aq_init(void *dev, u16 qidx, u16 sqb_aura); 15 int cn10k_lmtst_init(struct otx2_nic *pfvf); 16 int cn10k_free_all_ipolicers(struct otx2_nic *pfvf); 17 int cn10k_alloc_matchall_ipolicer(struct otx2_nic *pfvf); 18 int cn10k_free_matchall_ipolicer(struct otx2_nic *pfvf); 19 int cn10k_set_matchall_ipolicer_rate(struct otx2_nic *pfvf, 20 u32 burst, u64 rate); 21 int cn10k_map_unmap_rq_policer(struct otx2_nic *pfvf, int rq_idx, 22 u16 policer, bool map); 23 int cn10k_alloc_leaf_profile(struct otx2_nic *pfvf, u16 *leaf); 24 int cn10k_set_ipolicer_rate(struct otx2_nic *pfvf, u16 profile, 25 u32 burst, u64 rate, bool pps); 26 int cn10k_free_leaf_profile(struct otx2_nic *pfvf, u16 leaf); 27 #endif /* CN10K_H */ 28