|
LLVM 23.0.0git
|
#include "X86FrameLowering.h"#include "MCTargetDesc/X86MCTargetDesc.h"#include "X86InstrBuilder.h"#include "X86InstrInfo.h"#include "X86MachineFunctionInfo.h"#include "X86Subtarget.h"#include "X86TargetMachine.h"#include "llvm/ADT/Statistic.h"#include "llvm/CodeGen/LivePhysRegs.h"#include "llvm/CodeGen/MachineFrameInfo.h"#include "llvm/CodeGen/MachineFunction.h"#include "llvm/CodeGen/MachineInstrBuilder.h"#include "llvm/CodeGen/MachineModuleInfo.h"#include "llvm/CodeGen/MachineRegisterInfo.h"#include "llvm/CodeGen/RegisterScavenging.h"#include "llvm/CodeGen/WinEHFuncInfo.h"#include "llvm/IR/DataLayout.h"#include "llvm/IR/EHPersonalities.h"#include "llvm/IR/Function.h"#include "llvm/IR/Module.h"#include "llvm/MC/MCAsmInfo.h"#include "llvm/MC/MCObjectFileInfo.h"#include "llvm/MC/MCSymbol.h"#include "llvm/Support/LEB128.h"#include "llvm/Target/TargetOptions.h"#include <cstdlib>Go to the source code of this file.
Macros | |
| #define | DEBUG_TYPE "x86-fl" |
Variables | |
| constexpr uint64_t | MaxSPChunk = (1ULL << 31) - 1 |
| static const uint64_t | kSplitStackAvailable = 256 |
| #define DEBUG_TYPE "x86-fl" |
Definition at line 40 of file X86FrameLowering.cpp.
|
static |
Definition at line 3710 of file X86FrameLowering.cpp.
References llvm::all_of(), MBB, MBBI, and MI.
Referenced by llvm::X86FrameLowering::eliminateCallFramePseudoInstr().
Definition at line 1285 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitEpilogue(), llvm::X86FrameLowering::emitPrologue(), and llvm::X86FrameLowering::getFrameIndexReference().
|
static |
Definition at line 4472 of file X86FrameLowering.cpp.
References llvm::alignTo(), llvm::TargetSubtargetInfo::getFrameLowering(), llvm::TargetSubtargetInfo::getRegisterInfo(), llvm::TargetFrameLowering::getStackAlign(), llvm::MachineFunction::getSubtarget(), and TRI.
|
static |
Check if the flags need to be preserved before the terminators.
This would be the case, if the eflags is live-in of the region composed by the terminators or live-out of that region, without being defined by a terminator.
Definition at line 191 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::canUseAsEpilogue().
Definition at line 122 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::restoreWin32EHStackPointers().
Definition at line 130 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitSPUpdate().
Definition at line 134 of file X86FrameLowering.cpp.
|
static |
Definition at line 50 of file X86FrameLowering.cpp.
References contains(), Reg, and TRI.
Referenced by llvm::X86FrameLowering::assignCalleeSavedSpillSlots(), llvm::X86FrameLowering::restoreCalleeSavedRegisters(), and llvm::X86FrameLowering::spillCalleeSavedRegisters().
|
static |
Lookup an ERTS parameter in the !hipe.literals named metadata node.
HiPE provides Erlang Runtime System-internal parameters, such as PCB offsets to fields it needs, through a named metadata node "hipe.literals" containing name-value pairs.
Definition at line 3688 of file X86FrameLowering.cpp.
References llvm::dyn_cast(), llvm::dyn_cast_or_null(), llvm::NamedMDNode::getNumOperands(), llvm::NamedMDNode::getOperand(), llvm::MDString::getString(), llvm::ValueAsMetadata::getValue(), llvm::ConstantInt::getZExtValue(), and llvm::report_fatal_error().
Referenced by llvm::X86FrameLowering::adjustForHiPEPrologue().
Definition at line 138 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitEpilogue().
|
static |
Definition at line 170 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::restoreCalleeSavedRegisters().
|
static |
Definition at line 163 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitEpilogue(), and llvm::X86FrameLowering::restoreCalleeSavedRegisters().
|
static |
Definition at line 167 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::spillCalleeSavedRegisters().
|
static |
Definition at line 159 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitPrologue(), and llvm::X86FrameLowering::spillCalleeSavedRegisters().
|
static |
GetScratchRegister - Get a temp register for performing work in the segmented stack and the Erlang/HiPE stack prologue.
Depending on platform and the properties of the function either one or two registers will be needed. Set primary to true for the first register, false for the second.
Definition at line 3388 of file X86FrameLowering.cpp.
References llvm::CallingConv::Fast, llvm::Function::getCallingConv(), llvm::MachineFunction::getFunction(), HasNestArgument(), llvm::CallingConv::HiPE, llvm::report_fatal_error(), llvm::CallingConv::Tail, and llvm::CallingConv::X86_FastCall.
Referenced by llvm::X86FrameLowering::adjustForHiPEPrologue(), and llvm::X86FrameLowering::adjustForSegmentedStacks().
Definition at line 118 of file X86FrameLowering.cpp.
Definition at line 126 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitSPUpdate().
|
static |
Definition at line 3374 of file X86FrameLowering.cpp.
References E(), F, llvm::MachineFunction::getFunction(), and I.
Referenced by llvm::X86FrameLowering::adjustForSegmentedStacks(), and GetScratchRegister().
|
static |
Definition at line 174 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitPrologue(), and llvm::X86FrameLowering::emitSPUpdate().
|
static |
Definition at line 4634 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::spillFPBP().
|
static |
Definition at line 2416 of file X86FrameLowering.cpp.
References llvm_unreachable, and MI.
|
static |
Definition at line 4654 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::spillFPBP().
Return true if an opcode is part of the REP group of instructions.
Definition at line 1490 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitPrologue().
Definition at line 2482 of file X86FrameLowering.cpp.
References Opc.
| STATISTIC | ( | NumFrameExtraProbe | , |
| "Number of extra stack probes generated in prologue" | ) |
| STATISTIC | ( | NumFrameLoopProbe | , |
| "Number of loop stack probes used in prologue" | ) |
| STATISTIC | ( | NumFunctionUsingPush2Pop2 | , |
| "Number of functions using push2/pop2" | ) |
Definition at line 3424 of file X86FrameLowering.cpp.
|
constexpr |
Definition at line 225 of file X86FrameLowering.cpp.
Referenced by llvm::X86FrameLowering::emitSPUpdate().