kvm_host.h 6.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License, version 2, as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 *
 * Copyright IBM Corp. 2007
 *
 * Authors: Hollis Blanchard <hollisb@us.ibm.com>
 */

#ifndef __POWERPC_KVM_HOST_H__
#define __POWERPC_KVM_HOST_H__

#include <linux/mutex.h>
A
Alexander Graf 已提交
24 25
#include <linux/hrtimer.h>
#include <linux/interrupt.h>
26 27 28 29 30 31 32 33 34
#include <linux/types.h>
#include <linux/kvm_types.h>
#include <asm/kvm_asm.h>

#define KVM_MAX_VCPUS 1
#define KVM_MEMORY_SLOTS 32
/* memory slots that does not exposed to userspace */
#define KVM_PRIVATE_MEM_SLOTS 4

35 36
#define KVM_COALESCED_MMIO_PAGE_OFFSET 1

37
/* We don't currently support large pages. */
38 39
#define KVM_NR_PAGE_SIZES	1
#define KVM_PAGES_PER_HPAGE(x)	(1UL<<31)
40

41 42 43 44 45 46 47
#define HPTEG_CACHE_NUM			(1 << 15)
#define HPTEG_HASH_BITS_PTE		13
#define HPTEG_HASH_BITS_VPTE		13
#define HPTEG_HASH_BITS_VPTE_LONG	5
#define HPTEG_HASH_NUM_PTE		(1 << HPTEG_HASH_BITS_PTE)
#define HPTEG_HASH_NUM_VPTE		(1 << HPTEG_HASH_BITS_VPTE)
#define HPTEG_HASH_NUM_VPTE_LONG	(1 << HPTEG_HASH_BITS_VPTE_LONG)
A
Alexander Graf 已提交
48

49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
struct kvm;
struct kvm_run;
struct kvm_vcpu;

struct kvm_vm_stat {
	u32 remote_tlb_flush;
};

struct kvm_vcpu_stat {
	u32 sum_exits;
	u32 mmio_exits;
	u32 dcr_exits;
	u32 signal_exits;
	u32 light_exits;
	/* Account for special types of light exits: */
	u32 itlb_real_miss_exits;
	u32 itlb_virt_miss_exits;
	u32 dtlb_real_miss_exits;
	u32 dtlb_virt_miss_exits;
	u32 syscall_exits;
	u32 isi_exits;
	u32 dsi_exits;
	u32 emulated_inst_exits;
	u32 dec_exits;
	u32 ext_intr_exits;
74
	u32 halt_wakeup;
75
#ifdef CONFIG_PPC_BOOK3S
A
Alexander Graf 已提交
76 77 78 79 80 81 82 83 84 85
	u32 pf_storage;
	u32 pf_instruc;
	u32 sp_storage;
	u32 sp_instruc;
	u32 queue_intr;
	u32 ld;
	u32 ld_slow;
	u32 st;
	u32 st_slow;
#endif
86 87
};

88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
enum kvm_exit_types {
	MMIO_EXITS,
	DCR_EXITS,
	SIGNAL_EXITS,
	ITLB_REAL_MISS_EXITS,
	ITLB_VIRT_MISS_EXITS,
	DTLB_REAL_MISS_EXITS,
	DTLB_VIRT_MISS_EXITS,
	SYSCALL_EXITS,
	ISI_EXITS,
	DSI_EXITS,
	EMULATED_INST_EXITS,
	EMULATED_MTMSRWE_EXITS,
	EMULATED_WRTEE_EXITS,
	EMULATED_MTSPR_EXITS,
	EMULATED_MFSPR_EXITS,
	EMULATED_MTMSR_EXITS,
	EMULATED_MFMSR_EXITS,
	EMULATED_TLBSX_EXITS,
	EMULATED_TLBWE_EXITS,
	EMULATED_RFI_EXITS,
	DEC_EXITS,
	EXT_INTR_EXITS,
	HALT_WAKEUP,
	USR_PR_INST,
	FP_UNAVAIL,
	DEBUG_EXITS,
	TIMEINGUEST,
	__NUMBER_OF_KVM_EXIT_TYPES
};

