vmxnet3: prevent div-by-zero panic when ring resizing uninitialized dev
Linux is free to call ethtool ops as soon as a netdev exists when probe finishes. However, we only allocate vmxnet3 tx/rx queues and initialize the rx_buf_per_pkt field in struct vmxnet3_adapter when the interface is opened (UP). Signed-off-by: Bhavesh Davda <bhavesh@vmware.com> Signed-off-by: Shreyas N Bhatewara <sbhatewara@vmware.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
c5b1567947
commit
e4fabf2b6e
@@ -472,6 +472,12 @@ vmxnet3_set_ringparam(struct net_device *netdev,
|
||||
VMXNET3_RX_RING_MAX_SIZE)
|
||||
return -EINVAL;
|
||||
|
||||
/* if adapter not yet initialized, do nothing */
|
||||
if (adapter->rx_buf_per_pkt == 0) {
|
||||
netdev_err(netdev, "adapter not completely initialized, "
|
||||
"ring size cannot be changed yet\n");
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
/* round it up to a multiple of VMXNET3_RING_SIZE_ALIGN */
|
||||
new_tx_ring_size = (param->tx_pending + VMXNET3_RING_SIZE_MASK) &
|
||||
|
Reference in New Issue
Block a user