]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ethtool: Don't check for RXFH fields conflict when no input_xfrm is requested
authorGal Pressman <gal@nvidia.com>
Tue, 15 Jul 2025 14:07:54 +0000 (17:07 +0300)
committerJakub Kicinski <kuba@kernel.org>
Wed, 16 Jul 2025 22:03:56 +0000 (15:03 -0700)
The requirement of ->get_rxfh_fields() in ethtool_set_rxfh() is there to
verify that we have no conflict of input_xfrm with the RSS fields
options, there is no point in doing it if input_xfrm is not
supported/requested.

This is under the assumption that a driver that supports input_xfrm will
also support ->get_rxfh_fields(), so add a WARN_ON() to
ethtool_check_ops() to verify it, and remove the op NULL check.

This fixes the following error in mlx4_en, which doesn't support
getting/setting RXFH fields.
$ ethtool --set-rxfh-indir eth2 hfunc xor
Cannot set RX flow hash configuration: Operation not supported

Fixes: 72792461c8e8 ("net: ethtool: don't mux RXFH via rxnfc callbacks")
Reviewed-by: Dragos Tatulea <dtatulea@nvidia.com>
Signed-off-by: Gal Pressman <gal@nvidia.com>
Link: https://patch.msgid.link/20250715140754.489677-1-gal@nvidia.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/ethtool/common.c
net/ethtool/ioctl.c

index d62dc56f2f5b34029761cbe78da70e79e68aef4c..459cf25e763eb12af695aff43fb55d7dbc355b68 100644 (file)
@@ -812,6 +812,8 @@ int ethtool_check_ops(const struct ethtool_ops *ops)
                return -EINVAL;
        if (WARN_ON(ops->rxfh_max_num_contexts == 1))
                return -EINVAL;
+       if (WARN_ON(ops->supported_input_xfrm && !ops->get_rxfh_fields))
+               return -EINVAL;
        /* NOTE: sufficiently insane drivers may swap ethtool_ops at runtime,
         * the fact that ops are checked at registration time does not
         * mean the ops attached to a netdev later on are sane.
index cccb4694f5e18f2105db7112557c556b7594efa7..830623678cb3bdb54536c07b0a3b13dcb628192d 100644 (file)
@@ -1041,6 +1041,9 @@ static int ethtool_check_flow_types(struct net_device *dev, u32 input_xfrm)
        int err;
        u32 i;
 
+       if (!input_xfrm || input_xfrm == RXH_XFRM_NO_CHANGE)
+               return 0;
+
        for (i = 0; i < __FLOW_TYPE_COUNT; i++) {
                struct ethtool_rxfh_fields fields = {
                        .flow_type      = i,
@@ -1523,7 +1526,7 @@ static noinline_for_stack int ethtool_set_rxfh(struct net_device *dev,
        u8 *rss_config;
        int ret;
 
-       if (!ops->get_rxnfc || !ops->get_rxfh_fields || !ops->set_rxfh)
+       if (!ops->get_rxnfc || !ops->set_rxfh)
                return -EOPNOTSUPP;
 
        if (ops->get_rxfh_indir_size)