kvm_booke.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * This program is free software; you can redistribute it and/or modify
  3. * it under the terms of the GNU General Public License, version 2, as
  4. * published by the Free Software Foundation.
  5. *
  6. * This program is distributed in the hope that it will be useful,
  7. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  8. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  9. * GNU General Public License for more details.
  10. *
  11. * You should have received a copy of the GNU General Public License
  12. * along with this program; if not, write to the Free Software
  13. * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  14. *
  15. * Copyright SUSE Linux Products GmbH 2010
  16. *
  17. * Authors: Alexander Graf <agraf@suse.de>
  18. */
  19. #ifndef __ASM_KVM_BOOKE_H__
  20. #define __ASM_KVM_BOOKE_H__
  21. #include <linux/types.h>
  22. #include <linux/kvm_host.h>
  23. /* LPIDs we support with this build -- runtime limit may be lower */
  24. #define KVMPPC_NR_LPIDS 64
  25. static inline void kvmppc_set_gpr(struct kvm_vcpu *vcpu, int num, ulong val)
  26. {
  27. vcpu->arch.gpr[num] = val;
  28. }
  29. static inline ulong kvmppc_get_gpr(struct kvm_vcpu *vcpu, int num)
  30. {
  31. return vcpu->arch.gpr[num];
  32. }
  33. static inline void kvmppc_set_cr(struct kvm_vcpu *vcpu, u32 val)
  34. {
  35. vcpu->arch.cr = val;
  36. }
  37. static inline u32 kvmppc_get_cr(struct kvm_vcpu *vcpu)
  38. {
  39. return vcpu->arch.cr;
  40. }
  41. static inline void kvmppc_set_xer(struct kvm_vcpu *vcpu, u32 val)
  42. {
  43. vcpu->arch.xer = val;
  44. }
  45. static inline u32 kvmppc_get_xer(struct kvm_vcpu *vcpu)
  46. {
  47. return vcpu->arch.xer;
  48. }
  49. static inline u32 kvmppc_get_last_inst(struct kvm_vcpu *vcpu)
  50. {
  51. return vcpu->arch.last_inst;
  52. }
  53. static inline void kvmppc_set_ctr(struct kvm_vcpu *vcpu, ulong val)
  54. {
  55. vcpu->arch.ctr = val;
  56. }
  57. static inline ulong kvmppc_get_ctr(struct kvm_vcpu *vcpu)
  58. {
  59. return vcpu->arch.ctr;
  60. }
  61. static inline void kvmppc_set_lr(struct kvm_vcpu *vcpu, ulong val)
  62. {
  63. vcpu->arch.lr = val;
  64. }
  65. static inline ulong kvmppc_get_lr(struct kvm_vcpu *vcpu)
  66. {
  67. return vcpu->arch.lr;
  68. }
  69. static inline void kvmppc_set_pc(struct kvm_vcpu *vcpu, ulong val)
  70. {
  71. vcpu->arch.pc = val;
  72. }
  73. static inline ulong kvmppc_get_pc(struct kvm_vcpu *vcpu)
  74. {
  75. return vcpu->arch.pc;
  76. }
  77. static inline ulong kvmppc_get_fault_dar(struct kvm_vcpu *vcpu)
  78. {
  79. return vcpu->arch.fault_dear;
  80. }
  81. static inline ulong kvmppc_get_msr(struct kvm_vcpu *vcpu)
  82. {
  83. return vcpu->arch.shared->msr;
  84. }
  85. #endif /* __ASM_KVM_BOOKE_H__ */