arm-smmu-trace.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2019, 2021 The Linux Foundation. All rights reserved.
  4. */
  5. #undef TRACE_SYSTEM
  6. #define TRACE_SYSTEM arm_smmu
  7. #if !defined(_TRACE_ARM_SMMU_H) || defined(TRACE_HEADER_MULTI_READ)
  8. #define _TRACE_ARM_SMMU_H
  9. #include <linux/types.h>
  10. #include <linux/tracepoint.h>
  11. #include <linux/scatterlist.h>
  12. #include "arm-smmu.h"
  13. struct device;
  14. DECLARE_EVENT_CLASS(iommu_tlbi,
  15. TP_PROTO(struct arm_smmu_domain *domain),
  16. TP_ARGS(domain),
  17. TP_STRUCT__entry(
  18. __string(group_name, dev_name(domain->dev))
  19. ),
  20. TP_fast_assign(
  21. __assign_str(group_name, dev_name(domain->dev));
  22. ),
  23. TP_printk("group=%s",
  24. __get_str(group_name)
  25. )
  26. );
  27. DEFINE_EVENT(iommu_tlbi, tlbi_start,
  28. TP_PROTO(struct arm_smmu_domain *domain),
  29. TP_ARGS(domain)
  30. );
  31. DEFINE_EVENT(iommu_tlbi, tlbi_end,
  32. TP_PROTO(struct arm_smmu_domain *domain),
  33. TP_ARGS(domain)
  34. );
  35. DECLARE_EVENT_CLASS(iommu_pgtable,
  36. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  37. unsigned long long ipa, size_t granule),
  38. TP_ARGS(domain, iova, ipa, granule),
  39. TP_STRUCT__entry(
  40. __string(group_name, dev_name(domain->dev))
  41. __field(unsigned long, iova)
  42. __field(unsigned long long, ipa)
  43. __field(size_t, granule)
  44. ),
  45. TP_fast_assign(
  46. __assign_str(group_name, dev_name(domain->dev));
  47. __entry->iova = iova;
  48. __entry->ipa = ipa;
  49. __entry->granule = granule;
  50. ),
  51. TP_printk("group=%s table_base_iova=%lx table_ipa=%llx table_size=%zx",
  52. __get_str(group_name), __entry->iova,
  53. __entry->ipa, __entry->granule
  54. )
  55. );
  56. DEFINE_EVENT(iommu_pgtable, iommu_pgtable_add,
  57. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  58. unsigned long long ipa, size_t granule),
  59. TP_ARGS(domain, iova, ipa, granule)
  60. );
  61. DEFINE_EVENT(iommu_pgtable, iommu_pgtable_remove,
  62. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  63. unsigned long long ipa, size_t granule),
  64. TP_ARGS(domain, iova, ipa, granule)
  65. );
  66. DECLARE_EVENT_CLASS(iommu_map_pages,
  67. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  68. size_t pgsize, size_t pgcount),
  69. TP_ARGS(domain, iova, pgsize, pgcount),
  70. TP_STRUCT__entry(
  71. __string(group_name, dev_name(domain->dev))
  72. __field(unsigned long, iova)
  73. __field(size_t, pgsize)
  74. __field(size_t, pgcount)
  75. ),
  76. TP_fast_assign(
  77. __assign_str(group_name, dev_name(domain->dev));
  78. __entry->iova = iova;
  79. __entry->pgsize = pgsize;
  80. __entry->pgcount = pgcount;
  81. ),
  82. TP_printk("group=%s iova=%lx size=%zx pgsize=%zx pgcount=%zx",
  83. __get_str(group_name), __entry->iova,
  84. __entry->pgsize * __entry->pgcount,
  85. __entry->pgsize, __entry->pgcount
  86. )
  87. );
  88. DEFINE_EVENT(iommu_map_pages, map_pages,
  89. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  90. size_t pgsize, size_t pgcount),
  91. TP_ARGS(domain, iova, pgsize, pgcount)
  92. );
  93. DEFINE_EVENT(iommu_map_pages, unmap_pages,
  94. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  95. size_t pgsize, size_t pgcount),
  96. TP_ARGS(domain, iova, pgsize, pgcount)
  97. );
  98. /* Refer to samples/ftrace_events */
  99. #ifndef __TRACE_EVENT_ARM_SMMU_HELPER_FUNCTIONS
  100. #define __TRACE_EVENT_ARM_SMMU_HELPER_FUNCTIONS
  101. static inline unsigned long sum_scatterlist_length(struct scatterlist *sgl,
  102. unsigned int nents)
  103. {
  104. int i = 0;
  105. unsigned long sum = 0;
  106. for (i = 0; i < nents; i++, sgl = sg_next(sgl))
  107. sum += sgl->length;
  108. return sum;
  109. }
  110. #endif
  111. TRACE_EVENT(map_sg,
  112. TP_PROTO(struct arm_smmu_domain *domain, unsigned long iova,
  113. struct scatterlist *sgl, unsigned int nents),
  114. TP_ARGS(domain, iova, sgl, nents),
  115. TP_STRUCT__entry(
  116. __string(group_name, dev_name(domain->dev))
  117. __field(unsigned long, iova)
  118. __field(unsigned long, size)
  119. ),
  120. TP_fast_assign(
  121. __assign_str(group_name, dev_name(domain->dev));
  122. __entry->iova = iova;
  123. __entry->size = sum_scatterlist_length(sgl, nents);
  124. ),
  125. TP_printk("group=%s iova=%lx size=%lx",
  126. __get_str(group_name), __entry->iova,
  127. __entry->size
  128. )
  129. );
  130. TRACE_EVENT(tlbsync_timeout,
  131. TP_PROTO(struct device *dev),
  132. TP_ARGS(dev),
  133. TP_STRUCT__entry(
  134. __string(device, dev_name(dev))
  135. ),
  136. TP_fast_assign(
  137. __assign_str(device, dev_name(dev));
  138. ),
  139. TP_printk("smmu=%s",
  140. __get_str(device)
  141. )
  142. );
  143. TRACE_EVENT(smmu_init,
  144. TP_PROTO(u64 time),
  145. TP_ARGS(time),
  146. TP_STRUCT__entry(
  147. __field(u64, time)
  148. ),
  149. TP_fast_assign(
  150. __entry->time = time;
  151. ),
  152. TP_printk("ARM SMMU init latency: %lld us", __entry->time)
  153. );
  154. #endif /* _TRACE_ARM_SMMU_H */
  155. #undef TRACE_INCLUDE_PATH
  156. #define TRACE_INCLUDE_PATH ../../drivers/iommu/arm/arm-smmu
  157. #undef TRACE_INCLUDE_FILE
  158. #define TRACE_INCLUDE_FILE arm-smmu-trace
  159. /* This part must be outside protection */
  160. #include <trace/define_trace.h>