/****************************************************************************** * * Copyright(c) 2019 Realtek Corporation. * * This program is free software; you can redistribute it and/or modify it * under the terms of version 2 of the GNU General Public License as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * *****************************************************************************/ #define _PHL_NOTIFY_C_ #include "phl_headers.h" #ifdef CONFIG_CMD_DISP struct cmd_notify_param { u8 hw_idx; void *hal_cmd; enum phl_msg_evt_id event; }; static void _phl_notify_done(void *drv_priv, u8 *cmd, u32 cmd_len, enum rtw_phl_status status) { if (cmd) { _os_kmem_free(drv_priv, cmd, cmd_len); cmd = NULL; PHL_INFO("%s.....\n", __func__); } } enum rtw_phl_status phl_notify_cmd_hdl(struct phl_info_t *phl_info, u8 *param) { struct cmd_notify_param *cmd_notify = (struct cmd_notify_param *)param; if (cmd_notify->event == MSG_EVT_NOTIFY_BB || cmd_notify->event == MSG_EVT_NOTIFY_RF || cmd_notify->event == MSG_EVT_NOTIFY_MAC) rtw_hal_cmd_notification(phl_info->hal, cmd_notify->event, cmd_notify->hal_cmd, cmd_notify->hw_idx); else rtw_hal_notification(phl_info->hal, cmd_notify->event, cmd_notify->hw_idx); return RTW_PHL_STATUS_SUCCESS; } enum rtw_phl_status rtw_phl_cmd_notify(struct rtw_phl_com_t *phl_com, enum phl_msg_evt_id event, void *hal_cmd, u8 hw_idx) { void *drv = phlcom_to_drvpriv(phl_com); enum rtw_phl_status psts = RTW_PHL_STATUS_FAILURE; struct cmd_notify_param *param = NULL; u32 param_len = 0; param_len = sizeof(struct cmd_notify_param); param = _os_kmem_alloc(drv, param_len); if (param == NULL) { PHL_ERR("%s: alloc param failed!\n", __func__); psts = RTW_PHL_STATUS_RESOURCE; goto error_param; } _os_mem_set(drv, param, 0, param_len); param->event = event; param->hw_idx = hw_idx; param->hal_cmd = hal_cmd; psts = phl_cmd_enqueue(phl_com->phl_priv, hw_idx, MSG_EVT_NOTIFY_HAL, (u8 *)param, param_len, _phl_notify_done, PHL_CMD_NO_WAIT, 0); if (is_cmd_failure(psts)) { /* Send cmd success, but wait cmd fail*/ psts = RTW_PHL_STATUS_FAILURE; } else if (psts != RTW_PHL_STATUS_SUCCESS) { /* Send cmd fail */ _os_kmem_free(drv, param, param_len); psts = RTW_PHL_STATUS_FAILURE; } error_param: return psts; } #endif /* CONFIG_CMD_DISP */ void rtw_phl_notification(void *phl, enum phl_msg_evt_id event, struct rtw_wifi_role_t *wrole) { struct phl_info_t *phl_info = (struct phl_info_t *)phl; #ifdef CONFIG_CMD_DISP rtw_phl_cmd_notify(phl_info->phl_com, event, NULL, wrole->hw_band); #else PHL_TRACE(COMP_PHL_DBG, _PHL_INFO_, "%s: not support cmd notify\n", __func__); rtw_hal_notification(phl_info->hal, event, wrole->hw_band); #endif /* CONFIG_CMD_DISP */ } void rtw_phl_dev_terminate_ntf(void *phl) { struct phl_info_t *phl_info = (struct phl_info_t *)phl; SET_STATUS_FLAG(phl_info->phl_com->dev_state, RTW_DEV_SURPRISE_REMOVAL); phl_disp_eng_notify_shall_stop(phl_info); rtw_hal_notification(phl_info->hal, MSG_EVT_SURPRISE_REMOVE, HW_BAND_MAX); }