perf.h 4.6 KB

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