//===----------------------------------------------------------------------===//
#include "WebAssemblyMCInstLower.h"
-#include "WebAssemblyMachineFunctionInfo.h"
#include "llvm/ADT/SmallString.h"
+#include "llvm/IR/Constants.h"
#include "llvm/CodeGen/AsmPrinter.h"
#include "llvm/CodeGen/MachineBasicBlock.h"
-#include "llvm/CodeGen/MachineFunction.h"
#include "llvm/CodeGen/MachineInstr.h"
-#include "llvm/IR/Constants.h"
#include "llvm/MC/MCAsmInfo.h"
#include "llvm/MC/MCContext.h"
#include "llvm/MC/MCExpr.h"
default:
MI->dump();
llvm_unreachable("unknown operand type");
- case MachineOperand::MO_Register: {
+ case MachineOperand::MO_Register:
// Ignore all implicit register operands.
if (MO.isImplicit())
continue;
- // TODO: Handle physical registers.
- const WebAssemblyFunctionInfo &MFI =
- *MI->getParent()->getParent()->getInfo<WebAssemblyFunctionInfo>();
- unsigned WAReg = MFI.getWAReg(MO.getReg());
- MCOp = MCOperand::createReg(WAReg);
+ MCOp = MCOperand::createReg(MO.getReg());
break;
- }
case MachineOperand::MO_Immediate:
MCOp = MCOperand::createImm(MO.getImm());
break;
- case MachineOperand::MO_FPImmediate: {
- // TODO: MC converts all floating point immediate operands to double.
- // This is fine for numeric values, but may cause NaNs to change bits.
- const ConstantFP *Imm = MO.getFPImm();
- if (Imm->getType()->isFloatTy())
- MCOp = MCOperand::createFPImm(Imm->getValueAPF().convertToFloat());
- else if (Imm->getType()->isDoubleTy())
- MCOp = MCOperand::createFPImm(Imm->getValueAPF().convertToDouble());
- else
- llvm_unreachable("unknown floating point immediate type");
+ case MachineOperand::MO_FPImmediate:
+ MCOp = MCOperand::createFPImm(
+ MO.getFPImm()->getValueAPF().convertToDouble());
break;
- }
case MachineOperand::MO_MachineBasicBlock:
MCOp = MCOperand::createExpr(
MCSymbolRefExpr::create(MO.getMBB()->getSymbol(), Ctx));
break;
+ case MachineOperand::MO_RegisterMask:
+ continue;
case MachineOperand::MO_GlobalAddress:
MCOp = LowerSymbolOperand(MO, GetGlobalAddressSymbol(MO));
break;