LLVM  3.7.0
Public Member Functions | List of all members
llvm::ARMSelectionDAGInfo Class Reference

#include <ARMSelectionDAGInfo.h>

Inheritance diagram for llvm::ARMSelectionDAGInfo:
[legend]
Collaboration diagram for llvm::ARMSelectionDAGInfo:
[legend]

Public Member Functions

SDValue EmitTargetCodeForMemcpy (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, unsigned Align, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const override
 EmitTargetCodeForMemcpy - Emit target-specific code that performs a memcpy. More...
 
SDValue EmitTargetCodeForMemmove (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, unsigned Align, bool isVolatile, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const override
 EmitTargetCodeForMemmove - Emit target-specific code that performs a memmove. More...
 
SDValue EmitTargetCodeForMemset (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, unsigned Align, bool isVolatile, MachinePointerInfo DstPtrInfo) const override
 EmitTargetCodeForMemset - Emit target-specific code that performs a memset. More...
 
SDValue EmitSpecializedLibcall (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, unsigned Align, RTLIB::Libcall LC) const
 
- Public Member Functions inherited from llvm::TargetSelectionDAGInfo
 TargetSelectionDAGInfo ()=default
 
virtual ~TargetSelectionDAGInfo ()
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForMemcmp (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, MachinePointerInfo Op1PtrInfo, MachinePointerInfo Op2PtrInfo) const
 EmitTargetCodeForMemcmp - Emit target-specific code that performs a memcmp, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForMemchr (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Src, SDValue Char, SDValue Length, MachinePointerInfo SrcPtrInfo) const
 EmitTargetCodeForMemchr - Emit target-specific code that performs a memchr, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForStrcpy (SelectionDAG &DAG, SDLoc DL, SDValue Chain, SDValue Dest, SDValue Src, MachinePointerInfo DestPtrInfo, MachinePointerInfo SrcPtrInfo, bool isStpcpy) const
 EmitTargetCodeForStrcpy - Emit target-specific code that performs a strcpy or stpcpy, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForStrcmp (SelectionDAG &DAG, SDLoc dl, SDValue Chain, SDValue Op1, SDValue Op2, MachinePointerInfo Op1PtrInfo, MachinePointerInfo Op2PtrInfo) const
 EmitTargetCodeForStrcmp - Emit target-specific code that performs a strcmp, in cases where that is faster than a libcall. More...
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForStrlen (SelectionDAG &DAG, SDLoc DL, SDValue Chain, SDValue Src, MachinePointerInfo SrcPtrInfo) const
 
virtual std::pair< SDValue,
SDValue
EmitTargetCodeForStrnlen (SelectionDAG &DAG, SDLoc DL, SDValue Chain, SDValue Src, SDValue MaxLength, MachinePointerInfo SrcPtrInfo) const
 

Detailed Description

Definition at line 38 of file ARMSelectionDAGInfo.h.

Member Function Documentation

SDValue ARMSelectionDAGInfo::EmitSpecializedLibcall ( SelectionDAG DAG,
SDLoc  dl,
SDValue  Chain,
SDValue  Dst,
SDValue  Src,
SDValue  Size,
unsigned  Align,
RTLIB::Libcall  LC 
) const
SDValue ARMSelectionDAGInfo::EmitTargetCodeForMemcpy ( SelectionDAG DAG,
SDLoc  dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
bool  AlwaysInline,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const
overridevirtual

EmitTargetCodeForMemcpy - 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 from llvm::TargetSelectionDAGInfo.

Definition at line 132 of file ARMSelectionDAGInfo.cpp.

References llvm::ISD::ADD, llvm::dyn_cast(), EmitSpecializedLibcall(), llvm::SelectionDAG::getConstant(), llvm::SelectionDAG::getLoad(), llvm::SelectionDAG::getMachineFunction(), llvm::ARMSubtarget::getMaxInlineSizeThreshold(), llvm::SelectionDAG::getNode(), llvm::SelectionDAG::getStore(), llvm::MachineFunction::getSubtarget(), llvm::SDValue::getValue(), llvm::MachinePointerInfo::getWithOffset(), llvm::ConstantSDNode::getZExtValue(), llvm::MVT::i16, llvm::MVT::i32, llvm::MVT::i8, llvm::ARMSubtarget::isThumb1Only(), isVolatile(), Loads, llvm::makeArrayRef(), llvm::RTLIB::MEMCPY, llvm::MVT::Other, and llvm::ISD::TokenFactor.

SDValue ARMSelectionDAGInfo::EmitTargetCodeForMemmove ( SelectionDAG DAG,
SDLoc  dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const
overridevirtual

EmitTargetCodeForMemmove - 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 from llvm::TargetSelectionDAGInfo.

Definition at line 253 of file ARMSelectionDAGInfo.cpp.

References EmitSpecializedLibcall(), and llvm::RTLIB::MEMMOVE.

SDValue ARMSelectionDAGInfo::EmitTargetCodeForMemset ( SelectionDAG DAG,
SDLoc  dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
unsigned  Align,
bool  isVolatile,
MachinePointerInfo  DstPtrInfo 
) const
overridevirtual

EmitTargetCodeForMemset - 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 from llvm::TargetSelectionDAGInfo.

Definition at line 266 of file ARMSelectionDAGInfo.cpp.

References EmitSpecializedLibcall(), and llvm::RTLIB::MEMSET.


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