1c1191a19SLeon Romanovsky /* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
2fc385b7aSMark Bloch /*
3fc385b7aSMark Bloch  * Copyright (c) 2018 Mellanox Technologies. All rights reserved.
4fc385b7aSMark Bloch  */
5fc385b7aSMark Bloch 
6fc385b7aSMark Bloch #ifndef __MLX5_IB_REP_H__
7fc385b7aSMark Bloch #define __MLX5_IB_REP_H__
8fc385b7aSMark Bloch 
9fc385b7aSMark Bloch #include <linux/mlx5/eswitch.h>
10fc385b7aSMark Bloch #include "mlx5_ib.h"
11fc385b7aSMark Bloch 
12fc385b7aSMark Bloch #ifdef CONFIG_MLX5_ESWITCH
13fc385b7aSMark Bloch u8 mlx5_ib_eswitch_mode(struct mlx5_eswitch *esw);
14fc385b7aSMark Bloch struct mlx5_ib_dev *mlx5_ib_get_rep_ibdev(struct mlx5_eswitch *esw,
15fc385b7aSMark Bloch 					  int vport_index);
16b5ca15adSMark Bloch struct mlx5_ib_dev *mlx5_ib_get_uplink_ibdev(struct mlx5_eswitch *esw);
17fc385b7aSMark Bloch struct mlx5_eswitch_rep *mlx5_ib_vport_rep(struct mlx5_eswitch *esw,
18fc385b7aSMark Bloch 					   int vport_index);
19fc385b7aSMark Bloch void mlx5_ib_register_vport_reps(struct mlx5_ib_dev *dev);
20fc385b7aSMark Bloch void mlx5_ib_unregister_vport_reps(struct mlx5_ib_dev *dev);
21b96c9ddeSMark Bloch int create_flow_rule_vport_sq(struct mlx5_ib_dev *dev,
22b96c9ddeSMark Bloch 			      struct mlx5_ib_sq *sq);
23bcf87f1dSMark Bloch struct net_device *mlx5_ib_get_rep_netdev(struct mlx5_eswitch *esw,
24bcf87f1dSMark Bloch 					  int vport_index);
25fc385b7aSMark Bloch #else /* CONFIG_MLX5_ESWITCH */
26fc385b7aSMark Bloch static inline u8 mlx5_ib_eswitch_mode(struct mlx5_eswitch *esw)
27fc385b7aSMark Bloch {
28fc385b7aSMark Bloch 	return SRIOV_NONE;
29fc385b7aSMark Bloch }
30fc385b7aSMark Bloch 
31fc385b7aSMark Bloch static inline
32fc385b7aSMark Bloch struct mlx5_ib_dev *mlx5_ib_get_rep_ibdev(struct mlx5_eswitch *esw,
33fc385b7aSMark Bloch 					  int vport_index)
34fc385b7aSMark Bloch {
35fc385b7aSMark Bloch 	return NULL;
36fc385b7aSMark Bloch }
37fc385b7aSMark Bloch 
38fc385b7aSMark Bloch static inline
39b5ca15adSMark Bloch struct mlx5_ib_dev *mlx5_ib_get_uplink_ibdev(struct mlx5_eswitch *esw)
40b5ca15adSMark Bloch {
41b5ca15adSMark Bloch 	return NULL;
42b5ca15adSMark Bloch }
43b5ca15adSMark Bloch 
44b5ca15adSMark Bloch static inline
45fc385b7aSMark Bloch struct mlx5_eswitch_rep *mlx5_ib_vport_rep(struct mlx5_eswitch *esw,
46fc385b7aSMark Bloch 					   int vport_index)
47fc385b7aSMark Bloch {
48fc385b7aSMark Bloch 	return NULL;
49fc385b7aSMark Bloch }
50fc385b7aSMark Bloch 
51fc385b7aSMark Bloch static inline void mlx5_ib_register_vport_reps(struct mlx5_ib_dev *dev) {}
52fc385b7aSMark Bloch static inline void mlx5_ib_unregister_vport_reps(struct mlx5_ib_dev *dev) {}
53b96c9ddeSMark Bloch static inline int create_flow_rule_vport_sq(struct mlx5_ib_dev *dev,
54b96c9ddeSMark Bloch 					    struct mlx5_ib_sq *sq)
55b96c9ddeSMark Bloch {
56b96c9ddeSMark Bloch 	return 0;
57b96c9ddeSMark Bloch }
58b96c9ddeSMark Bloch 
59bcf87f1dSMark Bloch static inline
60bcf87f1dSMark Bloch struct net_device *mlx5_ib_get_rep_netdev(struct mlx5_eswitch *esw,
61bcf87f1dSMark Bloch 					  int vport_index)
62bcf87f1dSMark Bloch {
63bcf87f1dSMark Bloch 	return NULL;
64bcf87f1dSMark Bloch }
65fc385b7aSMark Bloch #endif
66fc385b7aSMark Bloch 
67fc385b7aSMark Bloch static inline
68fc385b7aSMark Bloch struct mlx5_ib_dev *mlx5_ib_rep_to_dev(struct mlx5_eswitch_rep *rep)
69fc385b7aSMark Bloch {
70fc385b7aSMark Bloch 	return (struct mlx5_ib_dev *)rep->rep_if[REP_IB].priv;
71fc385b7aSMark Bloch }
72fc385b7aSMark Bloch #endif /* __MLX5_IB_REP_H__ */
73