x86_platform_opsRegular
4.4: ✅struct x86_platform_ops {
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec *);
int (*set_wallclock)(const struct timespec *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
int (*i8042_detect)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
};
4.8: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec *);
int (*set_wallclock)(const struct timespec *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
int (*i8042_detect)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
};
4.10: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec *);
int (*set_wallclock)(const struct timespec *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
};
4.13: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec *);
int (*set_wallclock)(const struct timespec *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
};
4.15: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec *);
int (*set_wallclock)(const struct timespec *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
4.18: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.0: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.3: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.4: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.8: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.11: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.13: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.15: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
5.19: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
struct x86_guest guest;
};
6.2: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
void (*realmode_reserve)();
void (*realmode_init)();
struct x86_hyper_runtime hyper;
struct x86_guest guest;
};
6.5: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
void (*realmode_reserve)();
void (*realmode_init)();
struct x86_hyper_runtime hyper;
struct x86_guest guest;
};
6.8: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
void (*realmode_reserve)();
void (*realmode_init)();
struct x86_hyper_runtime hyper;
struct x86_guest guest;
};
arm64: Absent ⚠️
armhf: Absent ⚠️
ppc64el: Absent ⚠️
riscv64: Absent ⚠️
aws: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
azure: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
gcp: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
lowlatency: ✅struct x86_platform_ops {
long unsigned int (*calibrate_cpu)();
long unsigned int (*calibrate_tsc)();
void (*get_wallclock)(struct timespec64 *);
int (*set_wallclock)(const struct timespec64 *);
void (*iommu_shutdown)();
bool (*is_untracked_pat_range)(u64, u64);
void (*nmi_init)();
unsigned char (*get_nmi_reason)();
void (*save_sched_clock_state)();
void (*restore_sched_clock_state)();
void (*apic_post_init)();
struct x86_legacy_features legacy;
void (*set_legacy_features)();
struct x86_hyper_runtime hyper;
};
Regular
4.4 and 4.8 ⚠️long unsigned int (*calibrate_cpu)()
struct x86_legacy_features legacy
void (*set_legacy_features)()
4.8 and 4.10 ⚠️int (*i8042_detect)()
4.10 and 4.13 ✅
4.13 and 4.15 ⚠️struct x86_hyper_runtime hyper
4.15 and 4.18 ⚠️void (*get_wallclock)(struct timespec *) ➡️ void (*get_wallclock)(struct timespec64 *)
int (*set_wallclock)(const struct timespec *) ➡️ int (*set_wallclock)(const struct timespec64 *)
4.18 and 5.0 ✅
5.0 and 5.3 ✅
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ✅
5.15 and 5.19 ⚠️struct x86_guest guest
5.19 and 6.2 ⚠️void (*realmode_reserve)()
void (*realmode_init)()
6.2 and 6.5 ✅
6.5 and 6.8 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