/* allow access to big endian 32bit upper/lower parts and 64bit var */
120
struct kvmppc_exit_timing {
121 122 123 124 125 126 127 128
	union {
		u64 tv64;
		struct {
			u32 tbu, tbl;
		} tv32;
	};
};

129 130 131
struct kvm_arch {
};

A
Alexander Graf 已提交
132
struct kvmppc_pte {
A
Alexander Graf 已提交
133
	ulong eaddr;
A
Alexander Graf 已提交
134
	u64 vpage;
A
Alexander Graf 已提交
135
	ulong raddr;
A
Alexander Graf 已提交
136 137 138
	bool may_read		: 1;
	bool may_write		: 1;
	bool may_execute	: 1;
A
Alexander Graf 已提交
139 140 141 142 143 144 145 146 147 148 149 150 151 152 153
};

struct kvmppc_mmu {
	/* book3s_64 only */
	void (*slbmte)(struct kvm_vcpu *vcpu, u64 rb, u64 rs);
	u64  (*slbmfee)(struct kvm_vcpu *vcpu, u64 slb_nr);
	u64  (*slbmfev)(struct kvm_vcpu *vcpu, u64 slb_nr);
	void (*slbie)(struct kvm_vcpu *vcpu, u64 slb_nr);
	void (*slbia)(struct kvm_vcpu *vcpu);
	/* book3s */
	void (*mtsrin)(struct kvm_vcpu *vcpu, u32 srnum, ulong value);
	u32  (*mfsrin)(struct kvm_vcpu *vcpu, u32 srnum);
	int  (*xlate)(struct kvm_vcpu *vcpu, gva_t eaddr, struct kvmppc_pte *pte, bool data);
	void (*reset_msr)(struct kvm_vcpu *vcpu);
	void (*tlbie)(struct kvm_vcpu *vcpu, ulong addr, bool large);
A
Alexander Graf 已提交
154
	int  (*esid_to_vsid)(struct kvm_vcpu *vcpu, ulong esid, u64 *vsid);
A
Alexander Graf 已提交
155 156 157 158 159
	u64  (*ea_to_vp)(struct kvm_vcpu *vcpu, gva_t eaddr, bool data);
	bool (*is_dcbz32)(struct kvm_vcpu *vcpu);
};

struct hpte_cache {
160 161 162
	struct hlist_node list_pte;
	struct hlist_node list_vpte;
	struct hlist_node list_vpte_long;
A
Alexander Graf 已提交
163 164 165 166 167 168
	u64 host_va;
	u64 pfn;
	ulong slot;
	struct kvmppc_pte pte;
};

