x86_platform_ops
Regular
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
✅