rsi: add support for hardware scan offload

With the current approach of scanning, roaming delays are observed.
Firmware has support for back ground scanning. To get this advantage,
mac80211 hardware scan is implemented, which decides type of scan to
do based on connected state.

When station is in not connected, driver returns with special value 1
to trigger software scan in mac80211. In case of connected state,
background scan will be triggered.

Signed-off-by: Prameela Rani Garnepudi <prameela.j04cs@gmail.com>
Signed-off-by: Siva Rebbagondla <siva.rebbagondla@redpinesignals.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
Prameela Rani Garnepudi
2018-12-27 14:56:18 +05:30
committed by Kalle Valo
parent 42daad3343
commit 7fdcb8e126
6 changed files with 261 additions and 0 deletions

View File

@@ -164,6 +164,24 @@ struct transmit_q_stats {
u32 total_tx_pkt_freed[NUM_EDCA_QUEUES + 2];
};
#define MAX_BGSCAN_CHANNELS_DUAL_BAND 38
#define MAX_BGSCAN_PROBE_REQ_LEN 0x64
#define RSI_DEF_BGSCAN_THRLD 0x0
#define RSI_DEF_ROAM_THRLD 0xa
#define RSI_BGSCAN_PERIODICITY 0x1e
#define RSI_ACTIVE_SCAN_TIME 0x14
#define RSI_PASSIVE_SCAN_TIME 0x46
#define RSI_CHANNEL_SCAN_TIME 20
struct rsi_bgscan_params {
u16 bgscan_threshold;
u16 roam_threshold;
u16 bgscan_periodicity;
u8 num_bgscan_channels;
u8 two_probe;
u16 active_scan_duration;
u16 passive_scan_duration;
};
struct vif_priv {
bool is_ht;
bool sgi;
@@ -289,6 +307,10 @@ struct rsi_common {
bool eapol4_confirm;
void *bt_adapter;
struct cfg80211_scan_request *hwscan;
struct rsi_bgscan_params bgscan;
u8 bgscan_en;
};
struct eepromrw_info {