From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.4 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,NICE_REPLY_A,SIGNED_OFF_BY,SPF_HELO_NONE, SPF_PASS,USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 3744FC388F2 for ; Mon, 2 Nov 2020 14:55:02 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id E3DD42227F for ; Mon, 2 Nov 2020 14:55:01 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=nvidia.com header.i=@nvidia.com header.b="R3mZWX49" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726253AbgKBOzB (ORCPT ); Mon, 2 Nov 2020 09:55:01 -0500 Received: from hqnvemgate24.nvidia.com ([216.228.121.143]:5003 "EHLO hqnvemgate24.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725925AbgKBOzA (ORCPT ); Mon, 2 Nov 2020 09:55:00 -0500 Received: from hqmail.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate24.nvidia.com (using TLS: TLSv1.2, AES256-SHA) id ; Mon, 02 Nov 2020 06:55:03 -0800 Received: from [172.27.13.219] (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Mon, 2 Nov 2020 14:54:51 +0000 Subject: Re: [PATCH mlx5-next v1 10/11] net/mlx5: Simplify eswitch mode check To: Leon Romanovsky , Doug Ledford , Jason Gunthorpe , gregkh CC: Leon Romanovsky , Jakub Kicinski , Jason Wang , , "Michael S. Tsirkin" , , Parav Pandit , Saeed Mahameed , , , , , "David S . Miller" , , , , , , , References: <20201101201542.2027568-1-leon@kernel.org> <20201101201542.2027568-11-leon@kernel.org> From: Roi Dayan Message-ID: Date: Mon, 2 Nov 2020 16:54:49 +0200 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.4.0 MIME-Version: 1.0 In-Reply-To: <20201101201542.2027568-11-leon@kernel.org> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL105.nvidia.com (172.20.187.12) To HQMAIL107.nvidia.com (172.20.187.13) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1604328903; bh=w4bgReo+JKb2pj4MQ9s4f16lHoHnoUxnw6BPra7Cqjg=; h=Subject:To:CC:References:From:Message-ID:Date:User-Agent: MIME-Version:In-Reply-To:Content-Type:Content-Language: Content-Transfer-Encoding:X-Originating-IP:X-ClientProxiedBy; b=R3mZWX49X8p9g0TQ8x4I+hrP7SQW+CHkMfHMiUFZIjkYdZU+uYR55D3WYm/JfILn/ F3/r2/JAmIBGFUCLt/vyiCuFMOnlQneYNBBtlUlplYhof3y52PuC1+hillCaXjotQE drjS+Ei0xx9SOy0tntjurCSdFA3uF9xNVczu7+7injtRV1OIOvkhPgf3U3f/Is3NJU QJhQhEFL+0wpfyZDlm6yYL7HXAmxIWSPQzw0ZmdjC0ANwHe7/ddGu5tTzL2MgXSPgD WPu6KHDS5nOYZGJbxDr1maDtHZ2INw3Wjm/lPfiViCz4XODOERUyyniZCs8nICG55e N3jX1/H08UCpA== Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-11-01 10:15 PM, Leon Romanovsky wrote: > From: Leon Romanovsky > > Provide mlx5_core device instead of "priv" pointer while checking > eswith mode. > > Signed-off-by: Leon Romanovsky > --- > drivers/infiniband/hw/mlx5/counters.c | 7 ------- > drivers/infiniband/hw/mlx5/ib_rep.c | 5 ----- > drivers/infiniband/hw/mlx5/ib_rep.h | 6 ------ > drivers/net/ethernet/mellanox/mlx5/core/dev.c | 4 ++-- > drivers/net/ethernet/mellanox/mlx5/core/devlink.c | 2 +- > drivers/net/ethernet/mellanox/mlx5/core/en_main.c | 2 +- > drivers/net/ethernet/mellanox/mlx5/core/en_tc.c | 8 +++----- > drivers/net/ethernet/mellanox/mlx5/core/eswitch.c | 4 +++- > include/linux/mlx5/eswitch.h | 8 ++++++-- > 9 files changed, 16 insertions(+), 30 deletions(-) > > diff --git a/drivers/infiniband/hw/mlx5/counters.c b/drivers/infiniband/hw/mlx5/counters.c > index 70c8fd67ee2f..084652e2b15a 100644 > --- a/drivers/infiniband/hw/mlx5/counters.c > +++ b/drivers/infiniband/hw/mlx5/counters.c > @@ -138,13 +138,6 @@ static int mlx5_ib_create_counters(struct ib_counters *counters, > } > > > -static bool is_mdev_switchdev_mode(const struct mlx5_core_dev *mdev) > -{ > - return MLX5_ESWITCH_MANAGER(mdev) && > - mlx5_ib_eswitch_mode(mdev->priv.eswitch) == > - MLX5_ESWITCH_OFFLOADS; > -} > - > static const struct mlx5_ib_counters *get_counters(struct mlx5_ib_dev *dev, > u8 port_num) > { > diff --git a/drivers/infiniband/hw/mlx5/ib_rep.c b/drivers/infiniband/hw/mlx5/ib_rep.c > index 0dc15757cc66..9810bdd7f3bc 100644 > --- a/drivers/infiniband/hw/mlx5/ib_rep.c > +++ b/drivers/infiniband/hw/mlx5/ib_rep.c > @@ -102,11 +102,6 @@ static const struct mlx5_eswitch_rep_ops rep_ops = { > .get_proto_dev = mlx5_ib_vport_get_proto_dev, > }; > > -u8 mlx5_ib_eswitch_mode(struct mlx5_eswitch *esw) > -{ > - return mlx5_eswitch_mode(esw); > -} > - > struct mlx5_ib_dev *mlx5_ib_get_rep_ibdev(struct mlx5_eswitch *esw, > u16 vport_num) > { > diff --git a/drivers/infiniband/hw/mlx5/ib_rep.h b/drivers/infiniband/hw/mlx5/ib_rep.h > index 94bf51ddd422..93f562735e89 100644 > --- a/drivers/infiniband/hw/mlx5/ib_rep.h > +++ b/drivers/infiniband/hw/mlx5/ib_rep.h > @@ -12,7 +12,6 @@ > extern const struct mlx5_ib_profile raw_eth_profile; > > #ifdef CONFIG_MLX5_ESWITCH > -u8 mlx5_ib_eswitch_mode(struct mlx5_eswitch *esw); > struct mlx5_ib_dev *mlx5_ib_get_rep_ibdev(struct mlx5_eswitch *esw, > u16 vport_num); > struct mlx5_ib_dev *mlx5_ib_get_uplink_ibdev(struct mlx5_eswitch *esw); > @@ -26,11 +25,6 @@ struct mlx5_flow_handle *create_flow_rule_vport_sq(struct mlx5_ib_dev *dev, > struct net_device *mlx5_ib_get_rep_netdev(struct mlx5_eswitch *esw, > u16 vport_num); > #else /* CONFIG_MLX5_ESWITCH */ > -static inline u8 mlx5_ib_eswitch_mode(struct mlx5_eswitch *esw) > -{ > - return MLX5_ESWITCH_NONE; > -} > - > static inline > struct mlx5_ib_dev *mlx5_ib_get_rep_ibdev(struct mlx5_eswitch *esw, > u16 vport_num) > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/dev.c b/drivers/net/ethernet/mellanox/mlx5/core/dev.c > index 3a81c2f1971b..b051417ede67 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/dev.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/dev.c > @@ -47,7 +47,7 @@ static bool is_eth_rep_supported(struct mlx5_core_dev *dev) > if (!MLX5_ESWITCH_MANAGER(dev)) > return false; > > - if (mlx5_eswitch_mode(dev->priv.eswitch) != MLX5_ESWITCH_OFFLOADS) > + if (!is_mdev_switchdev_mode(dev)) > return false; > > return true; > @@ -144,7 +144,7 @@ static bool is_ib_rep_supported(struct mlx5_core_dev *dev) > if (!MLX5_ESWITCH_MANAGER(dev)) > return false; > > - if (mlx5_eswitch_mode(dev->priv.eswitch) != MLX5_ESWITCH_OFFLOADS) > + if (!is_mdev_switchdev_mode(dev)) > return false; > > if (mlx5_core_mp_enabled(dev)) > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/devlink.c b/drivers/net/ethernet/mellanox/mlx5/core/devlink.c > index 1a351e2f6ace..aeffb6b135ee 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/devlink.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/devlink.c > @@ -221,7 +221,7 @@ static int mlx5_devlink_fs_mode_validate(struct devlink *devlink, u32 id, > u8 eswitch_mode; > bool smfs_cap; > > - eswitch_mode = mlx5_eswitch_mode(dev->priv.eswitch); > + eswitch_mode = mlx5_eswitch_mode(dev); > smfs_cap = mlx5_fs_dr_is_supported(dev); > > if (!smfs_cap) { > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_main.c b/drivers/net/ethernet/mellanox/mlx5/core/en_main.c > index 3c4f880c6329..8d65ac888a28 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en_main.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_main.c > @@ -3135,7 +3135,7 @@ static void mlx5e_modify_admin_state(struct mlx5_core_dev *mdev, > > mlx5_set_port_admin_status(mdev, state); > > - if (!MLX5_ESWITCH_MANAGER(mdev) || mlx5_eswitch_mode(esw) == MLX5_ESWITCH_OFFLOADS) > + if (mlx5_eswitch_mode(mdev) != MLX5_ESWITCH_LEGACY) > return; > > if (state == MLX5_PORT_UP) > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > index e3a968e9e2a0..7548bab78654 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > @@ -271,8 +271,6 @@ mlx5e_tc_match_to_reg_set(struct mlx5_core_dev *mdev, > return 0; > } > > -#define esw_offloads_mode(esw) (mlx5_eswitch_mode(esw) == MLX5_ESWITCH_OFFLOADS) > - > static struct mlx5_tc_ct_priv * > get_ct_priv(struct mlx5e_priv *priv) > { > @@ -280,7 +278,7 @@ get_ct_priv(struct mlx5e_priv *priv) > struct mlx5_rep_uplink_priv *uplink_priv; > struct mlx5e_rep_priv *uplink_rpriv; > > - if (esw_offloads_mode(esw)) { > + if (is_mdev_switchdev_mode(priv->mdev)) { > uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > uplink_priv = &uplink_rpriv->uplink_priv; > > @@ -297,7 +295,7 @@ mlx5_tc_rule_insert(struct mlx5e_priv *priv, > { > struct mlx5_eswitch *esw = priv->mdev->priv.eswitch; > > - if (esw_offloads_mode(esw)) > + if (is_mdev_switchdev_mode(priv->mdev)) > return mlx5_eswitch_add_offloaded_rule(esw, spec, attr); > > return mlx5e_add_offloaded_nic_rule(priv, spec, attr); > @@ -310,7 +308,7 @@ mlx5_tc_rule_delete(struct mlx5e_priv *priv, > { > struct mlx5_eswitch *esw = priv->mdev->priv.eswitch; > > - if (esw_offloads_mode(esw)) { > + if (is_mdev_switchdev_mode(priv->mdev)) { > mlx5_eswitch_del_offloaded_rule(esw, rule, attr); > > return; > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/eswitch.c b/drivers/net/ethernet/mellanox/mlx5/core/eswitch.c > index b652b4bde733..b44f28fb5518 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/eswitch.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/eswitch.c > @@ -2439,8 +2439,10 @@ int mlx5_eswitch_get_vport_stats(struct mlx5_eswitch *esw, > return err; > } > > -u8 mlx5_eswitch_mode(struct mlx5_eswitch *esw) > +u8 mlx5_eswitch_mode(struct mlx5_core_dev *dev) > { > + struct mlx5_eswitch *esw = dev->priv.eswitch; > + > return ESW_ALLOWED(esw) ? esw->mode : MLX5_ESWITCH_NONE; > } > EXPORT_SYMBOL_GPL(mlx5_eswitch_mode); > diff --git a/include/linux/mlx5/eswitch.h b/include/linux/mlx5/eswitch.h > index b0ae8020f13e..29fd832950e0 100644 > --- a/include/linux/mlx5/eswitch.h > +++ b/include/linux/mlx5/eswitch.h > @@ -96,10 +96,10 @@ static inline u32 mlx5_eswitch_get_vport_metadata_mask(void) > > u32 mlx5_eswitch_get_vport_metadata_for_match(struct mlx5_eswitch *esw, > u16 vport_num); > -u8 mlx5_eswitch_mode(struct mlx5_eswitch *esw); > +u8 mlx5_eswitch_mode(struct mlx5_core_dev *dev); > #else /* CONFIG_MLX5_ESWITCH */ > > -static inline u8 mlx5_eswitch_mode(struct mlx5_eswitch *esw) > +static inline u8 mlx5_eswitch_mode(struct mlx5_core_dev *dev) > { > return MLX5_ESWITCH_NONE; > } > @@ -136,4 +136,8 @@ mlx5_eswitch_get_vport_metadata_mask(void) > } > #endif /* CONFIG_MLX5_ESWITCH */ > > +static inline bool is_mdev_switchdev_mode(struct mlx5_core_dev *dev) > +{ > + return mlx5_eswitch_mode(dev) == MLX5_ESWITCH_OFFLOADS; > +} > #endif > -- > 2.28.0 > Reviewed-by: Roi Dayan