2024-07-27 06:49:29 +00:00
|
|
|
From bc408ef546b08443dabbe8fcdfec5e1e48494ed8 Mon Sep 17 00:00:00 2001
|
|
|
|
From: aszlig <aszlig@redmoonstudios.org>
|
|
|
|
Date: Mon, 1 Aug 2016 20:45:47 +0200
|
|
|
|
Subject: [PATCH 04/16] linuxPackages.broadcom_sta: fix build for kernel 4.7+
|
|
|
|
|
|
|
|
Patch is from Arch Linux at:
|
|
|
|
|
|
|
|
https://aur.archlinux.org/cgit/aur.git/tree/?h=broadcom-wl
|
|
|
|
|
|
|
|
I've tested building against 3.18.36, 4.4.16 and 4.7.0.
|
|
|
|
|
|
|
|
Signed-off-by: aszlig <aszlig@redmoonstudios.org>
|
|
|
|
Cc: @phreedom, @vcunat
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
Since Linux 4.7, the enum ieee80211_band is no longer used
|
|
|
|
|
|
|
|
This shall cause no problem's since both enums ieee80211_band
|
|
|
|
and nl80211_band were added in the same commit:
|
2024-07-27 06:49:29 +00:00
|
|
|
https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit?id=13ae75b103e07304a34ab40c9136e9f53e06475c
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
This patch refactors the references of IEEE80211_BAND_* to NL80211_BAND_*
|
|
|
|
|
|
|
|
Reference:
|
2024-07-27 06:49:29 +00:00
|
|
|
https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit?id=57fbcce37be7c1d2622b56587c10ade00e96afa3
|
|
|
|
---
|
|
|
|
src/wl/sys/wl_cfg80211_hybrid.c | 24 ++++++++++++------------
|
|
|
|
1 file changed, 12 insertions(+), 12 deletions(-)
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
diff --git a/src/wl/sys/wl_cfg80211_hybrid.c b/src/wl/sys/wl_cfg80211_hybrid.c
|
|
|
|
index 7b606e0..3b438ba 100644
|
|
|
|
--- a/src/wl/sys/wl_cfg80211_hybrid.c
|
|
|
|
+++ b/src/wl/sys/wl_cfg80211_hybrid.c
|
|
|
|
@@ -236,7 +236,7 @@ static s8 wl_dbg_estr[][WL_DBG_ESTR_MAX] = {
|
2020-04-24 23:36:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define CHAN2G(_channel, _freq, _flags) { \
|
|
|
|
- .band = IEEE80211_BAND_2GHZ, \
|
|
|
|
+ .band = NL80211_BAND_2GHZ, \
|
|
|
|
.center_freq = (_freq), \
|
|
|
|
.hw_value = (_channel), \
|
|
|
|
.flags = (_flags), \
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -245,7 +245,7 @@ static s8 wl_dbg_estr[][WL_DBG_ESTR_MAX] = {
|
2020-04-24 23:36:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#define CHAN5G(_channel, _flags) { \
|
|
|
|
- .band = IEEE80211_BAND_5GHZ, \
|
|
|
|
+ .band = NL80211_BAND_5GHZ, \
|
|
|
|
.center_freq = 5000 + (5 * (_channel)), \
|
|
|
|
.hw_value = (_channel), \
|
|
|
|
.flags = (_flags), \
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -379,7 +379,7 @@ static struct ieee80211_channel __wl_5ghz_n_channels[] = {
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct ieee80211_supported_band __wl_band_2ghz = {
|
|
|
|
- .band = IEEE80211_BAND_2GHZ,
|
|
|
|
+ .band = NL80211_BAND_2GHZ,
|
|
|
|
.channels = __wl_2ghz_channels,
|
|
|
|
.n_channels = ARRAY_SIZE(__wl_2ghz_channels),
|
|
|
|
.bitrates = wl_g_rates,
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -387,7 +387,7 @@ static struct ieee80211_supported_band __wl_band_2ghz = {
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct ieee80211_supported_band __wl_band_5ghz_a = {
|
|
|
|
- .band = IEEE80211_BAND_5GHZ,
|
|
|
|
+ .band = NL80211_BAND_5GHZ,
|
|
|
|
.channels = __wl_5ghz_a_channels,
|
|
|
|
.n_channels = ARRAY_SIZE(__wl_5ghz_a_channels),
|
|
|
|
.bitrates = wl_a_rates,
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -395,7 +395,7 @@ static struct ieee80211_supported_band __wl_band_5ghz_a = {
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct ieee80211_supported_band __wl_band_5ghz_n = {
|
|
|
|
- .band = IEEE80211_BAND_5GHZ,
|
|
|
|
+ .band = NL80211_BAND_5GHZ,
|
|
|
|
.channels = __wl_5ghz_n_channels,
|
|
|
|
.n_channels = ARRAY_SIZE(__wl_5ghz_n_channels),
|
|
|
|
.bitrates = wl_a_rates,
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -1876,8 +1876,8 @@ static s32 wl_alloc_wdev(struct device *dev, struct wireless_dev **rwdev)
|
2020-04-24 23:36:52 +00:00
|
|
|
wdev->wiphy->max_num_pmkids = WL_NUM_PMKIDS_MAX;
|
|
|
|
#endif
|
|
|
|
wdev->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) | BIT(NL80211_IFTYPE_ADHOC);
|
|
|
|
- wdev->wiphy->bands[IEEE80211_BAND_2GHZ] = &__wl_band_2ghz;
|
|
|
|
- wdev->wiphy->bands[IEEE80211_BAND_5GHZ] = &__wl_band_5ghz_a;
|
|
|
|
+ wdev->wiphy->bands[NL80211_BAND_2GHZ] = &__wl_band_2ghz;
|
2024-07-27 06:49:29 +00:00
|
|
|
+ wdev->wiphy->bands[NL80211_BAND_5GHZ] = &__wl_band_5ghz_a;
|
2020-04-24 23:36:52 +00:00
|
|
|
wdev->wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
|
|
|
|
wdev->wiphy->cipher_suites = __wl_cipher_suites;
|
|
|
|
wdev->wiphy->n_cipher_suites = ARRAY_SIZE(__wl_cipher_suites);
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -2000,7 +2000,7 @@ static s32 wl_inform_single_bss(struct wl_cfg80211_priv *wl, struct wl_bss_info
|
2020-04-24 23:36:52 +00:00
|
|
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
|
|
|
|
freq = ieee80211_channel_to_frequency(notif_bss_info->channel,
|
|
|
|
(notif_bss_info->channel <= CH_MAX_2G_CHANNEL) ?
|
|
|
|
- IEEE80211_BAND_2GHZ : IEEE80211_BAND_5GHZ);
|
|
|
|
+ NL80211_BAND_2GHZ : NL80211_BAND_5GHZ);
|
|
|
|
#else
|
|
|
|
freq = ieee80211_channel_to_frequency(notif_bss_info->channel);
|
|
|
|
#endif
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -2116,7 +2116,7 @@ wl_notify_connect_status(struct wl_cfg80211_priv *wl, struct net_device *ndev,
|
2020-04-24 23:36:52 +00:00
|
|
|
return err;
|
|
|
|
}
|
|
|
|
chan = wf_chspec_ctlchan(chanspec);
|
|
|
|
- band = (chan <= CH_MAX_2G_CHANNEL) ? IEEE80211_BAND_2GHZ : IEEE80211_BAND_5GHZ;
|
|
|
|
+ band = (chan <= CH_MAX_2G_CHANNEL) ? NL80211_BAND_2GHZ : NL80211_BAND_5GHZ;
|
|
|
|
freq = ieee80211_channel_to_frequency(chan, band);
|
|
|
|
channel = ieee80211_get_channel(wiphy, freq);
|
|
|
|
cfg80211_ibss_joined(ndev, (u8 *)&wl->bssid, channel, GFP_KERNEL);
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -2250,10 +2250,10 @@ static void wl_ch_to_chanspec(struct ieee80211_channel *chan, struct wl_join_par
|
2020-04-24 23:36:52 +00:00
|
|
|
join_params->params.chanspec_list[0] =
|
|
|
|
ieee80211_frequency_to_channel(chan->center_freq);
|
|
|
|
|
|
|
|
- if (chan->band == IEEE80211_BAND_2GHZ) {
|
|
|
|
+ if (chan->band == NL80211_BAND_2GHZ) {
|
|
|
|
chanspec |= WL_CHANSPEC_BAND_2G;
|
|
|
|
}
|
|
|
|
- else if (chan->band == IEEE80211_BAND_5GHZ) {
|
|
|
|
+ else if (chan->band == NL80211_BAND_5GHZ) {
|
|
|
|
chanspec |= WL_CHANSPEC_BAND_5G;
|
|
|
|
}
|
|
|
|
else {
|
2024-07-27 06:49:29 +00:00
|
|
|
@@ -2885,7 +2885,7 @@ static s32 wl_update_wiphybands(struct wl_cfg80211_priv *wl)
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
if (phy == 'n' || phy == 'a' || phy == 'v') {
|
|
|
|
wiphy = wl_to_wiphy(wl);
|
|
|
|
- wiphy->bands[IEEE80211_BAND_5GHZ] = &__wl_band_5ghz_n;
|
|
|
|
+ wiphy->bands[NL80211_BAND_5GHZ] = &__wl_band_5ghz_n;
|
|
|
|
}
|
|
|
|
|
|
|
|
return err;
|
2024-07-27 06:49:29 +00:00
|
|
|
--
|
|
|
|
2.45.1
|
|
|
|
|