mirror of
https://github.com/luau-lang/luau.git
synced 2025-04-03 02:10:53 +01:00
CodeGen: Implement faddp opcode for A64
We now support scalar version of faddp opcode which can add the first two floats of the vector into the first scalar of the destination.
This commit is contained in:
parent
8fc458edbd
commit
6ebac70495
3 changed files with 12 additions and 0 deletions
|
@ -138,6 +138,7 @@ public:
|
|||
void fneg(RegisterA64 dst, RegisterA64 src);
|
||||
void fsqrt(RegisterA64 dst, RegisterA64 src);
|
||||
void fsub(RegisterA64 dst, RegisterA64 src1, RegisterA64 src2);
|
||||
void faddp(RegisterA64 dst, RegisterA64 src);
|
||||
|
||||
// Vector component manipulation
|
||||
void ins_4s(RegisterA64 dst, RegisterA64 src, uint8_t index);
|
||||
|
|
|
@ -586,6 +586,14 @@ void AssemblyBuilderA64::fabs(RegisterA64 dst, RegisterA64 src)
|
|||
placeR1("fabs", dst, src, 0b000'11110'01'1'0000'01'10000);
|
||||
}
|
||||
|
||||
void AssemblyBuilderA64::faddp(RegisterA64 dst, RegisterA64 src)
|
||||
{
|
||||
CODEGEN_ASSERT(dst.kind == KindA64::d || dst.kind == KindA64::s);
|
||||
CODEGEN_ASSERT(dst.kind == src.kind);
|
||||
|
||||
placeR1("faddp", dst, src, 0b011'11110'0'0'11000'01101'10 | ((dst.kind == KindA64::d) << 12));
|
||||
}
|
||||
|
||||
void AssemblyBuilderA64::fadd(RegisterA64 dst, RegisterA64 src1, RegisterA64 src2)
|
||||
{
|
||||
if (dst.kind == KindA64::d)
|
||||
|
|
|
@ -400,6 +400,9 @@ TEST_CASE_FIXTURE(AssemblyBuilderA64Fixture, "FPMath")
|
|||
SINGLE_COMPARE(fsub(d1, d2, d3), 0x1E633841);
|
||||
SINGLE_COMPARE(fsub(s29, s29, s28), 0x1E3C3BBD);
|
||||
|
||||
SINGLE_COMPARE(faddp(s29, s28), 0x7E30DB9D);
|
||||
SINGLE_COMPARE(faddp(d29, d28), 0x7E70DB9D);
|
||||
|
||||
SINGLE_COMPARE(frinta(d1, d2), 0x1E664041);
|
||||
SINGLE_COMPARE(frintm(d1, d2), 0x1E654041);
|
||||
SINGLE_COMPARE(frintp(d1, d2), 0x1E64C041);
|
||||
|
|
Loading…
Add table
Reference in a new issue