blob: ef3e692461a9fa9f0fb601fc1df895137b5ae469 [file] [log] [blame]
/* 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 <linux/types.h>
#include <linux/errno.h>
#include <linux/mm.h>
#include <linux/list.h>
#include <linux/socket.h>
#include <linux/gfp.h>
#include <linux/platform_device.h>
#include <linux/qmi_encdec.h>
#include <soc/qcom/msm_qmi_interface.h>
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 <node_id:port_id>.
*/
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
* <service_id:instance_id>.
*/
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