perf.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. #ifndef LINUX_POWERPC_PERF_REQ_GEN_PERF_H_
  2. #define LINUX_POWERPC_PERF_REQ_GEN_PERF_H_
  3. #include <linux/perf_event.h>
  4. #ifndef REQUEST_FILE
  5. #error "REQUEST_FILE must be defined before including"
  6. #endif
  7. #ifndef NAME_LOWER
  8. #error "NAME_LOWER must be defined before including"
  9. #endif
  10. #ifndef NAME_UPPER
  11. #error "NAME_UPPER must be defined before including"
  12. #endif
  13. #define BE_TYPE_b1 __u8
  14. #define BE_TYPE_b2 __be16
  15. #define BE_TYPE_b4 __be32
  16. #define BE_TYPE_b8 __be64
  17. #define BYTES_TO_BE_TYPE(bytes) \
  18. BE_TYPE_b##bytes
  19. #define CAT2_(a, b) a ## b
  20. #define CAT2(a, b) CAT2_(a, b)
  21. #define CAT3_(a, b, c) a ## b ## c
  22. #define CAT3(a, b, c) CAT3_(a, b, c)
  23. /*
  24. * enumerate the request values as
  25. * <NAME_UPPER>_<request name> = <request value>
  26. */
  27. #define REQUEST_VALUE__(name_upper, r_name) name_upper ## _ ## r_name
  28. #define REQUEST_VALUE_(name_upper, r_name) REQUEST_VALUE__(name_upper, r_name)
  29. #define REQUEST_VALUE(r_name) REQUEST_VALUE_(NAME_UPPER, r_name)
  30. #include "_clear.h"
  31. #define REQUEST_(r_name, r_value, r_idx_1, r_fields) \
  32. REQUEST_VALUE(r_name) = r_value,
  33. enum CAT2(NAME_LOWER, _requests) {
  34. #include REQUEST_FILE
  35. };
  36. /*
  37. * For each request:
  38. * struct <NAME_LOWER>_<request name> {
  39. * r_fields
  40. * };
  41. */
  42. #include "_clear.h"
  43. #define STRUCT_NAME__(name_lower, r_name) name_lower ## _ ## r_name
  44. #define STRUCT_NAME_(name_lower, r_name) STRUCT_NAME__(name_lower, r_name)
  45. #define STRUCT_NAME(r_name) STRUCT_NAME_(NAME_LOWER, r_name)
  46. #define REQUEST_(r_name, r_value, r_idx_1, r_fields) \
  47. struct STRUCT_NAME(r_name) { \
  48. r_fields \
  49. };
  50. #define __field_(r_name, r_value, r_idx_1, f_offset, f_bytes, f_name) \
  51. BYTES_TO_BE_TYPE(f_bytes) f_name;
  52. #define __count_(r_name, r_value, r_idx_1, f_offset, f_bytes, f_name) \
  53. __field_(r_name, r_value, r_idx_1, f_offset, f_bytes, f_name)
  54. #define __array_(r_name, r_value, r_idx_1, a_offset, a_bytes, a_name) \
  55. __u8 a_name[a_bytes];
  56. #include REQUEST_FILE
  57. /*
  58. * Generate a check of the field offsets
  59. * <NAME_LOWER>_assert_offsets_correct()
  60. */
  61. #include "_clear.h"
  62. #define REQUEST_(r_name, r_value, index, r_fields) \
  63. r_fields
  64. #define __field_(r_name, r_value, r_idx_1, f_offset, f_size, f_name) \
  65. BUILD_BUG_ON(offsetof(struct STRUCT_NAME(r_name), f_name) != f_offset);
  66. #define __count_(r_name, r_value, r_idx_1, c_offset, c_size, c_name) \
  67. __field_(r_name, r_value, r_idx_1, c_offset, c_size, c_name)
  68. #define __array_(r_name, r_value, r_idx_1, a_offset, a_size, a_name) \
  69. __field_(r_name, r_value, r_idx_1, a_offset, a_size, a_name)
  70. static inline void CAT2(NAME_LOWER, _assert_offsets_correct)(void)
  71. {
  72. #include REQUEST_FILE
  73. }
  74. /*
  75. * Generate event attributes:
  76. * PMU_EVENT_ATTR_STRING(<request name>_<field name>,
  77. * <NAME_LOWER>_event_attr_<request name>_<field name>,
  78. * "request=<request value>"
  79. * "starting_index=<starting index type>"
  80. * "counter_info_version=CURRENT_COUNTER_INFO_VERSION"
  81. * "length=<f_size>"
  82. * "offset=<f_offset>")
  83. *
  84. * TODO: counter_info_version may need to vary, we should interperate the
  85. * value to some extent
  86. */
  87. #define EVENT_ATTR_NAME__(name, r_name, c_name) \
  88. name ## _event_attr_ ## r_name ## _ ## c_name
  89. #define EVENT_ATTR_NAME_(name, r_name, c_name) \
  90. EVENT_ATTR_NAME__(name, r_name, c_name)
  91. #define EVENT_ATTR_NAME(r_name, c_name) \
  92. EVENT_ATTR_NAME_(NAME_LOWER, r_name, c_name)
  93. #include "_clear.h"
  94. #define __field_(r_name, r_value, r_idx_1, f_offset, f_size, f_name)
  95. #define __array_(r_name, r_value, r_idx_1, a_offset, a_size, a_name)
  96. #define __count_(r_name, r_value, r_idx_1, c_offset, c_size, c_name) \
  97. PMU_EVENT_ATTR_STRING( \
  98. CAT3(r_name, _, c_name), \
  99. EVENT_ATTR_NAME(r_name, c_name), \
  100. "request=" __stringify(r_value) "," \
  101. r_idx_1 "," \
  102. "counter_info_version=" \
  103. __stringify(COUNTER_INFO_VERSION_CURRENT) "," \
  104. "length=" #c_size "," \
  105. "offset=" #c_offset)
  106. #define REQUEST_(r_name, r_value, r_idx_1, r_fields) \
  107. r_fields
  108. #include REQUEST_FILE
  109. /*
  110. * Define event attribute array
  111. * static struct attribute *hv_gpci_event_attrs[] = {
  112. * &<NAME_LOWER>_event_attr_<request name>_<field name>.attr,
  113. * };
  114. */
  115. #include "_clear.h"
  116. #define __field_(r_name, r_value, r_idx_1, f_offset, f_size, f_name)
  117. #define __count_(r_name, r_value, r_idx_1, c_offset, c_size, c_name) \
  118. &EVENT_ATTR_NAME(r_name, c_name).attr.attr,
  119. #define __array_(r_name, r_value, r_idx_1, a_offset, a_size, a_name)
  120. #define REQUEST_(r_name, r_value, r_idx_1, r_fields) \
  121. r_fields
  122. static __maybe_unused struct attribute *hv_gpci_event_attrs[] = {
  123. #include REQUEST_FILE
  124. NULL
  125. };
  126. /* cleanup */
  127. #include "_clear.h"
  128. #undef EVENT_ATTR_NAME
  129. #undef EVENT_ATTR_NAME_
  130. #undef BIT_NAME
  131. #undef BIT_NAME_
  132. #undef STRUCT_NAME
  133. #undef REQUEST_VALUE
  134. #undef REQUEST_VALUE_
  135. #endif