|
|
@@ -5110,13 +5110,17 @@ static void fetch_possible_mmx_operand(struct x86_emulate_ctxt *ctxt,
|
|
|
|
|
|
static int fastop(struct x86_emulate_ctxt *ctxt, void (*fop)(struct fastop *))
|
|
|
{
|
|
|
+ register void *__sp asm(_ASM_SP);
|
|
|
ulong flags = (ctxt->eflags & EFLAGS_MASK) | X86_EFLAGS_IF;
|
|
|
+
|
|
|
if (!(ctxt->d & ByteOp))
|
|
|
fop += __ffs(ctxt->dst.bytes) * FASTOP_SIZE;
|
|
|
+
|
|
|
asm("push %[flags]; popf; call *%[fastop]; pushf; pop %[flags]\n"
|
|
|
: "+a"(ctxt->dst.val), "+d"(ctxt->src.val), [flags]"+D"(flags),
|
|
|
- [fastop]"+S"(fop)
|
|
|
+ [fastop]"+S"(fop), "+r"(__sp)
|
|
|
: "c"(ctxt->src2.val));
|
|
|
+
|
|
|
ctxt->eflags = (ctxt->eflags & ~EFLAGS_MASK) | (flags & EFLAGS_MASK);
|
|
|
if (!fop) /* exception is returned in fop variable */
|
|
|
return emulate_de(ctxt);
|