Commit 3bf0adbe authored by Stephen Hemminger's avatar Stephen Hemminger

[PATCH] sk98: no explicit module ref counting needed

Network driver's shouldn't be doing module reference counting
on 2.6.  This is a bad replication of 2.4 behaviour
Signed-off-by: default avatarStephen Hemminger <shemminger@osdl.org>
Signed-off-by: default avatarJeff Garzik <jgarzik@pobox.com>
parent 98adb34c
...@@ -1166,10 +1166,6 @@ struct SK_NET_DEVICE *dev) ...@@ -1166,10 +1166,6 @@ struct SK_NET_DEVICE *dev)
} }
#endif #endif
if (!try_module_get(THIS_MODULE)) {
return (-1); /* increase of usage count not possible */
}
/* Set blink mode */ /* Set blink mode */
if ((pAC->PciDev->vendor == 0x1186) || (pAC->PciDev->vendor == 0x11ab )) if ((pAC->PciDev->vendor == 0x1186) || (pAC->PciDev->vendor == 0x11ab ))
pAC->GIni.GILedBlinkCtrl = OEM_CONFIG_VALUE; pAC->GIni.GILedBlinkCtrl = OEM_CONFIG_VALUE;
...@@ -1177,7 +1173,6 @@ struct SK_NET_DEVICE *dev) ...@@ -1177,7 +1173,6 @@ struct SK_NET_DEVICE *dev)
if (pAC->BoardLevel == SK_INIT_DATA) { if (pAC->BoardLevel == SK_INIT_DATA) {
/* level 1 init common modules here */ /* level 1 init common modules here */
if (SkGeInit(pAC, pAC->IoBase, SK_INIT_IO) != 0) { if (SkGeInit(pAC, pAC->IoBase, SK_INIT_IO) != 0) {
module_put(THIS_MODULE); /* decrease usage count */
printk("%s: HWInit (1) failed.\n", pAC->dev[pNet->PortNr]->name); printk("%s: HWInit (1) failed.\n", pAC->dev[pNet->PortNr]->name);
return (-1); return (-1);
} }
...@@ -1193,7 +1188,6 @@ struct SK_NET_DEVICE *dev) ...@@ -1193,7 +1188,6 @@ struct SK_NET_DEVICE *dev)
if (pAC->BoardLevel != SK_INIT_RUN) { if (pAC->BoardLevel != SK_INIT_RUN) {
/* tschilling: Level 2 init modules here, check return value. */ /* tschilling: Level 2 init modules here, check return value. */
if (SkGeInit(pAC, pAC->IoBase, SK_INIT_RUN) != 0) { if (SkGeInit(pAC, pAC->IoBase, SK_INIT_RUN) != 0) {
module_put(THIS_MODULE); /* decrease usage count */
printk("%s: HWInit (2) failed.\n", pAC->dev[pNet->PortNr]->name); printk("%s: HWInit (2) failed.\n", pAC->dev[pNet->PortNr]->name);
return (-1); return (-1);
} }
...@@ -1285,7 +1279,6 @@ struct SK_NET_DEVICE *dev) ...@@ -1285,7 +1279,6 @@ struct SK_NET_DEVICE *dev)
#ifdef SK_DIAG_SUPPORT #ifdef SK_DIAG_SUPPORT
if (pAC->DiagModeActive == DIAG_ACTIVE) { if (pAC->DiagModeActive == DIAG_ACTIVE) {
if (pAC->DiagFlowCtrl == SK_FALSE) { if (pAC->DiagFlowCtrl == SK_FALSE) {
module_put(THIS_MODULE);
/* /*
** notify that the interface which has been closed ** notify that the interface which has been closed
** by operator interaction must not be started up ** by operator interaction must not be started up
...@@ -1376,7 +1369,6 @@ struct SK_NET_DEVICE *dev) ...@@ -1376,7 +1369,6 @@ struct SK_NET_DEVICE *dev)
pAC->MaxPorts--; pAC->MaxPorts--;
pNet->Up = 0; pNet->Up = 0;
module_put(THIS_MODULE);
return (0); return (0);
} /* SkGeClose */ } /* SkGeClose */
...@@ -4681,20 +4673,11 @@ int devNbr) /* what device is to be handled */ ...@@ -4681,20 +4673,11 @@ int devNbr) /* what device is to be handled */
dev = pAC->dev[devNbr]; dev = pAC->dev[devNbr];
/* /* On Linux 2.6 the network driver does NOT mess with reference
** Function SkGeClose() uses MOD_DEC_USE_COUNT (2.2/2.4) ** counts. The driver MUST be able to be unloaded at any time
** or module_put() (2.6) to decrease the number of users for ** due to the possibility of hotplug.
** a device, but if a device is to be put under control of */
** the DIAG, that count is OK already and does not need to
** be adapted! Hence the opposite MOD_INC_USE_COUNT or
** try_module_get() needs to be used again to correct that.
*/
if (!try_module_get(THIS_MODULE)) {
return (-1);
}
if (SkGeClose(dev) != 0) { if (SkGeClose(dev) != 0) {
module_put(THIS_MODULE);
return (-1); return (-1);
} }
return (0); return (0);
...@@ -4723,17 +4706,6 @@ int devNbr) /* what device is to be handled */ ...@@ -4723,17 +4706,6 @@ int devNbr) /* what device is to be handled */
if (SkGeOpen(dev) != 0) { if (SkGeOpen(dev) != 0) {
return (-1); return (-1);
} else {
/*
** Function SkGeOpen() uses MOD_INC_USE_COUNT (2.2/2.4)
** or try_module_get() (2.6) to increase the number of
** users for a device, but if a device was just under
** control of the DIAG, that count is OK already and
** does not need to be adapted! Hence the opposite
** MOD_DEC_USE_COUNT or module_put() needs to be used
** again to correct that.
*/
module_put(THIS_MODULE);
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment