xref: /openbmc/linux/include/trace/events/sunrpc.h (revision f7777dcc)
1 #undef TRACE_SYSTEM
2 #define TRACE_SYSTEM sunrpc
3 
4 #if !defined(_TRACE_SUNRPC_H) || defined(TRACE_HEADER_MULTI_READ)
5 #define _TRACE_SUNRPC_H
6 
7 #include <linux/sunrpc/sched.h>
8 #include <linux/sunrpc/clnt.h>
9 #include <net/tcp_states.h>
10 #include <linux/net.h>
11 #include <linux/tracepoint.h>
12 
13 DECLARE_EVENT_CLASS(rpc_task_status,
14 
15 	TP_PROTO(struct rpc_task *task),
16 
17 	TP_ARGS(task),
18 
19 	TP_STRUCT__entry(
20 		__field(unsigned int, task_id)
21 		__field(unsigned int, client_id)
22 		__field(int, status)
23 	),
24 
25 	TP_fast_assign(
26 		__entry->task_id = task->tk_pid;
27 		__entry->client_id = task->tk_client->cl_clid;
28 		__entry->status = task->tk_status;
29 	),
30 
31 	TP_printk("task:%u@%u, status %d",
32 		__entry->task_id, __entry->client_id,
33 		__entry->status)
34 );
35 
36 DEFINE_EVENT(rpc_task_status, rpc_call_status,
37 	TP_PROTO(struct rpc_task *task),
38 
39 	TP_ARGS(task)
40 );
41 
42 DEFINE_EVENT(rpc_task_status, rpc_bind_status,
43 	TP_PROTO(struct rpc_task *task),
44 
45 	TP_ARGS(task)
46 );
47 
48 TRACE_EVENT(rpc_connect_status,
49 	TP_PROTO(struct rpc_task *task, int status),
50 
51 	TP_ARGS(task, status),
52 
53 	TP_STRUCT__entry(
54 		__field(unsigned int, task_id)
55 		__field(unsigned int, client_id)
56 		__field(int, status)
57 	),
58 
59 	TP_fast_assign(
60 		__entry->task_id = task->tk_pid;
61 		__entry->client_id = task->tk_client->cl_clid;
62 		__entry->status = status;
63 	),
64 
65 	TP_printk("task:%u@%u, status %d",
66 		__entry->task_id, __entry->client_id,
67 		__entry->status)
68 );
69 
70 DECLARE_EVENT_CLASS(rpc_task_running,
71 
72 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
73 
74 	TP_ARGS(clnt, task, action),
75 
76 	TP_STRUCT__entry(
77 		__field(unsigned int, task_id)
78 		__field(unsigned int, client_id)
79 		__field(const void *, action)
80 		__field(unsigned long, runstate)
81 		__field(int, status)
82 		__field(unsigned short, flags)
83 		),
84 
85 	TP_fast_assign(
86 		__entry->client_id = clnt->cl_clid;
87 		__entry->task_id = task->tk_pid;
88 		__entry->action = action;
89 		__entry->runstate = task->tk_runstate;
90 		__entry->status = task->tk_status;
91 		__entry->flags = task->tk_flags;
92 		),
93 
94 	TP_printk("task:%u@%u flags=%4.4x state=%4.4lx status=%d action=%pf",
95 		__entry->task_id, __entry->client_id,
96 		__entry->flags,
97 		__entry->runstate,
98 		__entry->status,
99 		__entry->action
100 		)
101 );
102 
103 DEFINE_EVENT(rpc_task_running, rpc_task_begin,
104 
105 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
106 
107 	TP_ARGS(clnt, task, action)
108 
109 );
110 
111 DEFINE_EVENT(rpc_task_running, rpc_task_run_action,
112 
113 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
114 
115 	TP_ARGS(clnt, task, action)
116 
117 );
118 
119 DEFINE_EVENT(rpc_task_running, rpc_task_complete,
120 
121 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
122 
123 	TP_ARGS(clnt, task, action)
124 
125 );
126 
127 DECLARE_EVENT_CLASS(rpc_task_queued,
128 
129 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
130 
131 	TP_ARGS(clnt, task, q),
132 
133 	TP_STRUCT__entry(
134 		__field(unsigned int, task_id)
135 		__field(unsigned int, client_id)
136 		__field(unsigned long, timeout)
137 		__field(unsigned long, runstate)
138 		__field(int, status)
139 		__field(unsigned short, flags)
140 		__string(q_name, rpc_qname(q))
141 		),
142 
143 	TP_fast_assign(
144 		__entry->client_id = clnt->cl_clid;
145 		__entry->task_id = task->tk_pid;
146 		__entry->timeout = task->tk_timeout;
147 		__entry->runstate = task->tk_runstate;
148 		__entry->status = task->tk_status;
149 		__entry->flags = task->tk_flags;
150 		__assign_str(q_name, rpc_qname(q));
151 		),
152 
153 	TP_printk("task:%u@%u flags=%4.4x state=%4.4lx status=%d timeout=%lu queue=%s",
154 		__entry->task_id, __entry->client_id,
155 		__entry->flags,
156 		__entry->runstate,
157 		__entry->status,
158 		__entry->timeout,
159 		__get_str(q_name)
160 		)
161 );
162 
163 DEFINE_EVENT(rpc_task_queued, rpc_task_sleep,
164 
165 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
166 
167 	TP_ARGS(clnt, task, q)
168 
169 );
170 
171 DEFINE_EVENT(rpc_task_queued, rpc_task_wakeup,
172 
173 	TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
174 
175 	TP_ARGS(clnt, task, q)
176 
177 );
178 
179 #define rpc_show_socket_state(state) \
180 	__print_symbolic(state, \
181 		{ SS_FREE, "FREE" }, \
182 		{ SS_UNCONNECTED, "UNCONNECTED" }, \
183 		{ SS_CONNECTING, "CONNECTING," }, \
184 		{ SS_CONNECTED, "CONNECTED," }, \
185 		{ SS_DISCONNECTING, "DISCONNECTING" })
186 
187 #define rpc_show_sock_state(state) \
188 	__print_symbolic(state, \
189 		{ TCP_ESTABLISHED, "ESTABLISHED" }, \
190 		{ TCP_SYN_SENT, "SYN_SENT" }, \
191 		{ TCP_SYN_RECV, "SYN_RECV" }, \
192 		{ TCP_FIN_WAIT1, "FIN_WAIT1" }, \
193 		{ TCP_FIN_WAIT2, "FIN_WAIT2" }, \
194 		{ TCP_TIME_WAIT, "TIME_WAIT" }, \
195 		{ TCP_CLOSE, "CLOSE" }, \
196 		{ TCP_CLOSE_WAIT, "CLOSE_WAIT" }, \
197 		{ TCP_LAST_ACK, "LAST_ACK" }, \
198 		{ TCP_LISTEN, "LISTEN" }, \
199 		{ TCP_CLOSING, "CLOSING" })
200 
201 DECLARE_EVENT_CLASS(xs_socket_event,
202 
203 		TP_PROTO(
204 			struct rpc_xprt *xprt,
205 			struct socket *socket
206 		),
207 
208 		TP_ARGS(xprt, socket),
209 
210 		TP_STRUCT__entry(
211 			__field(unsigned int, socket_state)
212 			__field(unsigned int, sock_state)
213 			__field(unsigned long long, ino)
214 			__string(dstaddr,
215 				xprt->address_strings[RPC_DISPLAY_ADDR])
216 			__string(dstport,
217 				xprt->address_strings[RPC_DISPLAY_PORT])
218 		),
219 
220 		TP_fast_assign(
221 			struct inode *inode = SOCK_INODE(socket);
222 			__entry->socket_state = socket->state;
223 			__entry->sock_state = socket->sk->sk_state;
224 			__entry->ino = (unsigned long long)inode->i_ino;
225 			__assign_str(dstaddr,
226 				xprt->address_strings[RPC_DISPLAY_ADDR]);
227 			__assign_str(dstport,
228 				xprt->address_strings[RPC_DISPLAY_PORT]);
229 		),
230 
231 		TP_printk(
232 			"socket:[%llu] dstaddr=%s/%s "
233 			"state=%u (%s) sk_state=%u (%s)",
234 			__entry->ino, __get_str(dstaddr), __get_str(dstport),
235 			__entry->socket_state,
236 			rpc_show_socket_state(__entry->socket_state),
237 			__entry->sock_state,
238 			rpc_show_sock_state(__entry->sock_state)
239 		)
240 );
241 #define DEFINE_RPC_SOCKET_EVENT(name) \
242 	DEFINE_EVENT(xs_socket_event, name, \
243 			TP_PROTO( \
244 				struct rpc_xprt *xprt, \
245 				struct socket *socket \
246 			), \
247 			TP_ARGS(xprt, socket))
248 
249 DECLARE_EVENT_CLASS(xs_socket_event_done,
250 
251 		TP_PROTO(
252 			struct rpc_xprt *xprt,
253 			struct socket *socket,
254 			int error
255 		),
256 
257 		TP_ARGS(xprt, socket, error),
258 
259 		TP_STRUCT__entry(
260 			__field(int, error)
261 			__field(unsigned int, socket_state)
262 			__field(unsigned int, sock_state)
263 			__field(unsigned long long, ino)
264 			__string(dstaddr,
265 				xprt->address_strings[RPC_DISPLAY_ADDR])
266 			__string(dstport,
267 				xprt->address_strings[RPC_DISPLAY_PORT])
268 		),
269 
270 		TP_fast_assign(
271 			struct inode *inode = SOCK_INODE(socket);
272 			__entry->socket_state = socket->state;
273 			__entry->sock_state = socket->sk->sk_state;
274 			__entry->ino = (unsigned long long)inode->i_ino;
275 			__entry->error = error;
276 			__assign_str(dstaddr,
277 				xprt->address_strings[RPC_DISPLAY_ADDR]);
278 			__assign_str(dstport,
279 				xprt->address_strings[RPC_DISPLAY_PORT]);
280 		),
281 
282 		TP_printk(
283 			"error=%d socket:[%llu] dstaddr=%s/%s "
284 			"state=%u (%s) sk_state=%u (%s)",
285 			__entry->error,
286 			__entry->ino, __get_str(dstaddr), __get_str(dstport),
287 			__entry->socket_state,
288 			rpc_show_socket_state(__entry->socket_state),
289 			__entry->sock_state,
290 			rpc_show_sock_state(__entry->sock_state)
291 		)
292 );
293 #define DEFINE_RPC_SOCKET_EVENT_DONE(name) \
294 	DEFINE_EVENT(xs_socket_event_done, name, \
295 			TP_PROTO( \
296 				struct rpc_xprt *xprt, \
297 				struct socket *socket, \
298 				int error \
299 			), \
300 			TP_ARGS(xprt, socket, error))
301 
302 DEFINE_RPC_SOCKET_EVENT(rpc_socket_state_change);
303 DEFINE_RPC_SOCKET_EVENT_DONE(rpc_socket_connect);
304 DEFINE_RPC_SOCKET_EVENT_DONE(rpc_socket_reset_connection);
305 DEFINE_RPC_SOCKET_EVENT(rpc_socket_close);
306 DEFINE_RPC_SOCKET_EVENT(rpc_socket_shutdown);
307 
308 #endif /* _TRACE_SUNRPC_H */
309 
310 #include <trace/define_trace.h>
311