LLVM 20.0.0git
Public Member Functions | List of all members
llvm::AArch64SelectionDAGInfo Class Reference

#include "Target/AArch64/AArch64SelectionDAGInfo.h"

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

Public Member Functions

SDValue EmitMOPS (AArch64ISD::NodeType SDOpcode, SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Dst, SDValue SrcOrValue, SDValue Size, Align Alignment, bool isVolatile, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const
 
SDValue EmitTargetCodeForMemcpy (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const override
 Emit target-specific code that performs a memcpy.
 
SDValue EmitTargetCodeForMemset (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo) const override
 Emit target-specific code that performs a memset.
 
SDValue EmitTargetCodeForMemmove (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, Align Alignment, bool isVolatile, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const override
 Emit target-specific code that performs a memmove.
 
SDValue EmitTargetCodeForSetTag (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, MachinePointerInfo DstPtrInfo, bool ZeroData) const override
 
SDValue EmitStreamingCompatibleMemLibCall (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Dst, SDValue Src, SDValue Size, RTLIB::Libcall LC) const
 
- Public Member Functions inherited from llvm::SelectionDAGTargetInfo
 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, Align Alignment, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const
 Emit target-specific code that performs a memcpy.
 
virtual SDValue EmitTargetCodeForMemmove (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, Align Alignment, bool isVolatile, MachinePointerInfo DstPtrInfo, MachinePointerInfo SrcPtrInfo) const
 Emit target-specific code that performs a memmove.
 
virtual SDValue EmitTargetCodeForMemset (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Op1, SDValue Op2, SDValue Op3, Align Alignment, bool isVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo) const
 Emit target-specific code that performs a memset.
 
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/bcmp, in cases where that is faster than a libcall.
 
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.
 
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.
 
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.
 
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 SDValue EmitTargetCodeForSetTag (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Addr, SDValue Size, MachinePointerInfo DstPtrInfo, bool ZeroData) const
 
virtual bool disableGenericCombines (CodeGenOptLevel OptLevel) const
 

Detailed Description

Definition at line 20 of file AArch64SelectionDAGInfo.h.

Member Function Documentation

◆ EmitMOPS()

SDValue AArch64SelectionDAGInfo::EmitMOPS ( AArch64ISD::NodeType  SDOpcode,
SelectionDAG DAG,
const SDLoc DL,
SDValue  Chain,
SDValue  Dst,
SDValue  SrcOrValue,
SDValue  Size,
Align  Alignment,
bool  isVolatile,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const

◆ EmitStreamingCompatibleMemLibCall()

SDValue AArch64SelectionDAGInfo::EmitStreamingCompatibleMemLibCall ( SelectionDAG DAG,
const SDLoc DL,
SDValue  Chain,
SDValue  Dst,
SDValue  Src,
SDValue  Size,
RTLIB::Libcall  LC 
) const

◆ EmitTargetCodeForMemcpy()

SDValue AArch64SelectionDAGInfo::EmitTargetCodeForMemcpy ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
SDValue  Op3,
Align  Alignment,
bool  isVolatile,
bool  AlwaysInline,
MachinePointerInfo  DstPtrInfo,
MachinePointerInfo  SrcPtrInfo 
) const
overridevirtual

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::SelectionDAGTargetInfo.

Definition at line 143 of file AArch64SelectionDAGInfo.cpp.

References DL, EmitMOPS(), EmitStreamingCompatibleMemLibCall(), llvm::MachineFunction::getFunction(), llvm::SelectionDAG::getMachineFunction(), llvm::MachineFunction::getSubtarget(), LowerToSMERoutines, llvm::AArch64ISD::MOPS_MEMCOPY, and Size.

◆ EmitTargetCodeForMemmove()

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

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::SelectionDAGTargetInfo.

Definition at line 179 of file AArch64SelectionDAGInfo.cpp.

References EmitMOPS(), EmitStreamingCompatibleMemLibCall(), llvm::MachineFunction::getFunction(), llvm::SelectionDAG::getMachineFunction(), llvm::MachineFunction::getSubtarget(), LowerToSMERoutines, llvm::AArch64ISD::MOPS_MEMMOVE, and Size.

◆ EmitTargetCodeForMemset()

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

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. Note that if AlwaysInline is true the function has to return a valid SDValue.

Reimplemented from llvm::SelectionDAGTargetInfo.

Definition at line 161 of file AArch64SelectionDAGInfo.cpp.

References EmitMOPS(), EmitStreamingCompatibleMemLibCall(), llvm::MachineFunction::getFunction(), llvm::SelectionDAG::getMachineFunction(), llvm::MachineFunction::getSubtarget(), LowerToSMERoutines, llvm::AArch64ISD::MOPS_MEMSET, and Size.

◆ EmitTargetCodeForSetTag()

SDValue AArch64SelectionDAGInfo::EmitTargetCodeForSetTag ( SelectionDAG DAG,
const SDLoc dl,
SDValue  Chain,
SDValue  Op1,
SDValue  Op2,
MachinePointerInfo  DstPtrInfo,
bool  ZeroData 
) const
overridevirtual

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