2
0

kvmclock.c 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /*
  2. * QEMU KVM support, paravirtual clock device
  3. *
  4. * Copyright (C) 2011 Siemens AG
  5. *
  6. * Authors:
  7. * Jan Kiszka <jan.kiszka@siemens.com>
  8. *
  9. * This work is licensed under the terms of the GNU GPL version 2.
  10. * See the COPYING file in the top-level directory.
  11. *
  12. */
  13. #include "qemu-common.h"
  14. #include "sysemu.h"
  15. #include "sysbus.h"
  16. #include "kvm.h"
  17. #include "kvmclock.h"
  18. #include <linux/kvm.h>
  19. #include <linux/kvm_para.h>
  20. typedef struct KVMClockState {
  21. SysBusDevice busdev;
  22. uint64_t clock;
  23. bool clock_valid;
  24. } KVMClockState;
  25. static void kvmclock_pre_save(void *opaque)
  26. {
  27. KVMClockState *s = opaque;
  28. struct kvm_clock_data data;
  29. int ret;
  30. if (s->clock_valid) {
  31. return;
  32. }
  33. ret = kvm_vm_ioctl(kvm_state, KVM_GET_CLOCK, &data);
  34. if (ret < 0) {
  35. fprintf(stderr, "KVM_GET_CLOCK failed: %s\n", strerror(ret));
  36. data.clock = 0;
  37. }
  38. s->clock = data.clock;
  39. /*
  40. * If the VM is stopped, declare the clock state valid to avoid re-reading
  41. * it on next vmsave (which would return a different value). Will be reset
  42. * when the VM is continued.
  43. */
  44. s->clock_valid = !runstate_is_running();
  45. }
  46. static int kvmclock_post_load(void *opaque, int version_id)
  47. {
  48. KVMClockState *s = opaque;
  49. struct kvm_clock_data data;
  50. data.clock = s->clock;
  51. data.flags = 0;
  52. return kvm_vm_ioctl(kvm_state, KVM_SET_CLOCK, &data);
  53. }
  54. static void kvmclock_vm_state_change(void *opaque, int running,
  55. RunState state)
  56. {
  57. KVMClockState *s = opaque;
  58. if (running) {
  59. s->clock_valid = false;
  60. }
  61. }
  62. static int kvmclock_init(SysBusDevice *dev)
  63. {
  64. KVMClockState *s = FROM_SYSBUS(KVMClockState, dev);
  65. qemu_add_vm_change_state_handler(kvmclock_vm_state_change, s);
  66. return 0;
  67. }
  68. static const VMStateDescription kvmclock_vmsd = {
  69. .name = "kvmclock",
  70. .version_id = 1,
  71. .minimum_version_id = 1,
  72. .minimum_version_id_old = 1,
  73. .pre_save = kvmclock_pre_save,
  74. .post_load = kvmclock_post_load,
  75. .fields = (VMStateField[]) {
  76. VMSTATE_UINT64(clock, KVMClockState),
  77. VMSTATE_END_OF_LIST()
  78. }
  79. };
  80. static SysBusDeviceInfo kvmclock_info = {
  81. .qdev.name = "kvmclock",
  82. .qdev.size = sizeof(KVMClockState),
  83. .qdev.vmsd = &kvmclock_vmsd,
  84. .qdev.no_user = 1,
  85. .init = kvmclock_init,
  86. };
  87. /* Note: Must be called after VCPU initialization. */
  88. void kvmclock_create(void)
  89. {
  90. if (kvm_enabled() &&
  91. first_cpu->cpuid_kvm_features & ((1ULL << KVM_FEATURE_CLOCKSOURCE) |
  92. (1ULL << KVM_FEATURE_CLOCKSOURCE2))) {
  93. sysbus_create_simple("kvmclock", -1, NULL);
  94. }
  95. }
  96. static void kvmclock_register_device(void)
  97. {
  98. if (kvm_enabled()) {
  99. sysbus_register_withprop(&kvmclock_info);
  100. }
  101. }
  102. device_init(kvmclock_register_device);