aboutsummaryrefslogtreecommitdiffstats
path: root/package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2011-07-24 14:10:39 +0000
committerJo-Philipp Wich <jow@openwrt.org>2011-07-24 14:10:39 +0000
commit76f140409a9112440d56b9d54033d9e9ab241adf (patch)
treea885d4528a21fb5fd79e9faa59eb08878e372bb0 /package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch
parent3927d60ba3a09bafcbcd8f09be4f32ddee995458 (diff)
downloadmaster-187ad058-76f140409a9112440d56b9d54033d9e9ab241adf.tar.gz
master-187ad058-76f140409a9112440d56b9d54033d9e9ab241adf.tar.bz2
master-187ad058-76f140409a9112440d56b9d54033d9e9ab241adf.zip
[package] broadcom-wl: make it work on the RT-N16 and other device using the BCMA bus
- refresh and reorder patches - introduce a unified BCMA/SSB glue driver to accomodate for both bus types on brcm47xx - extend wlunbind init script to detach device from bcma-pci-bridge as well git-svn-id: svn://svn.openwrt.org/openwrt/trunk@27751 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch')
-rw-r--r--package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch31
1 files changed, 31 insertions, 0 deletions
diff --git a/package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch b/package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch
new file mode 100644
index 0000000000..41c246ff80
--- /dev/null
+++ b/package/broadcom-wl/patches/005-fix-mem-leak-on-unload.patch
@@ -0,0 +1,31 @@
+From: George Kashperko <george@znau.edu.ua>
+
+Release nvram variables buffer.
+Prevent block reserved by alloc_etherdev from being freed.
+Signed-off-by: George Kashperko <george@znau.edu.ua>
+---
+---
+--- a/driver/siutils.c
++++ b/driver/siutils.c
+@@ -647,7 +647,10 @@ si_detach(si_t *sih)
+ #if !defined(BCMBUSTYPE) || (BCMBUSTYPE == SI_BUS)
+ if (sii != &ksii)
+ #endif /* !BCMBUSTYPE || (BCMBUSTYPE == SI_BUS) */
+- MFREE(sii->osh, sii, sizeof(si_info_t));
++ do {
++ MFREE(sii->osh, sii, sizeof(si_info_t));
++ nvram_exit((void *)&(sii->pub));
++ } while (0);
+ }
+
+ void *
+--- a/driver/wl_linux.c
++++ b/driver/wl_linux.c
+@@ -1477,7 +1477,6 @@ wl_free_if(wl_info_t *wl, wl_if_t *wlif)
+ free_netdev(wlif->dev);
+ #endif
+ }
+- MFREE(wl->osh, wlif, sizeof(wl_if_t));
+ }
+
+ #ifdef AP