|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  |  | 
|  | /* Copyright (c) 2018, The Linux Foundation. All rights reserved. | 
|  | * Copyright (C) 2018-2024 Linaro Ltd. | 
|  | */ | 
|  | #ifndef _IPA_QMI_MSG_H_ | 
|  | #define _IPA_QMI_MSG_H_ | 
|  |  | 
|  | /* === Only "ipa_qmi" and "ipa_qmi_msg.c" should include this file === */ | 
|  |  | 
|  | #include <linux/types.h> | 
|  |  | 
|  | #include <linux/soc/qcom/qmi.h> | 
|  |  | 
|  | /* Request/response/indication QMI message ids used for IPA.  Receiving | 
|  | * end issues a response for requests; indications require no response. | 
|  | */ | 
|  | #define IPA_QMI_INDICATION_REGISTER	0x20	/* modem -> AP request */ | 
|  | #define IPA_QMI_INIT_DRIVER		0x21	/* AP -> modem request */ | 
|  | #define IPA_QMI_INIT_COMPLETE		0x22	/* AP -> modem indication */ | 
|  | #define IPA_QMI_DRIVER_INIT_COMPLETE	0x35	/* modem -> AP request */ | 
|  |  | 
|  | /* The maximum size required for message types.  These sizes include | 
|  | * the message data, along with type (1 byte) and length (2 byte) | 
|  | * information for each field.  The qmi_send_*() interfaces require | 
|  | * the message size to be provided. | 
|  | */ | 
|  | #define IPA_QMI_INDICATION_REGISTER_REQ_SZ	20	/* -> server handle */ | 
|  | #define IPA_QMI_INDICATION_REGISTER_RSP_SZ	7	/* <- server handle */ | 
|  | #define IPA_QMI_INIT_DRIVER_REQ_SZ		162	/* client handle -> */ | 
|  | #define IPA_QMI_INIT_DRIVER_RSP_SZ		25	/* client handle <- */ | 
|  | #define IPA_QMI_INIT_COMPLETE_IND_SZ		7	/* <- server handle */ | 
|  | #define IPA_QMI_DRIVER_INIT_COMPLETE_REQ_SZ	4	/* -> server handle */ | 
|  | #define IPA_QMI_DRIVER_INIT_COMPLETE_RSP_SZ	7	/* <- server handle */ | 
|  |  | 
|  | /* Maximum size of messages we expect the AP to receive (max of above) */ | 
|  | #define IPA_QMI_SERVER_MAX_RCV_SZ		8 | 
|  | #define IPA_QMI_CLIENT_MAX_RCV_SZ		25 | 
|  |  | 
|  | /* Request message for the IPA_QMI_INDICATION_REGISTER request */ | 
|  | struct ipa_indication_register_req { | 
|  | u8 master_driver_init_complete_valid; | 
|  | u8 master_driver_init_complete; | 
|  | u8 data_usage_quota_reached_valid; | 
|  | u8 data_usage_quota_reached; | 
|  | u8 ipa_mhi_ready_ind_valid; | 
|  | u8 ipa_mhi_ready_ind; | 
|  | u8 endpoint_desc_ind_valid; | 
|  | u8 endpoint_desc_ind; | 
|  | u8 bw_change_ind_valid; | 
|  | u8 bw_change_ind; | 
|  | }; | 
|  |  | 
|  | /* The response to a IPA_QMI_INDICATION_REGISTER request consists only of | 
|  | * a standard QMI response. | 
|  | */ | 
|  | struct ipa_indication_register_rsp { | 
|  | struct qmi_response_type_v01 rsp; | 
|  | }; | 
|  |  | 
|  | /* Request message for the IPA_QMI_DRIVER_INIT_COMPLETE request */ | 
|  | struct ipa_driver_init_complete_req { | 
|  | u8 status; | 
|  | }; | 
|  |  | 
|  | /* The response to a IPA_QMI_DRIVER_INIT_COMPLETE request consists only | 
|  | * of a standard QMI response. | 
|  | */ | 
|  | struct ipa_driver_init_complete_rsp { | 
|  | struct qmi_response_type_v01 rsp; | 
|  | }; | 
|  |  | 
|  | /* The message for the IPA_QMI_INIT_COMPLETE_IND indication consists | 
|  | * only of a standard QMI response. | 
|  | */ | 
|  | struct ipa_init_complete_ind { | 
|  | struct qmi_response_type_v01 status; | 
|  | }; | 
|  |  | 
|  | /* The AP tells the modem its platform type.  We assume Android. */ | 
|  | enum ipa_platform_type { | 
|  | IPA_QMI_PLATFORM_TYPE_INVALID		= 0x0,	/* Invalid */ | 
|  | IPA_QMI_PLATFORM_TYPE_TN		= 0x1,	/* Data card */ | 
|  | IPA_QMI_PLATFORM_TYPE_LE		= 0x2,	/* Data router */ | 
|  | IPA_QMI_PLATFORM_TYPE_MSM_ANDROID	= 0x3,	/* Android MSM */ | 
|  | IPA_QMI_PLATFORM_TYPE_MSM_WINDOWS	= 0x4,	/* Windows MSM */ | 
|  | IPA_QMI_PLATFORM_TYPE_MSM_QNX_V01	= 0x5,	/* QNX MSM */ | 
|  | }; | 
|  |  | 
|  | /* This defines the start and end offset of a range of memory.  The start | 
|  | * value is a byte offset relative to the start of IPA shared memory.  The | 
|  | * end value is the last addressable unit *within* the range.  Typically | 
|  | * the end value is in units of bytes, however it can also be a maximum | 
|  | * array index value. | 
|  | */ | 
|  | struct ipa_mem_bounds { | 
|  | u32 start; | 
|  | u32 end; | 
|  | }; | 
|  |  | 
|  | /* This defines the location and size of an array.  The start value | 
|  | * is an offset relative to the start of IPA shared memory.  The | 
|  | * size of the array is implied by the number of entries (the entry | 
|  | * size is assumed to be known). | 
|  | */ | 
|  | struct ipa_mem_array { | 
|  | u32 start; | 
|  | u32 count; | 
|  | }; | 
|  |  | 
|  | /* This defines the location and size of a range of memory.  The | 
|  | * start is an offset relative to the start of IPA shared memory. | 
|  | * This differs from the ipa_mem_bounds structure in that the size | 
|  | * (in bytes) of the memory region is specified rather than the | 
|  | * offset of its last byte. | 
|  | */ | 
|  | struct ipa_mem_range { | 
|  | u32 start; | 
|  | u32 size; | 
|  | }; | 
|  |  | 
|  | /* The message for the IPA_QMI_INIT_DRIVER request contains information | 
|  | * from the AP that affects modem initialization. | 
|  | */ | 
|  | struct ipa_init_modem_driver_req { | 
|  | u8			platform_type_valid; | 
|  | u32			platform_type;	/* enum ipa_platform_type */ | 
|  |  | 
|  | /* Modem header table information.  This defines the IPA shared | 
|  | * memory in which the modem may insert header table entries. | 
|  | */ | 
|  | u8			hdr_tbl_info_valid; | 
|  | struct ipa_mem_bounds	hdr_tbl_info; | 
|  |  | 
|  | /* Routing table information.  These define the location and maximum | 
|  | * *index* (not byte) for the modem portion of non-hashable IPv4 and | 
|  | * IPv6 routing tables.  The start values are byte offsets relative | 
|  | * to the start of IPA shared memory. | 
|  | */ | 
|  | u8			v4_route_tbl_info_valid; | 
|  | struct ipa_mem_bounds	v4_route_tbl_info; | 
|  | u8			v6_route_tbl_info_valid; | 
|  | struct ipa_mem_bounds	v6_route_tbl_info; | 
|  |  | 
|  | /* Filter table information.  These define the location of the | 
|  | * non-hashable IPv4 and IPv6 filter tables.  The start values are | 
|  | * byte offsets relative to the start of IPA shared memory. | 
|  | */ | 
|  | u8			v4_filter_tbl_start_valid; | 
|  | u32			v4_filter_tbl_start; | 
|  | u8			v6_filter_tbl_start_valid; | 
|  | u32			v6_filter_tbl_start; | 
|  |  | 
|  | /* Modem memory information.  This defines the location and | 
|  | * size of memory available for the modem to use. | 
|  | */ | 
|  | u8			modem_mem_info_valid; | 
|  | struct ipa_mem_range	modem_mem_info; | 
|  |  | 
|  | /* This defines the destination endpoint on the AP to which | 
|  | * the modem driver can send control commands.  Must be less | 
|  | * than ipa_endpoint_max(). | 
|  | */ | 
|  | u8			ctrl_comm_dest_end_pt_valid; | 
|  | u32			ctrl_comm_dest_end_pt; | 
|  |  | 
|  | /* This defines whether the modem should load the microcontroller | 
|  | * or not.  It is unnecessary to reload it if the modem is being | 
|  | * restarted. | 
|  | * | 
|  | * NOTE: this field is named "is_ssr_bootup" elsewhere. | 
|  | */ | 
|  | u8			skip_uc_load_valid; | 
|  | u8			skip_uc_load; | 
|  |  | 
|  | /* Processing context memory information.  This defines the memory in | 
|  | * which the modem may insert header processing context table entries. | 
|  | */ | 
|  | u8			hdr_proc_ctx_tbl_info_valid; | 
|  | struct ipa_mem_bounds	hdr_proc_ctx_tbl_info; | 
|  |  | 
|  | /* Compression command memory information.  This defines the memory | 
|  | * in which the modem may insert compression/decompression commands. | 
|  | */ | 
|  | u8			zip_tbl_info_valid; | 
|  | struct ipa_mem_bounds	zip_tbl_info; | 
|  |  | 
|  | /* Routing table information.  These define the location and maximum | 
|  | * *index* (not byte) for the modem portion of hashable IPv4 and IPv6 | 
|  | * routing tables (if supported by hardware).  The start values are | 
|  | * byte offsets relative to the start of IPA shared memory. | 
|  | */ | 
|  | u8			v4_hash_route_tbl_info_valid; | 
|  | struct ipa_mem_bounds	v4_hash_route_tbl_info; | 
|  | u8			v6_hash_route_tbl_info_valid; | 
|  | struct ipa_mem_bounds	v6_hash_route_tbl_info; | 
|  |  | 
|  | /* Filter table information.  These define the location and size | 
|  | * of hashable IPv4 and IPv6 filter tables (if supported by hardware). | 
|  | * The start values are byte offsets relative to the start of IPA | 
|  | * shared memory. | 
|  | */ | 
|  | u8			v4_hash_filter_tbl_start_valid; | 
|  | u32			v4_hash_filter_tbl_start; | 
|  | u8			v6_hash_filter_tbl_start_valid; | 
|  | u32			v6_hash_filter_tbl_start; | 
|  |  | 
|  | /* Statistics information.  These define the locations of the | 
|  | * first and last statistics sub-regions.  (IPA v4.0 and above) | 
|  | */ | 
|  | u8			hw_stats_quota_base_addr_valid; | 
|  | u32			hw_stats_quota_base_addr; | 
|  | u8			hw_stats_quota_size_valid; | 
|  | u32			hw_stats_quota_size; | 
|  | u8			hw_stats_drop_base_addr_valid; | 
|  | u32			hw_stats_drop_base_addr; | 
|  | u8			hw_stats_drop_size_valid; | 
|  | u32			hw_stats_drop_size; | 
|  | }; | 
|  |  | 
|  | /* The response to a IPA_QMI_INIT_DRIVER request begins with a standard | 
|  | * QMI response, but contains other information as well.  Currently we | 
|  | * simply wait for the INIT_DRIVER transaction to complete and | 
|  | * ignore any other data that might be returned. | 
|  | */ | 
|  | struct ipa_init_modem_driver_rsp { | 
|  | struct qmi_response_type_v01	rsp; | 
|  |  | 
|  | /* This defines the destination endpoint on the modem to which | 
|  | * the AP driver can send control commands.  Must be less than | 
|  | * ipa_endpoint_max(). | 
|  | */ | 
|  | u8				ctrl_comm_dest_end_pt_valid; | 
|  | u32				ctrl_comm_dest_end_pt; | 
|  |  | 
|  | /* This defines the default endpoint.  The AP driver is not | 
|  | * required to configure the hardware with this value.  Must | 
|  | * be less than ipa_endpoint_max(). | 
|  | */ | 
|  | u8				default_end_pt_valid; | 
|  | u32				default_end_pt; | 
|  |  | 
|  | /* This defines whether a second handshake is required to complete | 
|  | * initialization. | 
|  | */ | 
|  | u8				modem_driver_init_pending_valid; | 
|  | u8				modem_driver_init_pending; | 
|  | }; | 
|  |  | 
|  | /* Message structure definitions defined in "ipa_qmi_msg.c" */ | 
|  | extern const struct qmi_elem_info ipa_indication_register_req_ei[]; | 
|  | extern const struct qmi_elem_info ipa_indication_register_rsp_ei[]; | 
|  | extern const struct qmi_elem_info ipa_driver_init_complete_req_ei[]; | 
|  | extern const struct qmi_elem_info ipa_driver_init_complete_rsp_ei[]; | 
|  | extern const struct qmi_elem_info ipa_init_complete_ind_ei[]; | 
|  | extern const struct qmi_elem_info ipa_mem_bounds_ei[]; | 
|  | extern const struct qmi_elem_info ipa_mem_array_ei[]; | 
|  | extern const struct qmi_elem_info ipa_mem_range_ei[]; | 
|  | extern const struct qmi_elem_info ipa_init_modem_driver_req_ei[]; | 
|  | extern const struct qmi_elem_info ipa_init_modem_driver_rsp_ei[]; | 
|  |  | 
|  | #endif /* !_IPA_QMI_MSG_H_ */ |