1e6e01b5fSMaxim Mikityanskiy // SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
2e6e01b5fSMaxim Mikityanskiy /* Copyright (c) 2021, Mellanox Technologies inc. All rights reserved. */
3e6e01b5fSMaxim Mikityanskiy 
4e6e01b5fSMaxim Mikityanskiy #include "channels.h"
5e6e01b5fSMaxim Mikityanskiy #include "en.h"
6e6e01b5fSMaxim Mikityanskiy #include "en/ptp.h"
7e6e01b5fSMaxim Mikityanskiy 
mlx5e_channels_get_num(struct mlx5e_channels * chs)8e6e01b5fSMaxim Mikityanskiy unsigned int mlx5e_channels_get_num(struct mlx5e_channels *chs)
9e6e01b5fSMaxim Mikityanskiy {
10e6e01b5fSMaxim Mikityanskiy 	return chs->num;
11e6e01b5fSMaxim Mikityanskiy }
12e6e01b5fSMaxim Mikityanskiy 
mlx5e_channels_get(struct mlx5e_channels * chs,unsigned int ix)13*3db4c85cSMaxim Mikityanskiy static struct mlx5e_channel *mlx5e_channels_get(struct mlx5e_channels *chs, unsigned int ix)
14*3db4c85cSMaxim Mikityanskiy {
15*3db4c85cSMaxim Mikityanskiy 	WARN_ON_ONCE(ix >= mlx5e_channels_get_num(chs));
16*3db4c85cSMaxim Mikityanskiy 	return chs->c[ix];
17*3db4c85cSMaxim Mikityanskiy }
18*3db4c85cSMaxim Mikityanskiy 
mlx5e_channels_is_xsk(struct mlx5e_channels * chs,unsigned int ix)19*3db4c85cSMaxim Mikityanskiy bool mlx5e_channels_is_xsk(struct mlx5e_channels *chs, unsigned int ix)
20*3db4c85cSMaxim Mikityanskiy {
21*3db4c85cSMaxim Mikityanskiy 	struct mlx5e_channel *c = mlx5e_channels_get(chs, ix);
22*3db4c85cSMaxim Mikityanskiy 
23*3db4c85cSMaxim Mikityanskiy 	return test_bit(MLX5E_CHANNEL_STATE_XSK, c->state);
24*3db4c85cSMaxim Mikityanskiy }
25*3db4c85cSMaxim Mikityanskiy 
mlx5e_channels_get_regular_rqn(struct mlx5e_channels * chs,unsigned int ix,u32 * rqn)26e6e01b5fSMaxim Mikityanskiy void mlx5e_channels_get_regular_rqn(struct mlx5e_channels *chs, unsigned int ix, u32 *rqn)
27e6e01b5fSMaxim Mikityanskiy {
28*3db4c85cSMaxim Mikityanskiy 	struct mlx5e_channel *c = mlx5e_channels_get(chs, ix);
29e6e01b5fSMaxim Mikityanskiy 
30e6e01b5fSMaxim Mikityanskiy 	*rqn = c->rq.rqn;
31e6e01b5fSMaxim Mikityanskiy }
32e6e01b5fSMaxim Mikityanskiy 
mlx5e_channels_get_xsk_rqn(struct mlx5e_channels * chs,unsigned int ix,u32 * rqn)33*3db4c85cSMaxim Mikityanskiy void mlx5e_channels_get_xsk_rqn(struct mlx5e_channels *chs, unsigned int ix, u32 *rqn)
34e6e01b5fSMaxim Mikityanskiy {
35*3db4c85cSMaxim Mikityanskiy 	struct mlx5e_channel *c = mlx5e_channels_get(chs, ix);
36e6e01b5fSMaxim Mikityanskiy 
37*3db4c85cSMaxim Mikityanskiy 	WARN_ON_ONCE(!test_bit(MLX5E_CHANNEL_STATE_XSK, c->state));
38e6e01b5fSMaxim Mikityanskiy 
39e6e01b5fSMaxim Mikityanskiy 	*rqn = c->xskrq.rqn;
40e6e01b5fSMaxim Mikityanskiy }
41e6e01b5fSMaxim Mikityanskiy 
mlx5e_channels_get_ptp_rqn(struct mlx5e_channels * chs,u32 * rqn)42e6e01b5fSMaxim Mikityanskiy bool mlx5e_channels_get_ptp_rqn(struct mlx5e_channels *chs, u32 *rqn)
43e6e01b5fSMaxim Mikityanskiy {
44e6e01b5fSMaxim Mikityanskiy 	struct mlx5e_ptp *c = chs->ptp;
45e6e01b5fSMaxim Mikityanskiy 
46e6e01b5fSMaxim Mikityanskiy 	if (!c || !test_bit(MLX5E_PTP_STATE_RX, c->state))
47e6e01b5fSMaxim Mikityanskiy 		return false;
48e6e01b5fSMaxim Mikityanskiy 
49e6e01b5fSMaxim Mikityanskiy 	*rqn = c->rq.rqn;
50e6e01b5fSMaxim Mikityanskiy 	return true;
51e6e01b5fSMaxim Mikityanskiy }
52