mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2026-04-21 23:17:16 +00:00
Remove the API compatibility layer which converted add, sub, and mul
to fadd, fsub, and fmul, when used with a floating-point type. LLVM has supported the new instructions since 2.6, so it's time to get on board. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@102971 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -2351,11 +2351,28 @@ bool LLParser::ParseValID(ValID &ID, PerFunctionState *PFS) {
|
||||
if (NSW)
|
||||
return Error(ModifierLoc, "nsw only applies to integer operations");
|
||||
}
|
||||
// API compatibility: Accept either integer or floating-point types with
|
||||
// add, sub, and mul.
|
||||
if (!Val0->getType()->isIntOrIntVectorTy() &&
|
||||
!Val0->getType()->isFPOrFPVectorTy())
|
||||
return Error(ID.Loc,"constexpr requires integer, fp, or vector operands");
|
||||
// Check that the type is valid for the operator.
|
||||
switch (Opc) {
|
||||
case Instruction::Add:
|
||||
case Instruction::Sub:
|
||||
case Instruction::Mul:
|
||||
case Instruction::UDiv:
|
||||
case Instruction::SDiv:
|
||||
case Instruction::URem:
|
||||
case Instruction::SRem:
|
||||
if (!Val0->getType()->isIntOrIntVectorTy())
|
||||
return Error(ID.Loc, "constexpr requires integer operands");
|
||||
break;
|
||||
case Instruction::FAdd:
|
||||
case Instruction::FSub:
|
||||
case Instruction::FMul:
|
||||
case Instruction::FDiv:
|
||||
case Instruction::FRem:
|
||||
if (!Val0->getType()->isFPOrFPVectorTy())
|
||||
return Error(ID.Loc, "constexpr requires fp operands");
|
||||
break;
|
||||
default: llvm_unreachable("Unknown binary operator!");
|
||||
}
|
||||
unsigned Flags = 0;
|
||||
if (NUW) Flags |= OverflowingBinaryOperator::NoUnsignedWrap;
|
||||
if (NSW) Flags |= OverflowingBinaryOperator::NoSignedWrap;
|
||||
@@ -3000,8 +3017,7 @@ int LLParser::ParseInstruction(Instruction *&Inst, BasicBlock *BB,
|
||||
if (EatIfPresent(lltok::kw_nuw))
|
||||
NUW = true;
|
||||
}
|
||||
// API compatibility: Accept either integer or floating-point types.
|
||||
bool Result = ParseArithmetic(Inst, PFS, KeywordVal, 0);
|
||||
bool Result = ParseArithmetic(Inst, PFS, KeywordVal, 1);
|
||||
if (!Result) {
|
||||
if (!Inst->getType()->isIntOrIntVectorTy()) {
|
||||
if (NUW)
|
||||
|
||||
Reference in New Issue
Block a user