Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
authorDavid S. Miller <davem@davemloft.net>
Fri, 14 Aug 2009 02:59:44 +0000 (19:59 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 14 Aug 2009 02:59:44 +0000 (19:59 -0700)
Conflicts:
drivers/net/netxen/netxen_nic_main.c

1  2 
drivers/net/8139cp.c
drivers/net/ixgbe/ixgbe_ethtool.c
drivers/net/netxen/netxen_nic.h
drivers/net/netxen/netxen_nic_init.c
drivers/net/netxen/netxen_nic_main.c

Simple merge
Simple merge
Simple merge
Simple merge
index 98271f962ae465165b247b9d2c4f1810d512492f,28f270f5ac784e47d6c12110752f988bcae65b33..4e3fb30d66fed5fc9944e1a4552e41780b3cade5
@@@ -923,15 -905,19 +935,17 @@@ netxen_nic_attach(struct netxen_adapte
        struct nx_host_rds_ring *rds_ring;
        struct nx_host_tx_ring *tx_ring;
  
 +      if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC)
 +              return 0;
 +
        err = netxen_init_firmware(adapter);
-       if (err != 0) {
-               printk(KERN_ERR "Failed to init firmware\n");
-               return -EIO;
-       }
+       if (err)
+               return err;
+       err = netxen_napi_add(adapter, netdev);
+       if (err)
+               return err;
  
 -      if (adapter->fw_major < 4)
 -              adapter->max_rds_rings = 3;
 -      else
 -              adapter->max_rds_rings = 2;
 -
        err = netxen_alloc_sw_resources(adapter);
        if (err) {
                printk(KERN_ERR "%s: Error in setting sw resources\n",
@@@ -1245,13 -1189,17 +1260,15 @@@ static void __devexit netxen_nic_remove
  
        unregister_netdev(netdev);
  
 -      if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) {
 -              netxen_nic_detach(adapter);
 -      }
+       cancel_work_sync(&adapter->watchdog_task);
+       cancel_work_sync(&adapter->tx_timeout_task);
 +      netxen_nic_detach(adapter);
  
        if (adapter->portnum == 0)
 -              netxen_free_adapter_offload(adapter);
 +              netxen_free_dummy_dma(adapter);
  
        netxen_teardown_intr(adapter);
-       netxen_free_sds_rings(&adapter->recv_ctx);
  
        netxen_cleanup_pci_map(adapter);
  
@@@ -1277,7 -1225,11 +1294,10 @@@ netxen_nic_suspend(struct pci_dev *pdev
        if (netif_running(netdev))
                netxen_nic_down(adapter, netdev);
  
 -      if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC)
 -              netxen_nic_detach(adapter);
+       cancel_work_sync(&adapter->watchdog_task);
+       cancel_work_sync(&adapter->tx_timeout_task);
 +      netxen_nic_detach(adapter);
  
        pci_save_state(pdev);
  
@@@ -1746,15 -1686,11 +1783,13 @@@ void netxen_watchdog_task(struct work_s
  
  static void netxen_tx_timeout(struct net_device *netdev)
  {
-       struct netxen_adapter *adapter = (struct netxen_adapter *)
-                                               netdev_priv(netdev);
+       struct netxen_adapter *adapter = netdev_priv(netdev);
 +
 +      dev_err(&netdev->dev, "transmit timeout, resetting.\n");
-       SCHEDULE_WORK(&adapter->tx_timeout_task);
+       schedule_work(&adapter->tx_timeout_task);
  }
  
 -static void netxen_tx_timeout_task(struct work_struct *work)
 +static void netxen_reset_task(struct work_struct *work)
  {
        struct netxen_adapter *adapter =
                container_of(work, struct netxen_adapter, tx_timeout_task);
@@@ -2025,14 -1844,6 +2060,11 @@@ static int __init netxen_init_module(vo
  {
        printk(KERN_INFO "%s\n", netxen_nic_driver_string);
  
-       if ((netxen_workq = create_singlethread_workqueue("netxen")) == NULL)
-               return -ENOMEM;
 +#ifdef CONFIG_INET
 +      register_netdevice_notifier(&netxen_netdev_cb);
 +      register_inetaddr_notifier(&netxen_inetaddr_cb);
 +#endif
 +
        return pci_register_driver(&netxen_driver);
  }
  
@@@ -2041,12 -1852,6 +2073,11 @@@ module_init(netxen_init_module)
  static void __exit netxen_exit_module(void)
  {
        pci_unregister_driver(&netxen_driver);
-       destroy_workqueue(netxen_workq);
 +
 +#ifdef CONFIG_INET
 +      unregister_inetaddr_notifier(&netxen_inetaddr_cb);
 +      unregister_netdevice_notifier(&netxen_netdev_cb);
 +#endif
  }
  
  module_exit(netxen_exit_module);