xref: /kvmtool/include/kvm/kvm-cpu.h (revision 656be1b87953b73d98ef6e9ec32049bb439fd3a2)
15c3d55faSPekka Enberg #ifndef KVM__KVM_CPU_H
25c3d55faSPekka Enberg #define KVM__KVM_CPU_H
35c3d55faSPekka Enberg 
45c3d55faSPekka Enberg #include <linux/kvm.h>	/* for struct kvm_regs */
55c3d55faSPekka Enberg 
65ee154d1SPekka Enberg #include <pthread.h>
75c3d55faSPekka Enberg 
85c3d55faSPekka Enberg struct kvm;
95c3d55faSPekka Enberg 
105c3d55faSPekka Enberg struct kvm_cpu {
115ee154d1SPekka Enberg 	pthread_t		thread;		/* VCPU thread */
125ee154d1SPekka Enberg 
135ee154d1SPekka Enberg 	unsigned long		cpu_id;
145ee154d1SPekka Enberg 
155c3d55faSPekka Enberg 	struct kvm		*kvm;		/* parent KVM */
165c3d55faSPekka Enberg 	int			vcpu_fd;	/* For VCPU ioctls() */
175c3d55faSPekka Enberg 	struct kvm_run		*kvm_run;
185c3d55faSPekka Enberg 
195c3d55faSPekka Enberg 	struct kvm_regs		regs;
205c3d55faSPekka Enberg 	struct kvm_sregs	sregs;
215c3d55faSPekka Enberg 	struct kvm_fpu		fpu;
225c3d55faSPekka Enberg 
235c3d55faSPekka Enberg 	struct kvm_msrs		*msrs;		/* dynamically allocated */
24*656be1b8SSasha Levin 
25*656be1b8SSasha Levin 	u8			is_running;
265c3d55faSPekka Enberg };
275c3d55faSPekka Enberg 
285ee154d1SPekka Enberg struct kvm_cpu *kvm_cpu__init(struct kvm *kvm, unsigned long cpu_id);
2943835ac9SSasha Levin void kvm_cpu__delete(struct kvm_cpu *vcpu);
3043835ac9SSasha Levin void kvm_cpu__reset_vcpu(struct kvm_cpu *vcpu);
3143835ac9SSasha Levin void kvm_cpu__setup_cpuid(struct kvm_cpu *vcpu);
3243835ac9SSasha Levin void kvm_cpu__enable_singlestep(struct kvm_cpu *vcpu);
3343835ac9SSasha Levin void kvm_cpu__run(struct kvm_cpu *vcpu);
3465bab644SPekka Enberg int kvm_cpu__start(struct kvm_cpu *cpu);
355c3d55faSPekka Enberg 
3643835ac9SSasha Levin void kvm_cpu__show_code(struct kvm_cpu *vcpu);
3743835ac9SSasha Levin void kvm_cpu__show_registers(struct kvm_cpu *vcpu);
3843835ac9SSasha Levin void kvm_cpu__show_page_tables(struct kvm_cpu *vcpu);
395c3d55faSPekka Enberg 
405c3d55faSPekka Enberg #endif /* KVM__KVM_CPU_H */
41