qcacmn: Add NULL check for MLO dev context

MLO dev context is accessed without NULL check.
Add NULL check before accessing the MLO dev context.

Change-Id: I51d672924dbbf70cbf4b7e4951a3a45d4fd551ec
CRs-Fixed: 3409901
This commit is contained in:
Shashikala Prabhu
2023-02-27 10:20:08 +05:30
committed by Madan Koyyalamudi
parent 6d5fea01f7
commit 4ed5695ef3
2 changed files with 41 additions and 3 deletions

View File

@@ -2128,6 +2128,20 @@ QDF_STATUS wlan_vdev_get_bss_peer_mac(struct wlan_objmgr_vdev *vdev,
*/
QDF_STATUS wlan_vdev_get_bss_peer_mld_mac(struct wlan_objmgr_vdev *vdev,
struct qdf_mac_addr *mld_mac);
/**
* wlan_vdev_get_mlo_dev_ctx() - get MLO dev context
* @vdev: VDEV object
*
* API to get MLO dev context pointer from vdev
*
* Return: MLO dev context pointer
*/
static inline struct wlan_mlo_dev_context *wlan_vdev_get_mlo_dev_ctx(
struct wlan_objmgr_vdev *vdev)
{
return vdev->mlo_dev_ctx;
}
#endif
/**

View File

@@ -868,13 +868,21 @@ wlan_mlo_t2lm_timer_start(struct wlan_objmgr_vdev *vdev,
struct wlan_t2lm_timer *t2lm_timer;
struct wlan_t2lm_context *t2lm_ctx;
uint32_t target_out_time;
struct wlan_mlo_dev_context *mlo_dev_ctx;
if (!interval) {
t2lm_debug("Timer interval is 0");
return QDF_STATUS_E_NULL_VALUE;
}
t2lm_ctx = &vdev->mlo_dev_ctx->t2lm_ctx;
if (!vdev)
return QDF_STATUS_E_NULL_VALUE;
mlo_dev_ctx = wlan_vdev_get_mlo_dev_ctx(vdev);
if (!mlo_dev_ctx)
return QDF_STATUS_E_NULL_VALUE;
t2lm_ctx = &mlo_dev_ctx->t2lm_ctx;
t2lm_timer = &vdev->mlo_dev_ctx->t2lm_ctx.t2lm_timer;
if (!t2lm_timer) {
t2lm_err("t2lm timer ctx is null");
@@ -981,9 +989,17 @@ static QDF_STATUS wlan_update_mapping_switch_time_expected_dur(
{
struct wlan_t2lm_context *t2lm_ctx;
uint16_t tsf_bit25_10, ms_time;
struct wlan_mlo_dev_context *mlo_dev_ctx;
if (!vdev)
return QDF_STATUS_E_NULL_VALUE;
mlo_dev_ctx = wlan_vdev_get_mlo_dev_ctx(vdev);
if (!mlo_dev_ctx)
return QDF_STATUS_E_NULL_VALUE;
tsf_bit25_10 = (tsf & WLAN_T2LM_MAPPING_SWITCH_TSF_BITS) >> 10;
t2lm_ctx = &vdev->mlo_dev_ctx->t2lm_ctx;
t2lm_ctx = &mlo_dev_ctx->t2lm_ctx;
t2lm_dev_lock_acquire(t2lm_ctx);
@@ -1046,12 +1062,20 @@ QDF_STATUS wlan_process_bcn_prbrsp_t2lm_ie(
{
struct wlan_t2lm_context *t2lm_ctx;
QDF_STATUS status;
struct wlan_mlo_dev_context *mlo_dev_ctx;
/* Do not parse the T2LM IE if STA is not in connected state */
if (!wlan_cm_is_vdev_connected(vdev))
return QDF_STATUS_SUCCESS;
t2lm_ctx = &vdev->mlo_dev_ctx->t2lm_ctx;
if (!vdev)
return QDF_STATUS_E_NULL_VALUE;
mlo_dev_ctx = wlan_vdev_get_mlo_dev_ctx(vdev);
if (!mlo_dev_ctx)
return QDF_STATUS_E_NULL_VALUE;
t2lm_ctx = &mlo_dev_ctx->t2lm_ctx;
status = wlan_update_mapping_switch_time_expected_dur(
vdev, rx_t2lm_ie, tsf);