2010-09-05 02:46:39 +03:00
|
|
|
--- a/drivers/net/wireless/b43/b43.h
|
|
|
|
+++ b/drivers/net/wireless/b43/b43.h
|
2011-08-28 00:57:07 +03:00
|
|
|
@@ -751,6 +751,7 @@ struct b43_wldev {
|
2010-09-05 02:46:39 +03:00
|
|
|
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
|
2011-08-28 00:57:07 +03:00
|
|
|
@@ -74,6 +74,11 @@ MODULE_FIRMWARE("b43/ucode16_mimo.fw");
|
2010-09-05 02:46:39 +03:00
|
|
|
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,
|
2011-08-28 00:57:07 +03:00
|
|
|
@@ -2676,10 +2681,10 @@ static int b43_gpio_init(struct b43_wlde
|
2010-09-05 02:46:39 +03:00
|
|
|
& ~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;
|
2011-06-24 22:53:13 +03:00
|
|
|
if (dev->dev->chip_id == 0x4301) {
|
2010-09-05 02:46:39 +03:00
|
|
|
mask |= 0x0060;
|
|
|
|
set |= 0x0060;
|