104 lines
2.7 KiB
C
104 lines
2.7 KiB
C
/* Copyright (c) 2012-2014, 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;
|
|
};
|
|
|
|
struct svc_event_nb {
|
|
spinlock_t nb_lock;
|
|
uint32_t service_id;
|
|
uint32_t instance_id;
|
|
char pdriver_name[32];
|
|
int svc_avail;
|
|
struct platform_driver svc_driver;
|
|
struct raw_notifier_head svc_event_rcvr_list;
|
|
struct list_head 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
|