mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-24 08:33:39 +00:00
Add comments about DstAlign and SrcAlign.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100132 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
33f22e8c66
commit
42642d06c9
@ -634,8 +634,11 @@ public:
|
|||||||
|
|
||||||
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
||||||
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
||||||
/// It returns EVT::Other if SelectionDAG should be responsible for
|
/// If DstAlign is zero that means it's safe to destination alignment can
|
||||||
/// determining it.
|
/// satisfy any constraint. Similarly if SrcAlign is zero it means there isn't
|
||||||
|
/// a need to check it against alignment requirement, probably because the
|
||||||
|
/// source does not need to be loaded. It returns EVT::Other if SelectionDAG
|
||||||
|
/// should be responsible for determining it.
|
||||||
virtual EVT getOptimalMemOpType(uint64_t Size,
|
virtual EVT getOptimalMemOpType(uint64_t Size,
|
||||||
unsigned DstAlign, unsigned SrcAlign,
|
unsigned DstAlign, unsigned SrcAlign,
|
||||||
bool SafeToUseFP, SelectionDAG &DAG) const {
|
bool SafeToUseFP, SelectionDAG &DAG) const {
|
||||||
|
@ -5539,6 +5539,13 @@ PPCTargetLowering::isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
||||||
|
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
||||||
|
/// If DstAlign is zero that means it's safe to destination alignment can
|
||||||
|
/// satisfy any constraint. Similarly if SrcAlign is zero it means there
|
||||||
|
/// isn't a need to check it against alignment requirement, probably because
|
||||||
|
/// the source does not need to be loaded. It returns EVT::Other if
|
||||||
|
/// SelectionDAG should be responsible for determining it.
|
||||||
EVT PPCTargetLowering::getOptimalMemOpType(uint64_t Size,
|
EVT PPCTargetLowering::getOptimalMemOpType(uint64_t Size,
|
||||||
unsigned DstAlign, unsigned SrcAlign,
|
unsigned DstAlign, unsigned SrcAlign,
|
||||||
bool SafeToUseFP,
|
bool SafeToUseFP,
|
||||||
|
@ -347,6 +347,13 @@ namespace llvm {
|
|||||||
|
|
||||||
virtual bool isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const;
|
virtual bool isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const;
|
||||||
|
|
||||||
|
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
||||||
|
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
||||||
|
/// If DstAlign is zero that means it's safe to destination alignment can
|
||||||
|
/// satisfy any constraint. Similarly if SrcAlign is zero it means there
|
||||||
|
/// isn't a need to check it against alignment requirement, probably because
|
||||||
|
/// the source does not need to be loaded. It returns EVT::Other if
|
||||||
|
/// SelectionDAG should be responsible for determining it.
|
||||||
virtual EVT getOptimalMemOpType(uint64_t Size,
|
virtual EVT getOptimalMemOpType(uint64_t Size,
|
||||||
unsigned DstAlign, unsigned SrcAlign,
|
unsigned DstAlign, unsigned SrcAlign,
|
||||||
bool SafeToUseFP, SelectionDAG &DAG) const;
|
bool SafeToUseFP, SelectionDAG &DAG) const;
|
||||||
|
@ -1070,9 +1070,12 @@ unsigned X86TargetLowering::getByValTypeAlignment(const Type *Ty) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
||||||
/// and store operations as a result of memset, memcpy, and memmove
|
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
||||||
/// lowering. It returns MVT::iAny if SelectionDAG should be responsible for
|
/// If DstAlign is zero that means it's safe to destination alignment can
|
||||||
/// determining it.
|
/// satisfy any constraint. Similarly if SrcAlign is zero it means there
|
||||||
|
/// isn't a need to check it against alignment requirement, probably because
|
||||||
|
/// the source does not need to be loaded. It returns EVT::Other if
|
||||||
|
/// SelectionDAG should be responsible for determining it.
|
||||||
EVT
|
EVT
|
||||||
X86TargetLowering::getOptimalMemOpType(uint64_t Size,
|
X86TargetLowering::getOptimalMemOpType(uint64_t Size,
|
||||||
unsigned DstAlign, unsigned SrcAlign,
|
unsigned DstAlign, unsigned SrcAlign,
|
||||||
|
@ -420,9 +420,12 @@ namespace llvm {
|
|||||||
virtual unsigned getByValTypeAlignment(const Type *Ty) const;
|
virtual unsigned getByValTypeAlignment(const Type *Ty) const;
|
||||||
|
|
||||||
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
/// getOptimalMemOpType - Returns the target specific optimal type for load
|
||||||
/// and store operations as a result of memset, memcpy, and memmove
|
/// and store operations as a result of memset, memcpy, and memmove lowering.
|
||||||
/// lowering. It returns EVT::iAny if SelectionDAG should be responsible for
|
/// If DstAlign is zero that means it's safe to destination alignment can
|
||||||
/// determining it.
|
/// satisfy any constraint. Similarly if SrcAlign is zero it means there
|
||||||
|
/// isn't a need to check it against alignment requirement, probably because
|
||||||
|
/// the source does not need to be loaded. It returns EVT::Other if
|
||||||
|
/// SelectionDAG should be responsible for determining it.
|
||||||
virtual EVT getOptimalMemOpType(uint64_t Size,
|
virtual EVT getOptimalMemOpType(uint64_t Size,
|
||||||
unsigned DstAlign, unsigned SrcAlign,
|
unsigned DstAlign, unsigned SrcAlign,
|
||||||
bool SafeToUseFP, SelectionDAG &DAG) const;
|
bool SafeToUseFP, SelectionDAG &DAG) const;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user