/arch/powerpc/include/asm/kvm_booke.h

http://github.com/mirrors/linux · C Header · 106 lines · 73 code · 19 blank · 14 comment · 0 complexity · 27b39ba33763527dbe188b83d722c4a4 MD5 · raw file

  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. *
  4. * Copyright SUSE Linux Products GmbH 2010
  5. *
  6. * Authors: Alexander Graf <agraf@suse.de>
  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. static inline ulong kvmppc_get_fault_dar(struct kvm_vcpu *vcpu)
  75. {
  76. return vcpu->arch.fault_dear;
  77. }
  78. static inline bool kvmppc_supports_magic_page(struct kvm_vcpu *vcpu)
  79. {
  80. /* Magic page is only supported on e500v2 */
  81. #ifdef CONFIG_KVM_E500V2
  82. return true;
  83. #else
  84. return false;
  85. #endif
  86. }
  87. #endif /* __ASM_KVM_BOOKE_H__ */