static void ioc3_start(struct ioc3_private *ip);
 static inline void ioc3_stop(struct ioc3_private *ip);
 static void ioc3_init(struct net_device *dev);
+static void ioc3_alloc_rx_bufs(struct net_device *dev);
+static void ioc3_free_rx_bufs(struct ioc3_private *ip);
+static inline void ioc3_clean_tx_ring(struct ioc3_private *ip);
 
 static const char ioc3_str[] = "IOC3 Ethernet";
 static const struct ethtool_ops ioc3_ethtool_ops;
                net_err_ratelimited("%s: TX PCI error.\n", dev->name);
 
        ioc3_stop(ip);
+       ioc3_free_rx_bufs(ip);
+       ioc3_clean_tx_ring(ip);
+
        ioc3_init(dev);
+       ioc3_alloc_rx_bufs(dev);
        ioc3_start(ip);
        ioc3_mii_init(ip);
 
        ip->rx_pi = RX_BUFFS;
 }
 
-static void ioc3_init_rings(struct net_device *dev)
-{
-       struct ioc3_private *ip = netdev_priv(dev);
-
-       ioc3_free_rx_bufs(ip);
-       ioc3_alloc_rx_bufs(dev);
-
-       ioc3_clean_tx_ring(ip);
-}
-
 static inline void ioc3_ssram_disc(struct ioc3_private *ip)
 {
        struct ioc3_ethregs *regs = ip->regs;
        writel(ip->ehar_h, ®s->ehar_h);
        writel(ip->ehar_l, ®s->ehar_l);
        writel(42, ®s->ersr);                /* XXX should be random */
-
-       ioc3_init_rings(dev);
 }
 
 static void ioc3_start(struct ioc3_private *ip)
 
        ip->ehar_h = 0;
        ip->ehar_l = 0;
+
        ioc3_init(dev);
+       ioc3_alloc_rx_bufs(dev);
        ioc3_start(ip);
        ioc3_mii_start(ip);
 
        }
 
        ioc3_init(dev);
-       ioc3_start(ip);
 
        ip->pdev = pdev;
 
        return 0;
 
 out_stop:
-       ioc3_stop(ip);
        del_timer_sync(&ip->ioc3_timer);
-       ioc3_free_rx_bufs(ip);
        if (ip->rxr)
                free_page((unsigned long)ip->rxr);
        if (ip->txr)
        spin_lock_irq(&ip->ioc3_lock);
 
        ioc3_stop(ip);
+       ioc3_free_rx_bufs(ip);
+       ioc3_clean_tx_ring(ip);
+
        ioc3_init(dev);
+       ioc3_alloc_rx_bufs(dev);
        ioc3_start(ip);
        ioc3_mii_init(ip);
        ioc3_mii_start(ip);