qcacld-3.0: Enable FEATURE_WLAN_MCC_TO_SCC_SWITCH flag in the driver

Enable feature flag FEATURE_WLAN_MCC_TO_SCC_SWITCH in the Kbuild to
make use of the MCC to SCC switch feature. The resulting errors in
compilation are fixed along with some enhancement in the debug logs
in this feature path

Change-Id: I0ddb2f371c28ade6d8fc9ea12ba104a99394827f
CRs-Fixed: 986079
Bu işleme şunda yer alıyor:
Chandrasekaran Manishekar
2016-03-07 11:51:07 +05:30
işlemeyi yapan: Gerrit - the friendly Code Review server
ebeveyn 58f4d625fc
işleme 068e25eeb8
7 değiştirilmiş dosya ile 64 ekleme ve 17 silme

7
Kbuild
Dosyayı Görüntüle

@@ -135,6 +135,9 @@ ifeq ($(KERNEL_BUILD), 0)
# Flag to enable LFR Subnet Detection
CONFIG_LFR_SUBNET_DETECTION := y
# Flag to enable MCC to SCC switch feature
CONFIG_MCC_TO_SCC_SWITCH := y
endif
# If not set, assume, Common driver is with in the build tree
@@ -1363,6 +1366,10 @@ ifeq ($(CONFIG_LFR_SUBNET_DETECTION), y)
CDEFINES += -DFEATURE_LFR_SUBNET_DETECTION
endif
ifeq ($(CONFIG_MCC_TO_SCC_SWITCH), y)
CDEFINES += -DFEATURE_WLAN_MCC_TO_SCC_SWITCH
endif
KBUILD_CPPFLAGS += $(CDEFINES)
# Currently, for versions of gcc which support it, the kernel Makefile

Dosyayı Görüntüle

