kvm_booke.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. *
  4. * Copyright SUSE Linux Products GmbH 2010
  5. *
  6. * Authors: Alexander Graf <[email protected]>
  7. */
  8. #ifndef __ASM_KVM_BOOKE_H__
  9. #define __ASM_KVM_BOOKE_H__
  10. #include <linux/types.h>
  11. #include <linux/kvm_host.h>
  12. /*
  13. * Number of available lpids. Only the low-order 6 bits of LPID rgister are
  14. * implemented on e500mc+ cores.
  15. */
  16. #define KVMPPC_NR_LPIDS 64
  17. #define KVMPPC_INST_EHPRIV 0x7c00021c
  18. #define EHPRIV_OC_SHIFT 11
  19. /* "ehpriv 1" : ehpriv with OC = 1 is used for debug emulation */
  20. #define EHPRIV_OC_DEBUG 1
  21. static inline void kvmppc_set_gpr(struct kvm_vcpu *vcpu, int num, ulong val)
  22. {
  23. vcpu->arch.regs.gpr[num] = val;
  24. }
  25. static inline ulong kvmppc_get_gpr(struct kvm_vcpu *vcpu, int num)
  26. {
  27. return vcpu->arch.regs.gpr[num];
  28. }
  29. static inline void kvmppc_set_cr(struct kvm_vcpu *vcpu, u32 val)
  30. {
  31. vcpu->arch.regs.ccr = val;
  32. }
  33. static inline u32 kvmppc_get_cr(struct kvm_vcpu *vcpu)
  34. {
  35. return vcpu->arch.regs.ccr;
  36. }
  37. static inline void kvmppc_set_xer(struct kvm_vcpu *vcpu, ulong val)
  38. {
  39. vcpu->arch.regs.xer = val;
  40. }
  41. static inline ulong kvmppc_get_xer(struct kvm_vcpu *vcpu)
  42. {
  43. return vcpu->arch.regs.xer;
  44. }
  45. static inline bool kvmppc_need_byteswap(struct kvm_vcpu *vcpu)
  46. {
  47. /* XXX Would need to check TLB entry */
  48. return false;
  49. }
  50. static inline void kvmppc_set_ctr(struct kvm_vcpu *vcpu, ulong val)
  51. {
  52. vcpu->arch.regs.ctr = val;
  53. }
  54. static inline ulong kvmppc_get_ctr(struct kvm_vcpu *vcpu)
  55. {
  56. return vcpu->arch.regs.ctr;
  57. }
  58. static inline void kvmppc_set_lr(struct kvm_vcpu *vcpu, ulong val)
  59. {
  60. vcpu->arch.regs.link = val;
  61. }
  62. static inline ulong kvmppc_get_lr(struct kvm_vcpu *vcpu)
  63. {
  64. return vcpu->arch.regs.link;
  65. }
  66. static inline void kvmppc_set_pc(struct kvm_vcpu *vcpu, ulong val)
  67. {
  68. vcpu->arch.regs.nip = val;
  69. }
  70. static inline ulong kvmppc_get_pc(struct kvm_vcpu *vcpu)
  71. {
  72. return vcpu->arch.regs.nip;
  73. }
  74. #ifdef CONFIG_BOOKE
  75. static inline ulong kvmppc_get_fault_dar(struct kvm_vcpu *vcpu)
  76. {
  77. return vcpu->arch.fault_dear;
  78. }
  79. #endif
  80. static inline bool kvmppc_supports_magic_page(struct kvm_vcpu *vcpu)
  81. {
  82. /* Magic page is only supported on e500v2 */
  83. #ifdef CONFIG_KVM_E500V2
  84. return true;
  85. #else
  86. return false;
  87. #endif
  88. }
  89. #endif /* __ASM_KVM_BOOKE_H__ */