2007-07-11 21:13:50 +00:00
|
|
|
Index: madwifi-ng-r2568-20070710/ath/if_ath_ahb.c
|
2007-06-04 11:25:53 +00:00
|
|
|
===================================================================
|
2007-10-20 19:13:53 +00:00
|
|
|
--- madwifi-ng-r2568-20070710.orig/ath/if_ath_ahb.c 2007-10-20 20:51:37.000000000 +0200
|
|
|
|
+++ madwifi-ng-r2568-20070710/ath/if_ath_ahb.c 2007-10-20 20:52:09.000000000 +0200
|
2007-06-01 10:29:49 +00:00
|
|
|
@@ -275,11 +275,10 @@
|
2007-05-13 16:24:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
-exit_ath_wmac(u_int16_t wlanNum)
|
|
|
|
+exit_ath_wmac(u_int16_t wlanNum, struct ar531x_config *config)
|
|
|
|
{
|
|
|
|
struct ath_ahb_softc *sc = sclist[wlanNum];
|
|
|
|
struct net_device *dev;
|
|
|
|
- const char *sysType;
|
2007-06-01 10:29:49 +00:00
|
|
|
u_int16_t devid;
|
2007-05-13 16:24:11 +00:00
|
|
|
|
|
|
|
if (sc == NULL)
|
2007-07-13 08:23:22 +00:00
|
|
|
@@ -289,13 +288,17 @@
|
2007-06-01 10:30:35 +00:00
|
|
|
ath_detach(dev);
|
2007-05-13 16:24:11 +00:00
|
|
|
if (dev->irq)
|
|
|
|
free_irq(dev->irq, dev);
|
2007-06-01 10:30:35 +00:00
|
|
|
- sysType = get_system_type();
|
2007-05-13 16:24:11 +00:00
|
|
|
- if (!strcmp(sysType, "Atheros AR5315"))
|
|
|
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,19)
|
2007-07-13 08:23:22 +00:00
|
|
|
+ devid = sc->aps_sc.devid;
|
|
|
|
+ config->tag = (unsigned long) devid;
|
2007-05-13 16:24:11 +00:00
|
|
|
+#else
|
|
|
|
+ if (!strcmp(get_system_type(), "Atheros AR5315"))
|
|
|
|
devid = (u_int16_t) (sysRegRead(AR5315_SREV) &
|
|
|
|
(AR5315_REV_MAJ_M | AR5315_REV_MIN_M));
|
|
|
|
else
|
2007-06-01 10:29:49 +00:00
|
|
|
devid = (u_int16_t) ((sysRegRead(AR531X_REV) >> 8) &
|
2007-05-13 16:24:11 +00:00
|
|
|
(AR531X_REV_MAJ | AR531X_REV_MIN));
|
|
|
|
+#endif
|
2007-06-01 10:29:49 +00:00
|
|
|
|
2007-05-13 16:24:11 +00:00
|
|
|
ahb_disable_wmac(devid, wlanNum);
|
|
|
|
free_netdev(dev);
|
2007-07-13 08:23:22 +00:00
|
|
|
@@ -401,7 +404,7 @@
|
2007-05-13 16:24:11 +00:00
|
|
|
|
|
|
|
static int ahb_wmac_remove(struct platform_device *pdev)
|
|
|
|
{
|
|
|
|
- exit_ath_wmac(pdev->id);
|
|
|
|
+ exit_ath_wmac(pdev->id, (struct ar531x_config *) pdev->dev.platform_data);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|