mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 21:35:07 +00:00
8a55c2ecd4
The peephole tries to reorder MOV32r0 instructions such that they are before the instruction that modifies EFLAGS. The problem is that the peephole does not consider the case where the instruction that modifies EFLAGS also depends on the previous state of EFLAGS. Instead, walk backwards until we find an instruction that has a def for EFLAGS but does not have a use. If we find such an instruction, insert the MOV32r0 before it. If it cannot find such an instruction, skip the optimization. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182184 91177308-0d34-0410-b5e6-96231b3b80d8
28 lines
787 B
LLVM
28 lines
787 B
LLVM
; RUN: llc < %s -mtriple=i386-unknown-linux-gnu -mcpu=corei7-avx | FileCheck %s
|
|
|
|
; CHECK: main:
|
|
; CHECK: pushl %esi
|
|
; CHECK-NEXT: movl $-12, %eax
|
|
; CHECK-NEXT: movl $-1, %edx
|
|
; CHECK-NEXT: testb $1, 8(%esp)
|
|
; CHECK-NEXT: cmovel %edx, %eax
|
|
; CHECK-NEXT: xorl %ecx, %ecx
|
|
; CHECK-NEXT: movl %eax, %esi
|
|
; CHECK-NEXT: addl $-1, %esi
|
|
; CHECK-NEXT: movl $-1, %esi
|
|
; CHECK-NEXT: adcl $-1, %esi
|
|
; CHECK-NEXT: cmovsl %ecx, %eax
|
|
; CHECK-NEXT: cmovsl %ecx, %edx
|
|
; CHECK-NEXT: popl %esi
|
|
define i64 @main(i1 %tobool1) nounwind {
|
|
entry:
|
|
%0 = zext i1 %tobool1 to i32
|
|
%. = xor i32 %0, 1
|
|
%.21 = select i1 %tobool1, i32 -12, i32 -1
|
|
%conv = sext i32 %.21 to i64
|
|
%1 = add i64 %conv, -1
|
|
%cmp10 = icmp slt i64 %1, 0
|
|
%sub17 = select i1 %cmp10, i64 0, i64 %conv
|
|
ret i64 %sub17
|
|
}
|