diff options
author | Linux Build Service Account <lnxbuild@localhost> | 2020-10-24 01:46:49 -0700 |
---|---|---|
committer | Linux Build Service Account <lnxbuild@localhost> | 2020-10-24 01:46:49 -0700 |
commit | 2e52d37b75df1d06fde12922ecce8ba8046b3cf5 (patch) | |
tree | 0e7da73c6417f266d4cdc90b6757958e096f004f | |
parent | aea9e9a62c17fb77ffcfa6964dc0382592b0875a (diff) | |
parent | 43baab39ba2f2a93038691141dd051b7567067f4 (diff) |
Merge 43baab39ba2f2a93038691141dd051b7567067f4 on remote branchLA.UM.8.12.r1-14400-sm8250.0
Change-Id: I383c1a3f705b9f0f5beff18ad9e8d8377f6ddde9
-rw-r--r-- | drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.c | 45 | ||||
-rw-r--r-- | drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.h | 227 | ||||
-rw-r--r-- | drivers/soc/qcom/icnss.c | 12 | ||||
-rw-r--r-- | drivers/soc/qcom/icnss2/main.c | 49 | ||||
-rw-r--r-- | drivers/soc/qcom/icnss2/main.h | 7 | ||||
-rw-r--r-- | drivers/soc/qcom/icnss2/qmi.c | 60 | ||||
-rw-r--r-- | drivers/soc/qcom/icnss2/qmi.h | 6 | ||||
-rw-r--r-- | drivers/usb/dwc3/gadget.c | 27 | ||||
-rw-r--r-- | drivers/usb/dwc3/gadget.h | 2 | ||||
-rw-r--r-- | drivers/usb/pd/policy_engine.c | 27 |
10 files changed, 256 insertions, 206 deletions
diff --git a/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.c b/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.c index 5caf7ffea1eb..bda8d11c05c6 100644 --- a/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.c +++ b/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.c @@ -1444,6 +1444,24 @@ struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[] = { fw_caps), }, { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x1B, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + rd_card_chain_cap_valid), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_rd_card_chain_cap_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x1B, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + rd_card_chain_cap), + }, + { .data_type = QMI_EOTI, .array_type = NO_ARRAY, .tlv_type = QMI_COMMON_TLV_TYPE, @@ -4343,7 +4361,25 @@ struct qmi_elem_info wlfw_soc_wake_resp_msg_v01_ei[] = { }, }; -struct qmi_elem_info wlfw_exit_power_save_req_msg_v01_ei[] = { +struct qmi_elem_info wlfw_power_save_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_power_save_req_msg_v01, + power_save_mode_valid), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_power_save_mode_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_power_save_req_msg_v01, + power_save_mode), + }, { .data_type = QMI_EOTI, .array_type = NO_ARRAY, @@ -4351,21 +4387,20 @@ struct qmi_elem_info wlfw_exit_power_save_req_msg_v01_ei[] = { }, }; -struct qmi_elem_info wlfw_exit_power_save_resp_msg_v01_ei[] = { +struct qmi_elem_info wlfw_power_save_resp_msg_v01_ei[] = { { .data_type = QMI_STRUCT, .elem_len = 1, .elem_size = sizeof(struct qmi_response_type_v01), .array_type = NO_ARRAY, .tlv_type = 0x02, - .offset = offsetof(struct - wlfw_exit_power_save_resp_msg_v01, + .offset = offsetof(struct wlfw_power_save_resp_msg_v01, resp), .ei_array = qmi_response_type_v01_ei, }, { .data_type = QMI_EOTI, - .array_type = NO_ARRAY, + .array_type = NO_ARRAY, .tlv_type = QMI_COMMON_TLV_TYPE, }, }; diff --git a/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.h b/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.h index 76cf12933cfc..aac8403d11c3 100644 --- a/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.h +++ b/drivers/net/wireless/cnss_utils/wlan_firmware_service_v01.h @@ -9,91 +9,95 @@ #define WLFW_SERVICE_ID_V01 0x45 #define WLFW_SERVICE_VERS_V01 0x01 -#define QMI_WLFW_WFC_CALL_STATUS_REQ_V01 0x0049 -#define QMI_WLFW_DEVICE_INFO_RESP_V01 0x004C -#define QMI_WLFW_BDF_DOWNLOAD_REQ_V01 0x0025 -#define QMI_WLFW_FW_MEM_READY_IND_V01 0x0037 -#define QMI_WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_REQ_V01 0x0044 -#define QMI_WLFW_GET_INFO_REQ_V01 0x004A -#define QMI_WLFW_INITIATE_CAL_UPDATE_IND_V01 0x002A -#define QMI_WLFW_CAL_DONE_IND_V01 0x003E -#define QMI_WLFW_M3_DUMP_UPLOAD_REQ_IND_V01 0x004D -#define QMI_WLFW_WFC_CALL_STATUS_RESP_V01 0x0049 -#define QMI_WLFW_HOST_CAP_REQ_V01 0x0034 -#define QMI_WLFW_DYNAMIC_FEATURE_MASK_RESP_V01 0x003B -#define QMI_WLFW_M3_INFO_REQ_V01 0x003C +#define QMI_WLFW_POWER_SAVE_RESP_V01 0x0050 #define QMI_WLFW_CAP_REQ_V01 0x0024 -#define QMI_WLFW_FW_INIT_DONE_IND_V01 0x0038 -#define QMI_WLFW_ANTENNA_GRANT_RESP_V01 0x0048 #define QMI_WLFW_CAL_REPORT_REQ_V01 0x0026 -#define QMI_WLFW_RESPOND_GET_INFO_IND_V01 0x004B #define QMI_WLFW_M3_INFO_RESP_V01 0x003C -#define QMI_WLFW_CAL_UPDATE_RESP_V01 0x0029 -#define QMI_WLFW_M3_DUMP_UPLOAD_DONE_RESP_V01 0x004E -#define QMI_WLFW_CAL_DOWNLOAD_RESP_V01 0x0027 -#define QMI_WLFW_XO_CAL_IND_V01 0x003D -#define QMI_WLFW_INI_RESP_V01 0x002F #define QMI_WLFW_CAL_REPORT_RESP_V01 0x0026 -#define QMI_WLFW_QDSS_TRACE_MEM_INFO_REQ_V01 0x0040 -#define QMI_WLFW_ANTENNA_SWITCH_REQ_V01 0x0047 -#define QMI_WLFW_QDSS_TRACE_REQ_MEM_IND_V01 0x003F -#define QMI_WLFW_SHUTDOWN_RESP_V01 0x0043 #define QMI_WLFW_MAC_ADDR_RESP_V01 0x0033 -#define QMI_WLFW_INITIATE_CAL_DOWNLOAD_IND_V01 0x0028 +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_RESP_V01 0x003B +#define QMI_WLFW_IND_REGISTER_REQ_V01 0x0020 +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_REQ_V01 0x003B +#define QMI_WLFW_QDSS_TRACE_MODE_RESP_V01 0x0045 +#define QMI_WLFW_FW_READY_IND_V01 0x0021 +#define QMI_WLFW_QDSS_TRACE_MEM_INFO_RESP_V01 0x0040 +#define QMI_WLFW_CAL_UPDATE_REQ_V01 0x0029 +#define QMI_WLFW_REQUEST_MEM_IND_V01 0x0035 +#define QMI_WLFW_QDSS_TRACE_DATA_RESP_V01 0x0042 +#define QMI_WLFW_RESPOND_MEM_RESP_V01 0x0036 +#define QMI_WLFW_VBATT_RESP_V01 0x0032 +#define QMI_WLFW_QDSS_TRACE_MODE_REQ_V01 0x0045 +#define QMI_WLFW_CAL_DOWNLOAD_REQ_V01 0x0027 +#define QMI_WLFW_IND_REGISTER_RESP_V01 0x0020 +#define QMI_WLFW_CAL_UPDATE_RESP_V01 0x0029 +#define QMI_WLFW_M3_INFO_REQ_V01 0x003C +#define QMI_WLFW_PCIE_GEN_SWITCH_REQ_V01 0x0053 +#define QMI_WLFW_ANTENNA_GRANT_RESP_V01 0x0048 +#define QMI_WLFW_INITIATE_CAL_UPDATE_IND_V01 0x002A +#define QMI_WLFW_RESPOND_MEM_REQ_V01 0x0036 #define QMI_WLFW_HOST_CAP_RESP_V01 0x0034 #define QMI_WLFW_MSA_READY_IND_V01 0x002B -#define QMI_WLFW_ATHDIAG_WRITE_RESP_V01 0x0031 -#define QMI_WLFW_EXIT_POWER_SAVE_REQ_V01 0x0050 #define QMI_WLFW_WLAN_MODE_REQ_V01 0x0022 -#define QMI_WLFW_IND_REGISTER_REQ_V01 0x0020 #define QMI_WLFW_WLAN_CFG_RESP_V01 0x0023 -#define QMI_WLFW_QDSS_TRACE_MODE_REQ_V01 0x0045 -#define QMI_WLFW_REQUEST_MEM_IND_V01 0x0035 -#define QMI_WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_RESP_V01 0x0044 -#define QMI_WLFW_SOC_WAKE_RESP_V01 0x004F #define QMI_WLFW_REJUVENATE_IND_V01 0x0039 -#define QMI_WLFW_DYNAMIC_FEATURE_MASK_REQ_V01 0x003B #define QMI_WLFW_ATHDIAG_WRITE_REQ_V01 0x0031 -#define QMI_WLFW_WLAN_MODE_RESP_V01 0x0022 -#define QMI_WLFW_RESPOND_MEM_REQ_V01 0x0036 -#define QMI_WLFW_GET_INFO_RESP_V01 0x004A -#define QMI_WLFW_QDSS_TRACE_MODE_RESP_V01 0x0045 +#define QMI_WLFW_SOC_WAKE_REQ_V01 0x004F #define QMI_WLFW_PIN_CONNECT_RESULT_IND_V01 0x002C -#define QMI_WLFW_FW_READY_IND_V01 0x0021 +#define QMI_WLFW_M3_DUMP_UPLOAD_DONE_RESP_V01 0x004E #define QMI_WLFW_QDSS_TRACE_SAVE_IND_V01 0x0041 -#define QMI_WLFW_QDSS_TRACE_MEM_INFO_RESP_V01 0x0040 -#define QMI_WLFW_ANTENNA_GRANT_REQ_V01 0x0048 -#define QMI_WLFW_MSA_READY_RESP_V01 0x002E -#define QMI_WLFW_QDSS_TRACE_DATA_REQ_V01 0x0042 -#define QMI_WLFW_CAL_UPDATE_REQ_V01 0x0029 -#define QMI_WLFW_INI_REQ_V01 0x002F #define QMI_WLFW_BDF_DOWNLOAD_RESP_V01 0x0025 #define QMI_WLFW_REJUVENATE_ACK_RESP_V01 0x003A #define QMI_WLFW_MSA_INFO_RESP_V01 0x002D +#define QMI_WLFW_SHUTDOWN_REQ_V01 0x0043 +#define QMI_WLFW_VBATT_REQ_V01 0x0032 +#define QMI_WLFW_MAC_ADDR_REQ_V01 0x0033 +#define QMI_WLFW_WLAN_CFG_REQ_V01 0x0023 +#define QMI_WLFW_ANTENNA_GRANT_REQ_V01 0x0048 +#define QMI_WLFW_BDF_DOWNLOAD_REQ_V01 0x0025 +#define QMI_WLFW_FW_MEM_READY_IND_V01 0x0037 +#define QMI_WLFW_RESPOND_GET_INFO_IND_V01 0x004B +#define QMI_WLFW_QDSS_TRACE_DATA_REQ_V01 0x0042 +#define QMI_WLFW_CAL_DOWNLOAD_RESP_V01 0x0027 +#define QMI_WLFW_INI_RESP_V01 0x002F +#define QMI_WLFW_QDSS_TRACE_MEM_INFO_REQ_V01 0x0040 +#define QMI_WLFW_ANTENNA_SWITCH_REQ_V01 0x0047 +#define QMI_WLFW_QDSS_TRACE_REQ_MEM_IND_V01 0x003F +#define QMI_WLFW_INITIATE_CAL_DOWNLOAD_IND_V01 0x0028 +#define QMI_WLFW_ATHDIAG_WRITE_RESP_V01 0x0031 +#define QMI_WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_RESP_V01 0x0044 +#define QMI_WLFW_SOC_WAKE_RESP_V01 0x004F +#define QMI_WLFW_GET_INFO_RESP_V01 0x004A +#define QMI_WLFW_PCIE_GEN_SWITCH_RESP_V01 0x0053 +#define QMI_WLFW_INI_REQ_V01 0x002F #define QMI_WLFW_MSA_READY_REQ_V01 0x002E -#define QMI_WLFW_QDSS_TRACE_DATA_RESP_V01 0x0042 #define QMI_WLFW_M3_DUMP_UPLOAD_DONE_REQ_V01 0x004E #define QMI_WLFW_CAP_RESP_V01 0x0024 -#define QMI_WLFW_SOC_WAKE_REQ_V01 0x004F #define QMI_WLFW_REJUVENATE_ACK_REQ_V01 0x003A #define QMI_WLFW_ATHDIAG_READ_RESP_V01 0x0030 -#define QMI_WLFW_SHUTDOWN_REQ_V01 0x0043 -#define QMI_WLFW_VBATT_REQ_V01 0x0032 #define QMI_WLFW_ANTENNA_SWITCH_RESP_V01 0x0047 #define QMI_WLFW_DEVICE_INFO_REQ_V01 0x004C -#define QMI_WLFW_MAC_ADDR_REQ_V01 0x0033 -#define QMI_WLFW_EXIT_POWER_SAVE_RESP_V01 0x0050 -#define QMI_WLFW_RESPOND_MEM_RESP_V01 0x0036 -#define QMI_WLFW_WFC_CALL_TWT_CONFIG_IND_V01 0x0051 -#define QMI_WLFW_VBATT_RESP_V01 0x0032 #define QMI_WLFW_MSA_INFO_REQ_V01 0x002D -#define QMI_WLFW_QDSS_TRACE_FREE_IND_V01 0x0046 -#define QMI_WLFW_CAL_DOWNLOAD_REQ_V01 0x0027 +#define QMI_WLFW_HOST_CAP_REQ_V01 0x0034 +#define QMI_WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_REQ_V01 0x0044 +#define QMI_WLFW_GET_INFO_REQ_V01 0x004A +#define QMI_WLFW_CAL_DONE_IND_V01 0x003E +#define QMI_WLFW_M3_DUMP_UPLOAD_REQ_IND_V01 0x004D +#define QMI_WLFW_WFC_CALL_STATUS_RESP_V01 0x0049 +#define QMI_WLFW_FW_INIT_DONE_IND_V01 0x0038 +#define QMI_WLFW_POWER_SAVE_REQ_V01 0x0050 +#define QMI_WLFW_XO_CAL_IND_V01 0x003D +#define QMI_WLFW_SHUTDOWN_RESP_V01 0x0043 #define QMI_WLFW_ATHDIAG_READ_REQ_V01 0x0030 #define QMI_WLFW_WLAN_CFG_REQ_V01 0x0023 #define QMI_WLFW_IND_REGISTER_RESP_V01 0x0020 #define QMI_WLFW_PCIE_GEN_SWITCH_REQ_V01 0x0053 #define QMI_WLFW_PCIE_GEN_SWITCH_RESP_V01 0x0053 +#define QMI_WLFW_WFC_CALL_TWT_CONFIG_IND_V01 0x0051 +#define QMI_WLFW_WLAN_MODE_RESP_V01 0x0022 +#define QMI_WLFW_WFC_CALL_STATUS_REQ_V01 0x0049 +#define QMI_WLFW_DEVICE_INFO_RESP_V01 0x004C +#define QMI_WLFW_MSA_READY_RESP_V01 0x002E +#define QMI_WLFW_QDSS_TRACE_FREE_IND_V01 0x0046 #define QMI_WLFW_QDSS_MEM_READY_IND_V01 0x0052 #define QMI_WLFW_MAX_NUM_MEMORY_REGIONS_V01 2 @@ -201,6 +205,14 @@ enum wlfw_qmi_param_value_v01 { WLFW_QMI_PARAM_VALUE_MAX_VAL_V01 = INT_MAX, }; +enum wlfw_rd_card_chain_cap_v01 { + WLFW_RD_CARD_CHAIN_CAP_MIN_VAL_V01 = INT_MIN, + WLFW_RD_CARD_CHAIN_CAP_UNSPECIFIED_V01 = 0, + WLFW_RD_CARD_CHAIN_CAP_1x1_V01 = 1, + WLFW_RD_CARD_CHAIN_CAP_2x2_V01 = 2, + WLFW_RD_CARD_CHAIN_CAP_MAX_VAL_V01 = INT_MAX, +}; + enum wlfw_pcie_gen_speed_v01 { WLFW_PCIE_GEN_SPEED_MIN_VAL_V01 = INT_MIN, QMI_PCIE_GEN_SPEED_INVALID_V01 = 0, @@ -210,6 +222,13 @@ enum wlfw_pcie_gen_speed_v01 { WLFW_PCIE_GEN_SPEED_MAX_VAL_V01 = INT_MAX, }; +enum wlfw_power_save_mode_v01 { + WLFW_POWER_SAVE_MODE_MIN_VAL_V01 = INT_MIN, + WLFW_POWER_SAVE_ENTER_V01 = 0, + WLFW_POWER_SAVE_EXIT_V01 = 1, + WLFW_POWER_SAVE_MODE_MAX_VAL_V01 = INT_MAX, +}; + #define QMI_WLFW_CE_ATTR_FLAGS_V01 ((u32)0x00) #define QMI_WLFW_CE_ATTR_NO_SNOOP_V01 ((u32)0x01) #define QMI_WLFW_CE_ATTR_BYTE_SWAP_DATA_V01 ((u32)0x02) @@ -361,14 +380,12 @@ struct wlfw_ind_register_resp_msg_v01 { u8 fw_status_valid; u64 fw_status; }; - #define WLFW_IND_REGISTER_RESP_MSG_V01_MAX_MSG_LEN 18 extern struct qmi_elem_info wlfw_ind_register_resp_msg_v01_ei[]; struct wlfw_fw_ready_ind_msg_v01 { char placeholder; }; - #define WLFW_FW_READY_IND_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_fw_ready_ind_msg_v01_ei[]; @@ -378,7 +395,6 @@ struct wlfw_msa_ready_ind_msg_v01 { u8 hang_data_length_valid; u16 hang_data_length; }; - #define WLFW_MSA_READY_IND_MSG_V01_MAX_MSG_LEN 12 extern struct qmi_elem_info wlfw_msa_ready_ind_msg_v01_ei[]; @@ -390,7 +406,6 @@ struct wlfw_pin_connect_result_ind_msg_v01 { u8 rf_pin_result_valid; u32 rf_pin_result; }; - #define WLFW_PIN_CONNECT_RESULT_IND_MSG_V01_MAX_MSG_LEN 21 extern struct qmi_elem_info wlfw_pin_connect_result_ind_msg_v01_ei[]; @@ -399,14 +414,12 @@ struct wlfw_wlan_mode_req_msg_v01 { u8 hw_debug_valid; u8 hw_debug; }; - #define WLFW_WLAN_MODE_REQ_MSG_V01_MAX_MSG_LEN 11 extern struct qmi_elem_info wlfw_wlan_mode_req_msg_v01_ei[]; struct wlfw_wlan_mode_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_WLAN_MODE_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_wlan_mode_resp_msg_v01_ei[]; @@ -433,21 +446,18 @@ struct wlfw_wlan_cfg_req_msg_v01 { u32 msi_cfg_len; struct wlfw_msi_cfg_s_v01 msi_cfg[QMI_WLFW_MAX_NUM_CE_V01]; }; - #define WLFW_WLAN_CFG_REQ_MSG_V01_MAX_MSG_LEN 866 extern struct qmi_elem_info wlfw_wlan_cfg_req_msg_v01_ei[]; struct wlfw_wlan_cfg_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_WLAN_CFG_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_wlan_cfg_resp_msg_v01_ei[]; struct wlfw_cap_req_msg_v01 { char placeholder; }; - #define WLFW_CAP_REQ_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_cap_req_msg_v01_ei[]; @@ -475,9 +485,11 @@ struct wlfw_cap_resp_msg_v01 { u32 eeprom_caldata_read_timeout; u8 fw_caps_valid; u64 fw_caps; + u8 rd_card_chain_cap_valid; + enum wlfw_rd_card_chain_cap_v01 rd_card_chain_cap; }; -#define WLFW_CAP_RESP_MSG_V01_MAX_MSG_LEN 246 +#define WLFW_CAP_RESP_MSG_V01_MAX_MSG_LEN 253 extern struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[]; struct wlfw_bdf_download_req_msg_v01 { @@ -496,7 +508,6 @@ struct wlfw_bdf_download_req_msg_v01 { u8 bdf_type_valid; u8 bdf_type; }; - #define WLFW_BDF_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6182 extern struct qmi_elem_info wlfw_bdf_download_req_msg_v01_ei[]; @@ -517,14 +528,12 @@ struct wlfw_cal_report_req_msg_v01 { u8 cal_remove_supported_valid; u8 cal_remove_supported; }; - #define WLFW_CAL_REPORT_REQ_MSG_V01_MAX_MSG_LEN 32 extern struct qmi_elem_info wlfw_cal_report_req_msg_v01_ei[]; struct wlfw_cal_report_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_CAL_REPORT_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_cal_report_resp_msg_v01_ei[]; @@ -535,7 +544,6 @@ struct wlfw_initiate_cal_download_ind_msg_v01 { u8 cal_data_location_valid; u32 cal_data_location; }; - #define WLFW_INITIATE_CAL_DOWNLOAD_IND_MSG_V01_MAX_MSG_LEN 21 extern struct qmi_elem_info wlfw_initiate_cal_download_ind_msg_v01_ei[]; @@ -555,14 +563,12 @@ struct wlfw_cal_download_req_msg_v01 { u8 cal_data_location_valid; u32 cal_data_location; }; - #define WLFW_CAL_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6185 extern struct qmi_elem_info wlfw_cal_download_req_msg_v01_ei[]; struct wlfw_cal_download_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_CAL_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_cal_download_resp_msg_v01_ei[]; @@ -572,7 +578,6 @@ struct wlfw_initiate_cal_update_ind_msg_v01 { u8 cal_data_location_valid; u32 cal_data_location; }; - #define WLFW_INITIATE_CAL_UPDATE_IND_MSG_V01_MAX_MSG_LEN 21 extern struct qmi_elem_info wlfw_initiate_cal_update_ind_msg_v01_ei[]; @@ -580,7 +585,6 @@ struct wlfw_cal_update_req_msg_v01 { enum wlfw_cal_temp_id_enum_v01 cal_id; u32 seg_id; }; - #define WLFW_CAL_UPDATE_REQ_MSG_V01_MAX_MSG_LEN 14 extern struct qmi_elem_info wlfw_cal_update_req_msg_v01_ei[]; @@ -600,7 +604,6 @@ struct wlfw_cal_update_resp_msg_v01 { u8 cal_data_location_valid; u32 cal_data_location; }; - #define WLFW_CAL_UPDATE_RESP_MSG_V01_MAX_MSG_LEN 6188 extern struct qmi_elem_info wlfw_cal_update_resp_msg_v01_ei[]; @@ -608,7 +611,6 @@ struct wlfw_msa_info_req_msg_v01 { u64 msa_addr; u32 size; }; - #define WLFW_MSA_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 extern struct qmi_elem_info wlfw_msa_info_req_msg_v01_ei[]; @@ -618,21 +620,18 @@ struct wlfw_msa_info_resp_msg_v01 { struct wlfw_memory_region_info_s_v01 mem_region_info[QMI_WLFW_MAX_NUM_MEMORY_REGIONS_V01]; }; - #define WLFW_MSA_INFO_RESP_MSG_V01_MAX_MSG_LEN 37 extern struct qmi_elem_info wlfw_msa_info_resp_msg_v01_ei[]; struct wlfw_msa_ready_req_msg_v01 { char placeholder; }; - #define WLFW_MSA_READY_REQ_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_msa_ready_req_msg_v01_ei[]; struct wlfw_msa_ready_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_MSA_READY_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_msa_ready_resp_msg_v01_ei[]; @@ -640,14 +639,12 @@ struct wlfw_ini_req_msg_v01 { u8 enablefwlog_valid; u8 enablefwlog; }; - #define WLFW_INI_REQ_MSG_V01_MAX_MSG_LEN 4 extern struct qmi_elem_info wlfw_ini_req_msg_v01_ei[]; struct wlfw_ini_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_INI_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_ini_resp_msg_v01_ei[]; @@ -656,7 +653,6 @@ struct wlfw_athdiag_read_req_msg_v01 { u32 mem_type; u32 data_len; }; - #define WLFW_ATHDIAG_READ_REQ_MSG_V01_MAX_MSG_LEN 21 extern struct qmi_elem_info wlfw_athdiag_read_req_msg_v01_ei[]; @@ -666,7 +662,6 @@ struct wlfw_athdiag_read_resp_msg_v01 { u32 data_len; u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; }; - #define WLFW_ATHDIAG_READ_RESP_MSG_V01_MAX_MSG_LEN 6156 extern struct qmi_elem_info wlfw_athdiag_read_resp_msg_v01_ei[]; @@ -676,28 +671,24 @@ struct wlfw_athdiag_write_req_msg_v01 { u32 data_len; u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; }; - #define WLFW_ATHDIAG_WRITE_REQ_MSG_V01_MAX_MSG_LEN 6163 extern struct qmi_elem_info wlfw_athdiag_write_req_msg_v01_ei[]; struct wlfw_athdiag_write_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_ATHDIAG_WRITE_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_athdiag_write_resp_msg_v01_ei[]; struct wlfw_vbatt_req_msg_v01 { u64 voltage_uv; }; - #define WLFW_VBATT_REQ_MSG_V01_MAX_MSG_LEN 11 extern struct qmi_elem_info wlfw_vbatt_req_msg_v01_ei[]; struct wlfw_vbatt_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_VBATT_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_vbatt_resp_msg_v01_ei[]; @@ -705,14 +696,12 @@ struct wlfw_mac_addr_req_msg_v01 { u8 mac_addr_valid; u8 mac_addr[QMI_WLFW_MAC_ADDR_SIZE_V01]; }; - #define WLFW_MAC_ADDR_REQ_MSG_V01_MAX_MSG_LEN 9 extern struct qmi_elem_info wlfw_mac_addr_req_msg_v01_ei[]; struct wlfw_mac_addr_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_MAC_ADDR_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_mac_addr_resp_msg_v01_ei[]; @@ -754,14 +743,12 @@ struct wlfw_host_cap_req_msg_v01 { u8 host_build_type_valid; enum wlfw_host_build_type_v01 host_build_type; }; - #define WLFW_HOST_CAP_REQ_MSG_V01_MAX_MSG_LEN 319 extern struct qmi_elem_info wlfw_host_cap_req_msg_v01_ei[]; struct wlfw_host_cap_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_HOST_CAP_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_host_cap_resp_msg_v01_ei[]; @@ -769,7 +756,6 @@ struct wlfw_request_mem_ind_msg_v01 { u32 mem_seg_len; struct wlfw_mem_seg_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; }; - #define WLFW_REQUEST_MEM_IND_MSG_V01_MAX_MSG_LEN 1124 extern struct qmi_elem_info wlfw_request_mem_ind_msg_v01_ei[]; @@ -777,28 +763,24 @@ struct wlfw_respond_mem_req_msg_v01 { u32 mem_seg_len; struct wlfw_mem_seg_resp_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; }; - #define WLFW_RESPOND_MEM_REQ_MSG_V01_MAX_MSG_LEN 548 extern struct qmi_elem_info wlfw_respond_mem_req_msg_v01_ei[]; struct wlfw_respond_mem_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_RESPOND_MEM_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_respond_mem_resp_msg_v01_ei[]; struct wlfw_fw_mem_ready_ind_msg_v01 { char placeholder; }; - #define WLFW_FW_MEM_READY_IND_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_fw_mem_ready_ind_msg_v01_ei[]; struct wlfw_fw_init_done_ind_msg_v01 { char placeholder; }; - #define WLFW_FW_INIT_DONE_IND_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_fw_init_done_ind_msg_v01_ei[]; @@ -812,21 +794,18 @@ struct wlfw_rejuvenate_ind_msg_v01 { u8 function_name_valid; char function_name[QMI_WLFW_FUNCTION_NAME_LEN_V01 + 1]; }; - #define WLFW_REJUVENATE_IND_MSG_V01_MAX_MSG_LEN 144 extern struct qmi_elem_info wlfw_rejuvenate_ind_msg_v01_ei[]; struct wlfw_rejuvenate_ack_req_msg_v01 { char placeholder; }; - #define WLFW_REJUVENATE_ACK_REQ_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_rejuvenate_ack_req_msg_v01_ei[]; struct wlfw_rejuvenate_ack_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_REJUVENATE_ACK_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_rejuvenate_ack_resp_msg_v01_ei[]; @@ -834,7 +813,6 @@ struct wlfw_dynamic_feature_mask_req_msg_v01 { u8 mask_valid; u64 mask; }; - #define WLFW_DYNAMIC_FEATURE_MASK_REQ_MSG_V01_MAX_MSG_LEN 11 extern struct qmi_elem_info wlfw_dynamic_feature_mask_req_msg_v01_ei[]; @@ -845,7 +823,6 @@ struct wlfw_dynamic_feature_mask_resp_msg_v01 { u8 curr_mask_valid; u64 curr_mask; }; - #define WLFW_DYNAMIC_FEATURE_MASK_RESP_MSG_V01_MAX_MSG_LEN 29 extern struct qmi_elem_info wlfw_dynamic_feature_mask_resp_msg_v01_ei[]; @@ -853,28 +830,24 @@ struct wlfw_m3_info_req_msg_v01 { u64 addr; u32 size; }; - #define WLFW_M3_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 extern struct qmi_elem_info wlfw_m3_info_req_msg_v01_ei[]; struct wlfw_m3_info_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_M3_INFO_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_m3_info_resp_msg_v01_ei[]; struct wlfw_xo_cal_ind_msg_v01 { u8 xo_cal_data; }; - #define WLFW_XO_CAL_IND_MSG_V01_MAX_MSG_LEN 4 extern struct qmi_elem_info wlfw_xo_cal_ind_msg_v01_ei[]; struct wlfw_cal_done_ind_msg_v01 { char placeholder; }; - #define WLFW_CAL_DONE_IND_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_cal_done_ind_msg_v01_ei[]; @@ -882,7 +855,6 @@ struct wlfw_qdss_trace_req_mem_ind_msg_v01 { u32 mem_seg_len; struct wlfw_mem_seg_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; }; - #define WLFW_QDSS_TRACE_REQ_MEM_IND_MSG_V01_MAX_MSG_LEN 1124 extern struct qmi_elem_info wlfw_qdss_trace_req_mem_ind_msg_v01_ei[]; @@ -890,14 +862,12 @@ struct wlfw_qdss_trace_mem_info_req_msg_v01 { u32 mem_seg_len; struct wlfw_mem_seg_resp_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; }; - #define WLFW_QDSS_TRACE_MEM_INFO_REQ_MSG_V01_MAX_MSG_LEN 548 extern struct qmi_elem_info wlfw_qdss_trace_mem_info_req_msg_v01_ei[]; struct wlfw_qdss_trace_mem_info_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_QDSS_TRACE_MEM_INFO_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_qdss_trace_mem_info_resp_msg_v01_ei[]; @@ -910,14 +880,12 @@ struct wlfw_qdss_trace_save_ind_msg_v01 { u8 file_name_valid; char file_name[QMI_WLFW_MAX_STR_LEN_V01 + 1]; }; - #define WLFW_QDSS_TRACE_SAVE_IND_MSG_V01_MAX_MSG_LEN 581 extern struct qmi_elem_info wlfw_qdss_trace_save_ind_msg_v01_ei[]; struct wlfw_qdss_trace_data_req_msg_v01 { u32 seg_id; }; - #define WLFW_QDSS_TRACE_DATA_REQ_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_qdss_trace_data_req_msg_v01_ei[]; @@ -933,7 +901,6 @@ struct wlfw_qdss_trace_data_resp_msg_v01 { u8 end_valid; u8 end; }; - #define WLFW_QDSS_TRACE_DATA_RESP_MSG_V01_MAX_MSG_LEN 6174 extern struct qmi_elem_info wlfw_qdss_trace_data_resp_msg_v01_ei[]; @@ -948,14 +915,12 @@ struct wlfw_qdss_trace_config_download_req_msg_v01 { u8 end_valid; u8 end; }; - #define WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6167 extern struct qmi_elem_info wlfw_qdss_trace_config_download_req_msg_v01_ei[]; struct wlfw_qdss_trace_config_download_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_QDSS_TRACE_CONFIG_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_qdss_trace_config_download_resp_msg_v01_ei[]; @@ -967,14 +932,12 @@ struct wlfw_qdss_trace_mode_req_msg_v01 { u8 hw_trc_disable_override_valid; enum wlfw_qmi_param_value_v01 hw_trc_disable_override; }; - #define WLFW_QDSS_TRACE_MODE_REQ_MSG_V01_MAX_MSG_LEN 25 extern struct qmi_elem_info wlfw_qdss_trace_mode_req_msg_v01_ei[]; struct wlfw_qdss_trace_mode_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_QDSS_TRACE_MODE_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_qdss_trace_mode_resp_msg_v01_ei[]; @@ -983,7 +946,6 @@ struct wlfw_qdss_trace_free_ind_msg_v01 { u32 mem_seg_len; struct wlfw_mem_seg_resp_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; }; - #define WLFW_QDSS_TRACE_FREE_IND_MSG_V01_MAX_MSG_LEN 548 extern struct qmi_elem_info wlfw_qdss_trace_free_ind_msg_v01_ei[]; @@ -991,21 +953,18 @@ struct wlfw_shutdown_req_msg_v01 { u8 shutdown_valid; u8 shutdown; }; - #define WLFW_SHUTDOWN_REQ_MSG_V01_MAX_MSG_LEN 4 extern struct qmi_elem_info wlfw_shutdown_req_msg_v01_ei[]; struct wlfw_shutdown_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_SHUTDOWN_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_shutdown_resp_msg_v01_ei[]; struct wlfw_antenna_switch_req_msg_v01 { char placeholder; }; - #define WLFW_ANTENNA_SWITCH_REQ_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_antenna_switch_req_msg_v01_ei[]; @@ -1014,7 +973,6 @@ struct wlfw_antenna_switch_resp_msg_v01 { u8 antenna_valid; u64 antenna; }; - #define WLFW_ANTENNA_SWITCH_RESP_MSG_V01_MAX_MSG_LEN 18 extern struct qmi_elem_info wlfw_antenna_switch_resp_msg_v01_ei[]; @@ -1022,14 +980,12 @@ struct wlfw_antenna_grant_req_msg_v01 { u8 grant_valid; u64 grant; }; - #define WLFW_ANTENNA_GRANT_REQ_MSG_V01_MAX_MSG_LEN 11 extern struct qmi_elem_info wlfw_antenna_grant_req_msg_v01_ei[]; struct wlfw_antenna_grant_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_ANTENNA_GRANT_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_antenna_grant_resp_msg_v01_ei[]; @@ -1049,14 +1005,12 @@ struct wlfw_wfc_call_status_req_msg_v01 { u8 media_quality_valid; enum wlfw_wfc_media_quality_v01 media_quality; }; - #define WLFW_WFC_CALL_STATUS_REQ_MSG_V01_MAX_MSG_LEN 296 extern struct qmi_elem_info wlfw_wfc_call_status_req_msg_v01_ei[]; struct wlfw_wfc_call_status_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_WFC_CALL_STATUS_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_wfc_call_status_resp_msg_v01_ei[]; @@ -1065,14 +1019,12 @@ struct wlfw_get_info_req_msg_v01 { u32 data_len; u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; }; - #define WLFW_GET_INFO_REQ_MSG_V01_MAX_MSG_LEN 6153 extern struct qmi_elem_info wlfw_get_info_req_msg_v01_ei[]; struct wlfw_get_info_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_GET_INFO_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_get_info_resp_msg_v01_ei[]; @@ -1086,14 +1038,12 @@ struct wlfw_respond_get_info_ind_msg_v01 { u8 seq_no_valid; u32 seq_no; }; - #define WLFW_RESPOND_GET_INFO_IND_MSG_V01_MAX_MSG_LEN 6164 extern struct qmi_elem_info wlfw_respond_get_info_ind_msg_v01_ei[]; struct wlfw_device_info_req_msg_v01 { char placeholder; }; - #define WLFW_DEVICE_INFO_REQ_MSG_V01_MAX_MSG_LEN 0 extern struct qmi_elem_info wlfw_device_info_req_msg_v01_ei[]; @@ -1104,7 +1054,6 @@ struct wlfw_device_info_resp_msg_v01 { u8 bar_size_valid; u32 bar_size; }; - #define WLFW_DEVICE_INFO_RESP_MSG_V01_MAX_MSG_LEN 25 extern struct qmi_elem_info wlfw_device_info_resp_msg_v01_ei[]; @@ -1113,7 +1062,6 @@ struct wlfw_m3_dump_upload_req_ind_msg_v01 { u64 addr; u64 size; }; - #define WLFW_M3_DUMP_UPLOAD_REQ_IND_MSG_V01_MAX_MSG_LEN 29 extern struct qmi_elem_info wlfw_m3_dump_upload_req_ind_msg_v01_ei[]; @@ -1121,14 +1069,12 @@ struct wlfw_m3_dump_upload_done_req_msg_v01 { u32 pdev_id; u32 status; }; - #define WLFW_M3_DUMP_UPLOAD_DONE_REQ_MSG_V01_MAX_MSG_LEN 14 extern struct qmi_elem_info wlfw_m3_dump_upload_done_req_msg_v01_ei[]; struct wlfw_m3_dump_upload_done_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_M3_DUMP_UPLOAD_DONE_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_m3_dump_upload_done_resp_msg_v01_ei[]; @@ -1136,30 +1082,29 @@ struct wlfw_soc_wake_req_msg_v01 { u8 wake_valid; enum wlfw_soc_wake_enum_v01 wake; }; - #define WLFW_SOC_WAKE_REQ_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_soc_wake_req_msg_v01_ei[]; struct wlfw_soc_wake_resp_msg_v01 { struct qmi_response_type_v01 resp; }; - #define WLFW_SOC_WAKE_RESP_MSG_V01_MAX_MSG_LEN 7 extern struct qmi_elem_info wlfw_soc_wake_resp_msg_v01_ei[]; -struct wlfw_exit_power_save_req_msg_v01 { - char placeholder; +struct wlfw_power_save_req_msg_v01 { + u8 power_save_mode_valid; + enum wlfw_power_save_mode_v01 power_save_mode; }; -#define WLFW_EXIT_POWER_SAVE_REQ_MSG_V01_MAX_MSG_LEN 0 -extern struct qmi_elem_info wlfw_exit_power_save_req_msg_v01_ei[]; +#define WLFW_POWER_SAVE_REQ_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_power_save_req_msg_v01_ei[]; -struct wlfw_exit_power_save_resp_msg_v01 { +struct wlfw_power_save_resp_msg_v01 { struct qmi_response_type_v01 resp; }; -#define WLFW_EXIT_POWER_SAVE_RESP_MSG_V01_MAX_MSG_LEN 7 -extern struct qmi_elem_info wlfw_exit_power_save_resp_msg_v01_ei[]; +#define WLFW_POWER_SAVE_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_power_save_resp_msg_v01_ei[]; struct wlfw_wfc_call_twt_config_ind_msg_v01 { u8 twt_sta_start_valid; diff --git a/drivers/soc/qcom/icnss.c b/drivers/soc/qcom/icnss.c index 23b7609503ae..a5387a1b7643 100644 --- a/drivers/soc/qcom/icnss.c +++ b/drivers/soc/qcom/icnss.c @@ -1312,6 +1312,12 @@ static int icnss_driver_event_idle_restart(void *data) if (!penv->ops || !penv->ops->idle_restart) return 0; + if (!test_bit(ICNSS_DRIVER_PROBED, &penv->state) || + test_bit(ICNSS_DRIVER_UNLOADING, &penv->state)) { + icnss_pr_err("Driver unloaded or unloading is in progress, so reject idle restart"); + return -EINVAL; + } + if (penv->is_ssr || test_bit(ICNSS_PDR, &penv->state) || test_bit(ICNSS_REJUVENATE, &penv->state)) { icnss_pr_err("SSR/PDR is already in-progress during idle restart callback\n"); @@ -2335,6 +2341,12 @@ int icnss_idle_restart(struct device *dev) return -EINVAL; } + if (!test_bit(ICNSS_DRIVER_PROBED, &penv->state) || + test_bit(ICNSS_DRIVER_UNLOADING, &penv->state)) { + icnss_pr_err("Driver unloaded or unloading is in progress, so reject idle restart"); + return -EINVAL; + } + if (priv->is_ssr || test_bit(ICNSS_PDR, &priv->state) || test_bit(ICNSS_REJUVENATE, &penv->state)) { icnss_pr_err("SSR/PDR is already in-progress during idle restart\n"); diff --git a/drivers/soc/qcom/icnss2/main.c b/drivers/soc/qcom/icnss2/main.c index 56bfb3570726..017b14d41865 100644 --- a/drivers/soc/qcom/icnss2/main.c +++ b/drivers/soc/qcom/icnss2/main.c @@ -986,17 +986,10 @@ static int icnss_qdss_trace_save_hdlr(struct icnss_priv *priv, static int icnss_event_soc_wake_request(struct icnss_priv *priv, void *data) { int ret = 0; - int count = 0; if (!priv) return -ENODEV; - if (atomic_read(&priv->soc_wake_ref_count)) { - count = atomic_inc_return(&priv->soc_wake_ref_count); - icnss_pr_dbg("SOC already awake, Ref count: %d", count); - return 0; - } - ret = wlfw_send_soc_wake_msg(priv, QMI_WLFW_WAKE_REQUEST_V01); if (!ret) atomic_inc(&priv->soc_wake_ref_count); @@ -2309,6 +2302,7 @@ EXPORT_SYMBOL(icnss_set_fw_log_mode); int icnss_force_wake_request(struct device *dev) { struct icnss_priv *priv = dev_get_drvdata(dev); + int count = 0; if (!dev) return -ENODEV; @@ -2318,6 +2312,12 @@ int icnss_force_wake_request(struct device *dev) return -EINVAL; } + if (atomic_read(&priv->soc_wake_ref_count)) { + count = atomic_inc_return(&priv->soc_wake_ref_count); + icnss_pr_dbg("SOC already awake, Ref count: %d", count); + return 0; + } + icnss_pr_dbg("Calling SOC Wake request"); icnss_soc_wake_event_post(priv, ICNSS_SOC_WAKE_REQUEST_EVENT, @@ -2330,6 +2330,7 @@ EXPORT_SYMBOL(icnss_force_wake_request); int icnss_force_wake_release(struct device *dev) { struct icnss_priv *priv = dev_get_drvdata(dev); + int count = 0; if (!dev) return -ENODEV; @@ -2339,6 +2340,13 @@ int icnss_force_wake_release(struct device *dev) return -EINVAL; } + if (atomic_read(&priv->soc_wake_ref_count) > 1) { + count = atomic_dec_return(&priv->soc_wake_ref_count); + icnss_pr_dbg("SOC previous release pending, Ref count: %d", + count); + return 0; + } + icnss_pr_dbg("Calling SOC Wake response"); icnss_soc_wake_event_post(priv, ICNSS_SOC_WAKE_RELEASE_EVENT, @@ -2672,7 +2680,6 @@ EXPORT_SYMBOL(icnss_idle_restart); int icnss_exit_power_save(struct device *dev) { struct icnss_priv *priv = dev_get_drvdata(dev); - int ret = 0; icnss_pr_dbg("Calling Exit Power Save\n"); @@ -2680,12 +2687,8 @@ int icnss_exit_power_save(struct device *dev) !test_bit(ICNSS_MODE_ON, &priv->state)) return 0; - ret = wlfw_exit_power_save_send_msg(priv); - if (ret) { - priv->stats.pm_resume_err++; - return ret; - } - return 0; + return wlfw_power_save_send_msg(priv, + (enum wlfw_power_save_mode_v01)ICNSS_POWER_SAVE_EXIT); } EXPORT_SYMBOL(icnss_exit_power_save); @@ -3271,12 +3274,18 @@ static int icnss_pm_suspend(struct device *dev) if (!priv->ops || !priv->ops->pm_suspend || !test_bit(ICNSS_DRIVER_PROBED, &priv->state)) - goto out; + return 0; ret = priv->ops->pm_suspend(dev); -out: if (ret == 0) { + if (priv->device_id == WCN6750_DEVICE_ID) { + ret = wlfw_power_save_send_msg(priv, + (enum wlfw_power_save_mode_v01) + ICNSS_POWER_SAVE_ENTER); + if (ret) + return priv->ops->pm_resume(dev); + } priv->stats.pm_suspend++; set_bit(ICNSS_PM_SUSPEND, &priv->state); } else { @@ -3388,7 +3397,13 @@ static int icnss_pm_runtime_suspend(struct device *dev) icnss_pr_vdbg("Runtime suspend\n"); ret = priv->ops->runtime_suspend(dev); - + if (!ret) { + ret = wlfw_power_save_send_msg(priv, + (enum wlfw_power_save_mode_v01) + ICNSS_POWER_SAVE_ENTER); + if (ret) + return priv->ops->runtime_resume(dev); + } out: return ret; } diff --git a/drivers/soc/qcom/icnss2/main.h b/drivers/soc/qcom/icnss2/main.h index 6e4bff30a587..2206a1878cd5 100644 --- a/drivers/soc/qcom/icnss2/main.h +++ b/drivers/soc/qcom/icnss2/main.h @@ -169,6 +169,10 @@ struct icnss_fw_mem { unsigned long attrs; }; +enum icnss_power_save_mode { + ICNSS_POWER_SAVE_ENTER, + ICNSS_POWER_SAVE_EXIT, +}; struct icnss_stats { struct { uint32_t posted; @@ -241,6 +245,9 @@ struct icnss_stats { u32 exit_power_save_req; u32 exit_power_save_resp; u32 exit_power_save_err; + u32 enter_power_save_req; + u32 enter_power_save_resp; + u32 enter_power_save_err; u32 soc_wake_req; u32 soc_wake_resp; u32 soc_wake_err; diff --git a/drivers/soc/qcom/icnss2/qmi.c b/drivers/soc/qcom/icnss2/qmi.c index d053bfcef88c..ed30381e8369 100644 --- a/drivers/soc/qcom/icnss2/qmi.c +++ b/drivers/soc/qcom/icnss2/qmi.c @@ -340,11 +340,11 @@ out: return ret; } -int wlfw_exit_power_save_send_msg(struct icnss_priv *priv) +int wlfw_power_save_send_msg(struct icnss_priv *priv, + enum wlfw_power_save_mode_v01 mode) { int ret; - struct wlfw_exit_power_save_req_msg_v01 *req; - struct wlfw_exit_power_save_resp_msg_v01 *resp; + struct wlfw_power_save_req_msg_v01 *req; struct qmi_txn txn; if (!priv) @@ -353,23 +353,27 @@ int wlfw_exit_power_save_send_msg(struct icnss_priv *priv) if (test_bit(ICNSS_FW_DOWN, &priv->state)) return -EINVAL; - icnss_pr_dbg("Sending exit power save, state: 0x%lx\n", - priv->state); + if (test_bit(ICNSS_PD_RESTART, &priv->state) || + !test_bit(ICNSS_MODE_ON, &priv->state)) + return 0; + + icnss_pr_dbg("Sending power save mode: %d, state: 0x%lx\n", + mode, priv->state); req = kzalloc(sizeof(*req), GFP_KERNEL); if (!req) return -ENOMEM; - resp = kzalloc(sizeof(*resp), GFP_KERNEL); - if (!resp) { - kfree(req); - return -ENOMEM; - } + req->power_save_mode_valid = 1; + req->power_save_mode = mode; - priv->stats.exit_power_save_req++; + if (mode == WLFW_POWER_SAVE_EXIT_V01) + priv->stats.exit_power_save_req++; + else + priv->stats.enter_power_save_req++; ret = qmi_txn_init(&priv->qmi, &txn, - wlfw_exit_power_save_resp_msg_v01_ei, resp); + NULL, NULL); if (ret < 0) { icnss_qmi_fatal_err("Fail to init txn for exit power save%d\n", ret); @@ -377,9 +381,9 @@ int wlfw_exit_power_save_send_msg(struct icnss_priv *priv) } ret = qmi_send_request(&priv->qmi, NULL, &txn, - QMI_WLFW_EXIT_POWER_SAVE_REQ_V01, - WLFW_EXIT_POWER_SAVE_REQ_MSG_V01_MAX_MSG_LEN, - wlfw_exit_power_save_req_msg_v01_ei, req); + QMI_WLFW_POWER_SAVE_REQ_V01, + WLFW_POWER_SAVE_REQ_MSG_V01_MAX_MSG_LEN, + wlfw_power_save_req_msg_v01_ei, req); if (ret < 0) { qmi_txn_cancel(&txn); icnss_qmi_fatal_err("Fail to send exit power save req %d\n", @@ -387,29 +391,23 @@ int wlfw_exit_power_save_send_msg(struct icnss_priv *priv) goto out; } - ret = qmi_txn_wait(&txn, priv->ctrl_params.qmi_timeout); - if (ret < 0) { - icnss_qmi_fatal_err("Exit power save wait failed with ret %d\n", - ret); - goto out; - } else if (resp->resp.result != QMI_RESULT_SUCCESS_V01) { - icnss_qmi_fatal_err( - "QMI exit power save request rejected,result:%d error:%d\n", - resp->resp.result, resp->resp.error); - ret = -resp->resp.result; - goto out; - } + qmi_txn_cancel(&txn); - priv->stats.exit_power_save_resp++; + if (mode == WLFW_POWER_SAVE_EXIT_V01) + priv->stats.exit_power_save_resp++; + else + priv->stats.enter_power_save_resp++; - kfree(resp); kfree(req); return 0; out: - kfree(resp); kfree(req); - priv->stats.exit_power_save_err++; + + if (mode == WLFW_POWER_SAVE_EXIT_V01) + priv->stats.exit_power_save_err++; + else + priv->stats.enter_power_save_err++; return ret; } diff --git a/drivers/soc/qcom/icnss2/qmi.h b/drivers/soc/qcom/icnss2/qmi.h index f4c1d2b263f1..5df52e753302 100644 --- a/drivers/soc/qcom/icnss2/qmi.h +++ b/drivers/soc/qcom/icnss2/qmi.h @@ -129,7 +129,8 @@ int wlfw_qdss_trace_mem_info_send_sync(struct icnss_priv *priv) return 0; } -int wlfw_exit_power_save_send_msg(struct icnss_priv *priv) +int wlfw_power_save_send_msg(struct icnss_priv *priv, + enum wlfw_power_save_mode_v01 mode) { return 0; } @@ -180,7 +181,8 @@ int wlfw_wlan_mode_send_sync_msg(struct icnss_priv *priv, enum wlfw_driver_mode_enum_v01 mode); int icnss_wlfw_bdf_dnld_send_sync(struct icnss_priv *priv, u32 bdf_type); int wlfw_qdss_trace_mem_info_send_sync(struct icnss_priv *priv); -int wlfw_exit_power_save_send_msg(struct icnss_priv *priv); +int wlfw_power_save_send_msg(struct icnss_priv *priv, + enum wlfw_power_save_mode_v01 mode); int icnss_wlfw_get_info_send_sync(struct icnss_priv *priv, int type, void *cmd, int cmd_len); int wlfw_send_soc_wake_msg(struct icnss_priv *priv, diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index de3a9326ac1a..7d34ab366e83 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -901,7 +901,12 @@ static void dwc3_stop_active_transfers_to_halt(struct dwc3 *dwc) if (!(dep->flags & DWC3_EP_ENABLED)) continue; - dwc3_stop_active_transfer_noioc(dwc, dep->number, true); + /* + * If the transfers didn't stop due to some reason + * don't giveback the request to gadget driver. + */ + if (dwc3_stop_active_transfer_noioc(dwc, dep->number, true)) + continue; /* - giveback all requests to gadget driver */ while (!list_empty(&dep->started_list)) { @@ -2248,7 +2253,7 @@ static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) dwc->softconnect = is_on; if ((dwc3_is_otg_or_drd(dwc) && !dwc->vbus_active) - || !dwc->gadget_driver) { + || !dwc->gadget_driver || dwc->err_evt_seen) { /* * Need to wait for vbus_session(on) from otg driver or to * the udc_start. @@ -2310,8 +2315,15 @@ static int dwc3_gadget_pullup(struct usb_gadget *g, int is_on) ret = dwc3_gadget_run_stop(dwc, is_on, false); spin_unlock_irqrestore(&dwc->lock, flags); if (!is_on && ret == -ETIMEDOUT) { - dev_err(dwc->dev, "%s: Core soft reset...\n", __func__); - dwc3_device_core_soft_reset(dwc); + /* + * If we fail to stop the controller then mark it as an error + * event since it can lead the controller to go into an unknown + * state. + */ + dbg_log_string("%s: error event seen\n", __func__); + dwc->err_evt_seen = true; + dwc3_notify_event(dwc, DWC3_CONTROLLER_ERROR_EVENT, 0); + dwc3_notify_event(dwc, DWC3_CONTROLLER_NOTIFY_CLEAR_DB, 0); } enable_irq(dwc->irq); @@ -3226,17 +3238,17 @@ void dwc3_stop_active_transfer(struct dwc3 *dwc, u32 epnum, bool force) dep->name, dep->number, ret); } -void dwc3_stop_active_transfer_noioc(struct dwc3 *dwc, u32 epnum, bool force) +int dwc3_stop_active_transfer_noioc(struct dwc3 *dwc, u32 epnum, bool force) { struct dwc3_ep *dep; struct dwc3_gadget_ep_cmd_params params; u32 cmd; - int ret; + int ret = 0; dep = dwc->eps[epnum]; if (!dep->resource_index) - return; + return ret; if (dep->endpoint.endless) dwc3_notify_event(dwc, DWC3_CONTROLLER_NOTIFY_DISABLE_UPDXFER, @@ -3252,6 +3264,7 @@ void dwc3_stop_active_transfer_noioc(struct dwc3 *dwc, u32 epnum, bool force) dbg_log_string("%s(%d): endxfer ret:%d)", dep->name, dep->number, ret); + return ret; } static void dwc3_clear_stall_all_ep(struct dwc3 *dwc) diff --git a/drivers/usb/dwc3/gadget.h b/drivers/usb/dwc3/gadget.h index aa1ec8ad388f..69d866585c00 100644 --- a/drivers/usb/dwc3/gadget.h +++ b/drivers/usb/dwc3/gadget.h @@ -111,7 +111,7 @@ int dwc3_gadget_ep0_queue(struct usb_ep *ep, struct usb_request *request, gfp_t gfp_flags); int __dwc3_gadget_ep_set_halt(struct dwc3_ep *dep, int value, int protocol); void dwc3_stop_active_transfer(struct dwc3 *dwc, u32 epnum, bool force); -void dwc3_stop_active_transfer_noioc(struct dwc3 *dwc, u32 epnum, bool force); +int dwc3_stop_active_transfer_noioc(struct dwc3 *dwc, u32 epnum, bool force); void dwc3_ep_inc_enq(struct dwc3_ep *dep); void dwc3_ep_inc_deq(struct dwc3_ep *dep); diff --git a/drivers/usb/pd/policy_engine.c b/drivers/usb/pd/policy_engine.c index 07757eabcd43..bf15fb009e8a 100644 --- a/drivers/usb/pd/policy_engine.c +++ b/drivers/usb/pd/policy_engine.c @@ -476,6 +476,7 @@ struct usbpd { u8 get_battery_status_db; bool send_get_battery_status; u32 battery_sts_dobj; + bool typec_analog_audio_connected; }; static LIST_HEAD(_usbpd); /* useful for debugging */ @@ -3551,6 +3552,18 @@ static void usbpd_sm(struct work_struct *w) usbpd_dbg(&pd->dev, "handle state %s\n", usbpd_state_strings[pd->current_state]); + /* Register typec partner in case AAA is connected */ + if (pd->typec_mode == POWER_SUPPLY_TYPEC_SINK_AUDIO_ADAPTER) { + if (!pd->partner) { + memset(&pd->partner_identity, 0, + sizeof(pd->partner_identity)); + pd->partner_desc.usb_pd = false; + pd->partner_desc.accessory = TYPEC_ACCESSORY_AUDIO; + pd->partner = typec_register_partner(pd->typec_port, + &pd->partner_desc); + pd->typec_analog_audio_connected = true; + } + } hrtimer_cancel(&pd->timer); pd->sm_queued = false; @@ -3564,9 +3577,18 @@ static void usbpd_sm(struct work_struct *w) /* Disconnect? */ if (pd->current_pr == PR_NONE) { if (pd->current_state == PE_UNKNOWN && - pd->current_dr == DR_NONE) - goto sm_done; + pd->current_dr == DR_NONE) { + /* + * Since PD stack will not be loaded in case AAA is + * connected, call disconnect to unregister typec + * partner + */ + if (!pd->typec_analog_audio_connected && + pd->partner) + handle_disconnect(pd); + goto sm_done; + } handle_disconnect(pd); goto sm_done; } @@ -3636,6 +3658,7 @@ static int usbpd_process_typec_mode(struct usbpd *pd, } pd->current_pr = PR_NONE; + pd->typec_analog_audio_connected = false; break; /* Sink states */ |