mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-24 19:44:49 +00:00
Changed the encoding of X86 floating point stack operations where both operands
are st(0). These can be encoded using an opcode for storing in st(0) or using an opcode for storing in st(i), where i can also be 0. To allow testing with the darwin assembler and get a matching binary the opcode for storing in st(0) is now used. To do this the same logical trick is use from the darwin assembler in converting things like this: fmul %st(0), %st into this: fmul %st(0) by looking for the second operand being X86::ST0 for specific floating point mnemonics then removing the second X86::ST0 operand. This also has the add benefit to allow things like: fmul %st(1), %st that llvm-mc did not assemble. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104634 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
854f30d965
commit
cf50a5390c
@ -706,6 +706,17 @@ ParseInstruction(const StringRef &Name, SMLoc NameLoc,
|
||||
Operands.erase(Operands.begin() + 1);
|
||||
}
|
||||
|
||||
// FIXME: Hack to handle "f{mul*,add*,sub*,div*} $op, st(0)" the same as
|
||||
// "f{mul*,add*,sub*,div*} $op"
|
||||
if ((Name.startswith("fmul") || Name.startswith("fadd") ||
|
||||
Name.startswith("fsub") || Name.startswith("fdiv")) &&
|
||||
Operands.size() == 3 &&
|
||||
static_cast<X86Operand*>(Operands[2])->isReg() &&
|
||||
static_cast<X86Operand*>(Operands[2])->getReg() == X86::ST0) {
|
||||
delete Operands[2];
|
||||
Operands.erase(Operands.begin() + 2);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -277,3 +277,28 @@ retl
|
||||
// CHECK: cmpsd $7, %xmm0, %xmm1
|
||||
// CHECK: encoding: [0xf2,0x0f,0xc2,0xc8,0x07]
|
||||
cmpordsd %xmm0, %xmm1
|
||||
|
||||
// rdar://7995856
|
||||
// CHECK: fmul %st(0)
|
||||
// CHECK: encoding: [0xd8,0xc8]
|
||||
fmul %st(0), %st
|
||||
|
||||
// CHECK: fadd %st(0)
|
||||
// CHECK: encoding: [0xd8,0xc0]
|
||||
fadd %st(0), %st
|
||||
|
||||
// CHECK: fsub %st(0)
|
||||
// CHECK: encoding: [0xd8,0xe0]
|
||||
fsub %st(0), %st
|
||||
|
||||
// CHECK: fsubr %st(0)
|
||||
// CHECK: encoding: [0xd8,0xe8]
|
||||
fsubr %st(0), %st
|
||||
|
||||
// CHECK: fdivr %st(0)
|
||||
// CHECK: encoding: [0xd8,0xf8]
|
||||
fdivr %st(0), %st
|
||||
|
||||
// CHECK: fdiv %st(0)
|
||||
// CHECK: encoding: [0xd8,0xf0]
|
||||
fdiv %st(0), %st
|
||||
|
Loading…
x
Reference in New Issue
Block a user