diff options
| author | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
|---|---|---|
| committer | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
| commit | 79828b4fa835f73cdaf4bffa48696abdcbea9d02 (patch) | |
| tree | 5e0fa7156acb75ba603022bc807df8f2fedb97a8 /arch/powerpc/include/asm/kvm_book3s_asm.h | |
| parent | 721b51fcf91898299d96f4b72cb9434cda29dce6 (diff) | |
| parent | 8c1a9d6323abf0fb1e5dad96cf3f1c783505ea5a (diff) | |
Merge remote-tracking branch 'asoc/fix/rt5645' into asoc-fix-rt5645
Diffstat (limited to 'arch/powerpc/include/asm/kvm_book3s_asm.h')
| -rw-r--r-- | arch/powerpc/include/asm/kvm_book3s_asm.h | 22 | 
1 files changed, 21 insertions, 1 deletions
diff --git a/arch/powerpc/include/asm/kvm_book3s_asm.h b/arch/powerpc/include/asm/kvm_book3s_asm.h index 5bdfb5dd3400..72b6225aca73 100644 --- a/arch/powerpc/include/asm/kvm_book3s_asm.h +++ b/arch/powerpc/include/asm/kvm_book3s_asm.h @@ -25,6 +25,12 @@  #define XICS_MFRR		0xc  #define XICS_IPI		2	/* interrupt source # for IPIs */ +/* Maximum number of threads per physical core */ +#define MAX_SMT_THREADS		8 + +/* Maximum number of subcores per physical core */ +#define MAX_SUBCORES		4 +  #ifdef __ASSEMBLY__  #ifdef CONFIG_KVM_BOOK3S_HANDLER @@ -65,6 +71,19 @@ kvmppc_resume_\intno:  #else  /*__ASSEMBLY__ */ +struct kvmppc_vcore; + +/* Struct used for coordinating micro-threading (split-core) mode changes */ +struct kvm_split_mode { +	unsigned long	rpr; +	unsigned long	pmmar; +	unsigned long	ldbar; +	u8		subcore_size; +	u8		do_nap; +	u8		napped[MAX_SMT_THREADS]; +	struct kvmppc_vcore *master_vcs[MAX_SUBCORES]; +}; +  /*   * This struct goes in the PACA on 64-bit processors.  It is used   * to store host state that needs to be saved when we enter a guest @@ -100,6 +119,7 @@ struct kvmppc_host_state {  	u64 host_spurr;  	u64 host_dscr;  	u64 dec_expires; +	struct kvm_split_mode *kvm_split_mode;  #endif  #ifdef CONFIG_PPC_BOOK3S_64  	u64 cfar; @@ -112,7 +132,7 @@ struct kvmppc_book3s_shadow_vcpu {  	bool in_use;  	ulong gpr[14];  	u32 cr; -	u32 xer; +	ulong xer;  	ulong ctr;  	ulong lr;  	ulong pc;  |