1fc385b7aSMark Bloch /* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */ 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