arm_arch_timer.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * Copyright (C) 2012 ARM Ltd.
  3. * Author: Marc Zyngier <marc.zyngier@arm.com>
  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, write to the Free Software
  16. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  17. */
  18. #ifndef __ASM_ARM_KVM_ARCH_TIMER_H
  19. #define __ASM_ARM_KVM_ARCH_TIMER_H
  20. #include <linux/clocksource.h>
  21. #include <linux/hrtimer.h>
  22. #include <linux/workqueue.h>
  23. struct arch_timer_kvm {
  24. #ifdef CONFIG_KVM_ARM_TIMER
  25. /* Is the timer enabled */
  26. bool enabled;
  27. /* Virtual offset */
  28. cycle_t cntvoff;
  29. #endif
  30. };
  31. struct arch_timer_cpu {
  32. #ifdef CONFIG_KVM_ARM_TIMER
  33. /* Registers: control register, timer value */
  34. u32 cntv_ctl; /* Saved/restored */
  35. cycle_t cntv_cval; /* Saved/restored */
  36. /*
  37. * Anything that is not used directly from assembly code goes
  38. * here.
  39. */
  40. /* Background timer used when the guest is not running */
  41. struct hrtimer timer;
  42. /* Work queued with the above timer expires */
  43. struct work_struct expired;
  44. /* Background timer active */
  45. bool armed;
  46. /* Timer IRQ */
  47. const struct kvm_irq_level *irq;
  48. #endif
  49. };
  50. #ifdef CONFIG_KVM_ARM_TIMER
  51. int kvm_timer_hyp_init(void);
  52. void kvm_timer_enable(struct kvm *kvm);
  53. void kvm_timer_init(struct kvm *kvm);
  54. void kvm_timer_vcpu_reset(struct kvm_vcpu *vcpu,
  55. const struct kvm_irq_level *irq);
  56. void kvm_timer_vcpu_init(struct kvm_vcpu *vcpu);
  57. void kvm_timer_flush_hwstate(struct kvm_vcpu *vcpu);
  58. void kvm_timer_sync_hwstate(struct kvm_vcpu *vcpu);
  59. void kvm_timer_vcpu_terminate(struct kvm_vcpu *vcpu);
  60. u64 kvm_arm_timer_get_reg(struct kvm_vcpu *, u64 regid);
  61. int kvm_arm_timer_set_reg(struct kvm_vcpu *, u64 regid, u64 value);
  62. #else
  63. static inline int kvm_timer_hyp_init(void)
  64. {
  65. return 0;
  66. };
  67. static inline void kvm_timer_enable(struct kvm *kvm) {}
  68. static inline void kvm_timer_init(struct kvm *kvm) {}
  69. static inline void kvm_timer_vcpu_reset(struct kvm_vcpu *vcpu,
  70. const struct kvm_irq_level *irq) {}
  71. static inline void kvm_timer_vcpu_init(struct kvm_vcpu *vcpu) {}
  72. static inline void kvm_timer_flush_hwstate(struct kvm_vcpu *vcpu) {}
  73. static inline void kvm_timer_sync_hwstate(struct kvm_vcpu *vcpu) {}
  74. static inline void kvm_timer_vcpu_terminate(struct kvm_vcpu *vcpu) {}
  75. static inline int kvm_arm_timer_set_reg(struct kvm_vcpu *vcpu, u64 regid, u64 value)
  76. {
  77. return 0;
  78. }
  79. static inline u64 kvm_arm_timer_get_reg(struct kvm_vcpu *vcpu, u64 regid)
  80. {
  81. return 0;
  82. }
  83. #endif
  84. #endif