@@ -112,6 +112,7 @@
#define OP_31_XOP_LHBRX 790
#define OP_31_XOP_STHBRX 918
+#define OP_ADDIS 15
#define OP_LWZ 32
#define OP_LD 58
#define OP_LWZU 33
@@ -473,6 +473,13 @@ int kvmppc_emulate_any_instruction(struct kvm_vcpu *vcpu)
emulated = kvmppc_emulate_load(vcpu, addr, &value, 4);
kvmppc_set_gpr(vcpu, get_rt(inst), value);
break;
+ case OP_ADDIS:
+ value = 0;
+ if (get_ra(inst))
+ value = kvmppc_get_gpr(vcpu, get_ra(inst));
+ value += ((s16)get_d(inst)) << 16;
+ kvmppc_set_gpr(vcpu, get_rt(inst), value);
+ break;
case 31:
switch (get_xop(inst)) {
case OP_31_XOP_MFCR:
This patch implements emulation for the addis instruction which is also used to implement lis. Signed-off-by: Alexander Graf <agraf@suse.de> --- arch/powerpc/include/asm/ppc-opcode.h | 1 + arch/powerpc/kvm/emulate.c | 7 +++++++ 2 files changed, 8 insertions(+)