KVM: x86 emulator: Use opcode::execute for Group 9 instruction
[linux-2.6-block.git] / arch / x86 / kvm / lapic.h
CommitLineData
82470196
ZX
1#ifndef __KVM_X86_LAPIC_H
2#define __KVM_X86_LAPIC_H
3
4#include "iodev.h"
d3c7b77d 5#include "kvm_timer.h"
82470196
ZX
6
7#include <linux/kvm_host.h>
8
9struct kvm_lapic {
10 unsigned long base_address;
11 struct kvm_io_device dev;
d3c7b77d
MT
12 struct kvm_timer lapic_timer;
13 u32 divide_count;
82470196 14 struct kvm_vcpu *vcpu;
33e4c686 15 bool irr_pending;
82470196 16 void *regs;
b93463aa
AK
17 gpa_t vapic_addr;
18 struct page *vapic_page;
82470196
ZX
19};
20int kvm_create_lapic(struct kvm_vcpu *vcpu);
21void kvm_free_lapic(struct kvm_vcpu *vcpu);
22
23int kvm_apic_has_interrupt(struct kvm_vcpu *vcpu);
24int kvm_apic_accept_pic_intr(struct kvm_vcpu *vcpu);
25int kvm_get_apic_interrupt(struct kvm_vcpu *vcpu);
26void kvm_lapic_reset(struct kvm_vcpu *vcpu);
27u64 kvm_lapic_get_cr8(struct kvm_vcpu *vcpu);
28void kvm_lapic_set_tpr(struct kvm_vcpu *vcpu, unsigned long cr8);
58fbbf26 29void kvm_lapic_set_eoi(struct kvm_vcpu *vcpu);
82470196 30void kvm_lapic_set_base(struct kvm_vcpu *vcpu, u64 value);
8b2cf73c 31u64 kvm_lapic_get_base(struct kvm_vcpu *vcpu);
fc61b800 32void kvm_apic_set_version(struct kvm_vcpu *vcpu);
82470196
ZX
33
34int kvm_apic_match_physical_addr(struct kvm_lapic *apic, u16 dest);
35int kvm_apic_match_logical_addr(struct kvm_lapic *apic, u8 mda);
58c2dde1 36int kvm_apic_set_irq(struct kvm_vcpu *vcpu, struct kvm_lapic_irq *irq);
82470196
ZX
37
38u64 kvm_get_apic_base(struct kvm_vcpu *vcpu);
39void kvm_set_apic_base(struct kvm_vcpu *vcpu, u64 data);
40void kvm_apic_post_state_restore(struct kvm_vcpu *vcpu);
41int kvm_lapic_enabled(struct kvm_vcpu *vcpu);
343f94fe 42bool kvm_apic_present(struct kvm_vcpu *vcpu);
82470196 43int kvm_lapic_find_highest_irr(struct kvm_vcpu *vcpu);
82470196 44
a3e06bbe
LJ
45u64 kvm_get_lapic_tscdeadline_msr(struct kvm_vcpu *vcpu);
46void kvm_set_lapic_tscdeadline_msr(struct kvm_vcpu *vcpu, u64 data);
47
b93463aa
AK
48void kvm_lapic_set_vapic_addr(struct kvm_vcpu *vcpu, gpa_t vapic_addr);
49void kvm_lapic_sync_from_vapic(struct kvm_vcpu *vcpu);
50void kvm_lapic_sync_to_vapic(struct kvm_vcpu *vcpu);
51
0105d1a5
GN
52int kvm_x2apic_msr_write(struct kvm_vcpu *vcpu, u32 msr, u64 data);
53int kvm_x2apic_msr_read(struct kvm_vcpu *vcpu, u32 msr, u64 *data);
10388a07
GN
54
55int kvm_hv_vapic_msr_write(struct kvm_vcpu *vcpu, u32 msr, u64 data);
56int kvm_hv_vapic_msr_read(struct kvm_vcpu *vcpu, u32 msr, u64 *data);
57
58static inline bool kvm_hv_vapic_assist_page_enabled(struct kvm_vcpu *vcpu)
59{
60 return vcpu->arch.hv_vapic & HV_X64_MSR_APIC_ASSIST_PAGE_ENABLE;
61}
82470196 62#endif