mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Revert r174343, "When the target-independent DAGCombiner inferred a higher alignment for a load,"
It caused hangups in compiling clang/lib/Parse/ParseDecl.cpp and clang/lib/Driver/Tools.cpp in stage2 on some hosts. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@174374 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b0c899666a
commit
eb260b2527
@ -7199,15 +7199,12 @@ SDValue DAGCombiner::visitLOAD(SDNode *N) {
|
|||||||
// Try to infer better alignment information than the load already has.
|
// Try to infer better alignment information than the load already has.
|
||||||
if (OptLevel != CodeGenOpt::None && LD->isUnindexed()) {
|
if (OptLevel != CodeGenOpt::None && LD->isUnindexed()) {
|
||||||
if (unsigned Align = DAG.InferPtrAlignment(Ptr)) {
|
if (unsigned Align = DAG.InferPtrAlignment(Ptr)) {
|
||||||
if (Align > LD->getAlignment()) {
|
if (Align > LD->getAlignment())
|
||||||
SDValue NewLoad =
|
return DAG.getExtLoad(LD->getExtensionType(), N->getDebugLoc(),
|
||||||
DAG.getExtLoad(LD->getExtensionType(), N->getDebugLoc(),
|
|
||||||
LD->getValueType(0),
|
LD->getValueType(0),
|
||||||
Chain, Ptr, LD->getPointerInfo(),
|
Chain, Ptr, LD->getPointerInfo(),
|
||||||
LD->getMemoryVT(),
|
LD->getMemoryVT(),
|
||||||
LD->isVolatile(), LD->isNonTemporal(), Align);
|
LD->isVolatile(), LD->isNonTemporal(), Align);
|
||||||
return CombineTo(N, NewLoad, SDValue(NewLoad.getNode(), 1), true);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,8 +178,7 @@ define void @check_i128_stackalign(i32 %val0, i32 %val1, i32 %val2, i32 %val3,
|
|||||||
; Nothing local on stack in current codegen, so first stack is 16 away
|
; Nothing local on stack in current codegen, so first stack is 16 away
|
||||||
; CHECK: ldr {{x[0-9]+}}, [sp, #16]
|
; CHECK: ldr {{x[0-9]+}}, [sp, #16]
|
||||||
; Important point is that we address sp+24 for second dword
|
; Important point is that we address sp+24 for second dword
|
||||||
; CHECK: add [[REG:x[0-9]+]], sp, #16
|
; CHECK: ldr {{x[0-9]+}}, [sp, #24]
|
||||||
; CHECK: ldr {{x[0-9]+}}, {{\[}}[[REG]], #8]
|
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,9 +56,9 @@ entry:
|
|||||||
%div = sdiv i16 %x, 10
|
%div = sdiv i16 %x, 10
|
||||||
ret i16 %div
|
ret i16 %div
|
||||||
; CHECK: test6:
|
; CHECK: test6:
|
||||||
; CHECK: imull $26215, %eax, %ecx
|
; CHECK: imull $26215, %eax, %eax
|
||||||
; CHECK: sarl $18, %ecx
|
; CHECK: shrl $31, %ecx
|
||||||
; CHECK: shrl $15, %eax
|
; CHECK: sarl $18, %eax
|
||||||
}
|
}
|
||||||
|
|
||||||
define i32 @test7(i32 %x) nounwind {
|
define i32 @test7(i32 %x) nounwind {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user