mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-11 06:56:12 +00:00
a6b20ced76
- ISD::SHL/SRL/SRA must have either both scalar or both vector operands but TLI.getShiftAmountTy() so far only return scalar type. As a result, backend logic assuming that breaks. - Rename the original TLI.getShiftAmountTy() to TLI.getScalarShiftAmountTy() and re-define TLI.getShiftAmountTy() to return target-specificed scalar type or the same vector type as the 1st operand. - Fix most TICG logic assuming TLI.getShiftAmountTy() a simple scalar type. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176364 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
968 B
LLVM
31 lines
968 B
LLVM
; RUN: llc < %s -mtriple=x86_64-pc-linux -mcpu=corei7-avx
|
|
|
|
; No check in a crash test
|
|
|
|
define void @autogen_262380_1000() {
|
|
BB:
|
|
br label %CF79
|
|
|
|
CF79: ; preds = %CF79, %BB
|
|
br i1 undef, label %CF79, label %CF84.critedge.critedge
|
|
|
|
CF84.critedge.critedge: ; preds = %CF79
|
|
%L35 = load <8 x i32>* undef
|
|
br label %CF85
|
|
|
|
CF85: ; preds = %CF85, %CF84.critedge.critedge
|
|
br i1 undef, label %CF85, label %CF86
|
|
|
|
CF86: ; preds = %CF86, %CF85
|
|
%B61 = sub <8 x i32> %L35, zeroinitializer
|
|
%S64 = icmp ne <8 x i32> %B61, zeroinitializer
|
|
%E73 = extractelement <8 x i1> %S64, i32 6
|
|
br i1 %E73, label %CF86, label %CF87
|
|
|
|
CF87: ; preds = %CF87, %CF86
|
|
br i1 undef, label %CF87, label %CF88
|
|
|
|
CF88: ; preds = %CF87
|
|
ret void
|
|
}
|