mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-16 11:30:51 +00:00
058309ba87
This commit makes LLVM not estimate branch probabilities when doing a single bit bitmask tests. The code that originally made me discover this is: if ((a & 0x1) == 0x1) { .. } In this case we don't actually have any branch probability information and should not assume to have any. LLVM transforms this into: %and = and i32 %a, 1 %tobool = icmp eq i32 %and, 0 So, in this case, the result of a bitwise and is compared against 0, but nevertheless, we should not assume to have probability information. CodeGen/ARM/2013-10-11-select-stalls.ll started failing because the changed probabilities changed the results of ARMBaseInstrInfo::isProfitableToIfCvt() and led to an Ifcvt of the diamond in the test. AFAICT, the test was never meant to test this and thus changing the test input slightly to not change the probabilities seems like the best way to preserve the meaning of the test. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@234979 91177308-0d34-0410-b5e6-96231b3b80d8
158 lines
3.7 KiB
LLVM
158 lines
3.7 KiB
LLVM
; RUN: llc -O1 < %s -march=mips64 -mcpu=octeon | FileCheck %s -check-prefix=ALL -check-prefix=OCTEON
|
|
; RUN: llc -O1 < %s -march=mips64 -mcpu=mips64 | FileCheck %s -check-prefix=ALL -check-prefix=MIPS64
|
|
|
|
define i64 @addi64(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: addi64:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: baddu $2, $4, $5
|
|
; MIPS64: daddu $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: jr $ra
|
|
; MIPS64: andi $2, $[[T0]], 255
|
|
%add = add i64 %a, %b
|
|
%and = and i64 %add, 255
|
|
ret i64 %and
|
|
}
|
|
|
|
define i64 @mul(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: mul:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: dmul $2, $4, $5
|
|
; MIPS64: dmult $4, $5
|
|
; MIPS64: jr $ra
|
|
; MIPS64: mflo $2
|
|
%res = mul i64 %a, %b
|
|
ret i64 %res
|
|
}
|
|
|
|
define i64 @cmpeq(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpeq:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: seq $2, $4, $5
|
|
; MIPS64: xor $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: sltiu $[[T1:[0-9]+]], $[[T0]], 1
|
|
; MIPS64: dsll $[[T2:[0-9]+]], $[[T1]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T2]], 32
|
|
%res = icmp eq i64 %a, %b
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpeqi(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpeqi:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: seqi $2, $4, 42
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 42
|
|
; MIPS64: xor $[[T1:[0-9]+]], $4, $[[T0]]
|
|
; MIPS64: sltiu $[[T2:[0-9]+]], $[[T1]], 1
|
|
; MIPS64: dsll $[[T3:[0-9]+]], $[[T2]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T3]], 32
|
|
%res = icmp eq i64 %a, 42
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpne(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpne:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: sne $2, $4, $5
|
|
; MIPS64: xor $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: sltu $[[T1:[0-9]+]], $zero, $[[T0]]
|
|
; MIPS64: dsll $[[T2:[0-9]+]], $[[T1]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T2]], 32
|
|
%res = icmp ne i64 %a, %b
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpnei(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpnei:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: snei $2, $4, 42
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 42
|
|
; MIPS64: xor $[[T1:[0-9]+]], $4, $[[T0]]
|
|
; MIPS64: sltu $[[T2:[0-9]+]], $zero, $[[T1]]
|
|
; MIPS64: dsll $[[T3:[0-9]+]], $[[T2]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T3]], 32
|
|
%res = icmp ne i64 %a, 42
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @bbit0(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit0:
|
|
; OCTEON: bbit0 $4, 3, $[[BB0:BB[0-9_]+]]
|
|
; MIPS64: andi $[[T0:[0-9]+]], $4, 8
|
|
; MIPS64: bnez $[[T0]], $[[BB0:BB[0-9_]+]]
|
|
%bit = and i64 %a, 8
|
|
%res = icmp eq i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit032(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit032:
|
|
; OCTEON: bbit032 $4, 3, $[[BB0:BB[0-9_]+]]
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 1
|
|
; MIPS64: dsll $[[T1:[0-9]+]], $[[T0]], 35
|
|
; MIPS64: and $[[T2:[0-9]+]], $4, $[[T1]]
|
|
; MIPS64: bnez $[[T2]], $[[BB0:BB[0-9_]+]]
|
|
%bit = and i64 %a, 34359738368
|
|
%res = icmp eq i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit1(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit1:
|
|
; OCTEON: bbit1 $4, 3, $[[BB0:BB[0-9_]+]]
|
|
; MIPS64: andi $[[T0:[0-9]+]], $4, 8
|
|
; MIPS64: beqz $[[T0]], $[[BB0:BB[0-9_]+]]
|
|
%bit = and i64 %a, 8
|
|
%res = icmp ne i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit132(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit132:
|
|
; OCTEON: bbit132 $4, 3, $[[BB0:BB[0-9_]+]]
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 1
|
|
; MIPS64: dsll $[[T1:[0-9]+]], $[[T0]], 35
|
|
; MIPS64: and $[[T2:[0-9]+]], $4, $[[T1]]
|
|
; MIPS64: beqz $[[T2]], $[[BB0:BB[0-9_]+]]
|
|
%bit = and i64 %a, 34359738368
|
|
%res = icmp ne i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|