blob: 55aeadef5983b76e422a7f0bdf91c071dade390c [file] [log] [blame]
Karthikeyan Ramasubramanian1668cc62012-09-23 22:23:36 -06001/* Copyright (c) 2011-2013, The Linux Foundation. All rights reserved.
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#ifndef _ARCH_ARM_MACH_MSM_IPC_ROUTER_H
14#define _ARCH_ARM_MACH_MSM_IPC_ROUTER_H
15
16#include <linux/types.h>
17#include <linux/socket.h>
18#include <linux/errno.h>
19#include <linux/mm.h>
20#include <linux/list.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070021#include <linux/platform_device.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070022#include <linux/msm_ipc.h>
23
24#include <net/sock.h>
25
26/* definitions for the R2R wire protcol */
27#define IPC_ROUTER_VERSION 1
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070028
29#define IPC_ROUTER_CLIENT_BCAST_ID 0xffffffff
30#define IPC_ROUTER_ADDRESS 0xfffffffe
31
32#define IPC_ROUTER_NID_LOCAL 1
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070033
34#define IPC_ROUTER_CTRL_CMD_DATA 1
35#define IPC_ROUTER_CTRL_CMD_HELLO 2
36#define IPC_ROUTER_CTRL_CMD_BYE 3
37#define IPC_ROUTER_CTRL_CMD_NEW_SERVER 4
38#define IPC_ROUTER_CTRL_CMD_REMOVE_SERVER 5
39#define IPC_ROUTER_CTRL_CMD_REMOVE_CLIENT 6
40#define IPC_ROUTER_CTRL_CMD_RESUME_TX 7
41#define IPC_ROUTER_CTRL_CMD_EXIT 8
42#define IPC_ROUTER_CTRL_CMD_PING 9
43
44#define IPC_ROUTER_DEFAULT_RX_QUOTA 5
45
46#define IPC_ROUTER_XPRT_EVENT_DATA 1
47#define IPC_ROUTER_XPRT_EVENT_OPEN 2
48#define IPC_ROUTER_XPRT_EVENT_CLOSE 3
49
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070050#define IPC_ROUTER_INFINITY -1
Karthikeyan Ramasubramanian29f023b2013-03-18 11:52:46 -060051#define DEFAULT_RCV_TIMEO 0
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070052
53#define ALIGN_SIZE(x) ((4 - ((x) & 3)) & 3)
54
Karthikeyan Ramasubramanian1668cc62012-09-23 22:23:36 -060055#define ALL_SERVICE 0xFFFFFFFF
56#define ALL_INSTANCE 0xFFFFFFFF
57
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070058enum {
Karthikeyan Ramasubramaniand6dbfae2013-01-16 09:00:28 -070059 CLIENT_PORT,
60 SERVER_PORT,
61 CONTROL_PORT,
62 IRSC_PORT,
63};
64
Karthikeyan Ramasubramaniandc9c4442013-05-02 17:25:54 -060065enum {
66 NULL_MODE,
67 SINGLE_LINK_MODE,
68 MULTI_LINK_MODE,
69};
70
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070071union rr_control_msg {
72 uint32_t cmd;
73 struct {
74 uint32_t cmd;
75 uint32_t service;
76 uint32_t instance;
77 uint32_t node_id;
78 uint32_t port_id;
79 } srv;
80 struct {
81 uint32_t cmd;
82 uint32_t node_id;
83 uint32_t port_id;
84 } cli;
85};
86
87struct rr_header {
88 uint32_t version;
89 uint32_t type;
90 uint32_t src_node_id;
91 uint32_t src_port_id;
92 uint32_t confirm_rx;
93 uint32_t size;
94 uint32_t dst_node_id;
95 uint32_t dst_port_id;
96};
97
98#define IPC_ROUTER_HDR_SIZE sizeof(struct rr_header)
99#define MAX_IPC_PKT_SIZE 66000
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700100
101struct rr_packet {
102 struct list_head list;
103 struct sk_buff_head *pkt_fragment_q;
104 uint32_t length;
105};
106
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700107struct msm_ipc_sock {
108 struct sock sk;
109 struct msm_ipc_port *port;
Karthikeyan Ramasubramanianaf90ba82013-06-03 12:05:50 -0600110 void *default_pil;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700111};
112
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700113struct msm_ipc_router_xprt {
114 char *name;
115 uint32_t link_id;
116 void *priv;
117
Karthikeyan Ramasubramanian8cec5922012-02-16 17:41:58 -0700118 int (*read_avail)(struct msm_ipc_router_xprt *xprt);
119 int (*read)(void *data, uint32_t len,
120 struct msm_ipc_router_xprt *xprt);
121 int (*write_avail)(struct msm_ipc_router_xprt *xprt);
122 int (*write)(void *data, uint32_t len,
123 struct msm_ipc_router_xprt *xprt);
124 int (*close)(struct msm_ipc_router_xprt *xprt);
Zaheerulla Meer35893a62013-06-19 16:54:44 +0530125 void (*sft_close_done)(struct msm_ipc_router_xprt *xprt);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700126};
127
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700128void msm_ipc_router_xprt_notify(struct msm_ipc_router_xprt *xprt,
129 unsigned event,
130 void *data);
131
132
133struct rr_packet *clone_pkt(struct rr_packet *pkt);
134void release_pkt(struct rr_packet *pkt);
135
136
137struct msm_ipc_port *msm_ipc_router_create_raw_port(void *endpoint,
Karthikeyan Ramasubramanian70444192012-07-12 10:25:49 -0600138 void (*notify)(unsigned event, void *priv),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700139 void *priv);
140int msm_ipc_router_send_to(struct msm_ipc_port *src,
141 struct sk_buff_head *data,
142 struct msm_ipc_addr *dest);
143int msm_ipc_router_read(struct msm_ipc_port *port_ptr,
144 struct sk_buff_head **data,
145 size_t buf_len);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700146int msm_ipc_router_bind_control_port(struct msm_ipc_port *port_ptr);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700147
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700148int msm_ipc_router_recv_from(struct msm_ipc_port *port_ptr,
149 struct sk_buff_head **data,
150 struct msm_ipc_addr *src_addr,
Karthikeyan Ramasubramanian70444192012-07-12 10:25:49 -0600151 long timeout);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700152int msm_ipc_router_register_server(struct msm_ipc_port *server_port,
153 struct msm_ipc_addr *name);
154int msm_ipc_router_unregister_server(struct msm_ipc_port *server_port);
155
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700156int msm_ipc_router_init_sockets(void);
157void msm_ipc_router_exit_sockets(void);
158
Karthikeyan Ramasubramanian1668cc62012-09-23 22:23:36 -0600159void msm_ipc_sync_sec_rule(uint32_t service, uint32_t instance, void *rule);
160
161void msm_ipc_sync_default_sec_rule(void *rule);
162
Karthikeyan Ramasubramanianaf90ba82013-06-03 12:05:50 -0600163#if defined CONFIG_MSM_IPC_ROUTER_SMD_XPRT
164extern void *msm_ipc_load_default_node(void);
165
166extern void msm_ipc_unload_default_node(void *pil);
167#else
168static inline void *msm_ipc_load_default_node(void)
169{ return NULL; }
170
171static inline void msm_ipc_unload_default_node(void *pil) { }
172#endif
173
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700174#endif