blob: ad8fe0b059c7bfe02bd3678574613ab9b556d305 [file] [log] [blame]
Elliott Hughesabd62612013-11-08 11:45:48 -08001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_ASM_X86_KVM_PARA_H
20#define _UAPI_ASM_X86_KVM_PARA_H
21#include <linux/types.h>
Elliott Hughesabd62612013-11-08 11:45:48 -080022#define KVM_CPUID_SIGNATURE 0x40000000
23#define KVM_CPUID_FEATURES 0x40000001
24#define KVM_FEATURE_CLOCKSOURCE 0
25#define KVM_FEATURE_NOP_IO_DELAY 1
Elliott Hughesabd62612013-11-08 11:45:48 -080026#define KVM_FEATURE_MMU_OP 2
27#define KVM_FEATURE_CLOCKSOURCE2 3
28#define KVM_FEATURE_ASYNC_PF 4
29#define KVM_FEATURE_STEAL_TIME 5
Elliott Hughesabd62612013-11-08 11:45:48 -080030#define KVM_FEATURE_PV_EOI 6
Christopher Ferris38062f92014-07-09 15:33:25 -070031#define KVM_FEATURE_PV_UNHALT 7
Christopher Ferris76a1d452018-06-27 14:12:29 -070032#define KVM_FEATURE_PV_TLB_FLUSH 9
33#define KVM_FEATURE_ASYNC_PF_VMEXIT 10
Christopher Ferris9ce28842018-10-25 12:11:39 -070034#define KVM_FEATURE_PV_SEND_IPI 11
Christopher Ferrisb8a95e22019-10-02 18:29:20 -070035#define KVM_FEATURE_POLL_CONTROL 12
36#define KVM_FEATURE_PV_SCHED_YIELD 13
Christopher Ferris76a1d452018-06-27 14:12:29 -070037#define KVM_HINTS_REALTIME 0
Elliott Hughesabd62612013-11-08 11:45:48 -080038#define KVM_FEATURE_CLOCKSOURCE_STABLE_BIT 24
39#define MSR_KVM_WALL_CLOCK 0x11
Christopher Ferris38062f92014-07-09 15:33:25 -070040#define MSR_KVM_SYSTEM_TIME 0x12
Elliott Hughesabd62612013-11-08 11:45:48 -080041#define KVM_MSR_ENABLED 1
42#define MSR_KVM_WALL_CLOCK_NEW 0x4b564d00
43#define MSR_KVM_SYSTEM_TIME_NEW 0x4b564d01
Christopher Ferris38062f92014-07-09 15:33:25 -070044#define MSR_KVM_ASYNC_PF_EN 0x4b564d02
Elliott Hughesabd62612013-11-08 11:45:48 -080045#define MSR_KVM_STEAL_TIME 0x4b564d03
46#define MSR_KVM_PV_EOI_EN 0x4b564d04
Christopher Ferrisb8a95e22019-10-02 18:29:20 -070047#define MSR_KVM_POLL_CONTROL 0x4b564d05
Elliott Hughesabd62612013-11-08 11:45:48 -080048struct kvm_steal_time {
Tao Baod7db5942015-01-28 10:07:51 -080049 __u64 steal;
50 __u32 version;
51 __u32 flags;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080052 __u8 preempted;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080053 __u8 u8_pad[3];
54 __u32 pad[11];
Christopher Ferris38062f92014-07-09 15:33:25 -070055};
Christopher Ferris76a1d452018-06-27 14:12:29 -070056#define KVM_VCPU_PREEMPTED (1 << 0)
57#define KVM_VCPU_FLUSH_TLB (1 << 1)
Christopher Ferris525ce912017-07-26 13:12:53 -070058#define KVM_CLOCK_PAIRING_WALLCLOCK 0
59struct kvm_clock_pairing {
60 __s64 sec;
61 __s64 nsec;
62 __u64 tsc;
63 __u32 flags;
64 __u32 pad[9];
65};
Elliott Hughesabd62612013-11-08 11:45:48 -080066#define KVM_STEAL_ALIGNMENT_BITS 5
Tao Baod7db5942015-01-28 10:07:51 -080067#define KVM_STEAL_VALID_BITS ((- 1ULL << (KVM_STEAL_ALIGNMENT_BITS + 1)))
68#define KVM_STEAL_RESERVED_MASK (((1 << KVM_STEAL_ALIGNMENT_BITS) - 1) << 1)
Christopher Ferris38062f92014-07-09 15:33:25 -070069#define KVM_MAX_MMU_OP_BATCH 32
Elliott Hughesabd62612013-11-08 11:45:48 -080070#define KVM_ASYNC_PF_ENABLED (1 << 0)
71#define KVM_ASYNC_PF_SEND_ALWAYS (1 << 1)
Christopher Ferris1308ad32017-11-14 17:32:13 -080072#define KVM_ASYNC_PF_DELIVERY_AS_PF_VMEXIT (1 << 2)
Elliott Hughesabd62612013-11-08 11:45:48 -080073#define KVM_MMU_OP_WRITE_PTE 1
Christopher Ferris38062f92014-07-09 15:33:25 -070074#define KVM_MMU_OP_FLUSH_TLB 2
Elliott Hughesabd62612013-11-08 11:45:48 -080075#define KVM_MMU_OP_RELEASE_PT 3
76struct kvm_mmu_op_header {
Tao Baod7db5942015-01-28 10:07:51 -080077 __u32 op;
Tao Baod7db5942015-01-28 10:07:51 -080078 __u32 pad;
Elliott Hughesabd62612013-11-08 11:45:48 -080079};
80struct kvm_mmu_op_write_pte {
Tao Baod7db5942015-01-28 10:07:51 -080081 struct kvm_mmu_op_header header;
Tao Baod7db5942015-01-28 10:07:51 -080082 __u64 pte_phys;
83 __u64 pte_val;
Elliott Hughesabd62612013-11-08 11:45:48 -080084};
85struct kvm_mmu_op_flush_tlb {
Tao Baod7db5942015-01-28 10:07:51 -080086 struct kvm_mmu_op_header header;
Elliott Hughesabd62612013-11-08 11:45:48 -080087};
88struct kvm_mmu_op_release_pt {
Tao Baod7db5942015-01-28 10:07:51 -080089 struct kvm_mmu_op_header header;
Tao Baod7db5942015-01-28 10:07:51 -080090 __u64 pt_phys;
Elliott Hughesabd62612013-11-08 11:45:48 -080091};
92#define KVM_PV_REASON_PAGE_NOT_PRESENT 1
93#define KVM_PV_REASON_PAGE_READY 2
Christopher Ferris38062f92014-07-09 15:33:25 -070094struct kvm_vcpu_pv_apf_data {
Tao Baod7db5942015-01-28 10:07:51 -080095 __u32 reason;
96 __u8 pad[60];
97 __u32 enabled;
Christopher Ferris38062f92014-07-09 15:33:25 -070098};
Elliott Hughesabd62612013-11-08 11:45:48 -080099#define KVM_PV_EOI_BIT 0
100#define KVM_PV_EOI_MASK (0x1 << KVM_PV_EOI_BIT)
101#define KVM_PV_EOI_ENABLED KVM_PV_EOI_MASK
Christopher Ferris38062f92014-07-09 15:33:25 -0700102#define KVM_PV_EOI_DISABLED 0x0
Elliott Hughesabd62612013-11-08 11:45:48 -0800103#endif