LLVM 22.0.0git
llvm::SystemZSelectionDAGInfo Class Reference

#include "Target/SystemZ/SystemZSelectionDAGInfo.h"

Inheritance diagram for llvm::SystemZSelectionDAGInfo:
[legend]

Public Member Functions

 SystemZSelectionDAGInfo ()
const chargetTargetNodeName (unsigned Opcode) const override
 Returns the name of the given target-specific opcode, suitable for debug printing.
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 Byte, SDValue Size, Align Alignment, bool IsVolatile, bool AlwaysInline, MachinePointerInfo DstPtrInfo) const override
 Emit target-specific code that performs a memset.
std::pair< SDValue, SDValueEmitTargetCodeForMemcmp (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src1, SDValue Src2, SDValue Size, const CallInst *CI) const override
 Emit target-specific code that performs a memcmp/bcmp, in cases where that is faster than a libcall.
std::pair< SDValue, SDValueEmitTargetCodeForMemchr (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src, SDValue Char, SDValue Length, MachinePointerInfo SrcPtrInfo) const override
 Emit target-specific code that performs a memchr, in cases where that is faster than a libcall.
std::pair< SDValue, SDValueEmitTargetCodeForStrcpy (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Dest, SDValue Src, MachinePointerInfo DestPtrInfo, MachinePointerInfo SrcPtrInfo, bool isStpcpy) const override
 Emit target-specific code that performs a strcpy or stpcpy, in cases where that is faster than a libcall.
std::pair< SDValue, SDValueEmitTargetCodeForStrcmp (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src1, SDValue Src2, MachinePointerInfo Op1PtrInfo, MachinePointerInfo Op2PtrInfo) const override
 Emit target-specific code that performs a strcmp, in cases where that is faster than a libcall.
std::pair< SDValue, SDValueEmitTargetCodeForStrlen (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src, const CallInst *CI) const override
std::pair< SDValue, SDValueEmitTargetCodeForStrnlen (SelectionDAG &DAG, const SDLoc &DL, SDValue Chain, SDValue Src, SDValue MaxLength, MachinePointerInfo SrcPtrInfo) const override
Public Member Functions inherited from llvm::SelectionDAGGenTargetInfo
 ~SelectionDAGGenTargetInfo () override
bool isTargetMemoryOpcode (unsigned Opcode) const override
 Returns true if a node with the given target-specific opcode has a memory operand.
bool isTargetStrictFPOpcode (unsigned Opcode) const override
 Returns true if a node with the given target-specific opcode has strict floating-point semantics.
void verifyTargetNode (const SelectionDAG &DAG, const SDNode *N) const override
 Checks that the given target-specific node is valid. Aborts if it is not.
Public Member Functions inherited from llvm::SelectionDAGTargetInfo
 SelectionDAGTargetInfo ()=default
 SelectionDAGTargetInfo (const SelectionDAGTargetInfo &)=delete
SelectionDAGTargetInfooperator= (const SelectionDAGTargetInfo &)=delete
virtual ~SelectionDAGTargetInfo ()
virtual bool mayRaiseFPException (unsigned Opcode) const
 Returns true if a node with the given target-specific opcode may raise a floating-point exception.
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 EmitTargetCodeForSetTag (SelectionDAG &DAG, const SDLoc &dl, SDValue Chain, SDValue Addr, SDValue Size, MachinePointerInfo DstPtrInfo, bool ZeroData) const
virtual bool disableGenericCombines (CodeGenOptLevel OptLevel) const

Additional Inherited Members

Protected Member Functions inherited from llvm::SelectionDAGGenTargetInfo
 SelectionDAGGenTargetInfo (const SDNodeInfo &GenNodeInfo)
Protected Attributes inherited from llvm::SelectionDAGGenTargetInfo
const SDNodeInfoGenNodeInfo

Detailed Description

Definition at line 41 of file SystemZSelectionDAGInfo.h.

Constructor & Destructor Documentation

◆ SystemZSelectionDAGInfo()

SystemZSelectionDAGInfo::SystemZSelectionDAGInfo ( )

Member Function Documentation

◆ EmitTargetCodeForMemchr()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForMemchr ( SelectionDAG & DAG,
const SDLoc & dl,
SDValue Chain,
SDValue Src,
SDValue Char,
SDValue Length,
MachinePointerInfo SrcPtrInfo ) const
overridevirtual

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

Definition at line 203 of file SystemZSelectionDAGInfo.cpp.

