浏览代码

qcacld-3.0: Move LFR2 code under connection manager flag

Move LFR2 code under connection manager flag.

Change-Id: Ic82817a3265af0342cf317ec4f9f086f1a70bef0
CRs-fixed: 2883189
gaurank kathpalia 4 年之前
父节点
当前提交
dd6f134f2d

+ 13 - 2
components/umac/mlme/connection_mgr/core/src/wlan_cm_roam_offload.c

@@ -2608,11 +2608,14 @@ cm_roam_stop_req(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id,
 	status = wlan_cm_tgt_send_roam_stop_req(psoc, vdev_id, stop_req);
 	if (QDF_IS_STATUS_ERROR(status)) {
 		mlme_debug("fail to send roam stop");
-	} else {
+	}
+#ifndef FEATURE_CM_ENABLE
+	else {
 		status = wlan_cm_roam_scan_offload_rsp(vdev_id, reason);
 		if (QDF_IS_STATUS_ERROR(status))
 			mlme_debug("fail to send rso rsp msg");
 	}
+#endif
 
 rel_vdev_ref:
 	wlan_objmgr_vdev_release_ref(vdev, WLAN_MLME_CM_ID);
@@ -2966,9 +2969,12 @@ cm_roam_switch_to_rso_stop(struct wlan_objmgr_pdev *pdev,
 	 * nothing to do here
 	 */
 	default:
+
+#ifndef FEATURE_CM_ENABLE
 		/* For LFR2 BTM request, need handoff even roam disabled */
 		if (reason == REASON_OS_REQUESTED_ROAMING_NOW)
 			wlan_cm_roam_neighbor_proceed_with_handoff_req(vdev_id);
+#endif
 		return QDF_STATUS_SUCCESS;
 	}
 	mlme_set_roam_state(psoc, vdev_id, WLAN_ROAM_RSO_STOPPED);
@@ -3377,7 +3383,12 @@ cm_roam_switch_to_roam_sync(struct wlan_objmgr_pdev *pdev,
 		 * deauth roam trigger to stop data path queues
 		 */
 	case WLAN_ROAMING_IN_PROG:
-		if (!wlan_cm_is_sta_connected(vdev_id)) {
+#ifdef FEATURE_CM_ENABLE
+		if (!cm_is_vdevid_connected(pdev, vdev_id))
+#else
+		if (!wlan_cm_is_sta_connected(vdev_id))
+#endif
+		{
 			mlme_err("ROAM: STA not in connected state");
 			return QDF_STATUS_E_FAILURE;
 		}

+ 13 - 13
components/umac/mlme/connection_mgr/dispatcher/inc/wlan_cm_roam_api.h

@@ -104,7 +104,18 @@ wlan_roam_update_cfg(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id,
 QDF_STATUS
 wlan_cm_roam_cmd_allowed(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id,
 			 uint8_t rso_command, uint8_t reason);
-#endif
+
+/**
+ * wlan_cm_roam_neighbor_proceed_with_handoff_req() - invoke host handover to
+ * new AP
+ * @vdev_id: vdev id
+ *
+ * This function gets called to invoke host handover to new AP
+ *
+ * Return: QDF_STATUS
+ */
+QDF_STATUS
+wlan_cm_roam_neighbor_proceed_with_handoff_req(uint8_t vdev_id);
 
 /**
  * wlan_cm_roam_scan_offload_rsp() - send roam scan offload response message
@@ -117,6 +128,7 @@ wlan_cm_roam_cmd_allowed(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id,
  */
 QDF_STATUS
 wlan_cm_roam_scan_offload_rsp(uint8_t vdev_id, uint8_t reason);
+#endif
 
 /**
  * wlan_cm_send_beacon_miss() - initiate beacon miss
@@ -127,18 +139,6 @@ wlan_cm_roam_scan_offload_rsp(uint8_t vdev_id, uint8_t reason);
  */
 void wlan_cm_send_beacon_miss(uint8_t vdev_id, int32_t rssi);
 
-/**
- * wlan_cm_roam_neighbor_proceed_with_handoff_req() - invoke host handover to
- * new AP
- * @vdev_id: vdev id
- *
- * This function gets called to invoke host handover to new AP
- *
- * Return: QDF_STATUS
- */
-QDF_STATUS
-wlan_cm_roam_neighbor_proceed_with_handoff_req(uint8_t vdev_id);
-
 /**
  * wlan_cm_is_sta_connected() - check if STA is connected
  * @vdev_id: vdev id

+ 0 - 4
core/hdd/src/wlan_hdd_wext.c

@@ -6174,14 +6174,10 @@ static int __iw_get_char_setnone(struct net_device *dev,
 				scnprintf(extra + len, WE_MAX_STR_LEN - len,
 					  "\n HDD Conn State - %s "
 					  "\n\n SME State:"
-					  "\n Neighbour Roam State - %s"
 					  "\n CSR State - %s"
 					  "\n CSR Substate - %s",
 					  hdd_connection_state_string
 						  (sta_ctx->conn_info.conn_state),
-					  mac_trace_get_neighbour_roam_state
-						  (sme_get_neighbor_roam_state
-							  (mac_handle, stat_adapter->vdev_id)),
 					  mac_trace_getcsr_roam_state
 						  (sme_get_current_roam_state
 							  (mac_handle, stat_adapter->vdev_id)),

+ 3 - 1
core/mac/inc/mac_trace.h

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2013-2016, 2018-2020 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2013-2016, 2018-2021 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -61,7 +61,9 @@ uint8_t *mac_trace_get_info_log_string(uint16_t infoLog);
 
 #endif
 uint8_t *mac_trace_get_wma_msg_string(uint16_t wmaMsg);
+#ifndef FEATURE_CM_ENABLE
 uint8_t *mac_trace_get_neighbour_roam_state(uint16_t neighbourRoamState);
+#endif
 uint8_t *mac_trace_getcsr_roam_state(uint16_t csr_roamState);
 uint8_t *mac_trace_getcsr_roam_sub_state(uint16_t csr_roamSubState);
 uint8_t *mac_trace_get_lim_sme_state(uint16_t limState);

+ 4 - 0
core/mac/inc/wni_api.h

@@ -88,8 +88,10 @@ enum eWniMsgTypes {
 	/* unused SIR_SME_MSG_TYPES_BEGIN + 47, */
 	/* unused SIR_SME_MSG_TYPES_BEGIN + 48, */
 
+#ifndef FEATURE_CM_ENABLE
 	eWNI_SME_FT_PRE_AUTH_REQ = SIR_SME_MSG_TYPES_BEGIN + 49,
 	eWNI_SME_FT_PRE_AUTH_RSP = SIR_SME_MSG_TYPES_BEGIN + 50,
+#endif
 	eWNI_SME_FT_AGGR_QOS_REQ = SIR_SME_MSG_TYPES_BEGIN + 52,
 	eWNI_SME_FT_AGGR_QOS_RSP = SIR_SME_MSG_TYPES_BEGIN + 53,
 
@@ -122,12 +124,14 @@ enum eWniMsgTypes {
 #ifdef WLAN_FEATURE_GTK_OFFLOAD
 	eWNI_PMC_GTK_OFFLOAD_GETINFO_RSP = SIR_SME_MSG_TYPES_BEGIN + 75,
 #endif /* WLAN_FEATURE_GTK_OFFLOAD */
+#ifndef FEATURE_CM_ENABLE
 	/*ROAM candidate indication from FW */
 	eWNI_SME_CANDIDATE_FOUND_IND = SIR_SME_MSG_TYPES_BEGIN + 76,
 	/*upper layer requested handoff to driver in STA mode */
 	eWNI_SME_HANDOFF_REQ = SIR_SME_MSG_TYPES_BEGIN + 77,
 	/*Fwd the LFR scan offload rsp from FW to SME */
 	eWNI_SME_ROAM_SCAN_OFFLOAD_RSP = SIR_SME_MSG_TYPES_BEGIN + 78,
+#endif
 	eWNI_SME_GET_TSM_STATS_REQ = SIR_SME_MSG_TYPES_BEGIN + 80,
 	eWNI_SME_GET_TSM_STATS_RSP = SIR_SME_MSG_TYPES_BEGIN + 81,
 	eWNI_SME_TSM_IE_IND = SIR_SME_MSG_TYPES_BEGIN + 82,

+ 13 - 1
core/mac/src/pe/lim/lim_ft_preauth.c

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2016-2020 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2016-2021 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -588,6 +588,7 @@ void lim_post_ft_pre_auth_rsp(struct mac_context *mac_ctx,
 			      uint16_t auth_rsp_length,
 			      struct pe_session *session)
 {
+#ifndef FEATURE_CM_ENABLE
 	tpSirFTPreAuthRsp ft_pre_auth_rsp;
 	struct scheduler_msg mmh_msg = {0};
 	uint16_t rsp_len = sizeof(tSirFTPreAuthRsp);
@@ -613,6 +614,7 @@ void lim_post_ft_pre_auth_rsp(struct mac_context *mac_ctx,
 			    session->ftPEContext.pFTPreAuthReq->preAuthbssId);
 	}
 
+
 	ft_pre_auth_rsp->messageType = eWNI_SME_FT_PRE_AUTH_RSP;
 	ft_pre_auth_rsp->length = (uint16_t) rsp_len;
 	ft_pre_auth_rsp->status = status;
@@ -640,12 +642,22 @@ void lim_post_ft_pre_auth_rsp(struct mac_context *mac_ctx,
 	mmh_msg.bodyval = 0;
 
 	pe_debug("Posted Auth Rsp to SME with status of 0x%x", status);
+
 #ifdef FEATURE_WLAN_DIAG_SUPPORT_LIM    /* FEATURE_WLAN_DIAG_SUPPORT */
 	if (status == QDF_STATUS_SUCCESS)
 		lim_diag_event_report(mac_ctx, WLAN_PE_DIAG_PREAUTH_DONE,
 				      session, status, 0);
 #endif
+
 	lim_sys_process_mmh_msg_api(mac_ctx, &mmh_msg);
+#else
+#ifdef FEATURE_WLAN_DIAG_SUPPORT_LIM    /* FEATURE_WLAN_DIAG_SUPPORT */
+	if (status == QDF_STATUS_SUCCESS)
+		lim_diag_event_report(mac_ctx, WLAN_PE_DIAG_PREAUTH_DONE,
+				      session, status, 0);
+#endif
+	/* post msg to osif to cm */
+#endif
 }
 
 /**

+ 2 - 0
core/mac/src/pe/lim/lim_process_message_queue.c

@@ -1748,7 +1748,9 @@ static void lim_process_messages(struct mac_context *mac_ctx,
 #if defined FEATURE_WLAN_ESE
 	case eWNI_SME_ESE_ADJACENT_AP_REPORT:
 #endif
+#ifndef FEATURE_CM_ENABLE
 	case eWNI_SME_FT_PRE_AUTH_REQ:
+#endif
 	case eWNI_SME_FT_AGGR_QOS_REQ:
 	case eWNI_SME_REGISTER_MGMT_FRAME_REQ:
 #ifdef FEATURE_WLAN_ESE

+ 4 - 1
core/mac/src/pe/lim/lim_process_sme_req_messages.c

@@ -7379,10 +7379,13 @@ bool lim_process_sme_req_messages(struct mac_context *mac,
 		__lim_process_report_message(mac, pMsg);
 		break;
 
+#ifndef FEATURE_CM_ENABLE
 	case eWNI_SME_FT_PRE_AUTH_REQ:
 		bufConsumed = (bool) lim_process_ft_pre_auth_req(mac, pMsg);
 		break;
-
+#else
+	/* handle new command */
+#endif
 	case eWNI_SME_FT_AGGR_QOS_REQ:
 		lim_process_ft_aggr_qos_req(mac, msg_buf);
 		break;

+ 10 - 1
core/mac/src/sys/legacy/src/utils/src/mac_trace.c

@@ -41,6 +41,7 @@
 #include "wma_if.h"
 #include "wma.h"
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * mac_trace_get_neighbour_roam_state() - Get the neighbor roam state
  * @neighbourroamstate: State in numeric form
@@ -65,7 +66,7 @@ uint8_t *mac_trace_get_neighbour_roam_state(uint16_t neighbourroamstate)
 		break;
 	}
 }
-
+#endif
 /**
  * mac_trace_getcsr_roam_state() - Get the csr roam state
  * @csr_roam_state: State in numeric form
@@ -114,7 +115,9 @@ uint8_t *mac_trace_getcsr_roam_sub_state(uint16_t csr_roam_sub_state)
 		CASE_RETURN_STRING(eCSR_ROAM_SUBSTATE_DISASSOC_REASSOC_FAILURE);
 		CASE_RETURN_STRING(eCSR_ROAM_SUBSTATE_DISASSOC_FORCED);
 		CASE_RETURN_STRING(eCSR_ROAM_SUBSTATE_WAIT_FOR_KEY);
+#ifndef FEATURE_CM_ENABLE
 		CASE_RETURN_STRING(eCSR_ROAM_SUBSTATE_DISASSOC_HANDOFF);
+#endif
 		CASE_RETURN_STRING(eCSR_ROAM_SUBSTATE_JOINED_NO_TRAFFIC);
 		CASE_RETURN_STRING
 			(eCSR_ROAM_SUBSTATE_JOINED_NON_REALTIME_TRAFFIC);
@@ -255,8 +258,10 @@ uint8_t *mac_trace_get_sme_msg_string(uint16_t sme_msg)
 		CASE_RETURN_STRING(eWNI_SME_NEIGHBOR_REPORT_IND);
 		CASE_RETURN_STRING(eWNI_SME_BEACON_REPORT_REQ_IND);
 		CASE_RETURN_STRING(eWNI_SME_BEACON_REPORT_RESP_XMIT_IND);
+#ifndef FEATURE_CM_ENABLE
 		CASE_RETURN_STRING(eWNI_SME_FT_PRE_AUTH_REQ);
 		CASE_RETURN_STRING(eWNI_SME_FT_PRE_AUTH_RSP);
+#endif
 		CASE_RETURN_STRING(eWNI_SME_FT_AGGR_QOS_REQ);
 		CASE_RETURN_STRING(eWNI_SME_FT_AGGR_QOS_RSP);
 #if defined FEATURE_WLAN_ESE
@@ -268,7 +273,9 @@ uint8_t *mac_trace_get_sme_msg_string(uint16_t sme_msg)
 #ifdef WLAN_FEATURE_GTK_OFFLOAD
 		CASE_RETURN_STRING(eWNI_PMC_GTK_OFFLOAD_GETINFO_RSP);
 #endif /* WLAN_FEATURE_GTK_OFFLOAD */
+#ifndef FEATURE_CM_ENABLE
 		CASE_RETURN_STRING(eWNI_SME_ROAM_SCAN_OFFLOAD_RSP);
+#endif
 		CASE_RETURN_STRING(eWNI_SME_DFS_RADAR_FOUND);
 		CASE_RETURN_STRING(eWNI_SME_CHANNEL_CHANGE_REQ);
 		CASE_RETURN_STRING(eWNI_SME_CHANNEL_CHANGE_RSP);
@@ -304,8 +311,10 @@ uint8_t *mac_trace_get_sme_msg_string(uint16_t sme_msg)
 #ifdef WLAN_FEATURE_11W
 		CASE_RETURN_STRING(eWNI_SME_UNPROT_MGMT_FRM_IND);
 #endif
+#ifndef FEATURE_CM_ENABLE
 		CASE_RETURN_STRING(eWNI_SME_CANDIDATE_FOUND_IND);
 		CASE_RETURN_STRING(eWNI_SME_HANDOFF_REQ);
+#endif
 		CASE_RETURN_STRING(eWNI_SME_GET_TSM_STATS_REQ);
 		CASE_RETURN_STRING(eWNI_SME_GET_TSM_STATS_RSP);
 		CASE_RETURN_STRING(eWNI_SME_TSM_IE_IND);

+ 2 - 1
core/sme/inc/csr_api.h

@@ -1190,6 +1190,7 @@ typedef void (*tCsrTsmStatsCallback)(tAniTrafStrmMetrics tsmMetrics,
 #endif /* FEATURE_WLAN_ESE */
 typedef void (*tCsrSnrCallback)(int8_t snr, void *pContext);
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * csr_roam_issue_ft_preauth_req() - Initiate Preauthentication request
  * @max_ctx: Global MAC context
@@ -1221,7 +1222,7 @@ QDF_STATUS csr_continue_lfr2_connect(struct mac_context *mac,
 	return QDF_STATUS_E_NOSUPPORT;
 }
 #endif
-
+#endif
 typedef void (*csr_readyToSuspendCallback)(void *pContext, bool suspended);
 #ifdef WLAN_FEATURE_EXTWOW_SUPPORT
 typedef void (*csr_readyToExtWoWCallback)(void *pContext, bool status);

+ 3 - 1
core/sme/inc/csr_host_scan_roam.h

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2011-2019 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2011-2019,2021 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -19,6 +19,7 @@
 #ifndef CSR_HOST_SCAN_ROAM_H
 #define CSR_HOST_SCAN_ROAM_H
 
+#ifndef FEATURE_CM_ENABLE
 #ifdef WLAN_FEATURE_HOST_ROAM
 /**
  * csr_roam_issue_reassociate() - Issue Reassociate
@@ -263,4 +264,5 @@ csr_neighbor_roam_candidate_found_ind_hdlr(struct mac_context *mac,
 	return QDF_STATUS_E_NOSUPPORT;
 }
 #endif /* WLAN_FEATURE_HOST_ROAM */
+#endif /* FEATURE_CM_ENABLE */
 #endif /* CSR_HOST_SCAN_ROAM_H */

+ 10 - 5
core/sme/inc/csr_internal.h

@@ -109,22 +109,22 @@ enum csr_roam_reason {
 #ifndef FEATURE_CM_ENABLE
 	/* roaming because we need to force a Disassoc due to MIC failure */
 	eCsrForcedDisassocMICFailure,
-#endif
 	eCsrHddIssuedReassocToSameAP,
 	eCsrSmeIssuedReassocToSameAP,
-#ifndef FEATURE_CM_ENABLE
 	/* roaming because someone asked us to deauth and stay disassociated. */
 	eCsrForcedDeauth,
 	/* will be issued by Handoff logic to disconect from current AP */
 	eCsrSmeIssuedDisassocForHandoff,
-#endif
 	/* will be issued by Handoff logic to join a new AP with same profile */
 	eCsrSmeIssuedAssocToSimilarAP,
+#endif
 	eCsrStopBss,
 	eCsrSmeIssuedFTReassoc,
 	eCsrForcedDisassocSta,
 	eCsrForcedDeauthSta,
+#ifndef FEATURE_CM_ENABLE
 	eCsrPerformPreauth,
+#endif
 	/* Roaming disabled from driver during connect/start BSS */
 	ecsr_driver_disabled,
 };
@@ -145,7 +145,9 @@ enum csr_roam_substate {
 	eCSR_ROAM_SUBSTATE_DISASSOC_REASSOC_FAILURE,
 	eCSR_ROAM_SUBSTATE_DISASSOC_FORCED,
 	eCSR_ROAM_SUBSTATE_WAIT_FOR_KEY,
+#ifndef FEATURE_CM_ENABLE
 	eCSR_ROAM_SUBSTATE_DISASSOC_HANDOFF,
+#endif
 	eCSR_ROAM_SUBSTATE_JOINED_NO_TRAFFIC,
 	eCSR_ROAM_SUBSTATE_JOINED_NON_REALTIME_TRAFFIC,
 	eCSR_ROAM_SUBSTATE_JOINED_REALTIME_TRAFFIC,
@@ -547,8 +549,9 @@ struct csr_roamstruct {
 	 */
 	int32_t sPendingCommands;
 	struct csr_roam_session *roamSession;
+#ifndef FEATURE_CM_ENABLE
 	tCsrNeighborRoamControlInfo neighborRoamInfo[WLAN_MAX_VDEVS];
-	uint8_t isFastRoamIniFeatureEnabled;
+#endif
 #ifdef FEATURE_WLAN_ESE
 	uint8_t isEseIniFeatureEnabled;
 #endif
@@ -613,9 +616,11 @@ struct csr_roamstruct {
 #define CSR_IS_ROAM_SUBSTATE_WAITFORKEY(mac, sessionId) \
 		CSR_IS_ROAM_SUBSTATE((mac), \
 			eCSR_ROAM_SUBSTATE_WAIT_FOR_KEY, sessionId)
+#ifndef FEATURE_CM_ENABLE
 #define CSR_IS_ROAM_SUBSTATE_DISASSOC_HO(mac, sessionId) \
 		CSR_IS_ROAM_SUBSTATE((mac), \
 			eCSR_ROAM_SUBSTATE_DISASSOC_HANDOFF, sessionId)
+#endif
 #define CSR_IS_ROAM_SUBSTATE_HO_NT(mac, sessionId) \
 		CSR_IS_ROAM_SUBSTATE((mac), \
 			eCSR_ROAM_SUBSTATE_JOINED_NO_TRAFFIC, sessionId)
@@ -860,6 +865,7 @@ QDF_STATUS csr_get_tsm_stats(struct mac_context *mac,
 bool csr_roam_is_fast_roam_enabled(struct mac_context *mac,  uint8_t vdev_id);
 bool csr_roam_is_roam_offload_scan_enabled(
 	struct mac_context *mac);
+#ifndef FEATURE_CM_ENABLE
 #if defined(WLAN_FEATURE_HOST_ROAM) || defined(WLAN_FEATURE_ROAM_OFFLOAD)
 QDF_STATUS csr_roam_offload_scan_rsp_hdlr(struct mac_context *mac,
 		struct roam_offload_scan_rsp *scanOffloadRsp);
@@ -871,7 +877,6 @@ static inline QDF_STATUS csr_roam_offload_scan_rsp_hdlr(
 	return QDF_STATUS_E_NOSUPPORT;
 }
 #endif
-#ifndef FEATURE_CM_ENABLE
 QDF_STATUS csr_handoff_request(struct mac_context *mac, uint8_t sessionId,
 		tCsrHandoffRequest
 		*pHandoffInfo);

+ 11 - 4
core/sme/inc/csr_neighbor_roam.h

@@ -29,6 +29,7 @@
 #include "sme_api.h"
 #include "wlan_cm_roam_api.h"
 
+#ifndef FEATURE_CM_ENABLE
 #define ROAM_AP_AGE_LIMIT_MS                     10000
 
 /* Enumeration of various states in neighbor roam algorithm */
@@ -76,7 +77,6 @@ typedef struct sCsrNeighborRoamControlInfo {
 	eCsrNeighborRoamState neighborRoamState;
 	eCsrNeighborRoamState prevNeighborRoamState;
 	struct qdf_mac_addr currAPbssid;  /* current assoc AP */
-	uint32_t curr_ap_op_chan_freq; /* current assoc AP */
 	tDblLinkList roamableAPList;    /* List of current FT candidates */
 	struct csr_roam_profile csrNeighborRoamProfile;
 	tCsr11rAssocNeighborInfo FTRoamInfo;
@@ -88,13 +88,13 @@ typedef struct sCsrNeighborRoamControlInfo {
 	uint8_t uOsRequestedHandoff;
 	/* handoff related info came with upper layer's req for reassoc */
 	tCsrHandoffRequest handoffReqInfo;
-	uint8_t last_sent_cmd;
 	struct scan_result_list *scan_res_lfr2_roam_ap;
 } tCsrNeighborRoamControlInfo, *tpCsrNeighborRoamControlInfo;
 
 /* All the necessary Function declarations are here */
 QDF_STATUS csr_neighbor_roam_indicate_connect(struct mac_context *mac,
 		uint8_t sessionId, QDF_STATUS status);
+#endif
 #if defined(WLAN_FEATURE_HOST_ROAM) || defined(WLAN_FEATURE_ROAM_OFFLOAD)
 QDF_STATUS csr_roam_control_restore_default_config(struct mac_context *mac,
 						   uint8_t vdev_id);
@@ -112,14 +112,16 @@ static inline void csr_roam_restore_default_config(struct mac_context *mac_ctx,
 {
 }
 #endif
-
+#ifndef FEATURE_CM_ENABLE
 QDF_STATUS csr_neighbor_roam_indicate_disconnect(struct mac_context *mac,
 		uint8_t sessionId);
 QDF_STATUS csr_neighbor_roam_init(struct mac_context *mac, uint8_t sessionId);
 void csr_neighbor_roam_close(struct mac_context *mac, uint8_t sessionId);
 QDF_STATUS csr_neighbor_roam_preauth_rsp_handler(struct mac_context *mac,
 		uint8_t sessionId, QDF_STATUS limStatus);
+#endif
 bool csr_neighbor_roam_is11r_assoc(struct mac_context *mac, uint8_t sessionId);
+#ifndef FEATURE_CM_ENABLE
 #ifdef WLAN_FEATURE_HOST_ROAM
 void csr_neighbor_roam_tranistion_preauth_done_to_disconnected(
 		struct mac_context *mac, uint8_t sessionId);
@@ -145,6 +147,7 @@ static inline void csr_neighbor_roam_purge_preauth_failed_list(
 {}
 #endif
 bool csr_neighbor_middle_of_roaming(struct mac_context *mac, uint8_t sessionId);
+#endif
 QDF_STATUS csr_neighbor_roam_update_config(struct mac_context *mac_ctx,
 		uint8_t session_id, uint8_t value, uint8_t reason);
 QDF_STATUS csr_neighbor_roam_channels_filter_by_current_band(
@@ -175,7 +178,6 @@ QDF_STATUS csr_neighbor_roam_merge_channel_lists(struct mac_context *mac,
 QDF_STATUS csr_update_fils_config(struct mac_context *mac, uint8_t session_id,
 				  struct csr_roam_profile *src_profile);
 #endif
-#endif
 
 QDF_STATUS csr_neighbor_roam_handoff_req_hdlr(struct mac_context *mac, void *pMsg);
 QDF_STATUS csr_neighbor_roam_proceed_with_handoff_req(struct mac_context *mac,
@@ -184,12 +186,15 @@ QDF_STATUS csr_neighbor_roam_sssid_scan_done(struct mac_context *mac,
 		uint8_t sessionId, QDF_STATUS status);
 QDF_STATUS csr_neighbor_roam_start_lfr_scan(struct mac_context *mac,
 		uint8_t sessionId);
+#endif
 
 #ifdef FEATURE_WLAN_ESE
 QDF_STATUS csr_set_cckm_ie(struct mac_context *mac, const uint8_t sessionId,
 		const uint8_t *pCckmIe, const uint8_t ccKmIeLen);
+#ifndef FEATURE_CM_ENABLE
 QDF_STATUS csr_roam_read_tsf(struct mac_context *mac, uint8_t *pTimestamp,
 		const uint8_t sessionId);
+#endif
 #endif /* FEATURE_WLAN_ESE */
 #ifdef WLAN_FEATURE_ROAM_OFFLOAD
 QDF_STATUS csr_roam_synch_callback(struct mac_context *mac,
@@ -292,6 +297,7 @@ csr_roam_pmkid_req_callback(uint8_t vdev_id,
 	return QDF_STATUS_E_NOSUPPORT;
 }
 #endif
+#ifndef FEATURE_CM_ENABLE
 void csr_neighbor_roam_state_transition(struct mac_context *mac_ctx,
 		uint8_t newstate, uint8_t session);
 uint8_t *csr_neighbor_roam_state_to_string(uint8_t state);
@@ -311,6 +317,7 @@ static inline void csr_neighbor_roam_send_lfr_metric_event(
 
 QDF_STATUS csr_roam_copy_connected_profile(struct mac_context *mac,
 		uint32_t sessionId, struct csr_roam_profile *pDstProfile);
+#endif
 
 /**
  * csr_invoke_neighbor_report_request - Send neighbor report invoke command to

+ 0 - 5
core/sme/inc/sme_api.h

@@ -1118,8 +1118,6 @@ QDF_STATUS sme_set_neighbor_scan_max_chan_time(mac_handle_t mac_handle,
 				const uint16_t nNeighborScanMaxChanTime);
 uint16_t sme_get_neighbor_scan_min_chan_time(mac_handle_t mac_handle,
 					     uint8_t sessionId);
-uint32_t sme_get_neighbor_roam_state(mac_handle_t mac_handle,
-				     uint8_t sessionId);
 uint32_t sme_get_current_roam_state(mac_handle_t mac_handle, uint8_t sessionId);
 uint32_t sme_get_current_roam_sub_state(mac_handle_t mac_handle,
 					uint8_t sessionId);
@@ -1716,9 +1714,6 @@ QDF_STATUS sme_configure_guard_time(mac_handle_t mac_handle, uint8_t session_id,
 QDF_STATUS sme_wifi_start_logger(mac_handle_t mac_handle,
 				 struct sir_wifi_start_log start_log);
 
-bool sme_neighbor_middle_of_roaming(mac_handle_t mac_handle,
-				    uint8_t sessionId);
-
 /**
  * sme_is_any_session_in_middle_of_roaming() - check if roaming is in progress
  * @mac_handle: MAC Handle

+ 4 - 0
core/sme/inc/sme_ft_api.h

@@ -58,8 +58,10 @@ typedef struct sFTSMEContext {
 	/* Saved pFTPreAuthRsp */
 	tpSirFTPreAuthRsp psavedFTPreAuthRsp;
 	bool setFTPreAuthState;
+#ifndef FEATURE_CM_ENABLE
 	/* Time to trigger reassoc once pre-auth is successful */
 	qdf_mc_timer_t preAuthReassocIntvlTimer;
+#endif
 	bool addMDIE;
 	/* User context for the timer callback */
 	tpFTRoamCallbackUsrCtx pUsrCtx;
@@ -124,7 +126,9 @@ static inline void sme_reset_key(mac_handle_t mac_handle, uint32_t vdev_id)
 }
 #endif
 
+#ifndef FEATURE_CM_ENABLE
 void sme_preauth_reassoc_intvl_timer_callback(void *context);
+#endif
 void sme_set_ft_pre_auth_state(mac_handle_t mac_handle, uint32_t sessionId,
 			       bool state);
 bool sme_get_ft_pre_auth_state(mac_handle_t mac_handle, uint32_t sessionId);

+ 10 - 60
core/sme/src/common/sme_api.c

@@ -266,8 +266,11 @@ static QDF_STATUS sme_process_set_hw_mode_resp(struct mac_context *mac, uint8_t
 			  session_id);
 		csr_csa_restart(mac, session_id);
 	}
+	/* This is temp ifdef will be removed in near future */
+#ifndef FEATURE_CM_ENABLE
 	if (reason == POLICY_MGR_UPDATE_REASON_LFR2_ROAM)
 		csr_continue_lfr2_connect(mac, session_id);
+#endif
 
 	if (reason == POLICY_MGR_UPDATE_REASON_STA_CONNECT) {
 		QDF_STATUS status = QDF_STATUS_E_FAILURE;
@@ -2432,11 +2435,13 @@ QDF_STATUS sme_process_msg(struct mac_context *mac, struct scheduler_msg *pMsg)
 		}
 		break;
 #endif /* FEATURE_WLAN_ESE */
+#ifndef FEATURE_CM_ENABLE
 	case eWNI_SME_ROAM_SCAN_OFFLOAD_RSP:
 		status = csr_roam_offload_scan_rsp_hdlr((void *)mac,
 							pMsg->bodyptr);
 		qdf_mem_free(pMsg->bodyptr);
 		break;
+#endif
 #ifdef WLAN_FEATURE_EXTWOW_SUPPORT
 	case eWNI_SME_READY_TO_EXTWOW_IND:
 		if (pMsg->bodyptr) {
@@ -6255,13 +6260,9 @@ QDF_STATUS sme_update_wes_mode(mac_handle_t mac_handle, bool isWESModeEnabled,
 	status = sme_acquire_global_lock(&mac->sme);
 	if (QDF_IS_STATUS_SUCCESS(status)) {
 		QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_DEBUG,
-			  "LFR runtime successfully set WES Mode to %d - old value is %d - roam state is %s",
+			  "LFR runtime successfully set WES Mode to %d - old value is %d",
 			  isWESModeEnabled,
-			  mac->mlme_cfg->lfr.wes_mode_enabled,
-			  mac_trace_get_neighbour_roam_state(mac->roam.
-							     neighborRoamInfo
-							     [sessionId].
-							    neighborRoamState));
+			  mac->mlme_cfg->lfr.wes_mode_enabled);
 		mac->mlme_cfg->lfr.wes_mode_enabled = isWESModeEnabled;
 		sme_release_global_lock(&mac->sme);
 	}
@@ -6899,27 +6900,6 @@ uint16_t sme_get_neighbor_scan_min_chan_time(mac_handle_t mac_handle,
 	return temp.uint_value;
 }
 
-/*
- * sme_get_neighbor_roam_state() -
- * get neighbor roam state
- *
- * mac_handle - The handle returned by mac_open.
- * sessionId - Session Identifier
- * Return uint32_t - neighbor roam state
- */
-uint32_t sme_get_neighbor_roam_state(mac_handle_t mac_handle, uint8_t sessionId)
-{
-	struct mac_context *mac = MAC_CONTEXT(mac_handle);
-
-	if (sessionId >= WLAN_MAX_VDEVS) {
-		QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_ERROR,
-			  FL("Invalid sme session id: %d"), sessionId);
-		return 0;
-	}
-
-	return mac->roam.neighborRoamInfo[sessionId].neighborRoamState;
-}
-
 /*
  * sme_get_current_roam_state() -
  * get current roam state
@@ -9087,13 +9067,9 @@ QDF_STATUS sme_update_dfs_scan_mode(mac_handle_t mac_handle, uint8_t sessionId,
 	status = sme_acquire_global_lock(&mac->sme);
 	if (QDF_IS_STATUS_SUCCESS(status)) {
 		QDF_TRACE(QDF_MODULE_ID_SME, QDF_TRACE_LEVEL_DEBUG,
-			  "LFR runtime successfully set AllowDFSChannelRoam Mode to %d - old value is %d - roam state is %s",
+			  "LFR runtime successfully set AllowDFSChannelRoam Mode to %d - old value is %d",
 			  allowDFSChannelRoam,
-			  mac->mlme_cfg->lfr.roaming_dfs_channel,
-			  mac_trace_get_neighbour_roam_state(mac->roam.
-							     neighborRoamInfo
-							     [sessionId].
-							    neighborRoamState));
+			  mac->mlme_cfg->lfr.roaming_dfs_channel);
 		mac->mlme_cfg->lfr.roaming_dfs_channel =
 			allowDFSChannelRoam;
 		if (mac->mlme_cfg->lfr.roam_scan_offload_enabled)
@@ -10621,32 +10597,6 @@ QDF_STATUS sme_wifi_start_logger(mac_handle_t mac_handle,
 	return status;
 }
 
-/**
- * sme_neighbor_middle_of_roaming() - Function to know if
- * STA is in the middle of roaming states
- * @mac_handle:                Handle returned by macOpen
- * @sessionId: sessionId of the STA session
- *
- * This function is a wrapper to call
- * csr_neighbor_middle_of_roaming to know STA is in the
- * middle of roaming states
- *
- * Return: True or False
- *
- */
-bool sme_neighbor_middle_of_roaming(mac_handle_t mac_handle, uint8_t sessionId)
-{
-	struct mac_context *mac_ctx = MAC_CONTEXT(mac_handle);
-	bool val = false;
-
-	if (CSR_IS_SESSION_VALID(mac_ctx, sessionId))
-		val = csr_neighbor_middle_of_roaming(mac_ctx, sessionId);
-	else
-		sme_debug("Invalid Session: %d", sessionId);
-
-	return val;
-}
-
 bool sme_is_any_session_in_middle_of_roaming(mac_handle_t mac_handle)
 {
 	struct mac_context *mac_ctx = MAC_CONTEXT(mac_handle);
@@ -10654,7 +10604,7 @@ bool sme_is_any_session_in_middle_of_roaming(mac_handle_t mac_handle)
 
 	for (session_id = 0; session_id < WLAN_MAX_VDEVS; session_id++) {
 		if (CSR_IS_SESSION_VALID(mac_ctx, session_id) &&
-		    csr_neighbor_middle_of_roaming(mac_ctx, session_id))
+		    wlan_cm_host_roam_in_progress(mac_ctx->psoc, session_id))
 			return true;
 	}
 

+ 9 - 3
core/sme/src/common/sme_ft_api.c

@@ -26,7 +26,9 @@
 void sme_ft_open(mac_handle_t mac_handle, uint32_t sessionId)
 {
 	struct mac_context *mac = MAC_CONTEXT(mac_handle);
+#ifndef FEATURE_CM_ENABLE
 	QDF_STATUS status = QDF_STATUS_SUCCESS;
+#endif
 	struct csr_roam_session *pSession = CSR_GET_SESSION(mac, sessionId);
 
 	if (pSession) {
@@ -38,12 +40,12 @@ void sme_ft_open(mac_handle_t mac_handle, uint32_t sessionId)
 		if (!pSession->ftSmeContext.pUsrCtx)
 			return;
 
+#ifndef FEATURE_CM_ENABLE
 		pSession->ftSmeContext.pUsrCtx->mac = mac;
 		pSession->ftSmeContext.pUsrCtx->sessionId = sessionId;
 
 		status =
-			qdf_mc_timer_init(&pSession->ftSmeContext.
-					  preAuthReassocIntvlTimer,
+			qdf_mc_timer_init(&pSession->ftSmeContext.preAuthReassocIntvlTimer,
 					  QDF_TIMER_TYPE_SW,
 				sme_preauth_reassoc_intvl_timer_callback,
 					(void *)pSession->ftSmeContext.pUsrCtx);
@@ -54,6 +56,7 @@ void sme_ft_open(mac_handle_t mac_handle, uint32_t sessionId)
 			pSession->ftSmeContext.pUsrCtx = NULL;
 			return;
 		}
+#endif
 	}
 }
 
@@ -68,6 +71,7 @@ void sme_ft_close(mac_handle_t mac_handle, uint32_t sessionId)
 
 	pSession = CSR_GET_SESSION(mac, sessionId);
 	if (pSession) {
+#ifndef FEATURE_CM_ENABLE
 		/* check if the timer is running */
 		if (QDF_TIMER_STATE_RUNNING ==
 		    qdf_mc_timer_get_current_state(&pSession->ftSmeContext.
@@ -78,7 +82,7 @@ void sme_ft_close(mac_handle_t mac_handle, uint32_t sessionId)
 
 		qdf_mc_timer_destroy(&pSession->ftSmeContext.
 					preAuthReassocIntvlTimer);
-
+#endif
 		if (pSession->ftSmeContext.pUsrCtx) {
 			qdf_mem_free(pSession->ftSmeContext.pUsrCtx);
 			pSession->ftSmeContext.pUsrCtx = NULL;
@@ -375,6 +379,7 @@ void sme_get_rici_es(mac_handle_t mac_handle, uint32_t sessionId,
 	sme_release_global_lock(&mac->sme);
 }
 
+#ifndef FEATURE_CM_ENABLE
 /*
  * Timer callback for the timer that is started between the preauth completion
  * and reassoc request to the PE. In this interval, it is expected that the
@@ -389,6 +394,7 @@ void sme_preauth_reassoc_intvl_timer_callback(void *context)
 		csr_neighbor_roam_request_handoff(pUsrCtx->mac,
 						  pUsrCtx->sessionId);
 }
+#endif
 
 #ifdef WLAN_FEATURE_ROAM_OFFLOAD
 #ifdef FEATURE_WLAN_ESE

+ 157 - 157
core/sme/src/csr/csr_api_roam.c

@@ -94,8 +94,6 @@
 #define CSR_SINGLE_PMK_OUI               "\x00\x40\x96\x03"
 #define CSR_SINGLE_PMK_OUI_SIZE          4
 
-/* Flag to send/do not send disassoc frame over the air */
-#define CSR_DONT_SEND_DISASSOC_OVER_THE_AIR 1
 #define RSSI_HACK_BMPS (-40)
 #define MAX_CB_VALUE_IN_INI (2)
 
@@ -1055,14 +1053,13 @@ QDF_STATUS csr_start(struct mac_context *mac)
 
 		mac->roam.sPendingCommands = 0;
 
+#ifndef FEATURE_CM_ENABLE
 		for (i = 0; i < WLAN_MAX_VDEVS; i++)
 			status = csr_neighbor_roam_init(mac, i);
 		if (!QDF_IS_STATUS_SUCCESS(status)) {
 			sme_warn("Couldn't Init HO control blk");
 			break;
 		}
-		/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 		/* Register with scan component */
 		mac->scan.requester_id = ucfg_scan_register_requester(
 						mac->psoc,
@@ -1099,10 +1096,12 @@ QDF_STATUS csr_stop(struct mac_context *mac)
 	 */
 	csr_purge_pdev_all_ser_cmd_list(mac);
 	for (sessionId = 0; sessionId < WLAN_MAX_VDEVS; sessionId++)
-
 		csr_prepare_vdev_delete(mac, sessionId, true);
+	/* This is temp ifdef will be removed in near future */
+#ifndef FEATURE_CM_ENABLE
 	for (sessionId = 0; sessionId < WLAN_MAX_VDEVS; sessionId++)
 		csr_neighbor_roam_close(mac, sessionId);
+#endif
 	for (sessionId = 0; sessionId < WLAN_MAX_VDEVS; sessionId++)
 		if (CSR_IS_SESSION_VALID(mac, sessionId))
 			ucfg_scan_flush_results(mac->pdev, NULL);
@@ -1798,6 +1797,7 @@ QDF_STATUS csr_set_cckm_ie(struct mac_context *mac, const uint8_t sessionId,
 	return status;
 }
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * csr_roam_read_tsf() - read TSF
  * @mac: Global MAC context
@@ -1836,7 +1836,7 @@ QDF_STATUS csr_roam_read_tsf(struct mac_context *mac, uint8_t *pTimestamp,
 	qdf_mem_copy(pTimestamp, (void *)&timeStamp[0], sizeof(uint32_t) * 2);
 	return status;
 }
-
+#endif
 #endif /* FEATURE_WLAN_ESE */
 
 /**
@@ -4897,6 +4897,7 @@ static QDF_STATUS csr_roam(struct mac_context *mac, tSmeCmd *pCommand,
 	return status;
 }
 
+#ifndef FEATURE_CM_ENABLE
 static
 QDF_STATUS csr_process_ft_reassoc_roam_command(struct mac_context *mac,
 					       tSmeCmd *pCommand)
@@ -4978,9 +4979,7 @@ csr_roam_trigger_reassociate(struct mac_context *mac_ctx, tSmeCmd *cmd,
 			roam_info->bss_desc = session_ptr->pConnectBssDesc;
 			roam_info->pProfile = &cmd->u.roamCmd.roamProfile;
 			/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 			session_ptr->bRefAssocStartCnt++;
-#endif
 			sme_debug("calling csr_roam_issue_reassociate");
 			status = csr_roam_issue_reassociate(mac_ctx, session_id,
 					session_ptr->pConnectBssDesc, pIes,
@@ -5006,8 +5005,6 @@ csr_roam_trigger_reassociate(struct mac_context *mac_ctx, tSmeCmd *cmd,
 	return status;
 }
 
-
-#ifndef FEATURE_CM_ENABLE
 /**
  * csr_allow_concurrent_sta_connections() - Wrapper for policy_mgr api
  * @mac: mac context
@@ -5169,7 +5166,6 @@ QDF_STATUS csr_roam_process_command(struct mac_context *mac, tSmeCmd *pCommand)
 		csr_free_roam_profile(mac, sessionId);
 		sme_release_global_lock(&mac->sme);
 		break;
-#endif
 	case eCsrHddIssuedReassocToSameAP:
 	case eCsrSmeIssuedReassocToSameAP:
 		status = csr_roam_trigger_reassociate(mac, pCommand,
@@ -5179,7 +5175,7 @@ QDF_STATUS csr_roam_process_command(struct mac_context *mac, tSmeCmd *pCommand)
 		sme_debug("received FT Reassoc Req");
 		status = csr_process_ft_reassoc_roam_command(mac, pCommand);
 		break;
-
+#endif
 	case eCsrStopBss:
 		csr_roam_state_change(mac, eCSR_ROAMING_STATE_JOINING,
 				sessionId);
@@ -5212,12 +5208,13 @@ QDF_STATUS csr_roam_process_command(struct mac_context *mac, tSmeCmd *pCommand)
 				pCommand->u.roamCmd.peerMac,
 				pCommand->u.roamCmd.reason);
 		break;
-
+#ifndef FEATURE_CM_ENABLE
 	case eCsrPerformPreauth:
 		sme_debug("Attempting FT PreAuth Req");
 		status = csr_roam_issue_ft_preauth_req(mac, sessionId,
 				pCommand->u.roamCmd.pLastRoamBss);
 		break;
+#endif
 	case eCsrHddIssued:
 		/* This is temp ifdef will be removed in near future */
 #ifndef FEATURE_CM_ENABLE
@@ -5576,7 +5573,6 @@ static void csr_roam_process_results_default(struct mac_context *mac_ctx,
 		csr_roam_completion(mac_ctx, session_id, NULL, cmd,
 			eCSR_ROAM_RESULT_FAILURE, false);
 		break;
-#endif  /* ndef FEATURE_CM_ENABLE */
 	case eCsrHddIssuedReassocToSameAP:
 	case eCsrSmeIssuedReassocToSameAP:
 		csr_roam_state_change(mac_ctx, eCSR_ROAMING_STATE_IDLE,
@@ -5592,8 +5588,6 @@ static void csr_roam_process_results_default(struct mac_context *mac_ctx,
 		csr_roam_completion(mac_ctx, session_id, NULL, cmd,
 			eCSR_ROAM_RESULT_FAILURE, false);
 		break;
-	/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 	case eCsrForcedDisassoc:
 	case eCsrForcedDeauth:
 		csr_roam_state_change(mac_ctx, eCSR_ROAMING_STATE_IDLE,
@@ -6033,13 +6027,11 @@ static void csr_roam_process_join_res(struct mac_context *mac_ctx,
 		ind_qos = SME_QOS_CSR_ASSOC_COMPLETE;
 	}
 
-	/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 	if (CSR_IS_INFRASTRUCTURE(profile))
 		session->connectState = eCSR_ASSOC_STATE_TYPE_INFRA_ASSOCIATED;
 	else
 		session->connectState = eCSR_ASSOC_STATE_TYPE_WDS_CONNECTED;
-#endif
+
 	/*
 	 * Use the last connected bssdesc for reassoc-ing to the same AP.
 	 * NOTE: What to do when reassoc to a different AP???
@@ -6751,6 +6743,111 @@ end:
 	return status;
 }
 
+QDF_STATUS csr_roam_issue_connect(struct mac_context *mac, uint32_t sessionId,
+				  struct csr_roam_profile *pProfile,
+				  tScanResultHandle hBSSList,
+				  enum csr_roam_reason reason, uint32_t roamId,
+				  bool fImediate, bool fClearScan)
+{
+	QDF_STATUS status = QDF_STATUS_SUCCESS;
+	tSmeCmd *pCommand;
+
+	pCommand = csr_get_command_buffer(mac);
+	if (!pCommand) {
+		csr_scan_result_purge(mac, hBSSList);
+		sme_err(" fail to get command buffer");
+		status = QDF_STATUS_E_RESOURCES;
+	} else {
+		if (fClearScan)
+			csr_scan_abort_mac_scan(mac, sessionId, INVAL_SCAN_ID);
+
+		pCommand->u.roamCmd.fReleaseProfile = false;
+		if (!pProfile) {
+			/* We can roam now
+			 * Since pProfile is NULL, we need to build our own
+			 * profile, set everything to default We can only
+			 * support open and no encryption
+			 */
+			pCommand->u.roamCmd.roamProfile.AuthType.numEntries = 1;
+			pCommand->u.roamCmd.roamProfile.AuthType.authType[0] =
+				eCSR_AUTH_TYPE_OPEN_SYSTEM;
+			pCommand->u.roamCmd.roamProfile.EncryptionType.
+			numEntries = 1;
+			pCommand->u.roamCmd.roamProfile.EncryptionType.
+			encryptionType[0] = eCSR_ENCRYPT_TYPE_NONE;
+			pCommand->u.roamCmd.roamProfile.csrPersona =
+				QDF_STA_MODE;
+		} else {
+			/* make a copy of the profile */
+			status = csr_roam_copy_profile(mac, &pCommand->u.
+						       roamCmd.roamProfile,
+						       pProfile, sessionId);
+			if (QDF_IS_STATUS_SUCCESS(status))
+				pCommand->u.roamCmd.fReleaseProfile = true;
+		}
+
+		pCommand->command = eSmeCommandRoam;
+		pCommand->vdev_id = (uint8_t) sessionId;
+		pCommand->u.roamCmd.hBSSList = hBSSList;
+		pCommand->u.roamCmd.roamId = roamId;
+		pCommand->u.roamCmd.roamReason = reason;
+
+		/* We need to free the BssList when the command is done */
+		pCommand->u.roamCmd.fReleaseBssList = true;
+		pCommand->u.roamCmd.fUpdateCurRoamProfile = true;
+
+		status = csr_queue_sme_command(mac, pCommand, fImediate);
+		if (!QDF_IS_STATUS_SUCCESS(status)) {
+			sme_err("fail to send message status: %d", status);
+		}
+	}
+
+	return status;
+}
+
+#ifdef FEATURE_CM_ENABLE
+QDF_STATUS csr_roam_connect(struct mac_context *mac, uint32_t vdev_id,
+		struct csr_roam_profile *profile,
+		uint32_t *pRoamId)
+{
+	QDF_STATUS status = QDF_STATUS_SUCCESS;
+	uint32_t roam_id = 0;
+	struct csr_roam_session *session = CSR_GET_SESSION(mac, vdev_id);
+
+	if (!session) {
+		sme_err("session does not exist for given sessionId: %d",
+			vdev_id);
+		return QDF_STATUS_E_FAILURE;
+	}
+
+	if (!profile) {
+		sme_err("No profile specified");
+		return QDF_STATUS_E_FAILURE;
+	}
+
+	sme_debug("Persona %d authtype %d  encryType %d mc_encType %d",
+		  profile->csrPersona, profile->AuthType.authType[0],
+		  profile->EncryptionType.encryptionType[0],
+		  profile->mcEncryptionType.encryptionType[0]);
+	csr_roam_remove_duplicate_command(mac, vdev_id, NULL, eCsrHddIssued);
+
+	roam_id = GET_NEXT_ROAM_ID(&mac->roam);
+	if (pRoamId)
+		*pRoamId = roam_id;
+
+	if (CSR_IS_INFRA_AP(profile) || CSR_IS_NDI(profile)) {
+		status = csr_roam_issue_connect(mac, vdev_id, profile, NULL,
+						eCsrHddIssued, roam_id,
+						false, false);
+		if (QDF_IS_STATUS_ERROR(status))
+			sme_err("CSR failed to issue start BSS/NDI cmd with status: 0x%08X",
+				status);
+	}
+
+	return status;
+}
+#else
+
 QDF_STATUS csr_roam_copy_connected_profile(struct mac_context *mac,
 					   uint32_t sessionId,
 					   struct csr_roam_profile *pDstProfile)
@@ -6818,70 +6915,6 @@ end:
 	return status;
 }
 
-QDF_STATUS csr_roam_issue_connect(struct mac_context *mac, uint32_t sessionId,
-				  struct csr_roam_profile *pProfile,
-				  tScanResultHandle hBSSList,
-				  enum csr_roam_reason reason, uint32_t roamId,
-				  bool fImediate, bool fClearScan)
-{
-	QDF_STATUS status = QDF_STATUS_SUCCESS;
-	tSmeCmd *pCommand;
-
-	pCommand = csr_get_command_buffer(mac);
-	if (!pCommand) {
-		csr_scan_result_purge(mac, hBSSList);
-		sme_err(" fail to get command buffer");
-		status = QDF_STATUS_E_RESOURCES;
-	} else {
-		if (fClearScan)
-			csr_scan_abort_mac_scan(mac, sessionId, INVAL_SCAN_ID);
-
-		pCommand->u.roamCmd.fReleaseProfile = false;
-		if (!pProfile) {
-			/* We can roam now
-			 * Since pProfile is NULL, we need to build our own
-			 * profile, set everything to default We can only
-			 * support open and no encryption
-			 */
-			pCommand->u.roamCmd.roamProfile.AuthType.numEntries = 1;
-			pCommand->u.roamCmd.roamProfile.AuthType.authType[0] =
-				eCSR_AUTH_TYPE_OPEN_SYSTEM;
-			pCommand->u.roamCmd.roamProfile.EncryptionType.
-			numEntries = 1;
-			pCommand->u.roamCmd.roamProfile.EncryptionType.
-			encryptionType[0] = eCSR_ENCRYPT_TYPE_NONE;
-			pCommand->u.roamCmd.roamProfile.csrPersona =
-				QDF_STA_MODE;
-		} else {
-			/* make a copy of the profile */
-			status = csr_roam_copy_profile(mac, &pCommand->u.
-						       roamCmd.roamProfile,
-						       pProfile, sessionId);
-			if (QDF_IS_STATUS_SUCCESS(status))
-				pCommand->u.roamCmd.fReleaseProfile = true;
-		}
-
-		pCommand->command = eSmeCommandRoam;
-		pCommand->vdev_id = (uint8_t) sessionId;
-		pCommand->u.roamCmd.hBSSList = hBSSList;
-		pCommand->u.roamCmd.roamId = roamId;
-		pCommand->u.roamCmd.roamReason = reason;
-
-		/* We need to free the BssList when the command is done */
-		pCommand->u.roamCmd.fReleaseBssList = true;
-		pCommand->u.roamCmd.fUpdateCurRoamProfile = true;
-
-		status = csr_queue_sme_command(mac, pCommand, fImediate);
-		if (!QDF_IS_STATUS_SUCCESS(status)) {
-			sme_err("fail to send message status: %d", status);
-		}
-	}
-
-	return status;
-}
-
-#ifndef FEATURE_CM_ENABLE
-
 QDF_STATUS csr_roam_issue_reassoc(struct mac_context *mac, uint32_t sessionId,
 				  struct csr_roam_profile *pProfile,
 				  tCsrRoamModifyProfileFields
@@ -6939,7 +6972,6 @@ QDF_STATUS csr_roam_issue_reassoc(struct mac_context *mac, uint32_t sessionId,
 	}
 	return status;
 }
-#endif
 
 QDF_STATUS csr_dequeue_roam_command(struct mac_context *mac,
 			enum csr_roam_reason reason,
@@ -6981,49 +7013,6 @@ QDF_STATUS csr_dequeue_roam_command(struct mac_context *mac,
 	return QDF_STATUS_SUCCESS;
 }
 
-#ifdef FEATURE_CM_ENABLE
-QDF_STATUS csr_roam_connect(struct mac_context *mac, uint32_t vdev_id,
-		struct csr_roam_profile *profile,
-		uint32_t *pRoamId)
-{
-	QDF_STATUS status = QDF_STATUS_SUCCESS;
-	uint32_t roam_id = 0;
-	struct csr_roam_session *session = CSR_GET_SESSION(mac, vdev_id);
-
-	if (!session) {
-		sme_err("session does not exist for given sessionId: %d",
-			vdev_id);
-		return QDF_STATUS_E_FAILURE;
-	}
-
-	if (!profile) {
-		sme_err("No profile specified");
-		return QDF_STATUS_E_FAILURE;
-	}
-
-	sme_debug("Persona %d authtype %d  encryType %d mc_encType %d",
-		  profile->csrPersona, profile->AuthType.authType[0],
-		  profile->EncryptionType.encryptionType[0],
-		  profile->mcEncryptionType.encryptionType[0]);
-	csr_roam_remove_duplicate_command(mac, vdev_id, NULL, eCsrHddIssued);
-
-	roam_id = GET_NEXT_ROAM_ID(&mac->roam);
-	if (pRoamId)
-		*pRoamId = roam_id;
-
-	if (CSR_IS_INFRA_AP(profile) || CSR_IS_NDI(profile)) {
-		status = csr_roam_issue_connect(mac, vdev_id, profile, NULL,
-						eCsrHddIssued, roam_id,
-						false, false);
-		if (QDF_IS_STATUS_ERROR(status))
-			sme_err("CSR failed to issue start BSS/NDI cmd with status: 0x%08X",
-				status);
-	}
-
-	return status;
-}
-#else
-
 #ifdef WLAN_FEATURE_FILS_SK
 /**
  * csr_is_fils_connection() - API to check if FILS connection
@@ -8365,13 +8354,14 @@ csr_roaming_state_config_cnf_processor(struct mac_context *mac_ctx,
 		return;
 	}
 
+#ifndef FEATURE_CM_ENABLE
 	if (CSR_IS_ROAMING(session) && session->fCancelRoaming) {
 		/* the roaming is cancelled. Simply complete the command */
 		sme_warn("Roam command canceled");
 		csr_roam_complete(mac_ctx, eCsrNothingToJoin, NULL, vdev_id);
 		return;
 	}
-
+#endif
 	/*
 	 * Successfully set the configuration parameters for the new Bss.
 	 * Attempt to join the roaming Bss
@@ -8634,6 +8624,7 @@ static void csr_roam_roaming_state_stop_bss_rsp_processor(struct mac_context *ma
 	}
 }
 
+#ifndef FEATURE_CM_ENABLE
 #ifdef WLAN_FEATURE_HOST_ROAM
 /**
  * csr_dequeue_command() - removes a command from active cmd list
@@ -8680,7 +8671,6 @@ csr_dequeue_command(struct mac_context *mac_ctx)
 			cmd->u.roamCmd.roamReason);
 }
 
-#ifndef FEATURE_CM_ENABLE
 /**
  * csr_post_roam_failure() - post roam failure back to csr and issues a disassoc
  * @mac:               mac global context
@@ -8769,7 +8759,6 @@ csr_check_profile_in_scan_cache(struct mac_context *mac_ctx,
 	}
 	return true;
 }
-#endif
 
 static
 QDF_STATUS csr_roam_lfr2_issue_connect(struct mac_context *mac,
@@ -8858,14 +8847,11 @@ purge_scan_result:
 	csr_scan_result_purge(mac, scan_handle_roam_ap);
 
 POST_ROAM_FAILURE:
-#ifndef FEATURE_CM_ENABLE
 	csr_post_roam_failure(mac, session_id, roam_info, NULL);
-#endif
 	qdf_mem_free(roam_info);
 	return status;
 }
 
-#ifndef FEATURE_CM_ENABLE
 static
 void csr_handle_disassoc_ho(struct mac_context *mac, uint32_t session_id)
 {
@@ -8954,9 +8940,8 @@ POST_ROAM_FAILURE:
 	csr_post_roam_failure(mac, session_id, roam_info, NULL);
 	qdf_mem_free(roam_info);
 }
-#endif
+
 #else
-#ifndef FEATURE_CM_ENABLE
 static
 void csr_handle_disassoc_ho(struct mac_context *mac, uint32_t session_id)
 {
@@ -9829,7 +9814,6 @@ static void csr_update_fils_scan_filter(struct scan_filter *filter,
 					struct csr_roam_profile *profile)
 { }
 #endif
-#endif
 
 void csr_copy_ssids_from_roam_params(struct rso_config_params *rso_usr_cfg,
 				     struct scan_filter *filter)
@@ -9863,7 +9847,6 @@ void csr_update_scan_filter_dot11mode(struct mac_context *mac_ctx,
 		filter->dot11mode = ALLOW_11AX_ONLY;
 }
 
-#ifndef FEATURE_CM_ENABLE
 static inline void csr_copy_ssids(struct wlan_ssid *ssid, tSirMacSSid *from)
 {
 	ssid->length = from->length;
@@ -11111,13 +11094,16 @@ void csr_roam_check_for_link_status_change(struct mac_context *mac,
 		sme_debug("GetSnrReq from self");
 		csr_update_snr(mac, pSirMsg);
 		break;
+#ifndef FEATURE_CM_ENABLE
 	case eWNI_SME_FT_PRE_AUTH_RSP:
 		csr_roam_ft_pre_auth_rsp_processor(mac,
 						(tpSirFTPreAuthRsp) pSirMsg);
 		break;
+#endif
 	case eWNI_SME_MAX_ASSOC_EXCEEDED:
 		csr_roam_chk_lnk_max_assoc_exceeded(mac, pSirMsg);
 		break;
+#ifndef FEATURE_CM_ENABLE
 	case eWNI_SME_CANDIDATE_FOUND_IND:
 		csr_neighbor_roam_candidate_found_ind_hdlr(mac, pSirMsg);
 		break;
@@ -11125,7 +11111,7 @@ void csr_roam_check_for_link_status_change(struct mac_context *mac,
 		sme_debug("Handoff Req from self");
 		csr_neighbor_roam_handoff_req_hdlr(mac, pSirMsg);
 		break;
-
+#endif
 	default:
 		break;
 	} /* end switch on message type */
@@ -14292,6 +14278,7 @@ QDF_STATUS csr_send_mb_disassoc_req_msg(struct mac_context *mac,
 	pSession->disconnect_stats.disconnection_cnt++;
 	pSession->disconnect_stats.disconnection_by_app++;
 
+#ifndef FEATURE_CM_ENABLE
 	/*
 	 * The state will be DISASSOC_HANDOFF only when we are doing
 	 * handoff. Here we should not send the disassoc over the air
@@ -14301,8 +14288,9 @@ QDF_STATUS csr_send_mb_disassoc_req_msg(struct mac_context *mac,
 			&& csr_roam_is11r_assoc(mac, sessionId)) ||
 						pMsg->process_ho_fail) {
 		/* Set DoNotSendOverTheAir flag to 1 only for handoff case */
-		pMsg->doNotSendOverTheAir = CSR_DONT_SEND_DISASSOC_OVER_THE_AIR;
+		pMsg->doNotSendOverTheAir = 1;
 	}
+#endif
 	return umac_send_mb_message_to_mac(pMsg);
 }
 
@@ -15556,7 +15544,21 @@ wlan_cm_roam_cmd_allowed(struct wlan_objmgr_psoc *psoc, uint8_t vdev_id,
 
 	return QDF_STATUS_SUCCESS;
 }
-#endif
+
+QDF_STATUS
+wlan_cm_roam_neighbor_proceed_with_handoff_req(uint8_t vdev_id)
+{
+	struct mac_context *mac_ctx;
+
+	mac_ctx = sme_get_mac_context();
+	if (!mac_ctx) {
+		sme_err("mac_ctx is NULL");
+		return QDF_STATUS_E_FAILURE;
+	}
+
+	return csr_neighbor_roam_proceed_with_handoff_req(mac_ctx, vdev_id);
+}
+
 QDF_STATUS
 wlan_cm_roam_scan_offload_rsp(uint8_t vdev_id, uint8_t reason)
 {
@@ -15589,20 +15591,6 @@ wlan_cm_roam_scan_offload_rsp(uint8_t vdev_id, uint8_t reason)
 	return status;
 }
 
-QDF_STATUS
-wlan_cm_roam_neighbor_proceed_with_handoff_req(uint8_t vdev_id)
-{
-	struct mac_context *mac_ctx;
-
-	mac_ctx = sme_get_mac_context();
-	if (!mac_ctx) {
-		sme_err("mac_ctx is NULL");
-		return QDF_STATUS_E_FAILURE;
-	}
-
-	return csr_neighbor_roam_proceed_with_handoff_req(mac_ctx, vdev_id);
-}
-
 bool wlan_cm_is_sta_connected(uint8_t vdev_id)
 {
 	struct mac_context *mac_ctx;
@@ -15638,6 +15626,7 @@ csr_roam_offload_scan_rsp_hdlr(struct mac_context *mac,
 	return QDF_STATUS_SUCCESS;
 }
 #endif
+#endif
 
 tSmeCmd *csr_get_command_buffer(struct mac_context *mac)
 {
@@ -15752,38 +15741,42 @@ static enum wlan_serialization_cmd_type csr_get_roam_cmd_type(
 		else
 			cmd_type = WLAN_SER_CMD_VDEV_CONNECT;
 		break;
+	/* This is temp ifdef will be removed in near future */
+#ifndef FEATURE_CM_ENABLE
 	case eCsrHddIssuedReassocToSameAP:
 		cmd_type = WLAN_SER_CMD_HDD_ISSUE_REASSOC_SAME_AP;
 		break;
 	case eCsrSmeIssuedReassocToSameAP:
 		cmd_type = WLAN_SER_CMD_SME_ISSUE_REASSOC_SAME_AP;
 		break;
-	/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 	case eCsrSmeIssuedDisassocForHandoff:
 		cmd_type =
 			WLAN_SER_CMD_SME_ISSUE_DISASSOC_FOR_HANDOFF;
 		break;
-#endif
 	case eCsrSmeIssuedAssocToSimilarAP:
 		cmd_type =
 			WLAN_SER_CMD_SME_ISSUE_ASSOC_TO_SIMILAR_AP;
 		break;
+#endif
 	case eCsrStopBss:
 		cmd_type = WLAN_SER_CMD_VDEV_STOP_BSS;
 		break;
+#ifndef FEATURE_CM_ENABLE
 	case eCsrSmeIssuedFTReassoc:
 		cmd_type = WLAN_SER_CMD_SME_ISSUE_FT_REASSOC;
 		break;
+#endif
 	case eCsrForcedDisassocSta:
 		cmd_type = WLAN_SER_CMD_FORCE_DISASSOC_STA;
 		break;
 	case eCsrForcedDeauthSta:
 		cmd_type = WLAN_SER_CMD_FORCE_DEAUTH_STA;
 		break;
+#ifndef FEATURE_CM_ENABLE
 	case eCsrPerformPreauth:
 		cmd_type = WLAN_SER_CMD_PERFORM_PRE_AUTH;
 		break;
+#endif
 	default:
 		break;
 	}
@@ -15845,7 +15838,9 @@ static uint32_t csr_get_monotonous_number(struct mac_context *mac_ctx)
 static void csr_fill_cmd_timeout(struct wlan_serialization_command *cmd)
 {
 	switch (cmd->cmd_type) {
+#ifndef FEATURE_CM_ENABLE
 	case WLAN_SER_CMD_VDEV_DISCONNECT:
+#endif
 	case WLAN_SER_CMD_WM_STATUS_CHANGE:
 		cmd->cmd_timeout_duration = SME_CMD_VDEV_DISCONNECT_TIMEOUT;
 		break;
@@ -15863,6 +15858,7 @@ static void csr_fill_cmd_timeout(struct wlan_serialization_command *cmd)
 		cmd->cmd_timeout_duration =
 					SME_CMD_GET_DISCONNECT_STATS_TIMEOUT;
 		break;
+#ifndef FEATURE_CM_ENABLE
 	case WLAN_SER_CMD_HDD_ISSUE_REASSOC_SAME_AP:
 	case WLAN_SER_CMD_SME_ISSUE_REASSOC_SAME_AP:
 	case WLAN_SER_CMD_SME_ISSUE_DISASSOC_FOR_HANDOFF:
@@ -15871,6 +15867,7 @@ static void csr_fill_cmd_timeout(struct wlan_serialization_command *cmd)
 	case WLAN_SER_CMD_PERFORM_PRE_AUTH:
 		cmd->cmd_timeout_duration = SME_CMD_ROAM_CMD_TIMEOUT;
 		break;
+#endif
 	case WLAN_SER_CMD_ADDTS:
 	case WLAN_SER_CMD_DELTS:
 		cmd->cmd_timeout_duration = SME_CMD_ADD_DEL_TS_TIMEOUT;
@@ -17850,8 +17847,11 @@ csr_process_roam_sync_callback(struct mac_context *mac_ctx,
 	} else {
 		roam_info->fAuthRequired = true;
 		csr_roam_update_wait_for_key_timer_info(mac_ctx, session_id);
+		/* This is temp ifdef will be removed in near future */
+#ifndef FEATURE_CM_ENABLE
 		csr_neighbor_roam_state_transition(mac_ctx,
 				eCSR_NEIGHBOR_ROAM_STATE_INIT, session_id);
+#endif
 	}
 
 	if (roam_synch_data->is_ft_im_roam) {

+ 4 - 0
core/sme/src/csr/csr_api_scan.c

@@ -1871,6 +1871,10 @@ void csr_fill_enc_type(eCsrEncryptionType *cipher_type, uint32_t cipherset)
 static void csr_fill_neg_crypto_info(struct tag_csrscan_result *bss,
 				     struct security_info *sec_info)
 {
+	if (!sec_info->authmodeset && !sec_info->key_mgmt &&
+	    !sec_info->ucastcipherset)
+		return;
+
 	csr_fill_enc_type(&bss->ucEncryptionType, sec_info->ucastcipherset);
 	csr_fill_enc_type(&bss->mcEncryptionType, sec_info->mcastcipherset);
 	csr_fill_auth_type(&bss->authType, sec_info->authmodeset,

+ 3 - 1
core/sme/src/csr/csr_cmd_process.c

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2011-2020 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2011-2021 The Linux Foundation. All rights reserved.
  *
  * Permission to use, copy, modify, and/or distribute this software for
  * any purpose with or without fee is hereby granted, provided that the
@@ -92,6 +92,7 @@ QDF_STATUS csr_msg_processor(struct mac_context *mac_ctx, void *msg_buf)
 				sme_rsp->messageType, cur_state,
 				vdev_id);
 
+#ifndef FEATURE_CM_ENABLE
 			if (eWNI_SME_FT_PRE_AUTH_RSP ==
 					sme_rsp->messageType) {
 				sme_err("Dequeue eSmeCommandRoam command with reason eCsrPerformPreauth");
@@ -104,6 +105,7 @@ QDF_STATUS csr_msg_processor(struct mac_context *mac_ctx, void *msg_buf)
 					eCsrSmeIssuedFTReassoc,
 					vdev_id);
 			}
+#endif
 		}
 		break;
 	} /* switch */

+ 4 - 8
core/sme/src/csr/csr_host_scan_roam.c

@@ -22,6 +22,7 @@
  * Host based roaming processing scan results and initiating the roaming
  */
 
+#ifndef FEATURE_CM_ENABLE
 #include "wma_types.h"
 #include "csr_inside_api.h"
 #include "sme_qos_internal.h"
@@ -45,13 +46,10 @@ QDF_STATUS csr_roam_issue_reassociate(struct mac_context *mac, uint32_t vdev_id,
 	csr_roam_substate_change(mac, eCSR_ROAM_SUBSTATE_REASSOC_REQ, vdev_id);
 	sme_debug("calling csr_send_join_req_msg (eWNI_SME_REASSOC_REQ)");
 	/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
+
 	/* attempt to Join this BSS... */
 	return csr_send_join_req_msg(mac, vdev_id, bss_desc, roam_profile, ies,
 				     eWNI_SME_REASSOC_REQ);
-#else
-	return QDF_STATUS_SUCCESS;
-#endif
 }
 
 QDF_STATUS
@@ -577,8 +575,6 @@ void csr_neighbor_roam_request_handoff(struct mac_context *mac_ctx,
 
 	sme_debug("csr_roamHandoffRequested: disassociating with current AP");
 
-	/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 	if (!QDF_IS_STATUS_SUCCESS(csr_roam_issue_disassociate_cmd(
 					mac_ctx,
 					session_id,
@@ -588,7 +584,7 @@ void csr_neighbor_roam_request_handoff(struct mac_context *mac_ctx,
 		qdf_mem_free(roam_info);
 		return;
 	}
-#endif
+
 	/* notify HDD for handoff, providing the BSSID too */
 	roam_info->reasonCode = eCsrRoamReasonBetterAP;
 
@@ -687,4 +683,4 @@ void csr_neighbor_roam_free_neighbor_roam_bss_node(struct mac_context *mac,
 	qdf_mem_free(neighborRoamBSSNode);
 	neighborRoamBSSNode = NULL;
 }
-
+#endif

+ 8 - 14
core/sme/src/csr/csr_inside_api.h

@@ -394,6 +394,7 @@ QDF_STATUS csr_roam_get_session_id_from_bssid(struct mac_context *mac,
 enum csr_cfgdot11mode csr_find_best_phy_mode(struct mac_context *mac,
 							uint32_t phyMode);
 
+#ifndef FEATURE_CM_ENABLE
 /*
  * csr_copy_ssids_from_roam_params() - copy SSID from roam_params to scan filter
  * @rso_usr_cfg: rso user config
@@ -414,7 +415,6 @@ void csr_copy_ssids_from_roam_params(struct rso_config_params *rso_usr_cfg,
 void csr_update_scan_filter_dot11mode(struct mac_context *mac_ctx,
 				      struct scan_filter *filter);
 
-#ifndef FEATURE_CM_ENABLE
 /**
  * csr_roam_get_scan_filter_from_profile() - prepare scan filter from
  * given roam profile
@@ -434,7 +434,6 @@ csr_roam_get_scan_filter_from_profile(struct mac_context *mac_ctx,
 				      struct csr_roam_profile *profile,
 				      struct scan_filter *filter,
 				      bool is_roam, uint8_t vdev_id);
-#endif
 /**
  * csr_neighbor_roam_get_scan_filter_from_profile() - prepare scan filter from
  * connected profile
@@ -451,6 +450,7 @@ QDF_STATUS
 csr_neighbor_roam_get_scan_filter_from_profile(struct mac_context *mac,
 					       struct scan_filter *filter,
 					       uint8_t vdev_id);
+#endif
 /*
  * csr_scan_get_result() - Return scan results based on filter
  * @mac: Pointer to Global MAC structure
@@ -784,6 +784,7 @@ QDF_STATUS csr_roam_issue_deauth_sta_cmd(struct mac_context *mac,
 QDF_STATUS
 csr_send_chng_mcc_beacon_interval(struct mac_context *mac, uint32_t sessionId);
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * csr_roam_ft_pre_auth_rsp_processor() - Handle the preauth response
  * @mac_ctx: Global MAC context
@@ -800,6 +801,7 @@ void csr_roam_ft_pre_auth_rsp_processor(struct mac_context *mac_ctx,
 					tpSirFTPreAuthRsp pFTPreAuthRsp)
 {}
 #endif
+#endif
 
 #ifdef FEATURE_WLAN_ESE
 void update_cckmtsf(uint32_t *timeStamp0, uint32_t *timeStamp1,
@@ -812,13 +814,17 @@ static inline void csr_update_prev_ap_info(struct csr_roam_session *session,
 					   struct wlan_objmgr_vdev *vdev) {}
 #endif
 
+#ifndef FEATURE_CM_ENABLE
 QDF_STATUS csr_roam_enqueue_preauth(struct mac_context *mac, uint32_t sessionId,
 				    struct bss_description *pBssDescription,
 				    enum csr_roam_reason reason,
 				    bool fImmediate);
+
 QDF_STATUS csr_dequeue_roam_command(struct mac_context *mac,
 				enum csr_roam_reason reason,
 				uint8_t session_id);
+#endif
+
 QDF_STATUS csr_scan_create_entry_in_scan_cache(struct mac_context *mac,
 						uint32_t sessionId,
 						struct qdf_mac_addr bssid,
@@ -947,18 +953,6 @@ csr_roam_set_bss_config_cfg(struct mac_context *mac_ctx, uint32_t session_id,
 void csr_prune_channel_list_for_mode(struct mac_context *mac,
 				     struct csr_channel *pChannelList);
 
-/**
- * csr_get_rf_band()
- *
- * @channel: channel number
- *
- * This function is used to translate channel number to band
- *
- * Return: BAND_2G -  if 2.4GHZ channel
- *         BAND_5G -  if 5GHZ channel
- */
-enum band_info csr_get_rf_band(uint8_t channel);
-
 /**
  * csr_lookup_pmkid_using_bssid() - lookup pmkid using bssid
  * @mac: pointer to mac

+ 41 - 71
core/sme/src/csr/csr_neighbor_roam.c

@@ -49,6 +49,7 @@ static const char *lfr_get_config_item_string(uint8_t reason)
 	}
 }
 
+#ifndef FEATURE_CM_ENABLE
 void csr_neighbor_roam_state_transition(struct mac_context *mac_ctx,
 		uint8_t newstate, uint8_t session)
 {
@@ -108,24 +109,17 @@ void csr_neighbor_roam_send_lfr_metric_event(
 	}
 }
 #endif
+#endif
 
 QDF_STATUS csr_neighbor_roam_update_config(struct mac_context *mac_ctx,
 		uint8_t session_id, uint8_t value, uint8_t reason)
 {
-	tpCsrNeighborRoamControlInfo pNeighborRoamInfo =
-	    &mac_ctx->roam.neighborRoamInfo[session_id];
 	struct cm_roam_values_copy src_cfg;
-	eCsrNeighborRoamState state;
 	uint8_t old_value;
 	struct wlan_objmgr_vdev *vdev;
 	struct rso_config *rso_cfg;
 	struct rso_cfg_params *cfg_params;
 
-	if (!pNeighborRoamInfo) {
-		sme_err("Invalid Session ID %d", session_id);
-		return QDF_STATUS_E_FAILURE;
-	}
-
 	vdev = wlan_objmgr_get_vdev_by_id_from_pdev(mac_ctx->pdev, session_id,
 						    WLAN_LEGACY_SME_ID);
 	if (!vdev) {
@@ -138,56 +132,47 @@ QDF_STATUS csr_neighbor_roam_update_config(struct mac_context *mac_ctx,
 		return QDF_STATUS_E_FAILURE;
 	}
 	cfg_params = &rso_cfg->cfg_param;
-	state = pNeighborRoamInfo->neighborRoamState;
-	if ((state == eCSR_NEIGHBOR_ROAM_STATE_CONNECTED) ||
-			state == eCSR_NEIGHBOR_ROAM_STATE_INIT) {
-		switch (reason) {
-		case REASON_LOOKUP_THRESH_CHANGED:
-			old_value = cfg_params->neighbor_lookup_threshold;
-			cfg_params->neighbor_lookup_threshold = value;
-			break;
-		case REASON_OPPORTUNISTIC_THRESH_DIFF_CHANGED:
-			old_value = cfg_params->opportunistic_threshold_diff;
-			cfg_params->opportunistic_threshold_diff = value;
-			break;
-		case REASON_ROAM_RESCAN_RSSI_DIFF_CHANGED:
-			old_value = cfg_params->roam_rescan_rssi_diff;
-			cfg_params->roam_rescan_rssi_diff = value;
-			src_cfg.uint_value = value;
-			wlan_cm_roam_cfg_set_value(mac_ctx->psoc, session_id,
-						   RSSI_CHANGE_THRESHOLD,
-						   &src_cfg);
-			break;
-		case REASON_ROAM_BMISS_FIRST_BCNT_CHANGED:
-			old_value = cfg_params->roam_bmiss_first_bcn_cnt;
-			cfg_params->roam_bmiss_first_bcn_cnt = value;
-			break;
-		case REASON_ROAM_BMISS_FINAL_BCNT_CHANGED:
-			old_value = cfg_params->roam_bmiss_final_cnt;
-			cfg_params->roam_bmiss_final_cnt = value;
-			break;
-		default:
-			sme_debug("Unknown update cfg reason");
-			wlan_objmgr_vdev_release_ref(vdev, WLAN_LEGACY_SME_ID);
-			return QDF_STATUS_E_FAILURE;
-		}
-	} else {
-		sme_err("Unexpected state %s, return fail",
-			mac_trace_get_neighbour_roam_state(state));
+	switch (reason) {
+	case REASON_LOOKUP_THRESH_CHANGED:
+		old_value = cfg_params->neighbor_lookup_threshold;
+		cfg_params->neighbor_lookup_threshold = value;
+		break;
+	case REASON_OPPORTUNISTIC_THRESH_DIFF_CHANGED:
+		old_value = cfg_params->opportunistic_threshold_diff;
+		cfg_params->opportunistic_threshold_diff = value;
+		break;
+	case REASON_ROAM_RESCAN_RSSI_DIFF_CHANGED:
+		old_value = cfg_params->roam_rescan_rssi_diff;
+		cfg_params->roam_rescan_rssi_diff = value;
+		src_cfg.uint_value = value;
+		wlan_cm_roam_cfg_set_value(mac_ctx->psoc, session_id,
+					   RSSI_CHANGE_THRESHOLD,
+					   &src_cfg);
+		break;
+	case REASON_ROAM_BMISS_FIRST_BCNT_CHANGED:
+		old_value = cfg_params->roam_bmiss_first_bcn_cnt;
+		cfg_params->roam_bmiss_first_bcn_cnt = value;
+		break;
+	case REASON_ROAM_BMISS_FINAL_BCNT_CHANGED:
+		old_value = cfg_params->roam_bmiss_final_cnt;
+		cfg_params->roam_bmiss_final_cnt = value;
+		break;
+	default:
+		sme_debug("Unknown update cfg reason");
 		wlan_objmgr_vdev_release_ref(vdev, WLAN_LEGACY_SME_ID);
 		return QDF_STATUS_E_FAILURE;
 	}
 	wlan_objmgr_vdev_release_ref(vdev, WLAN_LEGACY_SME_ID);
-	if (state == eCSR_NEIGHBOR_ROAM_STATE_CONNECTED) {
-		sme_debug("CONNECTED, send update cfg cmd");
-		wlan_roam_update_cfg(mac_ctx->psoc, session_id, reason);
-	}
+	sme_debug("CONNECTED, send update cfg cmd");
+	wlan_roam_update_cfg(mac_ctx->psoc, session_id, reason);
+
 	sme_debug("LFR config for %s changed from %d to %d",
 		  lfr_get_config_item_string(reason), old_value, value);
 
 	return QDF_STATUS_SUCCESS;
 }
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * csr_neighbor_roam_reset_connected_state_control_info()
  *
@@ -380,19 +365,7 @@ csr_neighbor_roam_get_scan_filter_from_profile(struct mac_context *mac,
 
 	return QDF_STATUS_SUCCESS;
 }
-
-enum band_info csr_get_rf_band(uint8_t channel)
-{
-	if ((channel >= SIR_11A_CHANNEL_BEGIN) &&
-	    (channel <= SIR_11A_CHANNEL_END))
-		return BAND_5G;
-
-	if ((channel >= SIR_11B_CHANNEL_BEGIN) &&
-	    (channel <= SIR_11B_CHANNEL_END))
-		return BAND_2G;
-
-	return BAND_UNKNOWN;
-}
+#endif
 
 /**
  * csr_neighbor_roam_channels_filter_by_current_band()
@@ -423,7 +396,7 @@ QDF_STATUS csr_neighbor_roam_channels_filter_by_current_band(struct mac_context
 	uint8_t i = 0;
 	uint8_t numChannels = 0;
 	uint32_t curr_ap_op_chan_freq =
-		mac->roam.neighborRoamInfo[sessionId].curr_ap_op_chan_freq;
+		wlan_get_operation_chan_freq_vdev_id(mac->pdev, sessionId);
 	/* Check for NULL pointer */
 	if (!input_chan_freq_list)
 		return QDF_STATUS_E_INVAL;
@@ -655,6 +628,7 @@ void csr_roam_restore_default_config(struct mac_context *mac_ctx,
 }
 #endif
 
+#ifndef FEATURE_CM_ENABLE
 /**
  * csr_neighbor_roam_indicate_disconnect() - To indicate disconnect
  * @mac: The handle returned by mac_open
@@ -801,8 +775,6 @@ static void csr_neighbor_roam_info_ctx_init(struct mac_context *mac,
 
 	qdf_copy_macaddr(&ngbr_roam_info->currAPbssid,
 			&session->connectedProfile.bssid);
-	ngbr_roam_info->curr_ap_op_chan_freq =
-				      session->connectedProfile.op_freq;
 	/*
 	 * Update RSSI change params to vdev
 	 */
@@ -1049,8 +1021,7 @@ QDF_STATUS csr_neighbor_roam_init(struct mac_context *mac, uint8_t sessionId)
 	csr_neighbor_roam_state_transition(mac,
 			eCSR_NEIGHBOR_ROAM_STATE_INIT, sessionId);
 	pNeighborRoamInfo->uOsRequestedHandoff = 0;
-	/* Set the Last Sent Cmd as RSO_STOP */
-	pNeighborRoamInfo->last_sent_cmd = ROAM_SCAN_OFFLOAD_STOP;
+
 	return QDF_STATUS_SUCCESS;
 }
 
@@ -1093,6 +1064,7 @@ void csr_neighbor_roam_close(struct mac_context *mac, uint8_t sessionId)
 		eCSR_NEIGHBOR_ROAM_STATE_CLOSED, sessionId);
 
 }
+#endif
 
 /**
  * csr_neighbor_roam_is11r_assoc() - Check if association type is 11R
@@ -1110,6 +1082,7 @@ bool csr_neighbor_roam_is11r_assoc(struct mac_context *mac_ctx, uint8_t session_
 	return config.bool_value;
 }
 
+#ifndef FEATURE_CM_ENABLE
 /*
  * csr_neighbor_middle_of_roaming() -
  * This function returns true if STA is in the middle of roaming states
@@ -1132,7 +1105,6 @@ bool csr_neighbor_middle_of_roaming(struct mac_context *mac, uint8_t sessionId)
 	return val;
 }
 
-#ifndef FEATURE_CM_ENABLE
 bool
 wlan_cm_host_roam_in_progress(struct wlan_objmgr_psoc *psoc,
 			      uint8_t vdev_id)
@@ -1154,7 +1126,7 @@ wlan_cm_host_roam_in_progress(struct wlan_objmgr_psoc *psoc,
 
 	return csr_neighbor_middle_of_roaming(mac_ctx, vdev_id);
 }
-#endif
+
 /**
  * csr_neighbor_roam_process_handoff_req - Processes handoff request
  *
@@ -1260,12 +1232,10 @@ static QDF_STATUS csr_neighbor_roam_process_handoff_req(
 		csr_neighbor_roam_trigger_handoff(mac_ctx, session_id);
 	} else {
 		/* This is temp ifdef will be removed in near future */
-#ifndef FEATURE_CM_ENABLE
 		status = csr_scan_for_ssid(mac_ctx, session_id, profile,
 					   roam_id, false);
 		if (status != QDF_STATUS_SUCCESS)
 			sme_err("SSID scan failed");
-#endif
 	}
 
 end:
@@ -1330,7 +1300,6 @@ QDF_STATUS csr_neighbor_roam_sssid_scan_done(struct mac_context *mac,
 	return QDF_STATUS_SUCCESS;
 }
 
-
 /**
  * csr_neighbor_roam_handoff_req_hdlr - Processes handoff request
  * @mac_ctx  Pointer to mac context
@@ -1452,3 +1421,4 @@ QDF_STATUS csr_neighbor_roam_start_lfr_scan(struct mac_context *mac,
 
 
 }
+#endif

+ 2 - 1
core/sme/src/csr/csr_roam_preauth.c

@@ -22,6 +22,7 @@
  * Host based roaming preauthentication implementation
  */
 
+#ifndef FEATURE_CM_ENABLE
 #include "wma_types.h"
 #include "csr_inside_api.h"
 #include "sme_qos_internal.h"
@@ -789,4 +790,4 @@ QDF_STATUS csr_neighbor_roam_issue_preauth_req(struct mac_context *mac_ctx,
 
 	return status;
 }
-
+#endif

+ 4 - 0
core/wma/src/wma_scan_roam.c

@@ -4189,6 +4189,7 @@ QDF_STATUS wma_scan_probe_setoui(tp_wma_handle wma,
  */
 void wma_roam_better_ap_handler(tp_wma_handle wma, uint32_t vdev_id)
 {
+#ifndef FEATURE_CM_ENABLE
 	struct scheduler_msg cds_msg = {0};
 	tSirSmeCandidateFoundInd *candidate_ind;
 	QDF_STATUS status;
@@ -4211,6 +4212,9 @@ void wma_roam_better_ap_handler(tp_wma_handle wma, uint32_t vdev_id)
 					QDF_MODULE_ID_SCAN,  &cds_msg);
 	if (QDF_IS_STATUS_ERROR(status))
 		qdf_mem_free(candidate_ind);
+#else
+	/* post to osif queue to call cm API for LFR2 */
+#endif
 }
 
 /**