qcacmn: Move wakelock to psoc level

Wakelock is system level lock not required to be taken
for every vdev, Hence move the wakelock to the psoc
hierarchy.

Change-Id: I525baf5f4b5dcadb493d84900dbd0a2e7c6407f6
CRs-Fixed: 2563406
This commit is contained in:
Arun Kumar Khandavalli
2019-11-22 17:16:18 +05:30
vanhempi 614d1e4476
commit eaac8c195b
10 muutettua tiedostoa jossa 239 lisäystä ja 263 poistoa

Näytä tiedosto

@@ -17,13 +17,29 @@
*/
/**
* DOC: target_if_vdev_mgr_wake_lock.h
* DOC: target_if_psoc_wake_lock.h
*
* This file provides declaration for wakelock APIs
*/
#ifndef __TARGET_IF_VDEV_MGR_WAKE_LOCK_H__
#define __TARGET_IF_VDEV_MGR_WAKE_LOCK_H__
#ifndef __TARGET_IF_PSOC_WAKE_LOCK_H__
#define __TARGET_IF_PSOC_WAKE_LOCK_H__
#ifdef FEATURE_VDEV_RSP_WAKELOCK
/**
* struct wlan_vdev_wakelock - vdev wake lock sub structure
* @start_wakelock: wakelock for vdev start
* @stop_wakelock: wakelock for vdev stop
* @delete_wakelock: wakelock for vdev delete
* @wmi_cmd_rsp_runtime_lock: run time lock
*/
struct psoc_mlme_wakelock {
qdf_wake_lock_t start_wakelock;
qdf_wake_lock_t stop_wakelock;
qdf_wake_lock_t delete_wakelock;
qdf_runtime_lock_t wmi_cmd_rsp_runtime_lock;
};
#endif
enum wakelock_mode {
START_WAKELOCK,
@@ -37,65 +53,65 @@ enum wakelock_mode {
* target_if_wake_lock_init() - API to initialize
wakelocks:start,
stop and delete.
* @vdev: pointer to vdev
* @psoc: pointer to psoc
*
* This also initialize the runtime lock
*
* Return: None
*/
void target_if_wake_lock_init(struct wlan_objmgr_vdev *vdev);
void target_if_wake_lock_init(struct wlan_objmgr_psoc *psoc);
/**
* target_if_wake_lock_deinit() - API to destroy
wakelocks:start, stop and delete.
* @vdev: pointer to vdev
* @psoc: pointer to psoc
*
* This also destroy the runtime lock
*
* Return: None
*/
void target_if_wake_lock_deinit(struct wlan_objmgr_vdev *vdev);
void target_if_wake_lock_deinit(struct wlan_objmgr_psoc *psoc);
/**
* target_if_start_wake_lock_timeout_acquire() - acquire the
vdev start wakelock
* @vdev: pointer to vdev
* @psoc: pointer to psoc
*
* This also acquires the target_if runtime pm lock.
*
* Return: Success/Failure
*/
QDF_STATUS target_if_wake_lock_timeout_acquire(struct wlan_objmgr_vdev *vdev,
QDF_STATUS target_if_wake_lock_timeout_acquire(struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode);
/**
* target_if_start_wake_lock_timeout_release() - release the
start wakelock
* @vdev: pointer to vdev
* @psoc: pointer to psoc
*
* This also release the target_if runtime pm lock.
*
* Return: Success/Failure
*/
QDF_STATUS target_if_wake_lock_timeout_release(struct wlan_objmgr_vdev *vdev,
QDF_STATUS target_if_wake_lock_timeout_release(struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode);
#else
static inline void target_if_wake_lock_init(struct wlan_objmgr_vdev *vdev)
static inline void target_if_wake_lock_init(struct wlan_objmgr_psoc *psoc)
{
}
static inline void target_if_wake_lock_deinit(struct wlan_objmgr_vdev *vdev)
static inline void target_if_wake_lock_deinit(struct wlan_objmgr_psoc *psoc)
{
}
static inline QDF_STATUS target_if_wake_lock_timeout_acquire(
struct wlan_objmgr_vdev *vdev,
struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode)
{
return QDF_STATUS_SUCCESS;
}
static inline QDF_STATUS target_if_wake_lock_timeout_release(
struct wlan_objmgr_vdev *vdev,
struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode)
{
return QDF_STATUS_SUCCESS;

Näytä tiedosto

@@ -0,0 +1,151 @@
/*
* Copyright (c) 2013-2019 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
* above copyright notice and this permission notice appear in all
* copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
/**
* DOC: target_if_psoc_wake_lock.c
*
* This file provide definition for APIs related to wake lock
*/
#include "qdf_lock.h"
#include <target_if_psoc_wake_lock.h>
#include <wlan_lmac_if_def.h>
#include <host_diag_core_event.h>
#include <wlan_objmgr_psoc_obj.h>
#include <target_if.h>
void target_if_wake_lock_init(struct wlan_objmgr_psoc *psoc)
{
struct psoc_mlme_wakelock *psoc_wakelock;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops && !rx_ops->psoc_get_wakelock_info) {
mlme_err("vdev_id:%d psoc_id:%d No Rx Ops", vdev_id,
wlan_psoc_get_id(psoc));
return QDF_STATUS_E_INVAL;
}
psoc_wakelock = rx_ops->psoc_get_wakelock_info(psoc);
qdf_wake_lock_create(&psoc_wakelock->start_wakelock, "vdev_start");
qdf_wake_lock_create(&psoc_wakelock->stop_wakelock, "vdev_stop");
qdf_wake_lock_create(&psoc_wakelock->delete_wakelock, "vdev_delete");
qdf_runtime_lock_init(&psoc_wakelock->wmi_cmd_rsp_runtime_lock);
}
void target_if_wake_lock_deinit(struct wlan_objmgr_psoc *psoc)
{
struct psoc_mlme_wakelock *psoc_wakelock;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops && !rx_ops->psoc_get_wakelock_info) {
mlme_err("vdev_id:%d psoc_id:%d No Rx Ops", vdev_id,
wlan_psoc_get_id(psoc));
return QDF_STATUS_E_INVAL;
}
psoc_wakelock = rx_ops->psoc_get_wakelock_info(psoc);
qdf_wake_lock_destroy(&psoc_wakelock->start_wakelock);
qdf_wake_lock_destroy(&psoc_wakelock->stop_wakelock);
qdf_wake_lock_destroy(&psoc_wakelock->delete_wakelock);
qdf_runtime_lock_deinit(&vdev_wakelock->wmi_cmd_rsp_runtime_lock);
}
QDF_STATUS target_if_wake_lock_timeout_acquire(
struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode)
{
struct psoc_mlme_wakelock *psoc_wakelock;
struct wlan_objmgr_psoc *psoc;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops && !rx_ops->psoc_get_wakelock_info) {
mlme_err("vdev_id:%d psoc_id:%d No Rx Ops", vdev_id,
wlan_psoc_get_id(psoc));
return QDF_STATUS_E_INVAL;
}
psoc_wakelock = rx_ops->psoc_get_wakelock_info(psoc);
switch (mode) {
case START_WAKELOCK:
qdf_wake_lock_timeout_acquire(&psoc_wakelock->start_wakelock,
START_RESPONSE_TIMER);
break;
case STOP_WAKELOCK:
qdf_wake_lock_timeout_acquire(&psoc_wakelock->stop_wakelock,
STOP_RESPONSE_TIMER);
break;
case DELETE_WAKELOCK:
qdf_wake_lock_timeout_acquire(&vdev_wakelock->delete_wakelock,
DELETE_RESPONSE_TIMER);
break;
default:
target_if_err("operation mode is invalid");
return QDF_STATUS_E_FAILURE;
}
qdf_runtime_pm_prevent_suspend(
&psoc_wakelock->wmi_cmd_rsp_runtime_lock);
return QDF_STATUS_SUCCESS;
}
QDF_STATUS target_if_wake_lock_timeout_release(
struct wlan_objmgr_psoc *psoc,
enum wakelock_mode mode)
{
struct psoc_mlme_wakelock *psoc_wakelock;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops && !rx_ops->psoc_get_wakelock_info) {
mlme_err("vdev_id:%d psoc_id:%d No Rx Ops", vdev_id,
wlan_psoc_get_id(psoc));
return QDF_STATUS_E_INVAL;
}
psoc_wakelock = rx_ops->psoc_get_wakelock_info(psoc);
switch (mode) {
case START_WAKELOCK:
qdf_wake_lock_release(&psoc_wakelock->start_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
case STOP_WAKELOCK:
qdf_wake_lock_release(&psoc_wakelock->stop_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
case DELETE_WAKELOCK:
qdf_wake_lock_release(&psoc_wakelock->delete_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
default:
target_if_err("operation mode is invalid");
return QDF_STATUS_E_FAILURE;
}
qdf_runtime_pm_allow_suspend(&psoc_wakelock->wmi_cmd_rsp_runtime_lock);
return QDF_STATUS_SUCCESS;
}

Näytä tiedosto

@@ -28,7 +28,6 @@
#include <init_deinit_lmac.h>
#include <target_if_vdev_mgr_tx_ops.h>
#include <target_if_vdev_mgr_rx_ops.h>
#include <target_if_vdev_mgr_wake_lock.h>
#include <target_if.h>
#include <target_type.h>
#include <wlan_mlme_dbg.h>
@@ -38,6 +37,7 @@
#include <wmi_unified_vdev_api.h>
#include <cdp_txrx_ctrl.h>
#include <target_if_psoc_timer_tx_ops.h>
#include <target_if_psoc_wake_lock.h>
static QDF_STATUS target_if_vdev_mgr_register_event_handler(
struct wlan_objmgr_psoc *psoc)
@@ -444,7 +444,7 @@ static QDF_STATUS target_if_vdev_mgr_start_send(
}
vdev_rsp->expire_time = START_RESPONSE_TIMER;
target_if_wake_lock_timeout_acquire(vdev, START_WAKELOCK);
target_if_wake_lock_timeout_acquire(psoc, START_WAKELOCK);
if (param->is_restart)
target_if_vdev_mgr_rsp_timer_start(psoc, vdev_rsp,
@@ -457,7 +457,7 @@ static QDF_STATUS target_if_vdev_mgr_start_send(
if (QDF_IS_STATUS_ERROR(status)) {
vdev_rsp->timer_status = QDF_STATUS_E_CANCELED;
vdev_rsp->expire_time = 0;
target_if_wake_lock_timeout_release(vdev, START_WAKELOCK);
target_if_wake_lock_timeout_release(psoc, START_WAKELOCK);
if (param->is_restart)
target_if_vdev_mgr_rsp_timer_stop(psoc, vdev_rsp,
RESTART_RESPONSE_BIT);
@@ -478,7 +478,7 @@ static QDF_STATUS target_if_vdev_mgr_delete_response_send(
rsp.vdev_id = wlan_vdev_get_id(vdev);
status = rx_ops->vdev_mgr_delete_response(psoc, &rsp);
target_if_wake_lock_timeout_release(vdev, DELETE_WAKELOCK);
target_if_wake_lock_timeout_release(psoc, DELETE_WAKELOCK);
return status;
}
@@ -521,10 +521,10 @@ static QDF_STATUS target_if_vdev_mgr_delete_send(
return QDF_STATUS_E_INVAL;
}
target_if_wake_lock_timeout_acquire(vdev, DELETE_WAKELOCK);
vdev_rsp->expire_time = DELETE_RESPONSE_TIMER;
target_if_vdev_mgr_rsp_timer_start(psoc, vdev_rsp,
DELETE_RESPONSE_BIT);
target_if_wake_lock_timeout_acquire(psoc, DELETE_WAKELOCK);
status = wmi_unified_vdev_delete_send(wmi_handle, param->vdev_id);
if (QDF_IS_STATUS_SUCCESS(status)) {
@@ -540,11 +540,11 @@ static QDF_STATUS target_if_vdev_mgr_delete_send(
target_if_vdev_mgr_delete_response_send(vdev, rx_ops);
}
} else {
target_if_wake_lock_timeout_release(vdev, DELETE_WAKELOCK);
vdev_rsp->expire_time = 0;
vdev_rsp->timer_status = QDF_STATUS_E_CANCELED;
target_if_vdev_mgr_rsp_timer_stop(psoc, vdev_rsp,
DELETE_RESPONSE_BIT);
target_if_wake_lock_timeout_release(psoc, DELETE_WAKELOCK);
}
return status;
}
@@ -588,17 +588,17 @@ static QDF_STATUS target_if_vdev_mgr_stop_send(
return QDF_STATUS_E_INVAL;
}
target_if_wake_lock_timeout_acquire(vdev, STOP_WAKELOCK);
vdev_rsp->expire_time = STOP_RESPONSE_TIMER;
target_if_vdev_mgr_rsp_timer_start(psoc, vdev_rsp, STOP_RESPONSE_BIT);
target_if_wake_lock_timeout_acquire(psoc, STOP_WAKELOCK);
status = wmi_unified_vdev_stop_send(wmi_handle, param->vdev_id);
if (QDF_IS_STATUS_ERROR(status)) {
vdev_rsp->expire_time = 0;
vdev_rsp->timer_status = QDF_STATUS_E_CANCELED;
target_if_wake_lock_timeout_release(vdev, STOP_WAKELOCK);
target_if_vdev_mgr_rsp_timer_stop(psoc, vdev_rsp,
STOP_RESPONSE_BIT);
target_if_wake_lock_timeout_release(psoc, STOP_WAKELOCK);
}
return status;
}
@@ -609,6 +609,7 @@ static QDF_STATUS target_if_vdev_mgr_down_send(
{
QDF_STATUS status;
struct wmi_unified *wmi_handle;
struct wlan_objmgr_psoc *psoc;
if (!vdev || !param) {
mlme_err("Invalid input");
@@ -621,8 +622,14 @@ static QDF_STATUS target_if_vdev_mgr_down_send(
return QDF_STATUS_E_INVAL;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
mlme_err("Failed to get PSOC Object");
return QDF_STATUS_E_INVAL;
}
status = wmi_unified_vdev_down_send(wmi_handle, param->vdev_id);
target_if_wake_lock_timeout_release(vdev, START_WAKELOCK);
target_if_wake_lock_timeout_release(psoc, START_WAKELOCK);
return status;
}
@@ -636,6 +643,7 @@ static QDF_STATUS target_if_vdev_mgr_up_send(
struct vdev_set_params sparam = {0};
uint8_t bssid[QDF_MAC_ADDR_SIZE];
uint8_t vdev_id;
struct wlan_objmgr_psoc *psoc;
if (!vdev || !param) {
mlme_err("Invalid input");
@@ -648,6 +656,12 @@ static QDF_STATUS target_if_vdev_mgr_up_send(
return QDF_STATUS_E_INVAL;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
mlme_err("Failed to get PSOC Object");
return QDF_STATUS_E_INVAL;
}
vdev_id = wlan_vdev_get_id(vdev);
sparam.vdev_id = vdev_id;
@@ -661,7 +675,7 @@ static QDF_STATUS target_if_vdev_mgr_up_send(
ucfg_wlan_vdev_mgr_get_param_bssid(vdev, bssid);
status = wmi_unified_vdev_up_send(wmi_handle, bssid, param);
target_if_wake_lock_timeout_release(vdev, START_WAKELOCK);
target_if_wake_lock_timeout_release(psoc, START_WAKELOCK);
return status;
}
@@ -1174,5 +1188,9 @@ target_if_vdev_mgr_register_tx_ops(struct wlan_lmac_if_tx_ops *tx_ops)
target_if_psoc_vdev_rsp_timer_deinit;
mlme_tx_ops->psoc_vdev_rsp_timer_inuse =
target_if_psoc_vdev_rsp_timer_inuse;
mlme_tx_ops->psoc_wake_lock_init =
target_if_wake_lock_init;
mlme_tx_ops->psoc_wake_lock_deinit =
target_if_wake_lock_deinit;
return QDF_STATUS_SUCCESS;
}

Näytä tiedosto

@@ -1,199 +0,0 @@
/*
* Copyright (c) 2013-2019 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
* above copyright notice and this permission notice appear in all
* copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
/**
* DOC: target_if_vdev_mgr_wake_lock.c
*
* This file provide definition for APIs related to wake lock
*/
#include "wlan_objmgr_vdev_obj.h"
#include "include/wlan_vdev_mlme.h"
#include "qdf_lock.h"
#include "target_if_vdev_mgr_wake_lock.h"
#include "wlan_lmac_if_def.h"
#include "host_diag_core_event.h"
#include <wlan_objmgr_vdev_obj.h>
#include <wlan_objmgr_pdev_obj.h>
#include <target_if.h>
#include "target_if_vdev_mgr_rx_ops.h"
void target_if_wake_lock_init(struct wlan_objmgr_vdev *vdev)
{
struct vdev_mlme_wakelock *vdev_wakelock;
struct wlan_objmgr_psoc *psoc;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
if (!vdev) {
target_if_err(" VDEV is NULL");
return;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
target_if_err("PSOC is NULL");
return;
}
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops || !rx_ops->vdev_mgr_get_wakelock_info) {
target_if_err("No Rx Ops");
return;
}
vdev_wakelock = rx_ops->vdev_mgr_get_wakelock_info(vdev);
qdf_wake_lock_create(&vdev_wakelock->start_wakelock, "vdev_start");
qdf_wake_lock_create(&vdev_wakelock->stop_wakelock, "vdev_stop");
qdf_wake_lock_create(&vdev_wakelock->delete_wakelock, "vdev_delete");
qdf_runtime_lock_init(&vdev_wakelock->wmi_cmd_rsp_runtime_lock);
}
void target_if_wake_lock_deinit(struct wlan_objmgr_vdev *vdev)
{
struct vdev_mlme_wakelock *vdev_wakelock;
struct wlan_objmgr_psoc *psoc;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
if (!vdev) {
target_if_err(" VDEV is NULL");
return;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
target_if_err("PSOC is NULL");
return;
}
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops || !rx_ops->vdev_mgr_get_wakelock_info) {
target_if_err("No Rx Ops");
return;
}
vdev_wakelock = rx_ops->vdev_mgr_get_wakelock_info(vdev);
qdf_wake_lock_destroy(&vdev_wakelock->start_wakelock);
qdf_wake_lock_destroy(&vdev_wakelock->stop_wakelock);
qdf_wake_lock_destroy(&vdev_wakelock->delete_wakelock);
qdf_runtime_lock_deinit(&vdev_wakelock->wmi_cmd_rsp_runtime_lock);
}
QDF_STATUS target_if_wake_lock_timeout_acquire(
struct wlan_objmgr_vdev *vdev,
enum wakelock_mode mode)
{
struct vdev_mlme_wakelock *vdev_wakelock;
struct wlan_objmgr_psoc *psoc;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
if (!vdev) {
target_if_err(" VDEV is NULL");
return QDF_STATUS_E_FAILURE;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
target_if_err("PSOC is NULL");
return QDF_STATUS_E_FAILURE;
}
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops || !rx_ops->vdev_mgr_get_wakelock_info) {
target_if_err("No Rx Ops");
return QDF_STATUS_E_FAILURE;
}
vdev_wakelock = rx_ops->vdev_mgr_get_wakelock_info(vdev);
switch (mode) {
case START_WAKELOCK:
qdf_wake_lock_timeout_acquire(&vdev_wakelock->start_wakelock,
START_RESPONSE_TIMER);
break;
case STOP_WAKELOCK:
qdf_wake_lock_timeout_acquire(&vdev_wakelock->stop_wakelock,
STOP_RESPONSE_TIMER);
break;
case DELETE_WAKELOCK:
qdf_wake_lock_timeout_acquire(&vdev_wakelock->delete_wakelock,
DELETE_RESPONSE_TIMER);
break;
default:
target_if_err("operation mode is invalid");
return QDF_STATUS_E_FAILURE;
}
qdf_runtime_pm_prevent_suspend(
&vdev_wakelock->wmi_cmd_rsp_runtime_lock);
return QDF_STATUS_SUCCESS;
}
QDF_STATUS target_if_wake_lock_timeout_release(
struct wlan_objmgr_vdev *vdev,
enum wakelock_mode mode)
{
struct vdev_mlme_wakelock *vdev_wakelock;
struct wlan_objmgr_psoc *psoc;
struct wlan_lmac_if_mlme_rx_ops *rx_ops;
if (!vdev) {
target_if_err(" VDEV is NULL");
return QDF_STATUS_E_FAILURE;
}
psoc = wlan_vdev_get_psoc(vdev);
if (!psoc) {
target_if_err("PSOC is NULL");
return QDF_STATUS_E_FAILURE;
}
rx_ops = target_if_vdev_mgr_get_rx_ops(psoc);
if (!rx_ops || !rx_ops->vdev_mgr_get_wakelock_info) {
target_if_err("No Rx Ops");
return QDF_STATUS_E_FAILURE;
}
vdev_wakelock = rx_ops->vdev_mgr_get_wakelock_info(vdev);
switch (mode) {
case START_WAKELOCK:
qdf_wake_lock_release(&vdev_wakelock->start_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
case STOP_WAKELOCK:
qdf_wake_lock_release(&vdev_wakelock->stop_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
case DELETE_WAKELOCK:
qdf_wake_lock_release(&vdev_wakelock->delete_wakelock,
WIFI_POWER_EVENT_WAKELOCK_WMI_CMD_RSP);
break;
default:
target_if_err("operation mode is invalid");
return QDF_STATUS_E_FAILURE;
}
qdf_runtime_pm_allow_suspend(&vdev_wakelock->wmi_cmd_rsp_runtime_lock);
return QDF_STATUS_SUCCESS;
}

Näytä tiedosto

@@ -210,6 +210,8 @@ enum wlan_mlme_cfg_id;
* @psoc_vdev_rsp_timer_inuse: function to determine whether the vdev rsp
* timer is inuse or not
* @psoc_vdev_rsp_timer_mod: function to modify the time of vdev rsp timer
* @psoc_wake_lock_init: Initialize psoc wake lock for vdev response timer
* @psoc_wake_lock_deinit: De-Initialize psoc wake lock for vdev response timer
*/
struct wlan_lmac_if_mlme_tx_ops {
uint32_t (*get_wifi_iface_id) (struct wlan_objmgr_pdev *pdev);
@@ -281,7 +283,10 @@ struct wlan_lmac_if_mlme_tx_ops {
struct wlan_objmgr_psoc *psoc,
uint8_t vdev_id,
int mseconds);
void (*psoc_wake_lock_init)(
struct wlan_objmgr_psoc *psoc);
void (*psoc_wake_lock_deinit)(
struct wlan_objmgr_psoc *psoc);
};
/**
@@ -1507,7 +1512,7 @@ struct wlan_lmac_if_dfs_rx_ops {
* @vdev_mgr_tbttoffset_update_handle: function to handle tbtt offset event
* @vdev_mgr_peer_delete_all_response: function to handle vdev delete all peer
* event
* @vdev_mgr_get_wakelock_info: function to get wakelock info
* @psoc_get_wakelock_info: function to get wakelock info
* @psoc_get_vdev_response_timer_info: function to get vdev response timer
* structure for a specific vdev id
*/
@@ -1531,8 +1536,8 @@ struct wlan_lmac_if_mlme_rx_ops {
struct wlan_objmgr_psoc *psoc,
struct peer_delete_all_response *rsp);
#ifdef FEATURE_VDEV_RSP_WAKELOCK
struct vdev_mlme_wakelock *(*vdev_mgr_get_wakelock_info)(
struct wlan_objmgr_vdev *vdev);
struct vdev_mlme_wakelock *(*psoc_get_wakelock_info)(
struct wlan_objmgr_psoc *psoc);
#endif
struct vdev_response_timer *(*psoc_get_vdev_response_timer_info)(
struct wlan_objmgr_psoc *psoc,

Näytä tiedosto

@@ -29,11 +29,15 @@
* @psoc: PSoC object
* @ext_psoc_ptr: PSoC legacy pointer
* @psoc_vdev_rt: PSoC Vdev response timer
* @psoc_mlme_wakelock: Wakelock to prevent system going to suspend
*/
struct psoc_mlme_obj {
struct wlan_objmgr_psoc *psoc;
mlme_psoc_ext_t *ext_psoc_ptr;
struct vdev_response_timer psoc_vdev_rt[WLAN_UMAC_PSOC_MAX_VDEVS];
#ifdef FEATURE_VDEV_RSP_WAKELOCK
struct psoc_mlme_wakelock psoc_mlme_wakelock;
#endif
};
#endif

Näytä tiedosto

@@ -527,22 +527,6 @@ struct vdev_mlme_ops {
struct peer_delete_all_response *rsp);
};
#ifdef FEATURE_VDEV_RSP_WAKELOCK
/**
* struct wlan_vdev_wakelock - vdev wake lock sub structure
* @start_wakelock: wakelock for vdev start
* @stop_wakelock: wakelock for vdev stop
* @delete_wakelock: wakelock for vdev delete
* @wmi_cmd_rsp_runtime_lock: run time lock
*/
struct vdev_mlme_wakelock {
qdf_wake_lock_t start_wakelock;
qdf_wake_lock_t stop_wakelock;
qdf_wake_lock_t delete_wakelock;
qdf_runtime_lock_t wmi_cmd_rsp_runtime_lock;
};
#endif
/**
* struct vdev_mlme_obj - VDEV MLME component object
* @proto: VDEV MLME proto substructure
@@ -567,9 +551,6 @@ struct vdev_mlme_obj {
struct wlan_objmgr_vdev *vdev;
struct vdev_mlme_ops *ops;
mlme_vdev_ext_t *ext_vdev_ptr;
#ifdef FEATURE_VDEV_RSP_WAKELOCK
struct vdev_mlme_wakelock vdev_wakelock;
#endif
};
/**

Näytä tiedosto

@@ -25,6 +25,7 @@
#include <include/wlan_psoc_mlme.h>
#include <wlan_psoc_mlme_main.h>
#include <wlan_psoc_mlme_api.h>
#include <target_if_psoc_wake_lock.h>
struct psoc_mlme_obj *mlme_psoc_get_priv(struct wlan_objmgr_psoc *psoc)
{
@@ -69,7 +70,8 @@ static QDF_STATUS mlme_psoc_obj_create_handler(struct wlan_objmgr_psoc *psoc,
goto init_failed;
}
return status;
target_if_wake_lock_init(psoc);
return QDF_STATUS_SUCCESS;
init_failed:
qdf_mem_free(psoc_mlme);
@@ -87,6 +89,7 @@ static QDF_STATUS mlme_psoc_obj_destroy_handler(struct wlan_objmgr_psoc *psoc,
return QDF_STATUS_E_FAILURE;
}
target_if_wake_lock_deinit(psoc);
wlan_objmgr_psoc_component_obj_detach(psoc, WLAN_UMAC_COMP_MLME,
psoc_mlme);

Näytä tiedosto

@@ -31,7 +31,6 @@
#include <wlan_serialization_api.h>
#include <wlan_utility.h>
#include <cdp_txrx_cmn.h>
#include <target_if_vdev_mgr_wake_lock.h>
#include <wlan_lmac_if_def.h>
#include <target_if_vdev_mgr_tx_ops.h>
@@ -113,7 +112,6 @@ static QDF_STATUS mlme_vdev_obj_create_handler(struct wlan_objmgr_vdev *vdev,
(void *)vdev_mlme,
QDF_STATUS_SUCCESS);
target_if_wake_lock_init(vdev);
if (mlme_vdev_ops_ext_hdl_post_create(vdev_mlme) !=
QDF_STATUS_SUCCESS) {
mlme_err("Legacy vdev object post creation failed");
@@ -146,7 +144,6 @@ static QDF_STATUS mlme_vdev_obj_destroy_handler(struct wlan_objmgr_vdev *vdev,
mlme_err(" VDEV is NULL");
return QDF_STATUS_E_FAILURE;
}
target_if_wake_lock_deinit(vdev);
vdev_mlme = wlan_vdev_mlme_get_cmpt_obj(vdev);
if (!vdev_mlme) {

Näytä tiedosto

@@ -225,30 +225,30 @@ tgt_vdev_mgr_ext_tbttoffset_update_handle(uint32_t num_vdevs, bool is_ext)
}
#ifdef FEATURE_VDEV_RSP_WAKELOCK
static struct vdev_mlme_wakelock *
tgt_vdev_mgr_get_wakelock_info(struct wlan_objmgr_vdev *vdev)
static struct psoc_mlme_wakelock *
tgt_psoc_get_wakelock_info(struct wlan_objmgr_psoc *psoc)
{
struct vdev_mlme_obj *vdev_mlme;
struct psoc_mlme_obj *psoc_mlme;
vdev_mlme = wlan_vdev_mlme_get_cmpt_obj(vdev);
if (!vdev_mlme) {
mlme_err("VDEV_%d: VDEV_MLME is NULL", wlan_vdev_get_id(vdev));
psoc_mlme = mlme_psoc_get_priv(psoc);
if (!psoc_mlme) {
mlme_err("VDEV_%d: VDEV_MLME is NULL", wlan_vdev_get_id(psoc));
return NULL;
}
return &vdev_mlme->vdev_wakelock;
return &psoc_mlme->psoc_wakelock;
}
static inline void
tgt_vdev_mgr_reg_wakelock_info_rx_op(struct wlan_lmac_if_mlme_rx_ops
tgt_psoc_reg_wakelock_info_rx_op(struct wlan_lmac_if_mlme_rx_ops
*mlme_rx_ops)
{
mlme_rx_ops->vdev_mgr_get_wakelock_info =
tgt_vdev_mgr_get_wakelock_info;
mlme_rx_ops->psoc_get_wakelock_info =
tgt_psoc_get_wakelock_info;
}
#else
static inline void
tgt_vdev_mgr_reg_wakelock_info_rx_op(struct wlan_lmac_if_mlme_rx_ops
tgt_psoc_reg_wakelock_info_rx_op(struct wlan_lmac_if_mlme_rx_ops
*mlme_rx_ops)
{
}
@@ -272,5 +272,5 @@ void tgt_vdev_mgr_register_rx_ops(struct wlan_lmac_if_rx_ops *rx_ops)
tgt_vdev_mgr_peer_delete_all_response_handler;
mlme_rx_ops->psoc_get_vdev_response_timer_info =
tgt_vdev_mgr_get_response_timer_info;
tgt_vdev_mgr_reg_wakelock_info_rx_op(&rx_ops->mops);
tgt_psoc_reg_wakelock_info_rx_op(&rx_ops->mops);
}