mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 19:12:33 +08:00
a8f63a0717
This updates mac80211 to backprots-4.14-rc2. This was compile and runtime tested with ath9k, ath10k and b43 with multiple stations and ieee80211w and in different scenarios by many other people. To create the backports-4.14-rc2-1.tar.xz use this repository: https://git.kernel.org/pub/scm/linux/kernel/git/backports/backports.git from tag v4.14-rc2-1 Then run this: ./gentree.py --git-revision v4.14-rc2 --clean <path to linux repo> ../backports-4.14-rc2-1 This also adapts the ath10k-ct and mt76 driver to the changed cfg80211 APIs and syncs the nl80211.h file in iw with the new version from backports-4.14-rc2. Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
38 lines
1.4 KiB
Diff
38 lines
1.4 KiB
Diff
--- a/drivers/net/wireless/broadcom/b43/b43.h
|
|
+++ b/drivers/net/wireless/broadcom/b43/b43.h
|
|
@@ -839,6 +839,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/broadcom/b43/main.c
|
|
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
|
@@ -85,6 +85,11 @@ MODULE_FIRMWARE("b43/ucode40.fw");
|
|
MODULE_FIRMWARE("b43/ucode42.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,
|
|
@@ -2892,10 +2897,10 @@ static int b43_gpio_init(struct b43_wlde
|
|
u32 mask, set;
|
|
|
|
b43_maskset32(dev, B43_MMIO_MACCTL, ~B43_MACCTL_GPOUTSMSK, 0);
|
|
- b43_maskset16(dev, B43_MMIO_GPIO_MASK, ~0, 0xF);
|
|
+ b43_maskset16(dev, B43_MMIO_GPIO_MASK, ~0, modparam_gpiomask);
|
|
|
|
mask = 0x0000001F;
|
|
- set = 0x0000000F;
|
|
+ set = modparam_gpiomask;
|
|
if (dev->dev->chip_id == 0x4301) {
|
|
mask |= 0x0060;
|
|
set |= 0x0060;
|