mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-07 14:33:15 +00:00
Revert r147945 which disabled an addressing mode transformation. I had
hoped this would revive one of the llvm-gcc selfhost build bots, but it didn't so it doesn't appear that my transform is the culprit. If anyone else is seeing failures, please let me know! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@147957 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
313c703831
commit
11f0e7b158
@ -847,10 +847,6 @@ static bool FoldMaskAndShiftToScale(SelectionDAG &DAG, SDValue N,
|
||||
uint64_t Mask,
|
||||
SDValue Shift, SDValue X,
|
||||
X86ISelAddressMode &AM) {
|
||||
// FIXME!! Hack to disable this and see if it is responsible for a miscompile
|
||||
// on llvm-gcc's selfhost.
|
||||
return true;
|
||||
|
||||
if (Shift.getOpcode() != ISD::SRL || !Shift.hasOneUse() ||
|
||||
!isa<ConstantSDNode>(Shift.getOperand(1)))
|
||||
return true;
|
||||
|
@ -39,11 +39,11 @@ define i32 @t3(i16* %i.ptr, i32* %arr) {
|
||||
; To make matters worse, because of the two-phase zext of %i and their reuse in
|
||||
; the function, the DAG can get confusing trying to re-use both of them and
|
||||
; prevent easy analysis of the mask in order to match this.
|
||||
; BROKEN: t3:
|
||||
; BROKEN-NOT: and
|
||||
; BROKEN: shrl
|
||||
; BROKEN: addl (%{{...}},%{{...}},4),
|
||||
; BROKEN: ret
|
||||
; CHECK: t3:
|
||||
; CHECK-NOT: and
|
||||
; CHECK: shrl
|
||||
; CHECK: addl (%{{...}},%{{...}},4),
|
||||
; CHECK: ret
|
||||
|
||||
entry:
|
||||
%i = load i16* %i.ptr
|
||||
@ -58,11 +58,11 @@ entry:
|
||||
define i32 @t4(i16* %i.ptr, i32* %arr) {
|
||||
; A version of @t3 that has more zero extends and more re-use of intermediate
|
||||
; values. This exercise slightly different bits of canonicalization.
|
||||
; BROKEN: t4:
|
||||
; BROKEN-NOT: and
|
||||
; BROKEN: shrl
|
||||
; BROKEN: addl (%{{...}},%{{...}},4),
|
||||
; BROKEN: ret
|
||||
; CHECK: t4:
|
||||
; CHECK-NOT: and
|
||||
; CHECK: shrl
|
||||
; CHECK: addl (%{{...}},%{{...}},4),
|
||||
; CHECK: ret
|
||||
|
||||
entry:
|
||||
%i = load i16* %i.ptr
|
||||
|
Loading…
x
Reference in New Issue
Block a user