cpuid.h 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #ifndef ARCH_X86_KVM_CPUID_H
  2. #define ARCH_X86_KVM_CPUID_H
  3. #include "x86.h"
  4. void kvm_update_cpuid(struct kvm_vcpu *vcpu);
  5. struct kvm_cpuid_entry2 *kvm_find_cpuid_entry(struct kvm_vcpu *vcpu,
  6. u32 function, u32 index);
  7. int kvm_dev_ioctl_get_cpuid(struct kvm_cpuid2 *cpuid,
  8. struct kvm_cpuid_entry2 __user *entries,
  9. unsigned int type);
  10. int kvm_vcpu_ioctl_set_cpuid(struct kvm_vcpu *vcpu,
  11. struct kvm_cpuid *cpuid,
  12. struct kvm_cpuid_entry __user *entries);
  13. int kvm_vcpu_ioctl_set_cpuid2(struct kvm_vcpu *vcpu,
  14. struct kvm_cpuid2 *cpuid,
  15. struct kvm_cpuid_entry2 __user *entries);
  16. int kvm_vcpu_ioctl_get_cpuid2(struct kvm_vcpu *vcpu,
  17. struct kvm_cpuid2 *cpuid,
  18. struct kvm_cpuid_entry2 __user *entries);
  19. void kvm_cpuid(struct kvm_vcpu *vcpu, u32 *eax, u32 *ebx, u32 *ecx, u32 *edx);
  20. static inline bool guest_cpuid_has_xsave(struct kvm_vcpu *vcpu)
  21. {
  22. struct kvm_cpuid_entry2 *best;
  23. if (!static_cpu_has(X86_FEATURE_XSAVE))
  24. return 0;
  25. best = kvm_find_cpuid_entry(vcpu, 1, 0);
  26. return best && (best->ecx & bit(X86_FEATURE_XSAVE));
  27. }
  28. static inline bool guest_cpuid_has_tsc_adjust(struct kvm_vcpu *vcpu)
  29. {
  30. struct kvm_cpuid_entry2 *best;
  31. best = kvm_find_cpuid_entry(vcpu, 7, 0);
  32. return best && (best->ebx & bit(X86_FEATURE_TSC_ADJUST));
  33. }
  34. static inline bool guest_cpuid_has_smep(struct kvm_vcpu *vcpu)
  35. {
  36. struct kvm_cpuid_entry2 *best;
  37. best = kvm_find_cpuid_entry(vcpu, 7, 0);
  38. return best && (best->ebx & bit(X86_FEATURE_SMEP));
  39. }
  40. static inline bool guest_cpuid_has_smap(struct kvm_vcpu *vcpu)
  41. {
  42. struct kvm_cpuid_entry2 *best;
  43. best = kvm_find_cpuid_entry(vcpu, 7, 0);
  44. return best && (best->ebx & bit(X86_FEATURE_SMAP));
  45. }
  46. static inline bool guest_cpuid_has_fsgsbase(struct kvm_vcpu *vcpu)
  47. {
  48. struct kvm_cpuid_entry2 *best;
  49. best = kvm_find_cpuid_entry(vcpu, 7, 0);
  50. return best && (best->ebx & bit(X86_FEATURE_FSGSBASE));
  51. }
  52. static inline bool guest_cpuid_has_osvw(struct kvm_vcpu *vcpu)
  53. {
  54. struct kvm_cpuid_entry2 *best;
  55. best = kvm_find_cpuid_entry(vcpu, 0x80000001, 0);
  56. return best && (best->ecx & bit(X86_FEATURE_OSVW));
  57. }
  58. static inline bool guest_cpuid_has_pcid(struct kvm_vcpu *vcpu)
  59. {
  60. struct kvm_cpuid_entry2 *best;
  61. best = kvm_find_cpuid_entry(vcpu, 1, 0);
  62. return best && (best->ecx & bit(X86_FEATURE_PCID));
  63. }
  64. static inline bool guest_cpuid_has_x2apic(struct kvm_vcpu *vcpu)
  65. {
  66. struct kvm_cpuid_entry2 *best;
  67. best = kvm_find_cpuid_entry(vcpu, 1, 0);
  68. return best && (best->ecx & bit(X86_FEATURE_X2APIC));
  69. }
  70. static inline bool guest_cpuid_has_gbpages(struct kvm_vcpu *vcpu)
  71. {
  72. struct kvm_cpuid_entry2 *best;
  73. best = kvm_find_cpuid_entry(vcpu, 0x80000001, 0);
  74. return best && (best->edx & bit(X86_FEATURE_GBPAGES));
  75. }
  76. #endif