diff options
author | Maxime Martinasso <maxime.cscs@gmail.com> | 2015-01-03 17:51:48 -0600 |
---|---|---|
committer | Maxime Martinasso <maxime.cscs@gmail.com> | 2015-01-03 17:51:48 -0600 |
commit | 5a5416d575f68e416ebe713ad76dc468a59ac23c (patch) | |
tree | edebb20dcac36135e1a72ce824e55bac6f5e1348 | |
parent | 02c376ac44584484268bd714a45fa0f0265a896a (diff) | |
download | gem5-5a5416d575f68e416ebe713ad76dc468a59ac23c.tar.xz |
x86: implements the simd128 ADDSUBPD instruction
This patch implements the simd128 ADDSUBPD instruction for the x86 architecture.
Tested with a simple program in assembly language which executes the
instruction. Checked that different versions of the instruction are executed
by using the execution tracing option.
Committed by: Nilay Vaish <nilay@cs.wisc.edu
-rw-r--r-- | src/arch/x86/isa/decoder/two_byte_opcodes.isa | 2 | ||||
-rw-r--r-- | src/arch/x86/isa/insts/simd128/floating_point/arithmetic/simultaneous_addition_and_subtraction.py | 21 |
2 files changed, 21 insertions, 2 deletions
diff --git a/src/arch/x86/isa/decoder/two_byte_opcodes.isa b/src/arch/x86/isa/decoder/two_byte_opcodes.isa index e1b20feb1..dfc328c4b 100644 --- a/src/arch/x86/isa/decoder/two_byte_opcodes.isa +++ b/src/arch/x86/isa/decoder/two_byte_opcodes.isa @@ -903,7 +903,7 @@ } // operand size (0x66) 0x1: decode OPCODE_OP_BOTTOM3 { - 0x0: WarnUnimpl::addsubpd_Vo_Wo(); + 0x0: ADDSUBPD(Vo,Wo); 0x1: PSRLW(Vo,Wo); 0x2: PSRLD(Vo,Wo); 0x3: PSRLQ(Vo,Wo); diff --git a/src/arch/x86/isa/insts/simd128/floating_point/arithmetic/simultaneous_addition_and_subtraction.py b/src/arch/x86/isa/insts/simd128/floating_point/arithmetic/simultaneous_addition_and_subtraction.py index 2e9aebfdc..00b191eca 100644 --- a/src/arch/x86/isa/insts/simd128/floating_point/arithmetic/simultaneous_addition_and_subtraction.py +++ b/src/arch/x86/isa/insts/simd128/floating_point/arithmetic/simultaneous_addition_and_subtraction.py @@ -37,5 +37,24 @@ microcode = ''' # ADDSUBPS -# ADDSUBPD + +def macroop ADDSUBPD_XMM_XMM { + msubf xmml, xmml, xmmlm, size=8, ext=Scalar + maddf xmmh, xmmh, xmmhm, size=8, ext=Scalar +}; + +def macroop ADDSUBPD_XMM_M { + ldfp ufp1, seg, sib, disp, dataSize=8 + ldfp ufp2, seg, sib, "DISPLACEMENT+8", dataSize=8 + msubf xmmlm, xmml, ufp1, size=8, ext=0 + maddf xmmhm, xmmh, ufp2, size=8, ext=0 +}; + +def macroop ADDSUBPD_XMM_P { + rdip t7 + ldfp ufp1, seg, sib, disp, dataSize=8 + ldfp ufp2, seg, sib, "DISPLACEMENT+8", dataSize=8 + msubf xmmlm, xmml, ufp1, size=8, ext=0 + maddf xmmhm, xmmh, ufp2, size=8, ext=0 +}; ''' |