diff options
| author | Mateja Marjanovic | 2019-03-19 16:21:56 +0100 |
|---|---|---|
| committer | Alex Bennée | 2019-03-25 11:34:48 +0100 |
| commit | 7ca96e1a9cadc32af7df73dcf4438b08667d07a6 (patch) | |
| tree | f99f861a9a7433830f66cec1f8a4e3180cf008d0 /scripts/tracetool.py | |
| parent | .travis.yml: reduce number of targets built while disabling things (diff) | |
| download | qemu-7ca96e1a9cadc32af7df73dcf4438b08667d07a6.tar.gz qemu-7ca96e1a9cadc32af7df73dcf4438b08667d07a6.tar.xz qemu-7ca96e1a9cadc32af7df73dcf4438b08667d07a6.zip | |
target/mips: Fix minor bug in FPU
Wrong type of NaN was generated for IEEE 754-2008 by MADDF.<D|S> and
MSUBF.<D|S> instructions when the arguments were (Inf, Zero, NaN) or
(Zero, Inf, NaN).
The if-else statement establishes if the system conforms to IEEE
754-1985 or IEEE 754-2008, and defines different behaviors depending
on that. In case of IEEE 754-2008, in mentioned cases of inputs,
<MADDF|MSUBF>.<D|S> returns the input value 'c' [2] (page 53) and
raises floating point exception 'Invalid Operation' [1] (pages 349,
350).
These scenarios were tested and the results in QEMU emulation match
the results obtained on the machine that has a MIPS64R6 CPU.
[1] MIPS Architecture for Programmers Volume II-a: The MIPS64
Instruction Set Reference Manual, Revision 6.06
[2] MIPS Architecture for Programmers Volume IV-j: The MIPS64
SIMD Architecture Module, Revision 1.12
Signed-off-by: Mateja Marjanovic <mateja.marjanovic@rt-rk.com>
Message-Id: <1553008916-15274-2-git-send-email-mateja.marjanovic@rt-rk.com>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
[AJB: fixed up commit message]
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Diffstat (limited to 'scripts/tracetool.py')
0 files changed, 0 insertions, 0 deletions
