trace_mr.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. /*
  2. * Copyright(c) 2016 Intel Corporation.
  3. *
  4. * This file is provided under a dual BSD/GPLv2 license. When using or
  5. * redistributing this file, you may do so under either license.
  6. *
  7. * GPL LICENSE SUMMARY
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of version 2 of the GNU General Public License as
  11. * published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * General Public License for more details.
  17. *
  18. * BSD LICENSE
  19. *
  20. * Redistribution and use in source and binary forms, with or without
  21. * modification, are permitted provided that the following conditions
  22. * are met:
  23. *
  24. * - Redistributions of source code must retain the above copyright
  25. * notice, this list of conditions and the following disclaimer.
  26. * - Redistributions in binary form must reproduce the above copyright
  27. * notice, this list of conditions and the following disclaimer in
  28. * the documentation and/or other materials provided with the
  29. * distribution.
  30. * - Neither the name of Intel Corporation nor the names of its
  31. * contributors may be used to endorse or promote products derived
  32. * from this software without specific prior written permission.
  33. *
  34. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  35. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  36. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  37. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  38. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  39. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  40. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  41. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  42. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  43. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  44. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  45. *
  46. */
  47. #if !defined(__RVT_TRACE_MR_H) || defined(TRACE_HEADER_MULTI_READ)
  48. #define __RVT_TRACE_MR_H
  49. #include <linux/tracepoint.h>
  50. #include <linux/trace_seq.h>
  51. #include <rdma/ib_verbs.h>
  52. #include <rdma/rdma_vt.h>
  53. #include <rdma/rdmavt_mr.h>
  54. #undef TRACE_SYSTEM
  55. #define TRACE_SYSTEM rvt_mr
  56. DECLARE_EVENT_CLASS(
  57. rvt_mr_template,
  58. TP_PROTO(struct rvt_mregion *mr, u16 m, u16 n, void *v, size_t len),
  59. TP_ARGS(mr, m, n, v, len),
  60. TP_STRUCT__entry(
  61. RDI_DEV_ENTRY(ib_to_rvt(mr->pd->device))
  62. __field(void *, vaddr)
  63. __field(struct page *, page)
  64. __field(size_t, len)
  65. __field(u32, lkey)
  66. __field(u16, m)
  67. __field(u16, n)
  68. ),
  69. TP_fast_assign(
  70. RDI_DEV_ASSIGN(ib_to_rvt(mr->pd->device));
  71. __entry->vaddr = v;
  72. __entry->page = virt_to_page(v);
  73. __entry->m = m;
  74. __entry->n = n;
  75. __entry->len = len;
  76. ),
  77. TP_printk(
  78. "[%s] vaddr %p page %p m %u n %u len %ld",
  79. __get_str(dev),
  80. __entry->vaddr,
  81. __entry->page,
  82. __entry->m,
  83. __entry->n,
  84. __entry->len
  85. )
  86. );
  87. DEFINE_EVENT(
  88. rvt_mr_template, rvt_mr_page_seg,
  89. TP_PROTO(struct rvt_mregion *mr, u16 m, u16 n, void *v, size_t len),
  90. TP_ARGS(mr, m, n, v, len));
  91. DEFINE_EVENT(
  92. rvt_mr_template, rvt_mr_fmr_seg,
  93. TP_PROTO(struct rvt_mregion *mr, u16 m, u16 n, void *v, size_t len),
  94. TP_ARGS(mr, m, n, v, len));
  95. DEFINE_EVENT(
  96. rvt_mr_template, rvt_mr_user_seg,
  97. TP_PROTO(struct rvt_mregion *mr, u16 m, u16 n, void *v, size_t len),
  98. TP_ARGS(mr, m, n, v, len));
  99. DECLARE_EVENT_CLASS(
  100. rvt_sge_template,
  101. TP_PROTO(struct rvt_sge *sge, struct ib_sge *isge),
  102. TP_ARGS(sge, isge),
  103. TP_STRUCT__entry(
  104. RDI_DEV_ENTRY(ib_to_rvt(sge->mr->pd->device))
  105. __field(struct rvt_mregion *, mr)
  106. __field(struct rvt_sge *, sge)
  107. __field(struct ib_sge *, isge)
  108. __field(void *, vaddr)
  109. __field(u64, ivaddr)
  110. __field(u32, lkey)
  111. __field(u32, sge_length)
  112. __field(u32, length)
  113. __field(u32, ilength)
  114. __field(int, user)
  115. __field(u16, m)
  116. __field(u16, n)
  117. ),
  118. TP_fast_assign(
  119. RDI_DEV_ASSIGN(ib_to_rvt(sge->mr->pd->device));
  120. __entry->mr = sge->mr;
  121. __entry->sge = sge;
  122. __entry->isge = isge;
  123. __entry->vaddr = sge->vaddr;
  124. __entry->ivaddr = isge->addr;
  125. __entry->lkey = sge->mr->lkey;
  126. __entry->sge_length = sge->sge_length;
  127. __entry->length = sge->length;
  128. __entry->ilength = isge->length;
  129. __entry->m = sge->m;
  130. __entry->n = sge->m;
  131. __entry->user = ibpd_to_rvtpd(sge->mr->pd)->user;
  132. ),
  133. TP_printk(
  134. "[%s] mr %p sge %p isge %p vaddr %p ivaddr %llx lkey %x sge_length %u length %u ilength %u m %u n %u user %u",
  135. __get_str(dev),
  136. __entry->mr,
  137. __entry->sge,
  138. __entry->isge,
  139. __entry->vaddr,
  140. __entry->ivaddr,
  141. __entry->lkey,
  142. __entry->sge_length,
  143. __entry->length,
  144. __entry->ilength,
  145. __entry->m,
  146. __entry->n,
  147. __entry->user
  148. )
  149. );
  150. DEFINE_EVENT(
  151. rvt_sge_template, rvt_sge_adjacent,
  152. TP_PROTO(struct rvt_sge *sge, struct ib_sge *isge),
  153. TP_ARGS(sge, isge));
  154. DEFINE_EVENT(
  155. rvt_sge_template, rvt_sge_new,
  156. TP_PROTO(struct rvt_sge *sge, struct ib_sge *isge),
  157. TP_ARGS(sge, isge));
  158. #endif /* __RVT_TRACE_MR_H */
  159. #undef TRACE_INCLUDE_PATH
  160. #undef TRACE_INCLUDE_FILE
  161. #define TRACE_INCLUDE_PATH .
  162. #define TRACE_INCLUDE_FILE trace_mr
  163. #include <trace/define_trace.h>