Details
[Home]
Issue of the Implementation # L0009
Brief
drivers/net/znet.c: Sleeping function called from invalid context
Detailed Description
Driver drivers/net/znet.c might sleep in atomic context, because it calls free_dma under claim_dma_lock: .drivers/net/znet.c:
168 static int znet_request_resources (struct net_device *dev) ... 189 flags = claim_dma_lock(); 190 free_dma (znet->tx_dma); 191 release_dma_lock (flags); ...Path to might_sleep macro from znet_request_resources:
Possible solutions
drivers/net/znet.c | 8 --------
1 files changed, 0 insertions(+), 8 deletions(-)
diff --git a/drivers/net/znet.c b/drivers/net/znet.c
index a0384b6..b423473 100644
--- a/drivers/net/znet.c
+++ b/drivers/net/znet.c
@@ -169,7 +169,6 @@ static void znet_tx_timeout (struct net_device *dev);
static int znet_request_resources (struct net_device *dev)
{
struct znet_private *znet = netdev_priv(dev);
- unsigned long flags;
if (request_irq (dev->irq, &znet_interrupt, 0, "ZNet", dev))
goto failed;
@@ -187,13 +186,9 @@ static int znet_request_resources (struct net_device *dev)
free_sia:
release_region (znet->sia_base, znet->sia_size);
free_tx_dma:
- flags = claim_dma_lock();
free_dma (znet->tx_dma);
- release_dma_lock (flags);
free_rx_dma:
- flags = claim_dma_lock();
free_dma (znet->rx_dma);
- release_dma_lock (flags);
free_irq:
free_irq (dev->irq, dev);
failed:
@@ -203,14 +198,11 @@ static int znet_request_resources (struct net_device *dev)
static void znet_release_resources (struct net_device *dev)
{
struct znet_private *znet = netdev_priv(dev);
- unsigned long flags;
release_region (znet->sia_base, znet->sia_size);
release_region (dev->base_addr, znet->io_size);
- flags = claim_dma_lock();
free_dma (znet->tx_dma);
free_dma (znet->rx_dma);
- release_dma_lock (flags);
free_irq (dev->irq, dev);
}
Component
linux-kernel 2.6.31
Accepted
http://lkml.org/lkml/2009/10/7/317
commit
Status
Fixed in kernel 2.6.32
[Home]
»