sunrpc.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM sunrpc
  3. #if !defined(_TRACE_SUNRPC_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_SUNRPC_H
  5. #include <linux/sunrpc/sched.h>
  6. #include <linux/sunrpc/clnt.h>
  7. #include <linux/sunrpc/svc.h>
  8. #include <linux/sunrpc/xprtsock.h>
  9. #include <linux/sunrpc/svc_xprt.h>
  10. #include <net/tcp_states.h>
  11. #include <linux/net.h>
  12. #include <linux/tracepoint.h>
  13. DECLARE_EVENT_CLASS(rpc_task_status,
  14. TP_PROTO(struct rpc_task *task),
  15. TP_ARGS(task),
  16. TP_STRUCT__entry(
  17. __field(unsigned int, task_id)
  18. __field(unsigned int, client_id)
  19. __field(int, status)
  20. ),
  21. TP_fast_assign(
  22. __entry->task_id = task->tk_pid;
  23. __entry->client_id = task->tk_client->cl_clid;
  24. __entry->status = task->tk_status;
  25. ),
  26. TP_printk("task:%u@%u, status %d",
  27. __entry->task_id, __entry->client_id,
  28. __entry->status)
  29. );
  30. DEFINE_EVENT(rpc_task_status, rpc_call_status,
  31. TP_PROTO(struct rpc_task *task),
  32. TP_ARGS(task)
  33. );
  34. DEFINE_EVENT(rpc_task_status, rpc_bind_status,
  35. TP_PROTO(struct rpc_task *task),
  36. TP_ARGS(task)
  37. );
  38. TRACE_EVENT(rpc_connect_status,
  39. TP_PROTO(struct rpc_task *task, int status),
  40. TP_ARGS(task, status),
  41. TP_STRUCT__entry(
  42. __field(unsigned int, task_id)
  43. __field(unsigned int, client_id)
  44. __field(int, status)
  45. ),
  46. TP_fast_assign(
  47. __entry->task_id = task->tk_pid;
  48. __entry->client_id = task->tk_client->cl_clid;
  49. __entry->status = status;
  50. ),
  51. TP_printk("task:%u@%u, status %d",
  52. __entry->task_id, __entry->client_id,
  53. __entry->status)
  54. );
  55. DECLARE_EVENT_CLASS(rpc_task_running,
  56. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
  57. TP_ARGS(clnt, task, action),
  58. TP_STRUCT__entry(
  59. __field(unsigned int, task_id)
  60. __field(unsigned int, client_id)
  61. __field(const void *, action)
  62. __field(unsigned long, runstate)
  63. __field(int, status)
  64. __field(unsigned short, flags)
  65. ),
  66. TP_fast_assign(
  67. __entry->client_id = clnt ? clnt->cl_clid : -1;
  68. __entry->task_id = task->tk_pid;
  69. __entry->action = action;
  70. __entry->runstate = task->tk_runstate;
  71. __entry->status = task->tk_status;
  72. __entry->flags = task->tk_flags;
  73. ),
  74. TP_printk("task:%u@%d flags=%4.4x state=%4.4lx status=%d action=%pf",
  75. __entry->task_id, __entry->client_id,
  76. __entry->flags,
  77. __entry->runstate,
  78. __entry->status,
  79. __entry->action
  80. )
  81. );
  82. DEFINE_EVENT(rpc_task_running, rpc_task_begin,
  83. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
  84. TP_ARGS(clnt, task, action)
  85. );
  86. DEFINE_EVENT(rpc_task_running, rpc_task_run_action,
  87. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
  88. TP_ARGS(clnt, task, action)
  89. );
  90. DEFINE_EVENT(rpc_task_running, rpc_task_complete,
  91. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const void *action),
  92. TP_ARGS(clnt, task, action)
  93. );
  94. DECLARE_EVENT_CLASS(rpc_task_queued,
  95. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
  96. TP_ARGS(clnt, task, q),
  97. TP_STRUCT__entry(
  98. __field(unsigned int, task_id)
  99. __field(unsigned int, client_id)
  100. __field(unsigned long, timeout)
  101. __field(unsigned long, runstate)
  102. __field(int, status)
  103. __field(unsigned short, flags)
  104. __string(q_name, rpc_qname(q))
  105. ),
  106. TP_fast_assign(
  107. __entry->client_id = clnt->cl_clid;
  108. __entry->task_id = task->tk_pid;
  109. __entry->timeout = task->tk_timeout;
  110. __entry->runstate = task->tk_runstate;
  111. __entry->status = task->tk_status;
  112. __entry->flags = task->tk_flags;
  113. __assign_str(q_name, rpc_qname(q));
  114. ),
  115. TP_printk("task:%u@%u flags=%4.4x state=%4.4lx status=%d timeout=%lu queue=%s",
  116. __entry->task_id, __entry->client_id,
  117. __entry->flags,
  118. __entry->runstate,
  119. __entry->status,
  120. __entry->timeout,
  121. __get_str(q_name)
  122. )
  123. );
  124. DEFINE_EVENT(rpc_task_queued, rpc_task_sleep,
  125. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
  126. TP_ARGS(clnt, task, q)
  127. );
  128. DEFINE_EVENT(rpc_task_queued, rpc_task_wakeup,
  129. TP_PROTO(const struct rpc_clnt *clnt, const struct rpc_task *task, const struct rpc_wait_queue *q),
  130. TP_ARGS(clnt, task, q)
  131. );
  132. #define rpc_show_socket_state(state) \
  133. __print_symbolic(state, \
  134. { SS_FREE, "FREE" }, \
  135. { SS_UNCONNECTED, "UNCONNECTED" }, \
  136. { SS_CONNECTING, "CONNECTING," }, \
  137. { SS_CONNECTED, "CONNECTED," }, \
  138. { SS_DISCONNECTING, "DISCONNECTING" })
  139. #define rpc_show_sock_state(state) \
  140. __print_symbolic(state, \
  141. { TCP_ESTABLISHED, "ESTABLISHED" }, \
  142. { TCP_SYN_SENT, "SYN_SENT" }, \
  143. { TCP_SYN_RECV, "SYN_RECV" }, \
  144. { TCP_FIN_WAIT1, "FIN_WAIT1" }, \
  145. { TCP_FIN_WAIT2, "FIN_WAIT2" }, \
  146. { TCP_TIME_WAIT, "TIME_WAIT" }, \
  147. { TCP_CLOSE, "CLOSE" }, \
  148. { TCP_CLOSE_WAIT, "CLOSE_WAIT" }, \
  149. { TCP_LAST_ACK, "LAST_ACK" }, \
  150. { TCP_LISTEN, "LISTEN" }, \
  151. { TCP_CLOSING, "CLOSING" })
  152. DECLARE_EVENT_CLASS(xs_socket_event,
  153. TP_PROTO(
  154. struct rpc_xprt *xprt,
  155. struct socket *socket
  156. ),
  157. TP_ARGS(xprt, socket),
  158. TP_STRUCT__entry(
  159. __field(unsigned int, socket_state)
  160. __field(unsigned int, sock_state)
  161. __field(unsigned long long, ino)
  162. __string(dstaddr,
  163. xprt->address_strings[RPC_DISPLAY_ADDR])
  164. __string(dstport,
  165. xprt->address_strings[RPC_DISPLAY_PORT])
  166. ),
  167. TP_fast_assign(
  168. struct inode *inode = SOCK_INODE(socket);
  169. __entry->socket_state = socket->state;
  170. __entry->sock_state = socket->sk->sk_state;
  171. __entry->ino = (unsigned long long)inode->i_ino;
  172. __assign_str(dstaddr,
  173. xprt->address_strings[RPC_DISPLAY_ADDR]);
  174. __assign_str(dstport,
  175. xprt->address_strings[RPC_DISPLAY_PORT]);
  176. ),
  177. TP_printk(
  178. "socket:[%llu] dstaddr=%s/%s "
  179. "state=%u (%s) sk_state=%u (%s)",
  180. __entry->ino, __get_str(dstaddr), __get_str(dstport),
  181. __entry->socket_state,
  182. rpc_show_socket_state(__entry->socket_state),
  183. __entry->sock_state,
  184. rpc_show_sock_state(__entry->sock_state)
  185. )
  186. );
  187. #define DEFINE_RPC_SOCKET_EVENT(name) \
  188. DEFINE_EVENT(xs_socket_event, name, \
  189. TP_PROTO( \
  190. struct rpc_xprt *xprt, \
  191. struct socket *socket \
  192. ), \
  193. TP_ARGS(xprt, socket))
  194. DECLARE_EVENT_CLASS(xs_socket_event_done,
  195. TP_PROTO(
  196. struct rpc_xprt *xprt,
  197. struct socket *socket,
  198. int error
  199. ),
  200. TP_ARGS(xprt, socket, error),
  201. TP_STRUCT__entry(
  202. __field(int, error)
  203. __field(unsigned int, socket_state)
  204. __field(unsigned int, sock_state)
  205. __field(unsigned long long, ino)
  206. __string(dstaddr,
  207. xprt->address_strings[RPC_DISPLAY_ADDR])
  208. __string(dstport,
  209. xprt->address_strings[RPC_DISPLAY_PORT])
  210. ),
  211. TP_fast_assign(
  212. struct inode *inode = SOCK_INODE(socket);
  213. __entry->socket_state = socket->state;
  214. __entry->sock_state = socket->sk->sk_state;
  215. __entry->ino = (unsigned long long)inode->i_ino;
  216. __entry->error = error;
  217. __assign_str(dstaddr,
  218. xprt->address_strings[RPC_DISPLAY_ADDR]);
  219. __assign_str(dstport,
  220. xprt->address_strings[RPC_DISPLAY_PORT]);
  221. ),
  222. TP_printk(
  223. "error=%d socket:[%llu] dstaddr=%s/%s "
  224. "state=%u (%s) sk_state=%u (%s)",
  225. __entry->error,
  226. __entry->ino, __get_str(dstaddr), __get_str(dstport),
  227. __entry->socket_state,
  228. rpc_show_socket_state(__entry->socket_state),
  229. __entry->sock_state,
  230. rpc_show_sock_state(__entry->sock_state)
  231. )
  232. );
  233. #define DEFINE_RPC_SOCKET_EVENT_DONE(name) \
  234. DEFINE_EVENT(xs_socket_event_done, name, \
  235. TP_PROTO( \
  236. struct rpc_xprt *xprt, \
  237. struct socket *socket, \
  238. int error \
  239. ), \
  240. TP_ARGS(xprt, socket, error))
  241. DEFINE_RPC_SOCKET_EVENT(rpc_socket_state_change);
  242. DEFINE_RPC_SOCKET_EVENT_DONE(rpc_socket_connect);
  243. DEFINE_RPC_SOCKET_EVENT_DONE(rpc_socket_error);
  244. DEFINE_RPC_SOCKET_EVENT_DONE(rpc_socket_reset_connection);
  245. DEFINE_RPC_SOCKET_EVENT(rpc_socket_close);
  246. DEFINE_RPC_SOCKET_EVENT(rpc_socket_shutdown);
  247. DECLARE_EVENT_CLASS(rpc_xprt_event,
  248. TP_PROTO(struct rpc_xprt *xprt, __be32 xid, int status),
  249. TP_ARGS(xprt, xid, status),
  250. TP_STRUCT__entry(
  251. __field(__be32, xid)
  252. __field(int, status)
  253. __string(addr, xprt->address_strings[RPC_DISPLAY_ADDR])
  254. __string(port, xprt->address_strings[RPC_DISPLAY_PORT])
  255. ),
  256. TP_fast_assign(
  257. __entry->xid = xid;
  258. __entry->status = status;
  259. __assign_str(addr, xprt->address_strings[RPC_DISPLAY_ADDR]);
  260. __assign_str(port, xprt->address_strings[RPC_DISPLAY_PORT]);
  261. ),
  262. TP_printk("peer=[%s]:%s xid=0x%x status=%d", __get_str(addr),
  263. __get_str(port), be32_to_cpu(__entry->xid),
  264. __entry->status)
  265. );
  266. DEFINE_EVENT(rpc_xprt_event, xprt_lookup_rqst,
  267. TP_PROTO(struct rpc_xprt *xprt, __be32 xid, int status),
  268. TP_ARGS(xprt, xid, status));
  269. DEFINE_EVENT(rpc_xprt_event, xprt_transmit,
  270. TP_PROTO(struct rpc_xprt *xprt, __be32 xid, int status),
  271. TP_ARGS(xprt, xid, status));
  272. DEFINE_EVENT(rpc_xprt_event, xprt_complete_rqst,
  273. TP_PROTO(struct rpc_xprt *xprt, __be32 xid, int status),
  274. TP_ARGS(xprt, xid, status));
  275. TRACE_EVENT(xs_tcp_data_ready,
  276. TP_PROTO(struct rpc_xprt *xprt, int err, unsigned int total),
  277. TP_ARGS(xprt, err, total),
  278. TP_STRUCT__entry(
  279. __field(int, err)
  280. __field(unsigned int, total)
  281. __string(addr, xprt ? xprt->address_strings[RPC_DISPLAY_ADDR] :
  282. "(null)")
  283. __string(port, xprt ? xprt->address_strings[RPC_DISPLAY_PORT] :
  284. "(null)")
  285. ),
  286. TP_fast_assign(
  287. __entry->err = err;
  288. __entry->total = total;
  289. __assign_str(addr, xprt ?
  290. xprt->address_strings[RPC_DISPLAY_ADDR] : "(null)");
  291. __assign_str(port, xprt ?
  292. xprt->address_strings[RPC_DISPLAY_PORT] : "(null)");
  293. ),
  294. TP_printk("peer=[%s]:%s err=%d total=%u", __get_str(addr),
  295. __get_str(port), __entry->err, __entry->total)
  296. );
  297. #define rpc_show_sock_xprt_flags(flags) \
  298. __print_flags(flags, "|", \
  299. { TCP_RCV_LAST_FRAG, "TCP_RCV_LAST_FRAG" }, \
  300. { TCP_RCV_COPY_FRAGHDR, "TCP_RCV_COPY_FRAGHDR" }, \
  301. { TCP_RCV_COPY_XID, "TCP_RCV_COPY_XID" }, \
  302. { TCP_RCV_COPY_DATA, "TCP_RCV_COPY_DATA" }, \
  303. { TCP_RCV_READ_CALLDIR, "TCP_RCV_READ_CALLDIR" }, \
  304. { TCP_RCV_COPY_CALLDIR, "TCP_RCV_COPY_CALLDIR" }, \
  305. { TCP_RPC_REPLY, "TCP_RPC_REPLY" })
  306. TRACE_EVENT(xs_tcp_data_recv,
  307. TP_PROTO(struct sock_xprt *xs),
  308. TP_ARGS(xs),
  309. TP_STRUCT__entry(
  310. __string(addr, xs->xprt.address_strings[RPC_DISPLAY_ADDR])
  311. __string(port, xs->xprt.address_strings[RPC_DISPLAY_PORT])
  312. __field(__be32, xid)
  313. __field(unsigned long, flags)
  314. __field(unsigned long, copied)
  315. __field(unsigned int, reclen)
  316. __field(unsigned long, offset)
  317. ),
  318. TP_fast_assign(
  319. __assign_str(addr, xs->xprt.address_strings[RPC_DISPLAY_ADDR]);
  320. __assign_str(port, xs->xprt.address_strings[RPC_DISPLAY_PORT]);
  321. __entry->xid = xs->tcp_xid;
  322. __entry->flags = xs->tcp_flags;
  323. __entry->copied = xs->tcp_copied;
  324. __entry->reclen = xs->tcp_reclen;
  325. __entry->offset = xs->tcp_offset;
  326. ),
  327. TP_printk("peer=[%s]:%s xid=0x%x flags=%s copied=%lu reclen=%u offset=%lu",
  328. __get_str(addr), __get_str(port), be32_to_cpu(__entry->xid),
  329. rpc_show_sock_xprt_flags(__entry->flags),
  330. __entry->copied, __entry->reclen, __entry->offset)
  331. );
  332. #define show_rqstp_flags(flags) \
  333. __print_flags(flags, "|", \
  334. { (1UL << RQ_SECURE), "RQ_SECURE"}, \
  335. { (1UL << RQ_LOCAL), "RQ_LOCAL"}, \
  336. { (1UL << RQ_USEDEFERRAL), "RQ_USEDEFERRAL"}, \
  337. { (1UL << RQ_DROPME), "RQ_DROPME"}, \
  338. { (1UL << RQ_SPLICE_OK), "RQ_SPLICE_OK"}, \
  339. { (1UL << RQ_VICTIM), "RQ_VICTIM"}, \
  340. { (1UL << RQ_BUSY), "RQ_BUSY"})
  341. TRACE_EVENT(svc_recv,
  342. TP_PROTO(struct svc_rqst *rqst, int status),
  343. TP_ARGS(rqst, status),
  344. TP_STRUCT__entry(
  345. __field(struct sockaddr *, addr)
  346. __field(__be32, xid)
  347. __field(int, status)
  348. __field(unsigned long, flags)
  349. ),
  350. TP_fast_assign(
  351. __entry->addr = (struct sockaddr *)&rqst->rq_addr;
  352. __entry->xid = status > 0 ? rqst->rq_xid : 0;
  353. __entry->status = status;
  354. __entry->flags = rqst->rq_flags;
  355. ),
  356. TP_printk("addr=%pIScp xid=0x%x status=%d flags=%s", __entry->addr,
  357. be32_to_cpu(__entry->xid), __entry->status,
  358. show_rqstp_flags(__entry->flags))
  359. );
  360. DECLARE_EVENT_CLASS(svc_rqst_status,
  361. TP_PROTO(struct svc_rqst *rqst, int status),
  362. TP_ARGS(rqst, status),
  363. TP_STRUCT__entry(
  364. __field(struct sockaddr *, addr)
  365. __field(__be32, xid)
  366. __field(int, dropme)
  367. __field(int, status)
  368. __field(unsigned long, flags)
  369. ),
  370. TP_fast_assign(
  371. __entry->addr = (struct sockaddr *)&rqst->rq_addr;
  372. __entry->xid = rqst->rq_xid;
  373. __entry->status = status;
  374. __entry->flags = rqst->rq_flags;
  375. ),
  376. TP_printk("addr=%pIScp rq_xid=0x%x status=%d flags=%s",
  377. __entry->addr, be32_to_cpu(__entry->xid),
  378. __entry->status, show_rqstp_flags(__entry->flags))
  379. );
  380. DEFINE_EVENT(svc_rqst_status, svc_process,
  381. TP_PROTO(struct svc_rqst *rqst, int status),
  382. TP_ARGS(rqst, status));
  383. DEFINE_EVENT(svc_rqst_status, svc_send,
  384. TP_PROTO(struct svc_rqst *rqst, int status),
  385. TP_ARGS(rqst, status));
  386. #define show_svc_xprt_flags(flags) \
  387. __print_flags(flags, "|", \
  388. { (1UL << XPT_BUSY), "XPT_BUSY"}, \
  389. { (1UL << XPT_CONN), "XPT_CONN"}, \
  390. { (1UL << XPT_CLOSE), "XPT_CLOSE"}, \
  391. { (1UL << XPT_DATA), "XPT_DATA"}, \
  392. { (1UL << XPT_TEMP), "XPT_TEMP"}, \
  393. { (1UL << XPT_DEAD), "XPT_DEAD"}, \
  394. { (1UL << XPT_CHNGBUF), "XPT_CHNGBUF"}, \
  395. { (1UL << XPT_DEFERRED), "XPT_DEFERRED"}, \
  396. { (1UL << XPT_OLD), "XPT_OLD"}, \
  397. { (1UL << XPT_LISTENER), "XPT_LISTENER"}, \
  398. { (1UL << XPT_CACHE_AUTH), "XPT_CACHE_AUTH"}, \
  399. { (1UL << XPT_LOCAL), "XPT_LOCAL"})
  400. TRACE_EVENT(svc_xprt_do_enqueue,
  401. TP_PROTO(struct svc_xprt *xprt, struct svc_rqst *rqst),
  402. TP_ARGS(xprt, rqst),
  403. TP_STRUCT__entry(
  404. __field(struct svc_xprt *, xprt)
  405. __field(struct svc_rqst *, rqst)
  406. ),
  407. TP_fast_assign(
  408. __entry->xprt = xprt;
  409. __entry->rqst = rqst;
  410. ),
  411. TP_printk("xprt=0x%p addr=%pIScp pid=%d flags=%s", __entry->xprt,
  412. (struct sockaddr *)&__entry->xprt->xpt_remote,
  413. __entry->rqst ? __entry->rqst->rq_task->pid : 0,
  414. show_svc_xprt_flags(__entry->xprt->xpt_flags))
  415. );
  416. TRACE_EVENT(svc_xprt_dequeue,
  417. TP_PROTO(struct svc_xprt *xprt),
  418. TP_ARGS(xprt),
  419. TP_STRUCT__entry(
  420. __field(struct svc_xprt *, xprt)
  421. __field_struct(struct sockaddr_storage, ss)
  422. __field(unsigned long, flags)
  423. ),
  424. TP_fast_assign(
  425. __entry->xprt = xprt,
  426. xprt ? memcpy(&__entry->ss, &xprt->xpt_remote, sizeof(__entry->ss)) : memset(&__entry->ss, 0, sizeof(__entry->ss));
  427. __entry->flags = xprt ? xprt->xpt_flags : 0;
  428. ),
  429. TP_printk("xprt=0x%p addr=%pIScp flags=%s", __entry->xprt,
  430. (struct sockaddr *)&__entry->ss,
  431. show_svc_xprt_flags(__entry->flags))
  432. );
  433. TRACE_EVENT(svc_wake_up,
  434. TP_PROTO(int pid),
  435. TP_ARGS(pid),
  436. TP_STRUCT__entry(
  437. __field(int, pid)
  438. ),
  439. TP_fast_assign(
  440. __entry->pid = pid;
  441. ),
  442. TP_printk("pid=%d", __entry->pid)
  443. );
  444. TRACE_EVENT(svc_handle_xprt,
  445. TP_PROTO(struct svc_xprt *xprt, int len),
  446. TP_ARGS(xprt, len),
  447. TP_STRUCT__entry(
  448. __field(struct svc_xprt *, xprt)
  449. __field(int, len)
  450. ),
  451. TP_fast_assign(
  452. __entry->xprt = xprt;
  453. __entry->len = len;
  454. ),
  455. TP_printk("xprt=0x%p addr=%pIScp len=%d flags=%s", __entry->xprt,
  456. (struct sockaddr *)&__entry->xprt->xpt_remote, __entry->len,
  457. show_svc_xprt_flags(__entry->xprt->xpt_flags))
  458. );
  459. #endif /* _TRACE_SUNRPC_H */
  460. #include <trace/define_trace.h>