diff options
author | Sergei Shtylyov <sergei.shtylyov@cogentembedded.com> | 2013-05-02 07:10:22 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-05-06 12:22:11 -0400 |
commit | c81400be716aa4c76f6ebf339ba94358dbbf6da6 (patch) | |
tree | 36cafe2ad9c4a79ce7f43cde3d3c8253e59f15b3 /drivers/net/ethernet | |
parent | a3dbbc2bab8d9a6e55fc0af3906d1dddbc0c531e (diff) |
3c59x: fix freeing nonexistent resource on driver unload
When unloading the driver that drives an EISA board, a message similar to the
following one is displayed:
Trying to free nonexistent resource <0000000000013000-000000000001301f>
Then an user is unable to reload the driver because the resource it requested in
the previous load hasn't been freed. This happens most probably due to a typo in
vortex_eisa_remove() which calls release_region() with 'dev->base_addr' instead
of 'edev->base_addr'...
Reported-by: Matthew Whitehead <tedheadster@gmail.com>
Tested-by: Matthew Whitehead <tedheadster@gmail.com>
Signed-off-by: Sergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet')
-rw-r--r-- | drivers/net/ethernet/3com/3c59x.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/ethernet/3com/3c59x.c b/drivers/net/ethernet/3com/3c59x.c index 1928e2001587..de570a8f8967 100644 --- a/drivers/net/ethernet/3com/3c59x.c +++ b/drivers/net/ethernet/3com/3c59x.c | |||
@@ -951,7 +951,7 @@ static int vortex_eisa_remove(struct device *device) | |||
951 | 951 | ||
952 | unregister_netdev(dev); | 952 | unregister_netdev(dev); |
953 | iowrite16(TotalReset|0x14, ioaddr + EL3_CMD); | 953 | iowrite16(TotalReset|0x14, ioaddr + EL3_CMD); |
954 | release_region(dev->base_addr, VORTEX_TOTAL_SIZE); | 954 | release_region(edev->base_addr, VORTEX_TOTAL_SIZE); |
955 | 955 | ||
956 | free_netdev(dev); | 956 | free_netdev(dev); |
957 | return 0; | 957 | return 0; |