kvm_ppc.h 5.8 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 24 25 26 27 28 29 30
/*
 * 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. 2008
 *
 * Authors: Hollis Blanchard <hollisb@us.ibm.com>
 */

#ifndef __POWERPC_KVM_PPC_H__
#define __POWERPC_KVM_PPC_H__

/* This file exists just so we can dereference kvm_vcpu, avoiding nested header
 * dependencies. */

#include <linux/mutex.h>
#include <linux/timer.h>
#include <linux/types.h>
#include <linux/kvm_types.h>
#include <linux/kvm_host.h>
31 32 33
#ifdef CONFIG_PPC_BOOK3S
#include <asm/kvm_book3s.h>
#endif
34 35 36 37 38 39 40 41 42 43 44

enum emulation_result {
	EMULATE_DONE,         /* no further processing */
	EMULATE_DO_MMIO,      /* kvm_run filled with MMIO request */
	EMULATE_DO_DCR,       /* kvm_run filled with DCR request */
	EMULATE_FAIL,         /* can't emulate this instruction */
};

extern int __kvmppc_vcpu_run(struct kvm_run *kvm_run, struct kvm_vcpu *vcpu);
extern char kvmppc_handlers_start[];
extern unsigned long kvmppc_handler_len;
A
Alexander Graf 已提交
45
extern void kvmppc_handler_highmem(void);
46 47 48 49 50 51

extern void kvmppc_dump_vcpu(struct kvm_vcpu *vcpu);
extern int kvmppc_handle_load(struct kvm_run *run, struct kvm_vcpu *vcpu,
                              unsigned int rt, unsigned int bytes,
                              int is_bigendian);
extern int kvmppc_handle_store(struct kvm_run *run, struct kvm_vcpu *vcpu,
52
                               u64 val, unsigned int bytes, int is_bigendian);
53 54 55

extern int kvmppc_emulate_instruction(struct kvm_run *run,
                                      struct kvm_vcpu *vcpu);
56
extern int kvmppc_emulate_mmio(struct kvm_run *run, struct kvm_vcpu *vcpu);
57
extern void kvmppc_emulate_dec(struct kvm_vcpu *vcpu);
58

59 60
/* Core-specific hooks */

61
extern void kvmppc_mmu_map(struct kvm_vcpu *vcpu, u64 gvaddr, gpa_t gpaddr,
62
                           unsigned int gtlb_idx);
63
extern void kvmppc_mmu_priv_switch(struct kvm_vcpu *vcpu, int usermode);
64
extern void kvmppc_mmu_switch_pid(struct kvm_vcpu *vcpu, u32 pid);
65
extern void kvmppc_mmu_destroy(struct kvm_vcpu *vcpu);
66 67
extern int kvmppc_mmu_dtlb_index(struct kvm_vcpu *vcpu, gva_t eaddr);
extern int kvmppc_mmu_itlb_index(struct kvm_vcpu *vcpu, gva_t eaddr);
68 69
extern gpa_t kvmppc_mmu_xlate(struct kvm_vcpu *vcpu, unsigned int gtlb_index,
                              gva_t eaddr);
70 71
extern void kvmppc_mmu_dtlb_miss(struct kvm_vcpu *vcpu);
extern void kvmppc_mmu_itlb_miss(struct kvm_vcpu *vcpu);
72

73 74 75
extern struct kvm_vcpu *kvmppc_core_vcpu_create(struct kvm *kvm,
                                                unsigned int id);
extern void kvmppc_core_vcpu_free(struct kvm_vcpu *vcpu);
76
extern int kvmppc_core_vcpu_setup(struct kvm_vcpu *vcpu);
77
extern int kvmppc_core_check_processor_compat(void);
78 79
extern int kvmppc_core_vcpu_translate(struct kvm_vcpu *vcpu,
                                      struct kvm_translation *tr);
80 81 82 83 84 85

extern void kvmppc_core_vcpu_load(struct kvm_vcpu *vcpu, int cpu);
extern void kvmppc_core_vcpu_put(struct kvm_vcpu *vcpu);