@@ -6605,6 +6605,9 @@ static void cds_check_sta_ap_concurrent_ch_intf(void *data)
hdd_ap_ctx_t *hdd_ap_ctx;
uint16_t intf_ch = 0;
cds_info("cds_concurrent_open_sessions_running: %d",
cds_concurrent_open_sessions_running());
if ((hdd_ctx->config->WlanMccToSccSwitchMode ==
QDF_MCC_TO_SCC_SWITCH_DISABLE)
|| !(cds_concurrent_open_sessions_running()
@@ -6626,6 +6629,7 @@ static void cds_check_sta_ap_concurrent_ch_intf(void *data)
return;
intf_ch = wlansap_check_cc_intf(hdd_ap_ctx->sapContext);
cds_info("intf_ch:%d", intf_ch);
if (intf_ch == 0)
return;
@@ -6658,6 +6662,12 @@ void cds_check_concurrent_intf_and_restart_sap(hdd_station_ctx_t *hdd_sta_ctx,
return;
}
cds_info("mode:%d rule1:%d rule2:%d chan:%d",
hdd_ctx->config->WlanMccToSccSwitchMode,
hdd_ctx->config->conc_custom_rule1,
hdd_ctx->config->conc_custom_rule2,
hdd_sta_ctx->conn_info.operationChannel);
if ((hdd_ctx->config->WlanMccToSccSwitchMode
!= QDF_MCC_TO_SCC_SWITCH_DISABLE) &&
((0 == hdd_ctx->config->conc_custom_rule1) &&
@@ -7176,13 +7186,12 @@ void cds_restart_sap(hdd_adapter_t *ap_adapter)
hdd_ap_ctx_t *hdd_ap_ctx;
hdd_hostapd_state_t *hostapd_state;
QDF_STATUS qdf_status;
QDF_STATUS qdf_status;
hdd_context_t *hdd_ctx = WLAN_HDD_GET_CTX(ap_adapter);
tsap_Config_t *sap_config;
void *sap_ctx;
hdd_ap_ctx = WLAN_HDD_GET_AP_CTX_PTR(ap_adapter);
sap_config = &hdd_ap_ctx.sapConfig;
sap_config = &hdd_ap_ctx->sapConfig;
sap_ctx = hdd_ap_ctx->sapContext;
mutex_lock(&hdd_ctx->sap_lock);

Dosyayı Görüntüle

@@ -1839,6 +1839,7 @@ static QDF_STATUS hdd_association_completion_handler(hdd_adapter_t *pAdapter,
wlan_hdd_auto_shutdown_enable(pHddCtx, false);
#endif
hdd_info("check for SAP restart");
cds_check_concurrent_intf_and_restart_sap(pHddStaCtx,
pAdapter);

Dosyayı Görüntüle

@@ -1804,25 +1804,28 @@ void lim_fill_join_rsp_ht_caps(tpPESession session, tpSirSmeJoinRsp join_rsp)
{
tSirSmeHTProfile *ht_profile;
if (session == NULL) {
lim_log(mac_ctx, LOGE, FL("Invalid Session"));
QDF_TRACE(QDF_MODULE_ID_PE, QDF_TRACE_LEVEL_ERROR,
"Invalid Session");
return;
}
if (join_rsp == NULL) {
lim_log(mac_ctx, LOGE, FL("Invalid Join Response"));
QDF_TRACE(QDF_MODULE_ID_PE, QDF_TRACE_LEVEL_ERROR,
"Invalid Join Response");
return;
}
if (session->cc_switch_mode !=
QDF_MCC_TO_SCC_SWITCH_DISABLE) {
ht_profile = &join_rsp->HTProfile;
ht_profile->htSupportedChannelWidthSet =
session->htSupportedChannelWidthSet;
ht_profile->htRecommendedTxWidthSet =
session->htRecommendedTxWidthSet;
ht_profile->htSecondaryChannelOffset =
session->htSecondaryChannelOffset;
ht_profile->dot11mode = session->dot11mode;
ht_profile->htCapability = session->htCapability;
}
if (session->cc_switch_mode == QDF_MCC_TO_SCC_SWITCH_DISABLE)
return;
ht_profile = &join_rsp->HTProfile;
ht_profile->htSupportedChannelWidthSet =
session->htSupportedChannelWidthSet;
ht_profile->htRecommendedTxWidthSet =
session->htRecommendedTxWidthSet;
ht_profile->htSecondaryChannelOffset =
session->htSecondaryChannelOffset;
ht_profile->dot11mode = session->dot11mode;
ht_profile->htCapability = session->htCapability;
ht_profile->vhtCapability = session->vhtCapability;
ht_profile->vhtTxChannelWidthSet =
session->vhtTxChannelWidthSet;

Dosyayı Görüntüle

@@ -2146,6 +2146,10 @@ QDF_STATUS sap_goto_channel_sel(ptSapContext sap_context,
#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
if (sap_context->cc_switch_mode !=
QDF_MCC_TO_SCC_SWITCH_DISABLE) {
QDF_TRACE(QDF_MODULE_ID_SAP, QDF_TRACE_LEVEL_INFO,
FL("check for overlap: chan:%d mode:%d"),
sap_context->channel,
sap_context->csr_roamProfile.phyMode);
con_ch = sme_check_concurrent_channel_overlap(h_hal,
sap_context->channel,
sap_context->csr_roamProfile.phyMode,

Dosyayı Görüntüle

@@ -19041,6 +19041,10 @@ void csr_roam_synch_callback(tpAniSirGlobal mac_ctx,
struct qdf_mac_addr bcast_mac = QDF_MAC_ADDR_BROADCAST_INITIALIZER;
tpAddBssParams add_bss_params;
QDF_STATUS status = QDF_STATUS_SUCCESS;
#ifdef FEATURE_WLAN_MCC_TO_SCC_SWITCH
tSirSmeHTProfile *src_profile = NULL;
tCsrRoamHTProfile *dst_profile = NULL;
#endif
status = sme_acquire_global_lock(&mac_ctx->sme);
if (!QDF_IS_STATUS_SUCCESS(status)) {

Dosyayı Görüntüle

@@ -693,7 +693,10 @@ uint16_t csr_check_concurrent_channel_overlap(tpAniSirGlobal mac_ctx,
uint8_t i = 0, chb = PHY_SINGLE_CHANNEL_CENTERED;
uint16_t intf_ch = 0, sap_hbw = 0, intf_hbw = 0, intf_cfreq = 0;
uint16_t sap_cfreq = 0;
uint16_t sap_lfreq, sap_hfreq, intf_lfreq, intf_hfreq, sap_cch;
uint16_t sap_lfreq, sap_hfreq, intf_lfreq, intf_hfreq, sap_cch = 0;
sms_log(mac_ctx, LOG1, FL("sap_ch:%d sap_phymode:%d"),
sap_ch, sap_phymode);
if (mac_ctx->roam.configParam.cc_switch_mode ==
QDF_MCC_TO_SCC_SWITCH_DISABLE)
@@ -714,6 +717,10 @@ uint16_t csr_check_concurrent_channel_overlap(tpAniSirGlobal mac_ctx,
sap_cfreq = cds_chan_to_freq(sap_cch);
}
sms_log(mac_ctx, LOG1,
FL("sap_ch:%d sap_phymode:%d sap_cch:%d sap_hbw:%d chb:%d"),
sap_ch, sap_phymode, sap_cch, sap_hbw, chb);
for (i = 0; i < CSR_ROAM_SESSION_MAX; i++) {
if (!CSR_IS_SESSION_VALID(mac_ctx, i))
continue;
@@ -730,6 +737,9 @@ uint16_t csr_check_concurrent_channel_overlap(tpAniSirGlobal mac_ctx,
csr_get_ch_from_ht_profile(mac_ctx,
&session->connectedProfile.HTProfile,
intf_ch, &intf_cfreq, &intf_hbw);
sms_log(mac_ctx, LOG1,
FL("%d: intf_ch:%d intf_cfreq:%d intf_hbw:%d"),
i, intf_ch, intf_cfreq, intf_hbw);
} else if (((session->pCurRoamProfile->csrPersona ==
QDF_P2P_GO_MODE) ||
(session->pCurRoamProfile->csrPersona ==
@@ -742,9 +752,18 @@ uint16_t csr_check_concurrent_channel_overlap(tpAniSirGlobal mac_ctx,
csr_handle_conc_chnl_overlap_for_sap_go(mac_ctx,
session, &sap_ch, &sap_hbw, &sap_cfreq,
&intf_ch, &intf_hbw, &intf_cfreq);
sms_log(mac_ctx, LOG1,
FL("%d: sap_ch:%d sap_hbw:%d sap_cfreq:%d intf_ch:%d intf_hbw:%d, intf_cfreq:%d"),
i, sap_ch, sap_hbw, sap_cfreq,
intf_ch, intf_hbw, intf_cfreq);
}
}
sms_log(mac_ctx, LOG1,
FL("intf_ch:%d sap_ch:%d intf_ch:%d"),
intf_ch, sap_ch, intf_ch);
if (intf_ch && sap_ch != intf_ch &&
cc_switch_mode != QDF_MCC_TO_SCC_SWITCH_FORCE) {
sap_lfreq = sap_cfreq - sap_hbw;