mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-13 14:47:00 +00:00
afa4f41e9c
Presently, CodeGenPrepare deletes all nearly empty (only phi and branch) basic blocks. This pass can delete loop preheaders which frequently creates critical edges. A preheader can be a convenient place to spill registers to the stack. If the entrance to a loop body is a critical edge, then spills may occur in the loop body rather than immediately before it. This patch protects loop preheaders from deletion in CodeGenPrepare even if they are nearly empty. Since the patch alters the CFG, it affects a large number of test cases. In most cases, the changes are merely cosmetic (basic blocks have different names or instruction orders change slightly). I am somewhat concerned about the test/CodeGen/Mips/brdelayslot.ll test case. If the loop preheader is not deleted, then the MIPS backend does not take advantage of a branch delay slot. Consequently, I would like some close review by a MIPS expert. The patch also partially subsumes D16893 from George Burgess IV. George correctly notes that CodeGenPrepare does not actually preserve the dominator tree. I think the dominator tree was usually not valid when CodeGenPrepare ran, but I am using LoopInfo to mark preheaders, so the dominator tree is now always valid before CodeGenPrepare. Author: Tom Jablin (tjablin) Reviewers: hfinkel george.burgess.iv vkalintiris dsanders kbarton cycheng http://reviews.llvm.org/D16984 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@265397 91177308-0d34-0410-b5e6-96231b3b80d8
76 lines
3.0 KiB
LLVM
76 lines
3.0 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -mtriple=x86_64-unknown-unknown -mattr=+avx < %s | FileCheck %s --check-prefix=AVX
|
|
; RUN: llc -mtriple=i386-unknown-linux-gnu -mcpu=knl < %s | FileCheck %s --check-prefix=KNL-32
|
|
|
|
|
|
; Verify that we don't crash during codegen due to a wrong lowering
|
|
; of a setcc node with illegal operand types and return type.
|
|
|
|
define <8 x i16> @pr25080(<8 x i32> %a) {
|
|
; AVX-LABEL: pr25080:
|
|
; AVX: # BB#0: # %entry
|
|
; AVX-NEXT: vandps {{.*}}(%rip), %ymm0, %ymm0
|
|
; AVX-NEXT: vextractf128 $1, %ymm0, %xmm1
|
|
; AVX-NEXT: vpxor %xmm2, %xmm2, %xmm2
|
|
; AVX-NEXT: vpcmpeqd %xmm2, %xmm1, %xmm1
|
|
; AVX-NEXT: vmovdqa {{.*#+}} xmm3 = [0,1,4,5,8,9,12,13,8,9,12,13,12,13,14,15]
|
|
; AVX-NEXT: vpshufb %xmm3, %xmm1, %xmm1
|
|
; AVX-NEXT: vpcmpeqd %xmm2, %xmm0, %xmm0
|
|
; AVX-NEXT: vpshufb %xmm3, %xmm0, %xmm0
|
|
; AVX-NEXT: vpunpcklqdq {{.*#+}} xmm0 = xmm0[0],xmm1[0]
|
|
; AVX-NEXT: vpor {{.*}}(%rip), %xmm0, %xmm0
|
|
; AVX-NEXT: vpsllw $15, %xmm0, %xmm0
|
|
; AVX-NEXT: vpsraw $15, %xmm0, %xmm0
|
|
; AVX-NEXT: vzeroupper
|
|
; AVX-NEXT: retq
|
|
entry:
|
|
%0 = trunc <8 x i32> %a to <8 x i23>
|
|
%1 = icmp eq <8 x i23> %0, zeroinitializer
|
|
%2 = or <8 x i1> %1, <i1 true, i1 true, i1 true, i1 true, i1 false, i1 false, i1 false, i1 false>
|
|
%3 = sext <8 x i1> %2 to <8 x i16>
|
|
ret <8 x i16> %3
|
|
}
|
|
|
|
define void @pr26232(i64 %a) {
|
|
; KNL-32-LABEL: pr26232:
|
|
; KNL-32: # BB#0: # %for_loop599.preheader
|
|
; KNL-32-NEXT: pushl %esi
|
|
; KNL-32-NEXT: .Ltmp0:
|
|
; KNL-32-NEXT: .cfi_def_cfa_offset 8
|
|
; KNL-32-NEXT: .Ltmp1:
|
|
; KNL-32-NEXT: .cfi_offset %esi, -8
|
|
; KNL-32-NEXT: movl {{[0-9]+}}(%esp), %eax
|
|
; KNL-32-NEXT: movl {{[0-9]+}}(%esp), %ecx
|
|
; KNL-32-NEXT: movw $-1, %dx
|
|
; KNL-32-NEXT: .p2align 4, 0x90
|
|
; KNL-32-NEXT: .LBB1_1: # %for_loop599
|
|
; KNL-32-NEXT: # =>This Inner Loop Header: Depth=1
|
|
; KNL-32-NEXT: cmpl $65536, %ecx # imm = 0x10000
|
|
; KNL-32-NEXT: movl %eax, %esi
|
|
; KNL-32-NEXT: sbbl $0, %esi
|
|
; KNL-32-NEXT: movl $0, %esi
|
|
; KNL-32-NEXT: cmovlw %dx, %si
|
|
; KNL-32-NEXT: testw %si, %si
|
|
; KNL-32-NEXT: jne .LBB1_1
|
|
; KNL-32-NEXT: # BB#2: # %for_exit600
|
|
; KNL-32-NEXT: popl %esi
|
|
; KNL-32-NEXT: retl
|
|
allocas:
|
|
br label %for_test11.preheader
|
|
|
|
for_test11.preheader: ; preds = %for_test11.preheader, %allocas
|
|
br i1 undef, label %for_loop599, label %for_test11.preheader
|
|
|
|
for_loop599: ; preds = %for_loop599, %for_test11.preheader
|
|
%less_i_load605_ = icmp slt i64 %a, 65536
|
|
%less_i_load605__broadcast_init = insertelement <16 x i1> undef, i1 %less_i_load605_, i32 0
|
|
%less_i_load605__broadcast = shufflevector <16 x i1> %less_i_load605__broadcast_init, <16 x i1> undef, <16 x i32> zeroinitializer
|
|
%"oldMask&test607" = and <16 x i1> %less_i_load605__broadcast, undef
|
|
%intmask.i894 = bitcast <16 x i1> %"oldMask&test607" to i16
|
|
%res.i895 = icmp eq i16 %intmask.i894, 0
|
|
br i1 %res.i895, label %for_exit600, label %for_loop599
|
|
|
|
for_exit600: ; preds = %for_loop599
|
|
ret void
|
|
}
|