qcacld-3.0: Limit ROC for listen if NAN or NDI present

In P2P, if NDP is present, limit max ROC duration to
400ms on DBS and 250ms on non-DBS case.
If NAN is present, limit max ROC duration to 450ms on DBS
and 300ms on non-DBS case.

Change-Id: I2e943d2f55984464812bba16ca78dfab8681cf30
CRs-Fixed: 3046904
This commit is contained in:
Deeksha Gupta
2021-09-28 15:26:49 +05:30
committed by Madan Koyyalamudi
parent 3d2484f25f
commit 1bdf606dab
2 changed files with 40 additions and 5 deletions

View File

@@ -82,7 +82,9 @@ static QDF_STATUS p2p_scan_start(struct p2p_roc_context *roc_ctx)
struct wlan_objmgr_vdev *vdev;
struct p2p_soc_priv_obj *p2p_soc_obj = roc_ctx->p2p_soc_obj;
uint32_t go_num;
uint8_t ndp_num = 0, nan_disc_enabled_num = 0;
struct wlan_objmgr_pdev *pdev;
bool is_dbs;
vdev = wlan_objmgr_get_vdev_by_id_from_psoc(
p2p_soc_obj->soc, roc_ctx->vdev_id,
@@ -123,7 +125,17 @@ static QDF_STATUS p2p_scan_start(struct p2p_roc_context *roc_ctx)
if (req->scan_req.dwell_time_passive < P2P_MAX_ROC_DURATION) {
go_num = policy_mgr_mode_specific_connection_count(
p2p_soc_obj->soc, PM_P2P_GO_MODE, NULL);
p2p_debug("present go number:%d", go_num);
policy_mgr_mode_specific_num_active_sessions(p2p_soc_obj->soc,
QDF_NDI_MODE,
&ndp_num);
policy_mgr_mode_specific_num_active_sessions(p2p_soc_obj->soc,
QDF_NAN_DISC_MODE,
&nan_disc_enabled_num);
p2p_debug("present go number:%d, NDP number:%d, NAN number:%d",
go_num, ndp_num, nan_disc_enabled_num);
is_dbs = policy_mgr_is_hw_dbs_capable(p2p_soc_obj->soc);
if (go_num)
/* Add fixed 300ms extra ROC time instead of multiplying the
* ROC duration by const value as this causes the ROC to be
@@ -144,12 +156,31 @@ static QDF_STATUS p2p_scan_start(struct p2p_roc_context *roc_ctx)
* give a higher value from supplicant
*/
if (go_num && req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION_GO_PRESENT)
P2P_MAX_ROC_DURATION_GO_PRESENT) {
req->scan_req.dwell_time_passive =
P2P_MAX_ROC_DURATION_GO_PRESENT;
else if (req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION)
} else if (ndp_num) {
if (is_dbs && req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION_DBS_NDP_PRESENT)
req->scan_req.dwell_time_passive =
P2P_MAX_ROC_DURATION_DBS_NDP_PRESENT;
else if (!is_dbs && req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION_NON_DBS_NDP_PRESENT)
req->scan_req.dwell_time_passive =
P2P_MAX_ROC_DURATION_NON_DBS_NDP_PRESENT;
} else if (nan_disc_enabled_num) {
if (is_dbs && req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION_DBS_NAN_PRESENT)
req->scan_req.dwell_time_passive =
P2P_MAX_ROC_DURATION_DBS_NAN_PRESENT;
else if (!is_dbs && req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION_NON_DBS_NAN_PRESENT)
req->scan_req.dwell_time_passive =
P2P_MAX_ROC_DURATION_NON_DBS_NAN_PRESENT;
} else if (req->scan_req.dwell_time_passive >
P2P_MAX_ROC_DURATION) {
req->scan_req.dwell_time_passive = P2P_MAX_ROC_DURATION;
}
}
p2p_debug("FW requested roc duration is:%d",
req->scan_req.dwell_time_passive);

View File

@@ -31,7 +31,11 @@
#define P2P_WAIT_CANCEL_ROC 1000
#define P2P_WAIT_CLEANUP_ROC 2000
#define P2P_MAX_ROC_DURATION 1500
#define P2P_MAX_ROC_DURATION_GO_PRESENT 600
#define P2P_MAX_ROC_DURATION_GO_PRESENT 600
#define P2P_MAX_ROC_DURATION_DBS_NDP_PRESENT 400
#define P2P_MAX_ROC_DURATION_NON_DBS_NDP_PRESENT 250
#define P2P_MAX_ROC_DURATION_DBS_NAN_PRESENT 450
#define P2P_MAX_ROC_DURATION_NON_DBS_NAN_PRESENT 300
#define P2P_ROC_DURATION_MULTI_GO_PRESENT 300
#define P2P_ROC_DURATION_MULTI_GO_ABSENT 10