В настоящее время я пытаюсь собрать небольшой гипервизор и ядро, используя kvm, и я пытаюсь заставить гиперколлы с несколькими аргументами работать правильно.
Вот что я пробовал:
// guest.c
#define KVM_HYPERCALL vmcall
// #define KVM_HYPERCALL vmmcall
// #define KVM_HYPERCALL ".byte 0x0f,0x01,0xd9"
// #define KVM_HYPERCALL .byte 0x0f,0x01,0xc1"
static inline long kvm_hypercall4(int nr, unsigned long p1,
unsigned long p2, unsigned long p3,
unsigned long p4) {
long ret;
asm volatile(KVM_HYPERCALL
: "=a"(ret)
: "a"(nr), "b"(p1), "c"(p2), "d"(p3), "S"(p4)
: "memory");
return ret;
}
Любой из этих Гиперколлов приводит к vcpu->kvm_run->exit_reason
, равному 6, что, к моему удивлению, KVM_EXIT_MMIO
вместо KVM_EXIT_HYPERCALL
switch (vcpu->kvm_run->exit_reason) {
case KVM_EXIT_MMIO:
printf("syscall: %lld\n", vcpu->kvm_run->hypercall.nr); // prints 0
printf("arg 1: %lld\n", vcpu->kvm_run->hypercall.args[1]); // prints 0
printf("arg 2: %lld\n", vcpu->kvm_run->hypercall.args[2]); // prints 0
printf("arg 3: %lld\n", vcpu->kvm_run->hypercall.args[3]); // prints 0
if(ioctl(vcpu->fd, KVM_GET_REGS, ®s)<0) exit 1;
printf("rax: %lld\n", regs.rax); // prints 0
printf("rbx: %lld\n", regs.rbx); // prints 0
printf("rcx: %lld\n", regs.rcx); // prints 0
Помимо причины выхода KVM_EXIT_MMIO
, почему регистры не набор? Как правильно вызвать KVM_EXIT_HYPERCALL с несколькими аргументами?
Заранее спасибо
РЕДАКТИРОВАТЬ: В случае, если это имеет значение: я использую процессор Intel i7 9-го поколения, на котором запущен debian с linux ядро 5.4