#ifdef __V3_32BIT__
-void __inline__ v3_cpuid(uint_t target, uint_t * eax, uint_t * ebx, uint_t * ecx, uint_t * edx) {
+void __inline__ v3_cpuid(uint_t target, addr_t * eax, addr_t * ebx, addr_t * ecx, addr_t * edx) {
__asm__ __volatile__ (
"pushl %%ebx\n\t"
"cpuid\n\t"
return;
}
+#elif __V3_64BIT__
+void __inline__ v3_cpuid(uint_t target, addr_t * eax, addr_t * ebx, addr_t * ecx, addr_t * edx) {
+ __asm__ __volatile__ (
+ "pushq %%rbx\n\t"
+ "cpuid\n\t"
+ "movq %%rbx, %%rsi\n\t"
+ "popq %%rbx\n\t"
+ : "=a" (*eax), "=S" (*ebx), "=c" (*ecx), "=d" (*edx)
+ : "a" (target)
+ );
+ return;
+}
+
+#endif
void __inline__ v3_set_msr(uint_t msr, uint_t high_byte, uint_t low_byte) {
__asm__ __volatile__ ("cli");
}
-#endif
#if 1
// Dinda
uint_t vm_cr_low = 0, vm_cr_high = 0;
- uint_t eax = 0, ebx = 0, ecx = 0, edx = 0;
+ addr_t eax = 0, ebx = 0, ecx = 0, edx = 0;
v3_cpuid(CPUID_FEATURE_IDS, &eax, &ebx, &ecx, &edx);
#else
uint_t eax = 0, ebx = 0, ecx = 0, edx = 0;
- uint_t vm_cr_low = 0, vm_cr_high = 0;
+ addr_t vm_cr_low = 0, vm_cr_high = 0;
v3_cpuid(CPUID_FEATURE_IDS, &eax, &ebx, &ecx, &edx);
}
static int has_svm_nested_paging() {
- uint_t eax = 0, ebx = 0, ecx = 0, edx = 0;
+ addr_t eax = 0, ebx = 0, ecx = 0, edx = 0;
v3_cpuid(CPUID_SVM_REV_AND_FEATURE_IDS, &eax, &ebx, &ecx, &edx);