48 cl::desc(
"WebAssembly: output stack registers in"
49 " instruction output for test purposes only."),
55 const auto *BaseObject =
Global->getAliaseeObject();
60 "wasm_var address space symbol must resolve to a "
65 return !GV->isConstant();
71WebAssemblyMCInstLower::GetGlobalAddressSymbol(
const MachineOperand &MO)
const {
74 auto *WasmSym =
static_cast<MCSymbolWasm *
>(Printer.getSymbol(
Global));
79 !WasmSym->getType()) {
85 std::optional<bool> Mutable =
87 if (!Mutable.has_value())
101 const TargetMachine &TM = MF.
getTarget();
110 bool InvokeDetected =
false;
111 auto *WasmSym = Printer.getMCSymbolForFunction(
F, Signature, InvokeDetected);
112 WasmSym->setSignature(Signature);
117MCSymbol *WebAssemblyMCInstLower::GetExternalSymbolSymbol(
127 switch (TargetFlags) {
152 const auto *WasmSym =
static_cast<const MCSymbolWasm *
>(Sym);
155 if (WasmSym->isFunction())
157 if (WasmSym->isGlobal())
159 if (WasmSym->isTag())
161 if (WasmSym->isTable())
171MCOperand WebAssemblyMCInstLower::lowerTypeIndexOperand(
174 auto Signature = Ctx.createWasmSignature();
175 Signature->Returns = std::move(Returns);
176 Signature->Params = std::move(Params);
178 static_cast<MCSymbolWasm *
>(Printer.createTempSymbol(
"typeindex"));
179 Sym->setSignature(Signature);
187WebAssemblyMCInstLower::lowerEncodedFunctionSignature(
const APInt &Sig)
const {
194 auto GetWord = [&Idx, &Sig]() {
203 int NReturns = GetWord() ^ 0x7ffffff;
204 for (
int I = 0;
I < NReturns;
I++) {
207 int NParams = GetWord();
208 for (
int I = 0;
I < NParams;
I++) {
211 return lowerTypeIndexOperand(std::move(Returns), std::move(Params));
218 Type *RetTy =
F.getReturnType();
229 unsigned NumVariadicDefs =
MI->getNumExplicitDefs() -
Desc.getNumDefs();
237 for (
unsigned I = 0, E =
MI->getNumOperands();
I != E; ++
I) {
262 unsigned DescIndex =
I - NumVariadicDefs;
263 assert(DescIndex <
Desc.NumOperands &&
"unexpected CImmediate operand");
264 auto Operands =
Desc.operands();
267 "unexpected CImmediate operand");
273 unsigned DescIndex =
I - NumVariadicDefs;
274 if (DescIndex <
Desc.NumOperands) {
275 auto Operands =
Desc.operands();
286 MI->getParent()->getParent()->getRegInfo();
302 if (
MI->getOpcode() == WebAssembly::RET_CALL_INDIRECT)
305 MCOp = lowerTypeIndexOperand(std::move(Returns), std::move(Params));
329 MCOp = lowerTypeIndexOperand(std::move(Returns),
341 Imm->getValueAPF().bitcastToAPInt().getZExtValue();
342 if (Imm->getType()->isFloatTy())
344 else if (Imm->getType()->isDoubleTy())
351 MCOp = lowerSymbolOperand(MO, GetGlobalAddressSymbol(MO));
354 MCOp = lowerSymbolOperand(MO, GetExternalSymbolSymbol(MO));
358 "WebAssembly does not use target flags on MCSymbol");
368 else if (
Desc.variadicOpsAreDefs())
386 if (
MI->isDebugInstr() ||
MI->isLabel() ||
MI->isInlineAsm())
392 assert(StackOpcode != -1 &&
"Failed to stackify instruction");
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the SmallVector class.
cl::opt< bool > WasmKeepRegisters
This file contains the declaration of the WebAssemblyMCAsmInfo class.
static void removeRegisterOperands(const MachineInstr *MI, MCInst &OutMI)
static std::optional< bool > getWasmGlobalMutable(const GlobalValue *Global, const Function &CurrentFunc, const DiagnosticLocation &DL)
static cl::opt< bool > WasmKeepRegisters("wasm-keep-registers", cl::Hidden, cl::desc("WebAssembly: output stack registers in" " instruction output for test purposes only."), cl::init(false))
static void getFunctionReturns(const MachineInstr *MI, SmallVectorImpl< wasm::ValType > &Returns)
This file declares the class to lower WebAssembly MachineInstrs to their corresponding MCInst records...
This file provides WebAssembly-specific target descriptions.
This file contains the declaration of the WebAssembly-specific type parsing utility functions.
This file declares WebAssembly-specific per-machine-function information.
This file registers the WebAssembly target.
This file contains the declaration of the WebAssembly-specific type parsing utility functions.
This file contains the declaration of the WebAssembly-specific utility functions.
Class for arbitrary precision integers.
LLVM_ABI uint64_t extractBitsAsZExtValue(unsigned numBits, unsigned bitPosition) const
unsigned getNumWords() const
Get the number of words.
ConstantFP - Floating Point Values [float, double].
const APInt & getValue() const
Return the constant as an APInt value reference.
Diagnostic information for unsupported feature in backend.
LLVMContext & getContext() const
getContext - Return a reference to the LLVMContext associated with this function.
LLVM_ABI void diagnose(const DiagnosticInfo &DI)
Report a message to the currently installed diagnostic handler.
static const MCBinaryExpr * createAdd(const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx, SMLoc Loc=SMLoc())
static LLVM_ABI const MCConstantExpr * create(int64_t Value, MCContext &Ctx, bool PrintInHex=false, unsigned SizeInBytes=0)
Instances of this class represent a single low-level machine instruction.
unsigned getNumOperands() const
unsigned getOpcode() const
iterator insert(iterator I, const MCOperand &Op)
void addOperand(const MCOperand Op)
void setOpcode(unsigned Op)
const MCOperand & getOperand(unsigned i) const
Describe properties that are true of each instruction in the target description file.
This holds information about one operand of a machine instruction, indicating the register class for ...
Instances of this class represent operands of the MCInst class.
static MCOperand createExpr(const MCExpr *Val)
static MCOperand createSFPImm(uint32_t Val)
static MCOperand createReg(MCRegister Reg)
static MCOperand createImm(int64_t Val)
static MCOperand createDFPImm(uint64_t Val)
static const MCSymbolRefExpr * create(const MCSymbol *Symbol, MCContext &Ctx, SMLoc Loc=SMLoc())
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
const DataLayout & getDataLayout() const
Return the DataLayout attached to the Module associated to this MF.
Function & getFunction()
Return the LLVM function that this machine code represents.
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
Representation of each machine instruction.
const MachineBasicBlock * getParent() const
MachineOperand class - Representation of each machine instruction operand.
const GlobalValue * getGlobal() const
const ConstantInt * getCImm() const
bool isReg() const
isReg - Tests if this is a MO_Register operand.
MachineInstr * getParent()
getParent - Return the instruction that this operand belongs to.
unsigned getTargetFlags() const
MachineOperandType getType() const
getType - Returns the MachineOperandType for this operand.
const char * getSymbolName() const
Register getReg() const
getReg - Returns the register number.
const ConstantFP * getFPImm() const
MCSymbol * getMCSymbol() const
@ MO_Immediate
Immediate operand.
@ MO_MCSymbol
MCSymbol reference (for debug/eh info)
@ MO_GlobalAddress
Address of a global value.
@ MO_CImmediate
Immediate >64bit operand.
@ MO_MachineBasicBlock
MachineBasicBlock reference.
@ MO_Register
Register operand.
@ MO_ExternalSymbol
Name of external global symbol.
@ MO_FPImmediate
Floating-point immediate operand.
int64_t getOffset() const
Return the offset from the symbol in this operand.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
const TargetRegisterClass * getRegClass(Register Reg) const
Return the register class of the specified virtual register.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Primary interface to the complete machine description for the target machine.
unsigned getID() const
Return the register class ID number.
The instances of the Type class are immutable: once they are created, they are never changed.
This class is derived from MachineFunctionInfo and contains private WebAssembly-specific information ...
unsigned getWAReg(Register VReg) const
void lower(const MachineInstr *MI, MCInst &OutMI) const
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
bool isCallIndirect(unsigned Opc)
wasm::ValType regClassToValType(unsigned RC)
int32_t getStackOpcode(uint32_t Opcode)
BlockType
Used as immediate MachineOperands for block signatures.
void wasmSymbolSetType(MCSymbolWasm *Sym, const Type *GlobalVT, ArrayRef< MVT > VTs, bool Mutable)
Sets a Wasm Symbol Type.
@ OPERAND_TYPEINDEX
type signature immediate for call_indirect.
@ OPERAND_SIGNATURE
signature immediate for block/loop.
bool isWasmVarAddressSpace(unsigned AS)
initializer< Ty > init(const Ty &Val)
@ WASM_SYMBOL_TYPE_FUNCTION
This is an optimization pass for GlobalISel generic memory operations.
void computeSignatureVTs(const FunctionType *Ty, const Function *TargetFunc, const Function &ContextFunc, const TargetMachine &TM, SmallVectorImpl< MVT > &Params, SmallVectorImpl< MVT > &Results)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto dyn_cast_or_null(const Y &Val)
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
@ Global
Append to llvm.global_dtors.
void valTypesFromMVTs(ArrayRef< MVT > In, SmallVectorImpl< wasm::ValType > &Out)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
wasm::WasmSignature * signatureFromMVTs(MCContext &Ctx, const SmallVectorImpl< MVT > &Results, const SmallVectorImpl< MVT > &Params)
void computeLegalValueVTs(const WebAssemblyTargetLowering &TLI, LLVMContext &Ctx, const DataLayout &DL, Type *Ty, SmallVectorImpl< MVT > &ValueVTs)