kvm_ppc.h 6.0 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

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);
A
Alexander Graf 已提交
51 52 53
extern int kvmppc_handle_loads(struct kvm_run *run, struct kvm_vcpu *vcpu,
                               unsigned int rt, unsigned int bytes,
                               int is_bigendian);
54
extern int kvmppc_handle_store(struct kvm_run *run, struct kvm_vcpu *vcpu,
55
                               u64 val, unsigned int bytes, int is_bigendian);
56 57 58

extern int kvmppc_emulate_instruction(struct kvm_run *run,
                                      struct kvm_vcpu *vcpu);
59
extern int kvmppc_emulate_mmio(struct kvm_run *run, struct kvm_vcpu *vcpu);
60
extern void kvmppc_emulate_dec(struct kvm_vcpu *vcpu);
61

62 63
/* Core-specific hooks */

64
extern void kvmppc_mmu_map(struct kvm_vcpu *vcpu, u64 gvaddr, gpa_t gpaddr,
65
                           unsigned int gtlb_idx);
66
extern void kvmppc_mmu_priv_switch(struct kvm_vcpu *vcpu, int usermode);
67
extern void kvmppc_mmu_switch_pid(struct kvm_vcpu *vcpu, u32 pid);
68
extern void kvmppc_mmu_destroy(struct kvm_vcpu *vcpu);
69 70
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);
71 72
extern gpa_t kvmppc_mmu_xlate(struct kvm_vcpu *vcpu, unsigned int gtlb_index,
                              gva_t eaddr);
73 74
extern void kvmppc_mmu_dtlb_miss(struct kvm_vcpu *vcpu);
extern void kvmppc_mmu_itlb_miss(struct kvm_vcpu *vcpu);
75

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

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);
89
extern void kvmppc_core_queue_program(struct kvm_vcpu *vcpu, ulong flags);
90
extern void kvmppc_core_queue_dec(struct kvm_vcpu *vcpu);
91
extern void kvmppc_core_dequeue_dec(struct kvm_vcpu *vcpu);
92 93 94
extern void kvmppc_core_queue_external(struct kvm_vcpu *vcpu,
                                       struct kvm_interrupt *irq);

95 96 97 98 99
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);

100 101 102
extern int kvmppc_booke_init(void);
extern void kvmppc_booke_exit(void);

103 104
extern void kvmppc_core_destroy_mmu(struct kvm_vcpu *vcpu);

105 106
#ifdef CONFIG_PPC_BOOK3S

107 108
/* We assume we're always acting on the current vcpu */

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

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

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

static inline u32 kvmppc_get_cr(struct kvm_vcpu *vcpu)
{
134
	return get_paca()->shadow_vcpu.cr;
135 136 137 138
}

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

static inline u32 kvmppc_get_xer(struct kvm_vcpu *vcpu)
{
145
	return get_paca()->shadow_vcpu.xer;
146 147
}

148 149 150 151 152 153 154 155 156 157 158 159
#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];
}

160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179
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;
}

180 181
#endif

182
#endif /* __POWERPC_KVM_PPC_H__ */