Merge branch 'for-john' of git://git.kernel.org/pub/scm/linux/kernel/git/iwlwifi/iwlwifi-fixes
This commit is contained in:
commit
dc70a292da
|
@ -88,6 +88,7 @@
|
||||||
* P2P client interfaces simultaneously if they are in different bindings.
|
* P2P client interfaces simultaneously if they are in different bindings.
|
||||||
* @IWL_UCODE_TLV_FLAGS_P2P_BSS_PS_SCM: support power save on BSS station and
|
* @IWL_UCODE_TLV_FLAGS_P2P_BSS_PS_SCM: support power save on BSS station and
|
||||||
* P2P client interfaces simultaneously if they are in same bindings.
|
* P2P client interfaces simultaneously if they are in same bindings.
|
||||||
|
* @IWL_UCODE_TLV_FLAGS_UAPSD_SUPPORT: General support for uAPSD
|
||||||
* @IWL_UCODE_TLV_FLAGS_P2P_PS_UAPSD: P2P client supports uAPSD power save
|
* @IWL_UCODE_TLV_FLAGS_P2P_PS_UAPSD: P2P client supports uAPSD power save
|
||||||
* @IWL_UCODE_TLV_FLAGS_BCAST_FILTERING: uCode supports broadcast filtering.
|
* @IWL_UCODE_TLV_FLAGS_BCAST_FILTERING: uCode supports broadcast filtering.
|
||||||
* @IWL_UCODE_TLV_FLAGS_GO_UAPSD: AP/GO interfaces support uAPSD clients
|
* @IWL_UCODE_TLV_FLAGS_GO_UAPSD: AP/GO interfaces support uAPSD clients
|
||||||
|
|
|
@ -303,6 +303,13 @@ int iwl_mvm_mac_setup_register(struct iwl_mvm *mvm)
|
||||||
hw->uapsd_max_sp_len = IWL_UAPSD_MAX_SP;
|
hw->uapsd_max_sp_len = IWL_UAPSD_MAX_SP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mvm->fw->ucode_capa.flags & IWL_UCODE_TLV_FLAGS_UAPSD_SUPPORT &&
|
||||||
|
!iwlwifi_mod_params.uapsd_disable) {
|
||||||
|
hw->flags |= IEEE80211_HW_SUPPORTS_UAPSD;
|
||||||
|
hw->uapsd_queues = IWL_UAPSD_AC_INFO;
|
||||||
|
hw->uapsd_max_sp_len = IWL_UAPSD_MAX_SP;
|
||||||
|
}
|
||||||
|
|
||||||
hw->sta_data_size = sizeof(struct iwl_mvm_sta);
|
hw->sta_data_size = sizeof(struct iwl_mvm_sta);
|
||||||
hw->vif_data_size = sizeof(struct iwl_mvm_vif);
|
hw->vif_data_size = sizeof(struct iwl_mvm_vif);
|
||||||
hw->chanctx_data_size = sizeof(u16);
|
hw->chanctx_data_size = sizeof(u16);
|
||||||
|
|
|
@ -588,9 +588,7 @@ static void iwl_build_scan_cmd(struct iwl_mvm *mvm,
|
||||||
struct iwl_scan_offload_cmd *scan,
|
struct iwl_scan_offload_cmd *scan,
|
||||||
struct iwl_mvm_scan_params *params)
|
struct iwl_mvm_scan_params *params)
|
||||||
{
|
{
|
||||||
scan->channel_count =
|
scan->channel_count = req->n_channels;
|
||||||
mvm->nvm_data->bands[IEEE80211_BAND_2GHZ].n_channels +
|
|
||||||
mvm->nvm_data->bands[IEEE80211_BAND_5GHZ].n_channels;
|
|
||||||
scan->quiet_time = cpu_to_le16(IWL_ACTIVE_QUIET_TIME);
|
scan->quiet_time = cpu_to_le16(IWL_ACTIVE_QUIET_TIME);
|
||||||
scan->quiet_plcp_th = cpu_to_le16(IWL_PLCP_QUIET_THRESH);
|
scan->quiet_plcp_th = cpu_to_le16(IWL_PLCP_QUIET_THRESH);
|
||||||
scan->good_CRC_th = IWL_GOOD_CRC_TH_DEFAULT;
|
scan->good_CRC_th = IWL_GOOD_CRC_TH_DEFAULT;
|
||||||
|
@ -669,61 +667,37 @@ static void iwl_build_channel_cfg(struct iwl_mvm *mvm,
|
||||||
struct cfg80211_sched_scan_request *req,
|
struct cfg80211_sched_scan_request *req,
|
||||||
struct iwl_scan_channel_cfg *channels,
|
struct iwl_scan_channel_cfg *channels,
|
||||||
enum ieee80211_band band,
|
enum ieee80211_band band,
|
||||||
int *head, int *tail,
|
int *head,
|
||||||
u32 ssid_bitmap,
|
u32 ssid_bitmap,
|
||||||
struct iwl_mvm_scan_params *params)
|
struct iwl_mvm_scan_params *params)
|
||||||
{
|
{
|
||||||
struct ieee80211_supported_band *s_band;
|
int i, index = 0;
|
||||||
int n_channels = req->n_channels;
|
|
||||||
int i, j, index = 0;
|
|
||||||
bool partial;
|
|
||||||
|
|
||||||
/*
|
for (i = 0; i < req->n_channels; i++) {
|
||||||
* We have to configure all supported channels, even if we don't want to
|
struct ieee80211_channel *chan = req->channels[i];
|
||||||
* scan on them, but we have to send channels in the order that we want
|
|
||||||
* to scan. So add requested channels to head of the list and others to
|
|
||||||
* the end.
|
|
||||||
*/
|
|
||||||
s_band = &mvm->nvm_data->bands[band];
|
|
||||||
|
|
||||||
for (i = 0; i < s_band->n_channels && *head <= *tail; i++) {
|
if (chan->band != band)
|
||||||
partial = false;
|
continue;
|
||||||
for (j = 0; j < n_channels; j++)
|
|
||||||
if (s_band->channels[i].center_freq ==
|
index = *head;
|
||||||
req->channels[j]->center_freq) {
|
(*head)++;
|
||||||
index = *head;
|
|
||||||
(*head)++;
|
channels->channel_number[index] = cpu_to_le16(chan->hw_value);
|
||||||
/*
|
|
||||||
* Channels that came with the request will be
|
|
||||||
* in partial scan .
|
|
||||||
*/
|
|
||||||
partial = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!partial) {
|
|
||||||
index = *tail;
|
|
||||||
(*tail)--;
|
|
||||||
}
|
|
||||||
channels->channel_number[index] =
|
|
||||||
cpu_to_le16(ieee80211_frequency_to_channel(
|
|
||||||
s_band->channels[i].center_freq));
|
|
||||||
channels->dwell_time[index][0] = params->dwell[band].active;
|
channels->dwell_time[index][0] = params->dwell[band].active;
|
||||||
channels->dwell_time[index][1] = params->dwell[band].passive;
|
channels->dwell_time[index][1] = params->dwell[band].passive;
|
||||||
|
|
||||||
channels->iter_count[index] = cpu_to_le16(1);
|
channels->iter_count[index] = cpu_to_le16(1);
|
||||||
channels->iter_interval[index] = 0;
|
channels->iter_interval[index] = 0;
|
||||||
|
|
||||||
if (!(s_band->channels[i].flags & IEEE80211_CHAN_NO_IR))
|
if (!(chan->flags & IEEE80211_CHAN_NO_IR))
|
||||||
channels->type[index] |=
|
channels->type[index] |=
|
||||||
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_ACTIVE);
|
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_ACTIVE);
|
||||||
|
|
||||||
channels->type[index] |=
|
channels->type[index] |=
|
||||||
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_FULL);
|
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_FULL |
|
||||||
if (partial)
|
IWL_SCAN_OFFLOAD_CHANNEL_PARTIAL);
|
||||||
channels->type[index] |=
|
|
||||||
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_PARTIAL);
|
|
||||||
|
|
||||||
if (s_band->channels[i].flags & IEEE80211_CHAN_NO_HT40)
|
if (chan->flags & IEEE80211_CHAN_NO_HT40)
|
||||||
channels->type[index] |=
|
channels->type[index] |=
|
||||||
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_NARROW);
|
cpu_to_le32(IWL_SCAN_OFFLOAD_CHANNEL_NARROW);
|
||||||
|
|
||||||
|
@ -740,7 +714,6 @@ int iwl_mvm_config_sched_scan(struct iwl_mvm *mvm,
|
||||||
int band_2ghz = mvm->nvm_data->bands[IEEE80211_BAND_2GHZ].n_channels;
|
int band_2ghz = mvm->nvm_data->bands[IEEE80211_BAND_2GHZ].n_channels;
|
||||||
int band_5ghz = mvm->nvm_data->bands[IEEE80211_BAND_5GHZ].n_channels;
|
int band_5ghz = mvm->nvm_data->bands[IEEE80211_BAND_5GHZ].n_channels;
|
||||||
int head = 0;
|
int head = 0;
|
||||||
int tail = band_2ghz + band_5ghz - 1;
|
|
||||||
u32 ssid_bitmap;
|
u32 ssid_bitmap;
|
||||||
int cmd_len;
|
int cmd_len;
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -772,7 +745,7 @@ int iwl_mvm_config_sched_scan(struct iwl_mvm *mvm,
|
||||||
&scan_cfg->scan_cmd.tx_cmd[0],
|
&scan_cfg->scan_cmd.tx_cmd[0],
|
||||||
scan_cfg->data);
|
scan_cfg->data);
|
||||||
iwl_build_channel_cfg(mvm, req, &scan_cfg->channel_cfg,
|
iwl_build_channel_cfg(mvm, req, &scan_cfg->channel_cfg,
|
||||||
IEEE80211_BAND_2GHZ, &head, &tail,
|
IEEE80211_BAND_2GHZ, &head,
|
||||||
ssid_bitmap, ¶ms);
|
ssid_bitmap, ¶ms);
|
||||||
}
|
}
|
||||||
if (band_5ghz) {
|
if (band_5ghz) {
|
||||||
|
@ -782,7 +755,7 @@ int iwl_mvm_config_sched_scan(struct iwl_mvm *mvm,
|
||||||
scan_cfg->data +
|
scan_cfg->data +
|
||||||
SCAN_OFFLOAD_PROBE_REQ_SIZE);
|
SCAN_OFFLOAD_PROBE_REQ_SIZE);
|
||||||
iwl_build_channel_cfg(mvm, req, &scan_cfg->channel_cfg,
|
iwl_build_channel_cfg(mvm, req, &scan_cfg->channel_cfg,
|
||||||
IEEE80211_BAND_5GHZ, &head, &tail,
|
IEEE80211_BAND_5GHZ, &head,
|
||||||
ssid_bitmap, ¶ms);
|
ssid_bitmap, ¶ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -367,6 +367,7 @@ static DEFINE_PCI_DEVICE_TABLE(iwl_hw_card_ids) = {
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x5012, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x5012, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x5412, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x5412, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x5410, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x5410, iwl7265_2ac_cfg)},
|
||||||
|
{IWL_PCI_DEVICE(0x095A, 0x5510, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x5400, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x5400, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x1010, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x1010, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x5000, iwl7265_2n_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x5000, iwl7265_2n_cfg)},
|
||||||
|
@ -380,7 +381,7 @@ static DEFINE_PCI_DEVICE_TABLE(iwl_hw_card_ids) = {
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9110, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9110, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9112, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9112, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9210, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9210, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9200, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095B, 0x9200, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9510, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9510, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9310, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9310, iwl7265_2ac_cfg)},
|
||||||
{IWL_PCI_DEVICE(0x095A, 0x9410, iwl7265_2ac_cfg)},
|
{IWL_PCI_DEVICE(0x095A, 0x9410, iwl7265_2ac_cfg)},
|
||||||
|
|
Loading…
Reference in New Issue