References AbstractManglingParser< Derived, Alloc >::Ops, llvm::ISD::ADD, llvm::ISD::AND, llvm::SystemZ::CCMASK_SRST, llvm::SystemZ::CCMASK_SRST_FOUND, DL, llvm::SelectionDAG::getConstant(), llvm::SelectionDAG::getNode(), llvm::SelectionDAG::getTargetConstant(), llvm::SDValue::getValue(), llvm::SelectionDAG::getVTList(), llvm::SelectionDAG::getZExtOrTrunc(), and llvm::Length.

◆ EmitTargetCodeForMemcmp()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForMemcmp ( SelectionDAG & DAG,
const SDLoc & dl,
SDValue Chain,
SDValue Op1,
SDValue Op2,
SDValue Op3,
const CallInst * CI ) const
overridevirtual

Emit target-specific code that performs a memcmp/bcmp, 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 from llvm::SelectionDAGTargetInfo.

Definition at line 188 of file SystemZSelectionDAGInfo.cpp.

References addIPMSequence(), assert(), DL, llvm::dyn_cast(), emitMemMemImm(), emitMemMemReg(), llvm::SDValue::getValue(), and Size.

◆ EmitTargetCodeForMemcpy()

SDValue SystemZSelectionDAGInfo::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 76 of file SystemZSelectionDAGInfo.cpp.

References DL, llvm::dyn_cast(), emitMemMemImm(), emitMemMemReg(), SDValue(), and Size.

◆ EmitTargetCodeForMemset()

SDValue SystemZSelectionDAGInfo::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 104 of file SystemZSelectionDAGInfo.cpp.

References llvm::ISD::ADD, assert(), llvm::bit_floor(), DL, llvm::dyn_cast(), emitMemMemImm(), emitMemMemReg(), llvm::SelectionDAG::getAnyExtOrTrunc(), llvm::SelectionDAG::getConstant(), llvm::SelectionDAG::getNode(), llvm::SelectionDAG::getStore(), llvm::MachinePointerInfo::getWithOffset(), memsetStore(), llvm::popcount(), SDValue(), Size, and llvm::ISD::TokenFactor.

◆ EmitTargetCodeForStrcmp()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForStrcmp ( SelectionDAG & DAG,
const SDLoc & dl,
SDValue Chain,
SDValue Op1,
SDValue Op2,
MachinePointerInfo Op1PtrInfo,
MachinePointerInfo Op2PtrInfo ) const
overridevirtual

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

Definition at line 239 of file SystemZSelectionDAGInfo.cpp.

References addIPMSequence(), DL, llvm::SelectionDAG::getConstant(), llvm::SelectionDAG::getNode(), llvm::SDValue::getValueType(), and llvm::SelectionDAG::getVTList().

◆ EmitTargetCodeForStrcpy()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForStrcpy ( SelectionDAG & DAG,
const SDLoc & DL,
SDValue Chain,
SDValue Dest,
SDValue Src,
MachinePointerInfo DestPtrInfo,
MachinePointerInfo SrcPtrInfo,
bool isStpcpy ) const
overridevirtual

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

Definition at line 229 of file SystemZSelectionDAGInfo.cpp.

References DL, llvm::SelectionDAG::getConstant(), llvm::SelectionDAG::getNode(), llvm::SDValue::getValue(), llvm::SDValue::getValueType(), and llvm::SelectionDAG::getVTList().

◆ EmitTargetCodeForStrlen()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForStrlen ( SelectionDAG & DAG,
const SDLoc & DL,
SDValue Chain,
SDValue Src,
const CallInst * CI ) const
overridevirtual

◆ EmitTargetCodeForStrnlen()

std::pair< SDValue, SDValue > SystemZSelectionDAGInfo::EmitTargetCodeForStrnlen ( SelectionDAG & DAG,
const SDLoc & DL,
SDValue Chain,
SDValue Src,
SDValue MaxLength,
MachinePointerInfo SrcPtrInfo ) const
overridevirtual

◆ getTargetNodeName()

const char * SystemZSelectionDAGInfo::getTargetNodeName ( unsigned Opcode) const
overridevirtual

Returns the name of the given target-specific opcode, suitable for debug printing.

Reimplemented from llvm::SelectionDAGGenTargetInfo.

Definition at line 27 of file SystemZSelectionDAGInfo.cpp.

References llvm::SystemZISD::GET_CCMASK, and llvm::SelectionDAGGenTargetInfo::getTargetNodeName().


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