Re: [PATCH 2/3] MIPS: Add full ISA emulator.
From: Maciej W. Rozycki
Date: Thu Dec 04 2014 - 15:32:33 EST
On Thu, 4 Dec 2014, David Daney wrote:
> > GAS will happily schedule any instruction into a branch delay slot as
> > long as the instruction is not architecturally forbidden there (e.g.
> > ERET), there is no data dependency with the branch that would affect the
> > result produced and the instruction is not an explicit exception trap
> > operation (BREAK, SYSCALL, TEQ, etc.). For some reason, unknown to me all
> > MT ASE instructions are disallowed too. Anything else -- free to go in!
> >
> > Of course instructions can be scheduled into branch delay slots manually
> > too, in handcoded assembly, and that has to continue working.
> >
>
> It is not difficult to also emulate the trapping instructions. In order to
> move forward, I will implement the trapping instructions in my emulator for
> the next patch.
I'd be more concerned about getting the more exotic instructions or cases
right (did you get MADDU right for SmartMIPS processors and set the ACX
register on them?) -- how do you propose to validate and regression-test
the emulator in a reproducible manner?
The combination of the rare case of an instruction being placed in an FP
branch delay slot and the rarity of some instructions themselves makes me
scared of bugs lurking there forever and occasionally biting people -- who
may not be aware that software emulation is involved let alone be capable
to track them down -- in the most frustrating way. To say nothing of the
infinite amount of effort to maintain the emulator associated with adding
architectural and vendor-specific instructions. See how much effort has
been put into QEMU and still it does not get all the MIPS instruction set
bits right.
Maciej
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/