xref: /freebsd-src/sys/compat/linuxkpi/common/include/linux/soc/qcom/qmi.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
106a1103fSBjoern A. Zeeb /*-
206a1103fSBjoern A. Zeeb  * SPDX-License-Identifier: BSD-2-Clause
306a1103fSBjoern A. Zeeb  *
404729820SBjoern A. Zeeb  * Copyright (c) 2022-2023 Bjoern A. Zeeb
506a1103fSBjoern A. Zeeb  *
606a1103fSBjoern A. Zeeb  * Redistribution and use in source and binary forms, with or without
706a1103fSBjoern A. Zeeb  * modification, are permitted provided that the following conditions
806a1103fSBjoern A. Zeeb  * are met:
906a1103fSBjoern A. Zeeb  * 1. Redistributions of source code must retain the above copyright
1006a1103fSBjoern A. Zeeb  *    notice, this list of conditions and the following disclaimer.
1106a1103fSBjoern A. Zeeb  * 2. Redistributions in binary form must reproduce the above copyright
1206a1103fSBjoern A. Zeeb  *    notice, this list of conditions and the following disclaimer in the
1306a1103fSBjoern A. Zeeb  *    documentation and/or other materials provided with the distribution.
1406a1103fSBjoern A. Zeeb  *
1506a1103fSBjoern A. Zeeb  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
1606a1103fSBjoern A. Zeeb  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1706a1103fSBjoern A. Zeeb  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1806a1103fSBjoern A. Zeeb  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
1906a1103fSBjoern A. Zeeb  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2006a1103fSBjoern A. Zeeb  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2106a1103fSBjoern A. Zeeb  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2206a1103fSBjoern A. Zeeb  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2306a1103fSBjoern A. Zeeb  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2406a1103fSBjoern A. Zeeb  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2506a1103fSBjoern A. Zeeb  * SUCH DAMAGE.
2606a1103fSBjoern A. Zeeb  */
2706a1103fSBjoern A. Zeeb 
2806a1103fSBjoern A. Zeeb #ifndef	_LINUXKPI_LINUX_SOC_QCOM_QMI_H
2906a1103fSBjoern A. Zeeb #define	_LINUXKPI_LINUX_SOC_QCOM_QMI_H
3006a1103fSBjoern A. Zeeb 
3106a1103fSBjoern A. Zeeb /* QMI (Qualcomm MSM Interface) */
3206a1103fSBjoern A. Zeeb 
3306a1103fSBjoern A. Zeeb #include <linux/qrtr.h>
3406a1103fSBjoern A. Zeeb 
3506a1103fSBjoern A. Zeeb enum soc_qcom_qmi_data_type {
3606a1103fSBjoern A. Zeeb 	QMI_EOTI,
3706a1103fSBjoern A. Zeeb 	QMI_DATA_LEN,
3806a1103fSBjoern A. Zeeb 	QMI_OPT_FLAG,
3906a1103fSBjoern A. Zeeb 	QMI_UNSIGNED_1_BYTE,
4006a1103fSBjoern A. Zeeb 	QMI_UNSIGNED_2_BYTE,
4106a1103fSBjoern A. Zeeb 	QMI_UNSIGNED_4_BYTE,
4206a1103fSBjoern A. Zeeb 	QMI_UNSIGNED_8_BYTE,
4306a1103fSBjoern A. Zeeb 	QMI_SIGNED_4_BYTE_ENUM,
4406a1103fSBjoern A. Zeeb 	QMI_STRUCT,
4506a1103fSBjoern A. Zeeb 	QMI_STRING,
4606a1103fSBjoern A. Zeeb };
4706a1103fSBjoern A. Zeeb 
4806a1103fSBjoern A. Zeeb #define	QMI_RESULT_SUCCESS_V01	__LINE__
4906a1103fSBjoern A. Zeeb #define	QMI_INDICATION		__LINE__
5006a1103fSBjoern A. Zeeb 
5106a1103fSBjoern A. Zeeb struct qmi_handle;
5206a1103fSBjoern A. Zeeb 
5306a1103fSBjoern A. Zeeb enum soc_qcom_qmi_array_type {
5406a1103fSBjoern A. Zeeb 	NO_ARRAY,
55*bee50f89SBjoern A. Zeeb 	STATIC_ARRAY,
5606a1103fSBjoern A. Zeeb 	VAR_LEN_ARRAY,
5706a1103fSBjoern A. Zeeb };
5806a1103fSBjoern A. Zeeb 
5906a1103fSBjoern A. Zeeb /* Should this become an enum? */
6006a1103fSBjoern A. Zeeb #define	QMI_COMMON_TLV_TYPE			0
6106a1103fSBjoern A. Zeeb 
6206a1103fSBjoern A. Zeeb struct qmi_elem_info {
6306a1103fSBjoern A. Zeeb 	enum soc_qcom_qmi_data_type		data_type;
6406a1103fSBjoern A. Zeeb 	uint32_t				elem_len;
6506a1103fSBjoern A. Zeeb 	uint32_t				elem_size;
6606a1103fSBjoern A. Zeeb 	enum soc_qcom_qmi_array_type		array_type;
6706a1103fSBjoern A. Zeeb 	uint8_t					tlv_type;
6806a1103fSBjoern A. Zeeb 	uint32_t				offset;
6904729820SBjoern A. Zeeb 	const struct qmi_elem_info		*ei_array;
7006a1103fSBjoern A. Zeeb };
7106a1103fSBjoern A. Zeeb 
7206a1103fSBjoern A. Zeeb struct qmi_response_type_v01 {
7306a1103fSBjoern A. Zeeb 	uint16_t				result;
7406a1103fSBjoern A. Zeeb 	uint16_t				error;
7506a1103fSBjoern A. Zeeb };
7606a1103fSBjoern A. Zeeb 
7706a1103fSBjoern A. Zeeb struct qmi_txn {
7806a1103fSBjoern A. Zeeb };
7906a1103fSBjoern A. Zeeb 
8006a1103fSBjoern A. Zeeb struct qmi_service {
8106a1103fSBjoern A. Zeeb 	uint32_t				node;
8206a1103fSBjoern A. Zeeb 	uint32_t				port;
8306a1103fSBjoern A. Zeeb };
8406a1103fSBjoern A. Zeeb 
8506a1103fSBjoern A. Zeeb struct qmi_msg_handler {
8606a1103fSBjoern A. Zeeb 	uint32_t				type;
8706a1103fSBjoern A. Zeeb 	uint32_t				msg_id;
8804729820SBjoern A. Zeeb 	const struct qmi_elem_info		*ei;
8906a1103fSBjoern A. Zeeb 	size_t					decoded_size;
9006a1103fSBjoern A. Zeeb 	void	(*fn)(struct qmi_handle *, struct sockaddr_qrtr *, struct qmi_txn *, const void *);
9106a1103fSBjoern A. Zeeb };
9206a1103fSBjoern A. Zeeb 
9306a1103fSBjoern A. Zeeb struct qmi_ops {
9406a1103fSBjoern A. Zeeb 	int	(*new_server)(struct qmi_handle *, struct qmi_service *);
9506a1103fSBjoern A. Zeeb 	void	(*del_server)(struct qmi_handle *, struct qmi_service *);
9606a1103fSBjoern A. Zeeb };
9706a1103fSBjoern A. Zeeb 
9806a1103fSBjoern A. Zeeb struct qmi_handle {
9906a1103fSBjoern A. Zeeb 	int				sock;
10006a1103fSBjoern A. Zeeb 
10106a1103fSBjoern A. Zeeb 	const struct qmi_msg_handler	*handler;
10206a1103fSBjoern A. Zeeb 	struct qmi_ops			ops;
10306a1103fSBjoern A. Zeeb };
10406a1103fSBjoern A. Zeeb 
10506a1103fSBjoern A. Zeeb 
10606a1103fSBjoern A. Zeeb /* XXX-TODO need implementation somewhere... it is not in ath1xk* */
10706a1103fSBjoern A. Zeeb extern struct qmi_elem_info qmi_response_type_v01_ei[];
10806a1103fSBjoern A. Zeeb 
10906a1103fSBjoern A. Zeeb static inline int
qmi_handle_init(struct qmi_handle * handle,size_t resp_len_max,const struct qmi_ops * ops,const struct qmi_msg_handler * handler)11006a1103fSBjoern A. Zeeb qmi_handle_init(struct qmi_handle *handle, size_t resp_len_max,
11106a1103fSBjoern A. Zeeb     const struct qmi_ops *ops, const struct qmi_msg_handler *handler)
11206a1103fSBjoern A. Zeeb {
11306a1103fSBjoern A. Zeeb 
11406a1103fSBjoern A. Zeeb 	handle->handler = handler;
11506a1103fSBjoern A. Zeeb 	if (ops != NULL)
11606a1103fSBjoern A. Zeeb 		handle->ops = *ops;
11706a1103fSBjoern A. Zeeb 
11806a1103fSBjoern A. Zeeb         /* We will find out what else to do here. */
11906a1103fSBjoern A. Zeeb 	/* XXX TODO */
12006a1103fSBjoern A. Zeeb 
12106a1103fSBjoern A. Zeeb 	return (0);
12206a1103fSBjoern A. Zeeb }
12306a1103fSBjoern A. Zeeb 
12406a1103fSBjoern A. Zeeb static __inline int
qmi_add_lookup(struct qmi_handle * handle,uint32_t service,uint32_t version,uint32_t service_ins_id)12506a1103fSBjoern A. Zeeb qmi_add_lookup(struct qmi_handle *handle, uint32_t service, uint32_t version,
12606a1103fSBjoern A. Zeeb     uint32_t service_ins_id)
12706a1103fSBjoern A. Zeeb {
12806a1103fSBjoern A. Zeeb 
12906a1103fSBjoern A. Zeeb 	/* XXX TODO */
13006a1103fSBjoern A. Zeeb 	return (0);
13106a1103fSBjoern A. Zeeb }
13206a1103fSBjoern A. Zeeb 
13306a1103fSBjoern A. Zeeb static __inline void
qmi_handle_release(struct qmi_handle * handle)13406a1103fSBjoern A. Zeeb qmi_handle_release(struct qmi_handle *handle)
13506a1103fSBjoern A. Zeeb {
13606a1103fSBjoern A. Zeeb 
13706a1103fSBjoern A. Zeeb 	/* XXX TODO */
13806a1103fSBjoern A. Zeeb }
13906a1103fSBjoern A. Zeeb 
14006a1103fSBjoern A. Zeeb static __inline int
qmi_send_request(struct qmi_handle * handle,void * x,struct qmi_txn * txn,uint32_t msd_id,size_t len,const struct qmi_elem_info * ei,void * req)14106a1103fSBjoern A. Zeeb qmi_send_request(struct qmi_handle *handle, void *x, struct qmi_txn *txn,
14204729820SBjoern A. Zeeb     uint32_t msd_id, size_t len, const struct qmi_elem_info *ei, void *req)
14306a1103fSBjoern A. Zeeb {
14406a1103fSBjoern A. Zeeb 
14506a1103fSBjoern A. Zeeb 	/* XXX TODO */
14606a1103fSBjoern A. Zeeb 	return (-ENXIO);
14706a1103fSBjoern A. Zeeb }
14806a1103fSBjoern A. Zeeb 
14906a1103fSBjoern A. Zeeb static __inline void
qmi_txn_cancel(struct qmi_txn * txn)15006a1103fSBjoern A. Zeeb qmi_txn_cancel(struct qmi_txn *txn)
15106a1103fSBjoern A. Zeeb {
15206a1103fSBjoern A. Zeeb 
15306a1103fSBjoern A. Zeeb 	/* XXX TODO */
15406a1103fSBjoern A. Zeeb }
15506a1103fSBjoern A. Zeeb 
15606a1103fSBjoern A. Zeeb static __inline int
qmi_txn_init(struct qmi_handle * handle,struct qmi_txn * txn,const struct qmi_elem_info * ei,void * resp)15706a1103fSBjoern A. Zeeb qmi_txn_init(struct qmi_handle *handle, struct qmi_txn *txn,
15804729820SBjoern A. Zeeb     const struct qmi_elem_info *ei, void *resp)
15906a1103fSBjoern A. Zeeb {
16006a1103fSBjoern A. Zeeb 
16106a1103fSBjoern A. Zeeb 	/* XXX TODO */
16206a1103fSBjoern A. Zeeb 	return (-ENXIO);
16306a1103fSBjoern A. Zeeb }
16406a1103fSBjoern A. Zeeb 
16506a1103fSBjoern A. Zeeb static __inline int
qmi_txn_wait(struct qmi_txn * txn,uint64_t jiffies)16606a1103fSBjoern A. Zeeb qmi_txn_wait(struct qmi_txn *txn, uint64_t jiffies)
16706a1103fSBjoern A. Zeeb {
16806a1103fSBjoern A. Zeeb 
16906a1103fSBjoern A. Zeeb 	/* XXX TODO */
17006a1103fSBjoern A. Zeeb 	return (-ENXIO);
17106a1103fSBjoern A. Zeeb }
17206a1103fSBjoern A. Zeeb 
17306a1103fSBjoern A. Zeeb #endif	/* _LINUXKPI_LINUX_SOC_QCOM_QMI_H */
174