18/07/2009
Trying to achieve a more stable hybrid (broadcom-wl) kernel module for broadcom 4328
On my Macbook (4,1) I am currently using Debian with kernel 2.6.30-1-686-bigmem. This Macbook has Broadcom 4328 wireless chipset installed (02:00.0 Network controller: Broadcom Corporation BCM4328 802.11a/b/g/n (rev 03)) and unfortunately the necessary kernel module provided by Broadcom is pretty unstable. Or very unstable. Oh well…it’s totally unstable.
I had random freezes, usually when I first booted and tried to modprobe the module. After some searching around the net and a lot of experiments I’ve managed to create a kernel module that looks quite stable. At least I stopped getting any more lockups and freezes…To reproduce the module with the patches I’ve used follow the directions bellow step by step.
Find your kernel version:
mybox:~# uname -r
2.6.30-1-686-bigmem
Install kernel header files related to the kernel version you found (on the above example it is: 2.6.30-1-686-bigmem):
mybox:~# aptitude install linux-headers-2.6.30-1-686-bigmem
Remember to replace the version (2.6.30-1-6-bigmem) with the output of your mybox:~# uname -r
Create necessary dirs:
mybox:~# mkdir hybrid_wl
mybox:~# cd hybrid_wl
Download Linux drivers package from Broadcom:
802.11 Linux STA 32-bit Driver
(Driver info site: 802.11 Linux STA driver)
mybox:~/hybrid_wl# wget http://www.broadcom.com/docs/linux_sta/hybrid-portsrc-x86_32-v5_10_91_9.tar.gz
Download a few more patches from Archlinux and Gentoo:
hidden-essid patch
2.6.30 patch 1
2.6.30 patch 2
hybrid-portsrc-x86_32-v5_10_91_9-convert_to_net_device_ops.diff
mybox:~/hybrid_wl# wget http://aur.archlinux.org/packages/broadcom-wl/broadcom-wl/hidden-essid.patch
mybox:~/hybrid_wl# wget http://aur.archlinux.org/packages/broadcom-wl/broadcom-wl/broadcom-sta-5.10.91.9-linux-2.6.30.patch
mybox:~/hybrid_wl# wget http://aur.archlinux.org/packages/broadcom-wl/broadcom-wl/broadcom-sta-5.10.91.9-linux-2.6.30-2.patch
mybox:~/hybrid_wl# wget -O hybrid-portsrc-x86_32-v5_10_91_9-convert_to_net_device_ops.diff http://bugs.gentoo.org/attachment.cgi?id=195182
Extract package:
mybox:~/hybrid_wl# tar -xzf /path/to/hybrid-portsrc-x86_32-v5_10_91_9.tar.gz
Start Patching:
mybox:~/hybrid_wl# sed -i hidden-essid.patch -e 's|5.10.79.10|src/wl/sys|g'
mybox:~/hybrid_wl# patch -p0 < hidden-essid.patch
patching file src/wl/sys/wl_iw.c
mybox:~/hybrid_wl# sed -i broadcom-sta-5.10.91.9-linux-2.6.30.patch -e 's|hybrid-portsrc-x86_32-v5_10_91_9.orig/||g'
mybox:~/hybrid_wl# sed -i broadcom-sta-5.10.91.9-linux-2.6.30.patch -e 's|hybrid-portsrc-x86_32-v5_10_91_9/||g'
mybox:~/hybrid_wl# patch -p0 <broadcom-sta-5.10.91.9-linux-2.6.30.patch
patching file src/wl/sys/wl_iw.c
Hunk #1 succeeded at 611 (offset 1 line).
Hunk #2 succeeded at 640 (offset 1 line).
Hunk #3 succeeded at 1119 (offset 1 line).
Hunk #4 succeeded at 1147 (offset 1 line).
Hunk #5 succeeded at 1807 (offset 1 line).
Hunk #6 succeeded at 1942 (offset 1 line).
patching file src/wl/sys/wl_linux.c
patching file src/wl/sys/wl_linux.h
mybox:~/hybrid_wl# patch -p0 < broadcom-sta-5.10.91.9-linux-2.6.30-2.patch
patching file src/wl/sys/wl_linux.c
mybox:~/hybrid_wl# sed -i hybrid-portsrc-x86_32-v5_10_91_9-convert_to_net_device_ops.diff -e 's|a/src/|src/|g'
mybox:~/hybrid_wl# sed -i hybrid-portsrc-x86_32-v5_10_91_9-convert_to_net_device_ops.diff -e 's|b/src/|src/|g'
mybox:~/hybrid_wl# patch -p0 < hybrid-portsrc-x86_32-v5_10_91_9-convert_to_net_device_ops.diff
patching file src/wl/sys/wl_linux.c
Hunk #1 succeeded at 225 (offset 6 lines).
patching file src/wl/sys/wl_iw.c
Compile the kernel module:
mybox:~/hybrid_wl# make -C /lib/modules/2.6.30-1-686-bigmem/build M=`pwd` clean
make: Entering directory `/usr/src/linux-headers-2.6.30-1-686-bigmem'
make: Leaving directory `/usr/src/linux-headers-2.6.30-1-686-bigmem'
mybox:~/hybrid_wl# make -C /lib/modules/2.6.30-1-686-bigmem/build M=`pwd`
make: Entering directory `/usr/src/linux-headers-2.6.30-1-686-bigmem'
LD /root/hybrid_wl/built-in.o
CC [M] /root/hybrid_wl/src/wl/sys/wl_linux.o
CC [M] /root/hybrid_wl/src/wl/sys/wl_iw.o
CC [M] /root/hybrid_wl/src/shared/linux_osl.o
LD [M] /root/hybrid_wl/wl.o
Building modules, stage 2.
MODPOST 1 modules
WARNING: modpost: missing MODULE_LICENSE() in /root/hybrid_wl/wl.o
see include/linux/module.h for more information
CC /root/hybrid_wl/wl.mod.o
LD [M] /root/hybrid_wl/wl.ko
make: Leaving directory `/usr/src/linux-headers-2.6.30-1-686-bigmem'
Install the new module:
mybox:~/hybrid_wl# cp wl.ko /lib/modules/2.6.30-1-686-bigmem/kernel/drivers/net/wireless/
mybox:~/hybrid_wl# depmod
mybox:~/hybrid_wl# modprobe wl
Check if everything loads correctly:
mybox:~/hybrid_wl# dmesg |tail
[ 66.229797] lib80211: common routines for IEEE802.11 drivers
[ 66.229805] lib80211_crypt: registered algorithm 'NULL'
[ 66.301793] wl: module license 'unspecified' taints kernel.
[ 66.301802] Disabling lock debugging due to kernel taint
[ 66.305919] wl 0000:02:00.0: PCI INT A -> GSI 16 (level, low) -> IRQ 16
[ 66.305933] wl 0000:02:00.0: setting latency timer to 64
[ 66.406146] lib80211_crypt: registered algorithm 'TKIP'
[ 66.408646] eth1: Broadcom BCM4328 802.11 Wireless Controller 5.10.91.9
[ 76.524135] eth1: no IPv6 routers present
You can also chek the iwconfig output. Hopefully everything will be fine…
I hope this saves a few hours of searching and experimenting for some people…
References:
1) 802.11 Linux STA driver
2) AUR broadcom-wl 5.10.91.9-2
3) Gentoo Bug: 284450 (New ebuild: net/wireless/broadcom-sta)
Filed by kargig at 00:22 under Linux
Tags: 2.6.30, Archlinux, broadcom, bug, bugfix, debian, Gentoo, kernel, Linux, module, patch, wireless
9 Comments | 30,278 views
hi!
it was a very useful post.
i’m using debian lenny on a macbook 4.1 too, and yesterday i decided to upgrade to SID. Now folowing your post, i can get my wireless working again.
Let me do more one question….. with 2.6.26 kernel i always get an error “Disabling IRQ #11” and a freeze on my system, do you know something about?
i found a lot of posts talking about it on google, but nothing solved the problem, my hope is that with the kernel 2.6.30 it doesn’t appear anymore.
thank you!!
Hey, thanks for your kind words. I used to have some of these problems (Disabling IRQ #11) with 2.6.26 as well, but I decided to upgrade to 2.6.30 and fix the problem there. I never looked back at 2.6.26 after that…Right now the chip works great and I can suspend/resume without fear that the laptop will freeze.
hi just a complication with mine, i was hoping to get some help with?
umm turns out when i type
[code]john@mobius:/lib/modules/2.6.30.5-ep0/hybrid_wl$ patch -p1 < broadcom-sta-5.10.91.9-linux-2.6.30-2.patch
The program 'patch' is currently not installed. You can install it by typing:
sudo apt-get install patch
bash: patch: command not found
[/code]
that happens, it says that patch is not installed? ok i said, i tried to install it and
[code] john@mobius:/lib/modules/2.6.30.5-ep0/hybrid_wl$ sudo apt-get install patch
Reading package lists… Done
Building dependency tree
Reading state information… Done
Suggested packages:
diff-doc
The following NEW packages will be installed:
patch
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Need to get 100kB of archives.
After this operation, 213kB of additional disk space will be used.
Get:1 http://archive.ubuntu.com jaunty/main patch 2.5.9-5 [100kB]
Fetched 100kB in 0s (116kB/s)
debconf: unable to initialize frontend: Dialog
debconf: (Dialog frontend requires a screen at least 13 lines tall and 31 columns wide.)
debconf: falling back to frontend: Readline
Selecting previously deselected package patch.
(Reading database … 102689 files and directories currently installed.)
Unpacking patch (from …/patch_2.5.9-5_i386.deb) …
Processing triggers for man-db …
Setting up patch (2.5.9-5) …
E: Directory '/var/log/apt/' missing
[/code] apperently thats missing, any ideas? do i do a mkdir? any help is greatly appreciated thanks in advance
Check this: https://bugs.launchpad.net/ubuntu/+source/apt/+bug/220239/comments/5 might help… I don’t have any ubuntu installation to test it though…
Hi, thanks to your kind support. (I am pretty new in ubuntu) i’ve just updated my jaunty kernel to 2.6.31-020631rc9-generic and after that B43 wireless driver stoped functioning. after burning lots of hours, on google i found this article and now my wireless works beautifully. Thanks again..
-.-” i really need this patch. i tried this yesterday and i failed, so i wanted to do it again from step one, but now i’m stuck there i’m trying to intsall the kernal header and this pops up.
Couldn’t find any package whose name or description matched “linux-headers-2.6.30-1-686-bigmem”
Couldn’t find any package whose name or description matched “linux-headers-2.6.30-1-686-bigmem”
and says no header will be installed, upgraded, removed. so forth.
what gives?
ohhh wait nvm fixed my problem, i dident see the part that said i can replace it with my own 2.6.xx.xx
I am trying to learn a few things about openwrt.
I plan to use the broadcom linux kernel instead of openwrt kernel and want to compile it.it is throwing up errors..is it possible in any way..if so can you kindly refer as to how…
Thanks
-Roy
Hi
I tried to follow the step but I always get this error:
salade-tomate-oignon:/home/kebab/hybrid_wl# patch -p0 < hidden-essid.patch
patching file src/wl/sys/wl_iw.c
Hunk #1 FAILED at 580.
1 out of 1 hunk FAILED — saving rejects to file src/wl/sys/wl_iw.c.rej
If anyone got an idea, I'm desperate.