Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp2069637imm; Thu, 24 May 2018 05:22:10 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoxLV3Oh0p1Hzi6moGbA8JOnFI6LMuaHqNDvXhadWAam6C9YIwBUBqqZ26mnnRol6YiB6Rp X-Received: by 2002:a62:4a50:: with SMTP id x77-v6mr7106930pfa.142.1527164530133; Thu, 24 May 2018 05:22:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527164530; cv=none; d=google.com; s=arc-20160816; b=ath3OyHhtNiCTrkv2qvqxJuFF+gN1f07QH8ArgzWteqygQAZF5ByOUG/45xvjg7Jic IY4Pdghddl1StkkXVJbek2fSmv1cACESSRj5BYXM7cVv5lhDB8KJwWUG1jZK152JXvOh N5o3QkRPiZLjEhUVmT3tS9ZsUZGEB+JRr8sehy/EQ43C7E7JXoMVhlJHPUpNjmlHJFu4 dgwvCe2lK0a84HJ5bpAtbFiAMkobKuZtojlO7ZspVd7QPQq4iPYYz7ZAcuWbA++XxjGl 2L5eRt8d10MuGF7teUfQYnST/m5WtBeBGUOy8rAYqBYodEyC+7h+F83Nu9aSzxFxip5q a+Gw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=SpGrVwl0O2PruGTrD7a/6son6Hky1TscPljagaNmP/M=; b=UmGa6kFmUoJsKk3dX5QYSXVYKn+GRbn0YAZ+iSLl77zDMgjbECRWa7uWoI/Y6qNYbR RGs9q08RCsmv3NqcUYObFauIDh/Bhf9FfBSIpfTtRekArVdif0NGnY/axoJyOTV1gV3w G2br6d9cZ8ftfkTOXGfYqjlZ0Ht5GngeGP3NLprRPwT8otfged8OdCoBYBlPd6BfP3JV pC1ZAQ9KQB4/Xo2QGv5vyww8q6YYoU3f/I5FbKXlpPPahG3m4wqozLsIY5xxnvvGXjji VsLX6/SWNNNNj1O+F1EI/EltR4hiAFUvvD3nyvcbk1SGKw0nFuq2VeMXkmXRrS/LaCrS /alg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=mk7j85zY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f6-v6si17026166pgc.262.2018.05.24.05.21.55; Thu, 24 May 2018 05:22:10 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=mk7j85zY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S969944AbeEXMVI (ORCPT + 99 others); Thu, 24 May 2018 08:21:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:53268 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966179AbeEXJlW (ORCPT ); Thu, 24 May 2018 05:41:22 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9A1B22089E; Thu, 24 May 2018 09:41:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1527154882; bh=gKjIFyCABt3HCjzjrRaw437A7dtWa4XmUCm01F1x47w=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mk7j85zYy83hW+gRTAdniXFxzypD11s2aAGx7hdRxyu8sIRAzs07Gw8Xs0adQ0SLz Od8bcCFBIz4up342WJ8Y+srJG9qqRmfvpiBBcM9hfv4c/PFq8xXRKIAdaul6qCOEhP 34rYmGWynaL4Bq+3fT4bKBSdkPzVxXK+2ASq7zdM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Moshe Shemesh , Tariq Toukan , "David S. Miller" Subject: [PATCH 3.18 07/45] net/mlx4_en: Verify coalescing parameters are in range Date: Thu, 24 May 2018 11:38:15 +0200 Message-Id: <20180524093121.452401741@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180524093120.599252450@linuxfoundation.org> References: <20180524093120.599252450@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Moshe Shemesh [ Upstream commit 6ad4e91c6d796b38a7f0e724db1de28eeb122bad ] Add check of coalescing parameters received through ethtool are within range of values supported by the HW. Driver gets the coalescing rx/tx-usecs and rx/tx-frames as set by the users through ethtool. The ethtool support up to 32 bit value for each. However, mlx4 modify cq limits the coalescing time parameter and coalescing frames parameters to 16 bits. Return out of range error if user tries to set these parameters to higher values. Change type of sample-interval and adaptive_rx_coal parameters in mlx4 driver to u32 as the ethtool holds them as u32 and these parameters are not limited due to mlx4 HW. Fixes: c27a02cd94d6 ('mlx4_en: Add driver for Mellanox ConnectX 10GbE NIC') Signed-off-by: Moshe Shemesh Signed-off-by: Tariq Toukan Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/mellanox/mlx4/en_ethtool.c | 16 ++++++++++++++++ drivers/net/ethernet/mellanox/mlx4/mlx4_en.h | 7 +++++-- 2 files changed, 21 insertions(+), 2 deletions(-) --- a/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c +++ b/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c @@ -453,6 +453,22 @@ static int mlx4_en_set_coalesce(struct n if (!coal->tx_max_coalesced_frames_irq) return -EINVAL; + if (coal->tx_coalesce_usecs > MLX4_EN_MAX_COAL_TIME || + coal->rx_coalesce_usecs > MLX4_EN_MAX_COAL_TIME || + coal->rx_coalesce_usecs_low > MLX4_EN_MAX_COAL_TIME || + coal->rx_coalesce_usecs_high > MLX4_EN_MAX_COAL_TIME) { + netdev_info(dev, "%s: maximum coalesce time supported is %d usecs\n", + __func__, MLX4_EN_MAX_COAL_TIME); + return -ERANGE; + } + + if (coal->tx_max_coalesced_frames > MLX4_EN_MAX_COAL_PKTS || + coal->rx_max_coalesced_frames > MLX4_EN_MAX_COAL_PKTS) { + netdev_info(dev, "%s: maximum coalesced frames supported is %d\n", + __func__, MLX4_EN_MAX_COAL_PKTS); + return -ERANGE; + } + priv->rx_frames = (coal->rx_max_coalesced_frames == MLX4_EN_AUTO_CONF) ? MLX4_EN_RX_COAL_TARGET : --- a/drivers/net/ethernet/mellanox/mlx4/mlx4_en.h +++ b/drivers/net/ethernet/mellanox/mlx4/mlx4_en.h @@ -138,6 +138,9 @@ enum { #define MLX4_EN_TX_COAL_PKTS 16 #define MLX4_EN_TX_COAL_TIME 0x10 +#define MLX4_EN_MAX_COAL_PKTS U16_MAX +#define MLX4_EN_MAX_COAL_TIME U16_MAX + #define MLX4_EN_RX_RATE_LOW 400000 #define MLX4_EN_RX_COAL_TIME_LOW 0 #define MLX4_EN_RX_RATE_HIGH 450000 @@ -535,8 +538,8 @@ struct mlx4_en_priv { u16 rx_usecs_low; u32 pkt_rate_high; u16 rx_usecs_high; - u16 sample_interval; - u16 adaptive_rx_coal; + u32 sample_interval; + u32 adaptive_rx_coal; u32 msg_enable; u32 loopback_ok; u32 validate_loopback;