LLVM  6.0.0svn
Public Member Functions | List of all members
llvm::SelectionDAGTargetInfo Class Reference

Targets can subclass this to parameterize the SelectionDAG lowering and instruction selection process. More...

#include "llvm/CodeGen/SelectionDAGTargetInfo.h"

Inheritance diagram for llvm::SelectionDAGTargetInfo:
Inheritance graph
[legend]

Public Member Functions

 SelectionDAGTargetInfo ()=default
 
 SelectionDAGTargetInfo (const SelectionDAGTargetInfo &)=delete
 
SelectionDAGTargetInfooperator= (const SelectionDAGTargetInfo &)=delete
 
virtual ~SelectionDAGTargetInfo ()
 
virtual SDValue EmitTargetCodeForMemcpy (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, unsigned Align, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const
 Emit target-specific code that performs a memcpy. More...
 
virtual SDValue EmitTargetCodeForMemmove (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, unsigned Align, bool isVolatile, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const
 Emit target-specific code that performs a memmove. More...
 
virtual SDValue EmitTargetCodeForMemset (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, unsigned Align, bool isVolatile, MachinePointerInfo DstPtrInfo) const
 Emit target-specific code that performs a memset. More...
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForMemcmp (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, MachinePointerInfo Op1PtrInfo, MachinePointerInfo Op2PtrInfo) const
 Emit target-specific code that performs a memcmp, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForMemchr (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Src, SDValue Char, SDValue Length, MachinePointerInfo SrcPtrInfo) const
 Emit target-specific code that performs a memchr, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForStrcpy (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Dest, SDValue Src, MachinePointerInfo DestPtrInfo, MachinePointerInfo SrcPtrInfo, bool isStpcpy) const
 Emit target-specific code that performs a strcpy or stpcpy, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForStrcmp (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, MachinePointerInfo Op1PtrInfo, MachinePointerInfo Op2PtrInfo) const
 Emit target-specific code that performs a strcmp, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForStrlen (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src, MachinePointerInfo SrcPtrInfo) const
 
virtual std::pair< SDValue, SDValueEmitTargetCodeForStrnlen (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src, SDValue MaxLength, MachinePointerInfo SrcPtrInfo) const
 
virtual bool generateFMAsInMachineCombiner (CodeGenOpt::Level OptLevel) const
 

Detailed Description

Targets can subclass this to parameterize the SelectionDAG lowering and instruction selection process.

Definition at line 32 of file SelectionDAGTargetInfo.h.

Constructor & Destructor Documentation

◆ SelectionDAGTargetInfo() [1/2]

llvm::SelectionDAGTargetInfo::SelectionDAGTargetInfo ( )
explicitdefault

◆ SelectionDAGTargetInfo() [2/2]

llvm::SelectionDAGTargetInfo::SelectionDAGTargetInfo ( const SelectionDAGTargetInfo )
delete

◆ ~SelectionDAGTargetInfo()

SelectionDAGTargetInfo::~SelectionDAGTargetInfo ( )
virtualdefault

Member Function Documentation

◆ EmitTargetCodeForMemchr()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForMemchr ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Src,
SDValue  Char,
SDValue  Length,
MachinePointerInfo  SrcPtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a memchr, in cases where that is faster than a libcall.

The first returned SDValue is the result of the memchr and the second is the chain. Both SDValues can be null if a normal libcall should be used.

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 106 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ EmitTargetCodeForMemcmp()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForMemcmp ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
MachinePointerInfo  Op1PtrInfo,
MachinePointerInfo  Op2PtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a memcmp, in cases where that is faster than a libcall.

The first returned SDValue is the result of the memcmp and the second is the chain. Both SDValues can be null if a normal libcall should be used.

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 94 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ EmitTargetCodeForMemcpy()

virtual SDValue llvm::SelectionDAGTargetInfo::EmitTargetCodeForMemcpy ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
bool  AlwaysInline,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a memcpy.

This can be used by targets to provide code sequences for cases that don't fit the target's parameters for simple loads/stores and can be more efficient than using a library call. This function can return a null SDValue if the target declines to use custom code and a different lowering strategy should be used.

If AlwaysInline is true, the size is constant and the target should not emit any calls and is strongly encouraged to attempt to emit inline code even if it is beyond the usual threshold because this intrinsic is being expanded in a place where calls are not feasible (e.g. within the prologue for another call). If the target chooses to decline an AlwaysInline request here, legalize will resort to using simple loads and stores.

Reimplemented in llvm::ARMSelectionDAGInfo, llvm::X86SelectionDAGInfo, llvm::SystemZSelectionDAGInfo, llvm::LanaiSelectionDAGInfo, llvm::HexagonSelectionDAGInfo, and llvm::XCoreSelectionDAGInfo.

Definition at line 52 of file SelectionDAGTargetInfo.h.

Referenced by llvm::SelectionDAG::getMemcpy().

◆ EmitTargetCodeForMemmove()

virtual SDValue llvm::SelectionDAGTargetInfo::EmitTargetCodeForMemmove ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a memmove.

This can be used by targets to provide code sequences for cases that don't fit the target's parameters for simple loads/stores and can be more efficient than using a library call. This function can return a null SDValue if the target declines to use custom code and a different lowering strategy should be used.

Reimplemented in llvm::ARMSelectionDAGInfo.

Definition at line 68 of file SelectionDAGTargetInfo.h.

Referenced by llvm::SelectionDAG::getMemmove().

◆ EmitTargetCodeForMemset()

virtual SDValue llvm::SelectionDAGTargetInfo::EmitTargetCodeForMemset ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
MachinePointerInfo  DstPtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a memset.

This can be used by targets to provide code sequences for cases that don't fit the target's parameters for simple stores and can be more efficient than using a library call. This function can return a null SDValue if the target declines to use custom code and a different lowering strategy should be used.

Reimplemented in llvm::ARMSelectionDAGInfo, llvm::X86SelectionDAGInfo, llvm::SystemZSelectionDAGInfo, and llvm::AArch64SelectionDAGInfo.

Definition at line 81 of file SelectionDAGTargetInfo.h.

Referenced by llvm::SelectionDAG::getMemset().

◆ EmitTargetCodeForStrcmp()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForStrcmp ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
MachinePointerInfo  Op1PtrInfo,
MachinePointerInfo  Op2PtrInfo 
) const
inlinevirtual

Emit target-specific code that performs a strcmp, in cases where that is faster than a libcall.

The first returned SDValue is the result of the strcmp and the second is the chain. Both SDValues can be null if a normal libcall should be used.

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 131 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ EmitTargetCodeForStrcpy()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForStrcpy ( SelectionDAG DAG,
const SDLoc DL,
SDValue  Chain,
SDValue  Dest,
SDValue  Src,
MachinePointerInfo  DestPtrInfo,
MachinePointerInfo  SrcPtrInfo,
bool  isStpcpy 
) const
inlinevirtual

Emit target-specific code that performs a strcpy or stpcpy, in cases where that is faster than a libcall.

The first returned SDValue is the result of the copy (the start of the destination string for strcpy, a pointer to the null terminator for stpcpy) and the second is the chain. Both SDValues can be null if a normal libcall should be used.

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 119 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ EmitTargetCodeForStrlen()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForStrlen ( SelectionDAG DAG,
const SDLoc DL,
SDValue  Chain,
SDValue  Src,
MachinePointerInfo  SrcPtrInfo 
) const
inlinevirtual

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 139 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ EmitTargetCodeForStrnlen()

virtual std::pair<SDValue, SDValue> llvm::SelectionDAGTargetInfo::EmitTargetCodeForStrnlen ( SelectionDAG DAG,
const SDLoc DL,
SDValue  Chain,
SDValue  Src,
SDValue  MaxLength,
MachinePointerInfo  SrcPtrInfo 
) const
inlinevirtual

Reimplemented in llvm::SystemZSelectionDAGInfo.

Definition at line 145 of file SelectionDAGTargetInfo.h.

Referenced by getMemCmpLoad().

◆ generateFMAsInMachineCombiner()

virtual bool llvm::SelectionDAGTargetInfo::generateFMAsInMachineCombiner ( CodeGenOpt::Level  OptLevel) const
inlinevirtual

Reimplemented in llvm::AArch64SelectionDAGInfo.

Definition at line 153 of file SelectionDAGTargetInfo.h.

Referenced by isContractable().

◆ operator=()

SelectionDAGTargetInfo& llvm::SelectionDAGTargetInfo::operator= ( const SelectionDAGTargetInfo )
delete

The documentation for this class was generated from the following files: