On Tue, 29 May 2018 15:56:58 +0300, Igor Russkikh wrote: > +static int aq_set_ringparam(struct net_device *ndev, > + struct ethtool_ringparam *ring) > +{ > + int err = 0; > + struct aq_nic_s *aq_nic = netdev_priv(ndev); > + struct aq_nic_cfg_s *aq_nic_cfg = aq_nic_get_cfg(aq_nic); > + const struct aq_hw_caps_s *hw_caps = aq_nic_cfg->aq_hw_caps; > + > + if (ring->rx_mini_pending || ring->rx_jumbo_pending) { > + err = -EOPNOTSUPP; > + goto err_exit; > + } > + > + spin_lock(&aq_nic->aq_spinlock); > + > + if (netif_running(ndev)) > + dev_close(ndev);
I don't think you can hold a spinlock around dev_close()/dev_open() calls. > + aq_nic_free_vectors(aq_nic); > + > + aq_nic_cfg->rxds = max(ring->rx_pending, hw_caps->rxds_min); > + aq_nic_cfg->rxds = min(aq_nic_cfg->rxds, hw_caps->rxds_max); > + aq_nic_cfg->rxds = ALIGN(aq_nic_cfg->rxds, AQ_HW_RXD_MULTIPLE); > + > + aq_nic_cfg->txds = max(ring->tx_pending, hw_caps->txds_min); > + aq_nic_cfg->txds = min(aq_nic_cfg->txds, hw_caps->txds_max); > + aq_nic_cfg->txds = ALIGN(aq_nic_cfg->txds, AQ_HW_TXD_MULTIPLE); > + > + for (aq_nic->aq_vecs = 0; aq_nic->aq_vecs < aq_nic_cfg->vecs; > + aq_nic->aq_vecs++) { > + aq_nic->aq_vec[aq_nic->aq_vecs] = > + aq_vec_alloc(aq_nic, aq_nic->aq_vecs, aq_nic_cfg); > + if (unlikely(!aq_nic->aq_vec[aq_nic->aq_vecs])) { > + err = -ENOMEM; > + goto err_unlock; > + } > + } > + if (!netif_running(ndev)) > + err = dev_open(ndev); Will this not open the device regardless if it was open before or not? > +err_unlock: > + spin_unlock(&aq_nic->aq_spinlock); > +err_exit: > + return err; > +}