162306a36Sopenharmony_ci/* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
262306a36Sopenharmony_ci/* Copyright (c) 2021 Marvell International Ltd. All rights reserved. */
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#ifndef _PRESTERA_COUNTER_H_
562306a36Sopenharmony_ci#define _PRESTERA_COUNTER_H_
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#include <linux/types.h>
862306a36Sopenharmony_ci
962306a36Sopenharmony_cistruct prestera_counter_stats {
1062306a36Sopenharmony_ci	u64 packets;
1162306a36Sopenharmony_ci	u64 bytes;
1262306a36Sopenharmony_ci};
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_cistruct prestera_switch;
1562306a36Sopenharmony_cistruct prestera_counter;
1662306a36Sopenharmony_cistruct prestera_counter_block;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ciint prestera_counter_init(struct prestera_switch *sw);
1962306a36Sopenharmony_civoid prestera_counter_fini(struct prestera_switch *sw);
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ciint prestera_counter_get(struct prestera_counter *counter, u32 client,
2262306a36Sopenharmony_ci			 struct prestera_counter_block **block,
2362306a36Sopenharmony_ci			 u32 *counter_id);
2462306a36Sopenharmony_civoid prestera_counter_put(struct prestera_counter *counter,
2562306a36Sopenharmony_ci			  struct prestera_counter_block *block, u32 counter_id);
2662306a36Sopenharmony_ciint prestera_counter_stats_get(struct prestera_counter *counter,
2762306a36Sopenharmony_ci			       struct prestera_counter_block *block,
2862306a36Sopenharmony_ci			       u32 counter_id, u64 *packets, u64 *bytes);
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci#endif /* _PRESTERA_COUNTER_H_ */
31