summary refs log tree commit diff
path: root/pkgs/os-specific/linux/broadcom-sta
diff options
context:
space:
mode:
authorShea Levy <shea@shealevy.com>2011-04-12 15:54:39 +0000
committerShea Levy <shea@shealevy.com>2011-04-12 15:54:39 +0000
commit564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c (patch)
treefec76a2c56e459771ffb8e4255a0c662d573896f /pkgs/os-specific/linux/broadcom-sta
parentce249b627baa0c0b2415e9df3477cfa1728da343 (diff)
downloadnixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar.gz
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar.bz2
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar.lz
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar.xz
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.tar.zst
nixpkgs-564edafa1a0c3c56a9dc49fbccb1c25da8b6cd0c.zip
Get broadcom-sta to work on kernels >= 2.6.37
Patch from http://forums.linuxmint.com/viewtopic.php?f=141&t=57056&start=20#p378103

svn path=/nixpkgs/trunk/; revision=26806
Diffstat (limited to 'pkgs/os-specific/linux/broadcom-sta')
-rw-r--r--pkgs/os-specific/linux/broadcom-sta/default.nix5
-rw-r--r--pkgs/os-specific/linux/broadcom-sta/mutex-sema.patch12
2 files changed, 16 insertions, 1 deletions
diff --git a/pkgs/os-specific/linux/broadcom-sta/default.nix b/pkgs/os-specific/linux/broadcom-sta/default.nix
index ba1630d2ed5..d2c2b5f1307 100644
--- a/pkgs/os-specific/linux/broadcom-sta/default.nix
+++ b/pkgs/os-specific/linux/broadcom-sta/default.nix
@@ -15,7 +15,10 @@ stdenv.mkDerivation {
   };
 
   buildInputs = [ kernel ];
-  patches = [ ./makefile.patch ];
+  patches = [ ./makefile.patch ]
+    ++ stdenv.lib.optional
+    (! builtins.lessThan (builtins.compareVersions kernel.version "2.6.37") 0)
+      [ ./mutex-sema.patch ];
 
   makeFlags = "KDIR=${kernel}/lib/modules/${kernel.version}/build";
 
diff --git a/pkgs/os-specific/linux/broadcom-sta/mutex-sema.patch b/pkgs/os-specific/linux/broadcom-sta/mutex-sema.patch
new file mode 100644
index 00000000000..922c8f2d22d
--- /dev/null
+++ b/pkgs/os-specific/linux/broadcom-sta/mutex-sema.patch
@@ -0,0 +1,12 @@
+diff -aur old/src/wl/sys/wl_linux.c new/src/wl/sys/wl_linux.c
+--- old/src/wl/sys/wl_linux.c	2010-12-25 18:17:33.333343048 +0100
++++ new/src/wl/sys/wl_linux.c	2010-12-25 18:21:05.856676376 +0100
+@@ -483,7 +483,7 @@
+ #ifdef WL_ALL_PASSIVE
+ 		spin_lock_init(&wl->txq_lock);
+ #endif 
+-		init_MUTEX(&wl->sem);
++		sema_init(&wl->sem, 1);
+ 	}
+ 
+ 	if (!(wl->wlc = wlc_attach((void *) wl, vendor, device, unit, wl->piomode,