mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 10:13:56 -06:00
kvm: i8254: require KVM_CAP_PIT2 and KVM_CAP_PIT_STATE2
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
52b04ea49d
commit
39dd3e1f55
4 changed files with 13 additions and 39 deletions
|
@ -97,24 +97,12 @@ static void kvm_pit_get(PITCommonState *pit)
|
|||
return;
|
||||
}
|
||||
|
||||
if (kvm_has_pit_state2()) {
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_GET_PIT2, &kpit);
|
||||
if (ret < 0) {
|
||||
fprintf(stderr, "KVM_GET_PIT2 failed: %s\n", strerror(-ret));
|
||||
abort();
|
||||
}
|
||||
pit->channels[0].irq_disabled = kpit.flags & KVM_PIT_FLAGS_HPET_LEGACY;
|
||||
} else {
|
||||
/*
|
||||
* kvm_pit_state2 is superset of kvm_pit_state struct,
|
||||
* so we can use it for KVM_GET_PIT as well.
|
||||
*/
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_GET_PIT, &kpit);
|
||||
if (ret < 0) {
|
||||
fprintf(stderr, "KVM_GET_PIT failed: %s\n", strerror(-ret));
|
||||
abort();
|
||||
}
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_GET_PIT2, &kpit);
|
||||
if (ret < 0) {
|
||||
fprintf(stderr, "KVM_GET_PIT2 failed: %s\n", strerror(-ret));
|
||||
abort();
|
||||
}
|
||||
pit->channels[0].irq_disabled = kpit.flags & KVM_PIT_FLAGS_HPET_LEGACY;
|
||||
for (i = 0; i < 3; i++) {
|
||||
kchan = &kpit.channels[i];
|
||||
sc = &pit->channels[i];
|
||||
|
@ -170,12 +158,9 @@ static void kvm_pit_put(PITCommonState *pit)
|
|||
kchan->count_load_time = sc->count_load_time - s->kernel_clock_offset;
|
||||
}
|
||||
|
||||
ret = kvm_vm_ioctl(kvm_state,
|
||||
kvm_has_pit_state2() ? KVM_SET_PIT2 : KVM_SET_PIT,
|
||||
&kpit);
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_SET_PIT2, &kpit);
|
||||
if (ret < 0) {
|
||||
fprintf(stderr, "%s failed: %s\n",
|
||||
kvm_has_pit_state2() ? "KVM_SET_PIT2" : "KVM_SET_PIT",
|
||||
fprintf(stderr, "KVM_SET_PIT2 failed: %s\n",
|
||||
strerror(-ret));
|
||||
abort();
|
||||
}
|
||||
|
@ -261,11 +246,12 @@ static void kvm_pit_realizefn(DeviceState *dev, Error **errp)
|
|||
};
|
||||
int ret;
|
||||
|
||||
if (kvm_check_extension(kvm_state, KVM_CAP_PIT2)) {
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_CREATE_PIT2, &config);
|
||||
} else {
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_CREATE_PIT);
|
||||
if (!kvm_check_extension(kvm_state, KVM_CAP_PIT_STATE2) ||
|
||||
!kvm_check_extension(kvm_state, KVM_CAP_PIT2)) {
|
||||
error_setg(errp, "In-kernel PIT not available");
|
||||
}
|
||||
|
||||
ret = kvm_vm_ioctl(kvm_state, KVM_CREATE_PIT2, &config);
|
||||
if (ret < 0) {
|
||||
error_setg(errp, "Create kernel PIC irqchip failed: %s",
|
||||
strerror(-ret));
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue