[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-ppc] [PATCH V2 00/19] PowerPC VSX Stage 3
From: |
Tom Musta |
Subject: |
[Qemu-ppc] [PATCH V2 00/19] PowerPC VSX Stage 3 |
Date: |
Tue, 29 Oct 2013 08:01:27 -0500 |
User-agent: |
Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20100101 Thunderbird/24.0.1 |
From 89de52ee03f68cef1f3343d3275162427ec22ded Mon Sep 17 00:00:00 2001
From: Tom Musta <address@hidden>
Date: Tue, 29 Oct 2013 07:52:19 -0500
Subject:
To: address@hidden
This is the third series of patches to add PowerPC VSX emulation support
to QEMU.
This series adds the floating point arithmetic, compare, conversion and
rounding instructions. Instructions are implemented using helpers and
wherever practical, existing floating point code such as the softfloat
library and the existing PowerPC floating point helper code.
As with the previous series, the Power ISA V2.06 instructions are added
but the V2.07 instructions are not. The latter will be implemented in a
future patch series.
V2: Implemented changes based on feedback from Richard Henderson and
Peter Maydell:
- Included float64_to_uint64() patch in this series rather than just
cite it as a pre-requesite.
- Isolated float32_to_uint64() in its own patch.
- Re-implemented helpers and eliminated the need for some of the proposed
softfloat routines (float*_is_denormal, float*_get_unbiased_exp).
- Re-implemented severy helpers so that corner cases (e.g. invalid
operations) are detected by softfloat.
- Re-implemented fused multiply-add to use the softfloat muladd routines.
- Re-implemented the min/max instructions to used the softfloat
min/max functions.
- assorted style fixes
Tom Musta (19):
Fix float64_to_uint64
Add float32_to_uint64()
Add set_fprf Argument to fload_invalid_op_excp()
General Support for VSX Helpers
Add VSX ISA2.06 xadd/xsub Instructions
Add VSX ISA2.06 xmul Instructions
Add VSX ISA2.06 xdiv Instructions
Add VSX ISA2.06 xre Instructions
Add VSX ISA2.06 xsqrt Instructions
Add VSX ISA2.06 xrsqrte Instructions
Add VSX ISA2.06 xtdiv Instructions
Add VSX ISA2.06 xtsqrt Instructions
Add VSX ISA2.06 Multiply Add Instructions
Add VSX xscmp*dp Instructions
Add VSX xmax/xmin Instructions
Add VSX Vector Compare Instructions
Add VSX Floating Point to Floating Point Conversion Instructions
Add VSX ISA2.06 Integer Conversion Instructions
Add VSX Rounding Instructions
fpu/softfloat.c | 140 +++++++-
include/fpu/softfloat.h | 1 +
target-ppc/fpu_helper.c | 1002 ++++++++++++++++++++++++++++++++++++++++++++---
target-ppc/helper.h | 109 +++++
target-ppc/translate.c | 243 ++++++++++++
5 files changed, 1439 insertions(+), 56 deletions(-)
- [Qemu-ppc] [PATCH V2 00/19] PowerPC VSX Stage 3,
Tom Musta <=
- [Qemu-ppc] [PATCH V2 01/19] Fix float64_to_uint64, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 02/19] Add float32_to_uint64(), Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 03/19] Add set_fprf Argument to fload_invalid_op_excp(), Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 04/19] General Support for VSX Helpers, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 05/19] Add VSX ISA2.06 xadd/xsub Instructions, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 06/19] Add VSX ISA2.06 xmul Instructions, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 07/19] Add VSX ISA2.06 xdiv Instructions, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 08/19] Add VSX ISA2.06 xre Instructions, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 09/19] Add VSX ISA2.06 xsqrt Instructions, Tom Musta, 2013/10/29
- [Qemu-ppc] [PATCH V2 10/19] Add VSX ISA2.06 xrsqrte Instructions, Tom Musta, 2013/10/29