diff options
author | Tejun Heo <tj@kernel.org> | 2010-12-12 10:45:14 -0500 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2010-12-12 10:45:14 -0500 |
commit | 23f333a2bfafba80339315b724808982a9de57d9 (patch) | |
tree | 55819e6a8eeb9c2d34b42c77e7e38f7f6571baf9 /drivers/net/sis190.c | |
parent | 6e07ebd84eef00be9e169a6d15a0bc20b06578fa (diff) |
drivers/net: don't use flush_scheduled_work()
flush_scheduled_work() is on its way out. This patch contains simple
conversions to replace flush_scheduled_work() usage with direct
cancels and flushes.
Directly cancel the used works on driver detach and flush them in
other cases.
The conversions are mostly straight forward and the only dangers are,
* Forgetting to cancel/flush one or more used works.
* Cancelling when a work should be flushed (ie. the work must be
executed once scheduled whether the driver is detaching or not).
I've gone over the changes multiple times but it would be much
appreciated if you can review with the above points in mind.
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Jay Cliburn <jcliburn@gmail.com>
Cc: Michael Chan <mchan@broadcom.com>
Cc: Divy Le Ray <divy@chelsio.com>
Cc: e1000-devel@lists.sourceforge.net
Cc: Vasanthy Kolluri <vkolluri@cisco.com>
Cc: Samuel Ortiz <samuel@sortiz.org>
Cc: Lennert Buytenhek <buytenh@wantstofly.org>
Cc: Andrew Gallatin <gallatin@myri.com>
Cc: Francois Romieu <romieu@fr.zoreil.com>
Cc: Ramkrishna Vepa <ramkrishna.vepa@exar.com>
Cc: Matt Carlson <mcarlson@broadcom.com>
Cc: David Brownell <dbrownell@users.sourceforge.net>
Cc: Shreyas Bhatewara <sbhatewara@vmware.com>
Cc: netdev@vger.kernel.org
Diffstat (limited to 'drivers/net/sis190.c')
-rw-r--r-- | drivers/net/sis190.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/net/sis190.c b/drivers/net/sis190.c index a5d6a6bd0c1a..3406ed870917 100644 --- a/drivers/net/sis190.c +++ b/drivers/net/sis190.c | |||
@@ -1915,9 +1915,10 @@ err_release_board: | |||
1915 | static void __devexit sis190_remove_one(struct pci_dev *pdev) | 1915 | static void __devexit sis190_remove_one(struct pci_dev *pdev) |
1916 | { | 1916 | { |
1917 | struct net_device *dev = pci_get_drvdata(pdev); | 1917 | struct net_device *dev = pci_get_drvdata(pdev); |
1918 | struct sis190_private *tp = netdev_priv(dev); | ||
1918 | 1919 | ||
1919 | sis190_mii_remove(dev); | 1920 | sis190_mii_remove(dev); |
1920 | flush_scheduled_work(); | 1921 | cancel_work_sync(&tp->phy_task); |
1921 | unregister_netdev(dev); | 1922 | unregister_netdev(dev); |
1922 | sis190_release_board(pdev); | 1923 | sis190_release_board(pdev); |
1923 | pci_set_drvdata(pdev, NULL); | 1924 | pci_set_drvdata(pdev, NULL); |