aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-09-04 23:46:39 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-09-04 23:46:39 +0000
commita2aa84c1c707e3f58e3cf8efbe0fb2a60aed2daa (patch)
treecc150dd42daa05c27b6fc3a19ea26ce2e706c960
parent89f806fe5f6af42a20ff8e6e44ef58d34bbf668e (diff)
downloadupstream-a2aa84c1c707e3f58e3cf8efbe0fb2a60aed2daa.tar.gz
upstream-a2aa84c1c707e3f58e3cf8efbe0fb2a60aed2daa.tar.bz2
upstream-a2aa84c1c707e3f58e3cf8efbe0fb2a60aed2daa.zip
b43: Module option added to change the GPIO LED mask. This patch exposes the GPIO mask as a module option. This makes it possible to limit the GPIO lines used by the b43 module. Useful for those using the GPIO lines for other things like mmc over GPIO.
It is helpful to those not able / interested in recompiling OpenWRT themselves. The default action is the same as before, that is 0xf gpiomask. Signed-off-by: Simon Gaynor <openwrt@simong.net> SVN-Revision: 22927
-rw-r--r--package/mac80211/patches/800-b43-gpio-mask-module-option.patch50
1 files changed, 50 insertions, 0 deletions
diff --git a/package/mac80211/patches/800-b43-gpio-mask-module-option.patch b/package/mac80211/patches/800-b43-gpio-mask-module-option.patch
new file mode 100644
index 0000000000..35bea59cca
--- /dev/null
+++ b/package/mac80211/patches/800-b43-gpio-mask-module-option.patch
@@ -0,0 +1,50 @@
+--- a/drivers/net/wireless/b43/b43.h
++++ b/drivers/net/wireless/b43/b43.h
+@@ -704,6 +704,7 @@ struct b43_wldev {
+ bool qos_enabled; /* TRUE, if QoS is used. */
+ bool hwcrypto_enabled; /* TRUE, if HW crypto acceleration is enabled. */
+ bool use_pio; /* TRUE if next init should use PIO */
++ int gpiomask; /* GPIO LED mask as a module parameter */
+
+ /* PHY/Radio device. */
+ struct b43_phy phy;
+--- a/drivers/net/wireless/b43/main.c
++++ b/drivers/net/wireless/b43/main.c
+@@ -75,6 +75,11 @@ MODULE_FIRMWARE("b43/ucode15.fw");
+ MODULE_FIRMWARE("b43/ucode5.fw");
+ MODULE_FIRMWARE("b43/ucode9.fw");
+
++static int modparam_gpiomask = 0x000F;
++module_param_named(gpiomask, modparam_gpiomask, int, 0444);
++MODULE_PARM_DESC(gpiomask,
++ "GPIO mask for LED control (default 0x000F)");
++
+ static int modparam_bad_frames_preempt;
+ module_param_named(bad_frames_preempt, modparam_bad_frames_preempt, int, 0444);
+ MODULE_PARM_DESC(bad_frames_preempt,
+@@ -2534,10 +2539,10 @@ static int b43_gpio_init(struct b43_wlde
+ & ~B43_MACCTL_GPOUTSMSK);
+
+ b43_write16(dev, B43_MMIO_GPIO_MASK, b43_read16(dev, B43_MMIO_GPIO_MASK)
+- | 0x000F);
++ | modparam_gpiomask);
+
+ mask = 0x0000001F;
+- set = 0x0000000F;
++ set = modparam_gpiomask;
+ if (dev->dev->bus->chip_id == 0x4301) {
+ mask |= 0x0060;
+ set |= 0x0060;
+@@ -5094,10 +5099,10 @@ static void b43_print_driverinfo(void)
+ feat_sdio = "S";
+ #endif
+ printk(KERN_INFO "Broadcom 43xx driver loaded "
+- "[ Features: %s%s%s%s%s, Firmware-ID: "
++ "[ Features: %s%s%s%s%s, GPIO LED Mask: 0x%04x, Firmware-ID: "
+ B43_SUPPORTED_FIRMWARE_ID " ]\n",
+ feat_pci, feat_pcmcia, feat_nphy,
+- feat_leds, feat_sdio);
++ feat_leds, feat_sdio, modparam_gpiomask);
+ }
+
+ static int __init b43_init(void)