Commit 82a72298 authored by Moshe Shemesh's avatar Moshe Shemesh Committed by Khalid Elmously

net/mlx4_en: Verify coalescing parameters are in range

BugLink: https://bugs.launchpad.net/bugs/1775477

[ Upstream commit 6ad4e91c ]

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: c27a02cd ('mlx4_en: Add driver for Mellanox ConnectX 10GbE NIC')
Signed-off-by: default avatarMoshe Shemesh <moshe@mellanox.com>
Signed-off-by: default avatarTariq Toukan <tariqt@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
Acked-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent 48ff8905
...@@ -967,6 +967,22 @@ static int mlx4_en_set_coalesce(struct net_device *dev, ...@@ -967,6 +967,22 @@ static int mlx4_en_set_coalesce(struct net_device *dev,
if (!coal->tx_max_coalesced_frames_irq) if (!coal->tx_max_coalesced_frames_irq)
return -EINVAL; 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 == priv->rx_frames = (coal->rx_max_coalesced_frames ==
MLX4_EN_AUTO_CONF) ? MLX4_EN_AUTO_CONF) ?
MLX4_EN_RX_COAL_TARGET : MLX4_EN_RX_COAL_TARGET :
......
...@@ -140,6 +140,9 @@ enum { ...@@ -140,6 +140,9 @@ enum {
#define MLX4_EN_TX_COAL_PKTS 16 #define MLX4_EN_TX_COAL_PKTS 16
#define MLX4_EN_TX_COAL_TIME 0x10 #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_RATE_LOW 400000
#define MLX4_EN_RX_COAL_TIME_LOW 0 #define MLX4_EN_RX_COAL_TIME_LOW 0
#define MLX4_EN_RX_RATE_HIGH 450000 #define MLX4_EN_RX_RATE_HIGH 450000
...@@ -518,8 +521,8 @@ struct mlx4_en_priv { ...@@ -518,8 +521,8 @@ struct mlx4_en_priv {
u16 rx_usecs_low; u16 rx_usecs_low;
u32 pkt_rate_high; u32 pkt_rate_high;
u16 rx_usecs_high; u16 rx_usecs_high;
u16 sample_interval; u32 sample_interval;
u16 adaptive_rx_coal; u32 adaptive_rx_coal;
u32 msg_enable; u32 msg_enable;
u32 loopback_ok; u32 loopback_ok;
u32 validate_loopback; u32 validate_loopback;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment