mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
14957cb237
HexagonGenMux would collapse pairs of predicated transfers if it assumed that the predicated .new forms cannot be created. Turns out that generating mux is preferable in almost all cases. Introduce an option -hexagon-gen-mux-threshold that controls the minimum distance between the instruction defining the predicate and the later of the two transfers. If the distance is closer than the threshold, mux will not be generated. Set the threshold to 0 by default. llvm-svn: 328346
18 lines
587 B
LLVM
18 lines
587 B
LLVM
; RUN: llc -march=hexagon < %s | FileCheck %s
|
|
; This tests validates the fact that the formal arguments of type scalar i1
|
|
; (passed using 32-bit register) is converted back to use predicate registers
|
|
; CHECK: [[P0:p[0-3]]] = tstbit(r0,#0)
|
|
; CHECK: [[R0:r[0-9]+]] = mux([[P0]],#3,r2)
|
|
; CHECK: memb(r1+#0) = [[R0]]
|
|
|
|
target triple = "hexagon"
|
|
|
|
define void @f0(i1 zeroext %a0, i8* nocapture %a1, i8 %a2) local_unnamed_addr #0 {
|
|
entry:
|
|
%v0 = select i1 %a0, i8 3, i8 %a2
|
|
store i8 %v0, i8* %a1, align 1
|
|
ret void
|
|
}
|
|
|
|
attributes #0 = { norecurse nounwind optsize "target-cpu"="hexagonv60" }
|