hv-common.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #ifndef LINUX_POWERPC_PERF_HV_COMMON_H_
  2. #define LINUX_POWERPC_PERF_HV_COMMON_H_
  3. #include <linux/perf_event.h>
  4. #include <linux/types.h>
  5. struct hv_perf_caps {
  6. u16 version;
  7. u16 collect_privileged:1,
  8. ga:1,
  9. expanded:1,
  10. lab:1,
  11. unused:12;
  12. };
  13. unsigned long hv_perf_caps_get(struct hv_perf_caps *caps);
  14. #define EVENT_DEFINE_RANGE_FORMAT(name, attr_var, bit_start, bit_end) \
  15. PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end); \
  16. EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end)
  17. /*
  18. * The EVENT_DEFINE_RANGE_FORMAT() macro above includes helper functions
  19. * for the fields (eg: event_get_starting_index()). For some fields we
  20. * need the bit-range definition, but no the helper functions. Define a
  21. * lite version of the above macro without the helpers and silence
  22. * compiler warnings unused static functions.
  23. */
  24. #define EVENT_DEFINE_RANGE_FORMAT_LITE(name, attr_var, bit_start, bit_end) \
  25. PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end);
  26. #define EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end) \
  27. static u64 event_get_##name##_max(void) \
  28. { \
  29. BUILD_BUG_ON((bit_start > bit_end) \
  30. || (bit_end >= (sizeof(1ull) * 8))); \
  31. return (((1ull << (bit_end - bit_start)) - 1) << 1) + 1; \
  32. } \
  33. static u64 event_get_##name(struct perf_event *event) \
  34. { \
  35. return (event->attr.attr_var >> (bit_start)) & \
  36. event_get_##name##_max(); \
  37. }
  38. #endif