]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
ixgbe: use msleep for long delays
authorArnd Bergmann <arnd@arndb.de>
Sat, 16 Apr 2016 20:35:08 +0000 (22:35 +0200)
committerChuck Anderson <chuck.anderson@oracle.com>
Sat, 25 Feb 2017 05:47:34 +0000 (21:47 -0800)
Orabug: 24568240

The newly added x550em_a support causes a link failure on ARM because of
an overly long time passed into udelay():

ERROR: "__bad_udelay" [drivers/net/ethernet/intel/ixgbe/ixgbe.ko] undefined!

There are multiple variants of the ixgbe_acquire_swfw_sync_*() function,
and the other ones all use msleep(), so we can safely assume that all
callers are allowed to sleep, which makes msleep() a better replacement
than mdelay().

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Fixes: 49425dfc7451 ("ixgbe: Add support for x550em_a 10G MAC type")
Tested-by: Andrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
(cherry picked from commit d4f90d9dca26efef7a1112a8f4258c90b73bb37f)
Signed-off-by: Brian Maly <brian.maly@oracle.com>
drivers/net/ethernet/intel/ixgbe/ixgbe_x550.c

index c8a4f5ef06c07fd5cc86e95f3030c1abba6bbf73..19b75cd986820380507f11f6031903e51348d908 100644 (file)
@@ -2765,7 +2765,7 @@ static s32 ixgbe_acquire_swfw_sync_x550em_a(struct ixgbe_hw *hw, u32 mask)
                        ixgbe_release_swfw_sync_X540(hw, hmask);
                if (status != IXGBE_ERR_TOKEN_RETRY)
                        return status;
-               udelay(FW_PHY_TOKEN_DELAY * 1000);
+               msleep(FW_PHY_TOKEN_DELAY);
        }
 
        return status;