extern void kvmppc_core_deliver_interrupts(struct kvm_vcpu *vcpu);
extern int kvmppc_core_pending_dec(struct kvm_vcpu *vcpu);
86
extern void kvmppc_core_queue_program(struct kvm_vcpu *vcpu, ulong flags);
87
extern void kvmppc_core_queue_dec(struct kvm_vcpu *vcpu);
88
extern void kvmppc_core_dequeue_dec(struct kvm_vcpu *vcpu);
89 90 91
extern void kvmppc_core_queue_external(struct kvm_vcpu *vcpu,
                                       struct kvm_interrupt *irq);

92 93 94 95 96
extern int kvmppc_core_emulate_op(struct kvm_run *run, struct kvm_vcpu *vcpu,
                                  unsigned int op, int *advance);
extern int kvmppc_core_emulate_mtspr(struct kvm_vcpu *vcpu, int sprn, int rs);
extern int kvmppc_core_emulate_mfspr(struct kvm_vcpu *vcpu, int sprn, int rt);

97 98 99
extern int kvmppc_booke_init(void);
extern void kvmppc_booke_exit(void);

100 101
extern void kvmppc_core_destroy_mmu(struct kvm_vcpu *vcpu);

102 103
#ifdef CONFIG_PPC_BOOK3S

104 105
/* We assume we're always acting on the current vcpu */

106 107
static inline void kvmppc_set_gpr(struct kvm_vcpu *vcpu, int num, ulong val)
{
108
	if ( num < 14 ) {
109
		get_paca()->shadow_vcpu.gpr[num] = val;
110 111
		to_book3s(vcpu)->shadow_vcpu.gpr[num] = val;
	} else
112
		vcpu->arch.gpr[num] = val;
113 114 115 116
}

static inline ulong kvmppc_get_gpr(struct kvm_vcpu *vcpu, int num)
{
117 118 119 120
	if ( num < 14 )
		return get_paca()->shadow_vcpu.gpr[num];
	else
		return vcpu->arch.gpr[num];
121 122
}

123 124
static inline void kvmppc_set_cr(struct kvm_vcpu *vcpu, u32 val)
{
125
	get_paca()->shadow_vcpu.cr = val;
126
	to_book3s(vcpu)->shadow_vcpu.cr = val;
127 128 129 130
}

static inline u32 kvmppc_get_cr(struct kvm_vcpu *vcpu)
{
131
	return get_paca()->shadow_vcpu.cr;
132 133 134 135
}

static inline void kvmppc_set_xer(struct kvm_vcpu *vcpu, u32 val)
{
136
	get_paca()->shadow_vcpu.xer = val;
137
	to_book3s(vcpu)->shadow_vcpu.xer = val;
138 139 140 141
}

static inline u32 kvmppc_get_xer(struct kvm_vcpu *vcpu)
{
142
	return get_paca()->shadow_vcpu.xer;
143 144
}

145 146 147 148 149 150 151 152 153 154 155 156
#else

static inline void kvmppc_set_gpr(struct kvm_vcpu *vcpu, int num, ulong val)
{
	vcpu->arch.gpr[num] = val;
}

static inline ulong kvmppc_get_gpr(struct kvm_vcpu *vcpu, int num)
{
	return vcpu->arch.gpr[num];
}

157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176
static inline void kvmppc_set_cr(struct kvm_vcpu *vcpu, u32 val)
{
	vcpu->arch.cr = val;
}

static inline u32 kvmppc_get_cr(struct kvm_vcpu *vcpu)
{
	return vcpu->arch.cr;
}

static inline void kvmppc_set_xer(struct kvm_vcpu *vcpu, u32 val)
{
	vcpu->arch.xer = val;
}

static inline u32 kvmppc_get_xer(struct kvm_vcpu *vcpu)
{
	return vcpu->arch.xer;
}

177 178
#endif

179
#endif /* __POWERPC_KVM_PPC_H__ */