169
struct kvm_vcpu_arch {
A
Alexander Graf 已提交
170
	ulong host_stack;
171
	u32 host_pid;
172
#ifdef CONFIG_PPC_BOOK3S
A
Alexander Graf 已提交
173 174 175 176 177 178
	ulong host_msr;
	ulong host_r2;
	void *host_retip;
	ulong trampoline_lowmem;
	ulong trampoline_enter;
	ulong highmem_handler;
179
	ulong rmcall;
A
Alexander Graf 已提交
180 181 182
	ulong host_paca_phys;
	struct kvmppc_mmu mmu;
#endif
183

184
	ulong gpr[32];
185

186
	u64 fpr[32];
A
Alexander Graf 已提交
187
	u64 fpscr;
188 189 190 191 192 193 194 195 196 197

#ifdef CONFIG_ALTIVEC
	vector128 vr[32];
	vector128 vscr;
#endif

#ifdef CONFIG_VSX
	u64 vsr[32];
#endif

A
Alexander Graf 已提交
198 199 200 201 202
#ifdef CONFIG_PPC_BOOK3S
	/* For Gekko paired singles */
	u32 qpr[32];
#endif

203
#ifdef CONFIG_BOOKE
204 205 206
	ulong pc;
	ulong ctr;
	ulong lr;
207

208
	ulong xer;
209 210
	u32 cr;
#endif
211

212
	ulong msr;
213
#ifdef CONFIG_PPC_BOOK3S
A
Alexander Graf 已提交
214 215
	ulong shadow_msr;
	ulong hflags;
216
	ulong guest_owned_ext;
A
Alexander Graf 已提交
217
#endif
218
	u32 mmucr;
219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234
	ulong sprg0;
	ulong sprg1;
	ulong sprg2;
	ulong sprg3;
	ulong sprg4;
	ulong sprg5;
	ulong sprg6;
	ulong sprg7;
	ulong srr0;
	ulong srr1;
	ulong csrr0;
	ulong csrr1;
	ulong dsrr0;
	ulong dsrr1;
	ulong dear;
	ulong esr;
235 236 237 238 239 240
	u32 dec;
	u32 decar;
	u32 tbl;
	u32 tbu;
	u32 tcr;
	u32 tsr;
241
	u32 ivor[64];
242
	ulong ivpr;
243
	u32 pir;
A
Alexander Graf 已提交
244
	u32 pvr;
245 246

	u32 shadow_pid;
247
	u32 pid;
248 249
	u32 swap_pid;

250 251 252 253
	u32 ccr0;
	u32 ccr1;
	u32 dbcr0;
	u32 dbcr1;
254
	u32 dbsr;
255

256
#ifdef CONFIG_KVM_EXIT_TIMING
257 258
	struct kvmppc_exit_timing timing_exit;
	struct kvmppc_exit_timing timing_last_enter;
259 260 261 262 263 264 265 266 267 268
	u32 last_exit_type;
	u32 timing_count_type[__NUMBER_OF_KVM_EXIT_TYPES];
	u64 timing_sum_duration[__NUMBER_OF_KVM_EXIT_TYPES];
	u64 timing_sum_quad_duration[__NUMBER_OF_KVM_EXIT_TYPES];
	u64 timing_min_duration[__NUMBER_OF_KVM_EXIT_TYPES];
	u64 timing_max_duration[__NUMBER_OF_KVM_EXIT_TYPES];
	u64 timing_last_exit;
	struct dentry *debugfs_exit_timing;
#endif

269
#ifdef CONFIG_BOOKE
270
	u32 last_inst;
271 272
	ulong fault_dear;
	ulong fault_esr;
273 274
	ulong queued_dear;
	ulong queued_esr;
275
#endif
276 277 278 279
	gpa_t paddr_accessed;

	u8 io_gpr; /* GPR used as IO source/target */
	u8 mmio_is_bigendian;
A
Alexander Graf 已提交
280
	u8 mmio_sign_extend;
281 282
	u8 dcr_needed;
	u8 dcr_is_write;
283 284
	u8 osi_needed;
	u8 osi_enabled;
285 286 287

	u32 cpr0_cfgaddr; /* holds the last set cpr0_cfgaddr */

A
Alexander Graf 已提交
288 289
	struct hrtimer dec_timer;
	struct tasklet_struct tasklet;
A
Alexander Graf 已提交
290
	u64 dec_jiffies;
291
	unsigned long pending_exceptions;
A
Alexander Graf 已提交
292

293
#ifdef CONFIG_PPC_BOOK3S
294 295 296 297
	struct hlist_head hpte_hash_pte[HPTEG_HASH_NUM_PTE];
	struct hlist_head hpte_hash_vpte[HPTEG_HASH_NUM_VPTE];
	struct hlist_head hpte_hash_vpte_long[HPTEG_HASH_NUM_VPTE_LONG];
	int hpte_cache_count;
A
Alexander Graf 已提交
298
#endif
299 300 301
};

#endif /* __POWERPC_KVM_HOST_H__ */