/* Copyright (c) 2012-2015, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 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. */ #ifndef _QMI_INTERFACE_PRIV_H_ #define _QMI_INTERFACE_PRIV_H_ #include #include #include #include #include #include #include #include #include enum txn_type { QMI_SYNC_TXN = 1, QMI_ASYNC_TXN, }; /** * handle_type - Enum to identify QMI handle type */ enum handle_type { QMI_CLIENT_HANDLE = 1, QMI_SERVICE_HANDLE, }; struct qmi_txn { struct list_head list; uint16_t txn_id; enum txn_type type; struct qmi_handle *handle; void *enc_data; unsigned int enc_data_len; struct msg_desc *resp_desc; void *resp; unsigned int resp_len; int resp_received; int send_stat; void (*resp_cb)(struct qmi_handle *handle, unsigned int msg_id, void *msg, void *resp_cb_data, int stat); void *resp_cb_data; wait_queue_head_t wait_q; }; /** * svc_addr - Data structure to maintain a list of service addresses. * @list_node: Service address list node used by "svc_addr_list" * @port_addr: Service address in . */ struct svc_addr { struct list_head list_node; struct msm_ipc_port_addr port_addr; }; /** * svc_event_nb - Service event notification structure. * @nb_lock: Spinlock for the notifier block lists. * @service_id: Service id for which list of notifier blocks are maintained. * @instance_id: Instance id for which list of notifier blocks are maintained. * @svc_event_rcvr_list: List of notifier blocks which clients have registered. * @list: Used to chain this structure in a global list. * @svc_addr_list_lock: Lock to protect @svc_addr_list. * @svc_addr_list: List for mantaining all the address for a specific * . */ struct svc_event_nb { spinlock_t nb_lock; uint32_t service_id; uint32_t instance_id; struct raw_notifier_head svc_event_rcvr_list; struct list_head list; struct mutex svc_addr_list_lock; struct list_head svc_addr_list; }; /** * req_handle - Data structure to store request information * @list: Points to req_handle_list maintained per connection. * @conn_h: Connection handle on which the concerned request is received. * @msg_id: Message ID of the request. * @txn_id: Transaction ID of the request. */ struct req_handle { struct list_head list; struct qmi_svc_clnt_conn *conn_h; uint16_t msg_id; uint16_t txn_id; }; /** * qmi_svc_clnt_conn - Data structure to identify client service connection * @list: List to chain up the client conncection to the connection list. * @svc_handle: Service side information of the connection. * @clnt_addr: Client side information of the connection. * @clnt_addr_len: Length of the client address. * @req_handle_list: Pending requests in this connection. * @pending_tx_list: Pending response/indications awaiting flow control. */ struct qmi_svc_clnt_conn { struct list_head list; void *svc_handle; void *clnt_addr; size_t clnt_addr_len; struct list_head req_handle_list; struct delayed_work resume_tx_work; struct list_head pending_txn_list; struct mutex pending_txn_lock; }; #endif