arm_pmu.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * Copyright (C) 2015 Linaro Ltd.
  3. * Author: Shannon Zhao <shannon.zhao@linaro.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License version 2 as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. #ifndef __ASM_ARM_KVM_PMU_H
  18. #define __ASM_ARM_KVM_PMU_H
  19. #include <linux/perf_event.h>
  20. #include <asm/perf_event.h>
  21. #define ARMV8_PMU_CYCLE_IDX (ARMV8_PMU_MAX_COUNTERS - 1)
  22. #ifdef CONFIG_KVM_ARM_PMU
  23. struct kvm_pmc {
  24. u8 idx; /* index into the pmu->pmc array */
  25. struct perf_event *perf_event;
  26. u64 bitmask;
  27. };
  28. struct kvm_pmu {
  29. int irq_num;
  30. struct kvm_pmc pmc[ARMV8_PMU_MAX_COUNTERS];
  31. bool ready;
  32. bool irq_level;
  33. };
  34. #define kvm_arm_pmu_v3_ready(v) ((v)->arch.pmu.ready)
  35. #define kvm_arm_pmu_irq_initialized(v) ((v)->arch.pmu.irq_num >= VGIC_NR_SGIS)
  36. u64 kvm_pmu_get_counter_value(struct kvm_vcpu *vcpu, u64 select_idx);
  37. void kvm_pmu_set_counter_value(struct kvm_vcpu *vcpu, u64 select_idx, u64 val);
  38. u64 kvm_pmu_valid_counter_mask(struct kvm_vcpu *vcpu);
  39. void kvm_pmu_vcpu_reset(struct kvm_vcpu *vcpu);
  40. void kvm_pmu_vcpu_destroy(struct kvm_vcpu *vcpu);
  41. void kvm_pmu_disable_counter(struct kvm_vcpu *vcpu, u64 val);
  42. void kvm_pmu_enable_counter(struct kvm_vcpu *vcpu, u64 val);
  43. void kvm_pmu_overflow_set(struct kvm_vcpu *vcpu, u64 val);
  44. void kvm_pmu_flush_hwstate(struct kvm_vcpu *vcpu);
  45. void kvm_pmu_sync_hwstate(struct kvm_vcpu *vcpu);
  46. void kvm_pmu_software_increment(struct kvm_vcpu *vcpu, u64 val);
  47. void kvm_pmu_handle_pmcr(struct kvm_vcpu *vcpu, u64 val);
  48. void kvm_pmu_set_counter_event_type(struct kvm_vcpu *vcpu, u64 data,
  49. u64 select_idx);
  50. bool kvm_arm_support_pmu_v3(void);
  51. int kvm_arm_pmu_v3_set_attr(struct kvm_vcpu *vcpu,
  52. struct kvm_device_attr *attr);
  53. int kvm_arm_pmu_v3_get_attr(struct kvm_vcpu *vcpu,
  54. struct kvm_device_attr *attr);
  55. int kvm_arm_pmu_v3_has_attr(struct kvm_vcpu *vcpu,
  56. struct kvm_device_attr *attr);
  57. #else
  58. struct kvm_pmu {
  59. };
  60. #define kvm_arm_pmu_v3_ready(v) (false)
  61. #define kvm_arm_pmu_irq_initialized(v) (false)
  62. static inline u64 kvm_pmu_get_counter_value(struct kvm_vcpu *vcpu,
  63. u64 select_idx)
  64. {
  65. return 0;
  66. }
  67. static inline void kvm_pmu_set_counter_value(struct kvm_vcpu *vcpu,
  68. u64 select_idx, u64 val) {}
  69. static inline u64 kvm_pmu_valid_counter_mask(struct kvm_vcpu *vcpu)
  70. {
  71. return 0;
  72. }
  73. static inline void kvm_pmu_vcpu_reset(struct kvm_vcpu *vcpu) {}
  74. static inline void kvm_pmu_vcpu_destroy(struct kvm_vcpu *vcpu) {}
  75. static inline void kvm_pmu_disable_counter(struct kvm_vcpu *vcpu, u64 val) {}
  76. static inline void kvm_pmu_enable_counter(struct kvm_vcpu *vcpu, u64 val) {}
  77. static inline void kvm_pmu_overflow_set(struct kvm_vcpu *vcpu, u64 val) {}
  78. static inline void kvm_pmu_flush_hwstate(struct kvm_vcpu *vcpu) {}
  79. static inline void kvm_pmu_sync_hwstate(struct kvm_vcpu *vcpu) {}
  80. static inline void kvm_pmu_software_increment(struct kvm_vcpu *vcpu, u64 val) {}
  81. static inline void kvm_pmu_handle_pmcr(struct kvm_vcpu *vcpu, u64 val) {}
  82. static inline void kvm_pmu_set_counter_event_type(struct kvm_vcpu *vcpu,
  83. u64 data, u64 select_idx) {}
  84. static inline bool kvm_arm_support_pmu_v3(void) { return false; }
  85. static inline int kvm_arm_pmu_v3_set_attr(struct kvm_vcpu *vcpu,
  86. struct kvm_device_attr *attr)
  87. {
  88. return -ENXIO;
  89. }
  90. static inline int kvm_arm_pmu_v3_get_attr(struct kvm_vcpu *vcpu,
  91. struct kvm_device_attr *attr)
  92. {
  93. return -ENXIO;
  94. }
  95. static inline int kvm_arm_pmu_v3_has_attr(struct kvm_vcpu *vcpu,
  96. struct kvm_device_attr *attr)
  97. {
  98. return -ENXIO;
  99. }
  100. #endif
  101. #endif