diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2019-05-03 19:06:57 +0000 |
---|---|---|
committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2019-05-03 19:06:57 +0000 |
commit | b6c599afd3cfd02c49c49797fd1126afe63330fd (patch) | |
tree | 82fa3a448f0a57eb483477e2c1633b265fe8a7b3 /llvm/test/CodeGen/X86 | |
parent | 13cf19dff098bf89216a14eee0314afd850278a2 (diff) | |
download | bcm5719-llvm-b6c599afd3cfd02c49c49797fd1126afe63330fd.tar.gz bcm5719-llvm-b6c599afd3cfd02c49c49797fd1126afe63330fd.zip |
Reapply r359906, "RegAllocFast: Add heuristic to detect values not live-out of a block"
This reverts commit r359912.
This should pass now, since the clang test was made less fragile in
r359918.
llvm-svn: 359919
Diffstat (limited to 'llvm/test/CodeGen/X86')
-rw-r--r-- | llvm/test/CodeGen/X86/atomic-unordered.ll | 17 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/atomic32.ll | 41 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/atomic64.ll | 66 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/atomic6432.ll | 12 | ||||
-rwxr-xr-x | llvm/test/CodeGen/X86/avx512-mask-zext-bugfix.ll | 11 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr11415.ll | 1 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr30430.ll | 8 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr32284.ll | 13 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr32484.ll | 1 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr34592.ll | 10 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr34653.ll | 34 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/swifterror.ll | 15 |
12 files changed, 55 insertions, 174 deletions
diff --git a/llvm/test/CodeGen/X86/atomic-unordered.ll b/llvm/test/CodeGen/X86/atomic-unordered.ll index 430e45b20bf..eaccb3f23d0 100644 --- a/llvm/test/CodeGen/X86/atomic-unordered.ll +++ b/llvm/test/CodeGen/X86/atomic-unordered.ll @@ -561,8 +561,6 @@ define void @widen_zero_init(i32* %p0, i32 %v1, i32 %v2) { ; CHECK-O0: # %bb.0: ; CHECK-O0-NEXT: movl $0, (%rdi) ; CHECK-O0-NEXT: movl $0, 4(%rdi) -; CHECK-O0-NEXT: movl %esi, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-O0-NEXT: movl %edx, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: widen_zero_init: @@ -582,8 +580,6 @@ define void @widen_zero_init_unaligned(i32* %p0, i32 %v1, i32 %v2) { ; CHECK-O0: # %bb.0: ; CHECK-O0-NEXT: movl $0, (%rdi) ; CHECK-O0-NEXT: movl $0, 4(%rdi) -; CHECK-O0-NEXT: movl %esi, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-O0-NEXT: movl %edx, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: widen_zero_init_unaligned: @@ -1537,7 +1533,6 @@ define void @rmw_fold_add1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: addq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_add1: @@ -1576,7 +1571,6 @@ define void @rmw_fold_sub1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: addq $-15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_sub1: @@ -1616,7 +1610,6 @@ define void @rmw_fold_mul1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: leaq (%rax,%rax,4), %rax ; CHECK-O0-NEXT: leaq (%rax,%rax,2), %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_mul1: @@ -1667,7 +1660,6 @@ define void @rmw_fold_sdiv1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: sarq $3, %rdx ; CHECK-O0-NEXT: addq %rcx, %rdx ; CHECK-O0-NEXT: movq %rdx, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_sdiv1: @@ -1733,7 +1725,6 @@ define void @rmw_fold_udiv1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: mulq %rcx ; CHECK-O0-NEXT: shrq $3, %rdx ; CHECK-O0-NEXT: movq %rdx, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_udiv1: @@ -1804,7 +1795,6 @@ define void @rmw_fold_srem1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: leaq (%rcx,%rcx,2), %rcx ; CHECK-O0-NEXT: subq %rcx, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_srem1: @@ -1878,7 +1868,6 @@ define void @rmw_fold_urem1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rcx # 8-byte Reload ; CHECK-O0-NEXT: subq %rax, %rcx ; CHECK-O0-NEXT: movq %rcx, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_urem1: @@ -1942,7 +1931,6 @@ define void @rmw_fold_shl1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: shlq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_shl1: @@ -1987,7 +1975,6 @@ define void @rmw_fold_lshr1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: shrq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_lshr1: @@ -2032,7 +2019,6 @@ define void @rmw_fold_ashr1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: sarq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_ashr1: @@ -2079,7 +2065,6 @@ define void @rmw_fold_and1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: andl $15, %ecx ; CHECK-O0-NEXT: movl %ecx, %eax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_and1: @@ -2118,7 +2103,6 @@ define void @rmw_fold_or1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: orq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_or1: @@ -2157,7 +2141,6 @@ define void @rmw_fold_xor1(i64* %p, i64 %v) { ; CHECK-O0-NEXT: movq (%rdi), %rax ; CHECK-O0-NEXT: xorq $15, %rax ; CHECK-O0-NEXT: movq %rax, (%rdi) -; CHECK-O0-NEXT: movq %rsi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-O0-NEXT: retq ; ; CHECK-O3-LABEL: rmw_fold_xor1: diff --git a/llvm/test/CodeGen/X86/atomic32.ll b/llvm/test/CodeGen/X86/atomic32.ll index 3a8038a2d76..461e0b5beff 100644 --- a/llvm/test/CodeGen/X86/atomic32.ll +++ b/llvm/test/CodeGen/X86/atomic32.ll @@ -324,7 +324,7 @@ define void @atomic_fetch_max32(i32 %x) nounwind { ; X86-NOCMOV: # %bb.0: ; X86-NOCMOV-NEXT: pushl %ebx ; X86-NOCMOV-NEXT: pushl %esi -; X86-NOCMOV-NEXT: subl $24, %esp +; X86-NOCMOV-NEXT: subl $20, %esp ; X86-NOCMOV-NEXT: movl {{[0-9]+}}(%esp), %eax ; X86-NOCMOV-NEXT: movl sc32, %ecx ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill @@ -337,7 +337,6 @@ define void @atomic_fetch_max32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: subl %edx, %ecx ; X86-NOCMOV-NEXT: movl %eax, %esi ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X86-NOCMOV-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: jge .LBB6_4 ; X86-NOCMOV-NEXT: # %bb.3: # %atomicrmw.start @@ -358,7 +357,7 @@ define void @atomic_fetch_max32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: jne .LBB6_2 ; X86-NOCMOV-NEXT: jmp .LBB6_1 ; X86-NOCMOV-NEXT: .LBB6_2: # %atomicrmw.end -; X86-NOCMOV-NEXT: addl $24, %esp +; X86-NOCMOV-NEXT: addl $20, %esp ; X86-NOCMOV-NEXT: popl %esi ; X86-NOCMOV-NEXT: popl %ebx ; X86-NOCMOV-NEXT: retl @@ -420,7 +419,7 @@ define void @atomic_fetch_min32(i32 %x) nounwind { ; X86-NOCMOV: # %bb.0: ; X86-NOCMOV-NEXT: pushl %ebx ; X86-NOCMOV-NEXT: pushl %esi -; X86-NOCMOV-NEXT: subl $24, %esp +; X86-NOCMOV-NEXT: subl $20, %esp ; X86-NOCMOV-NEXT: movl {{[0-9]+}}(%esp), %eax ; X86-NOCMOV-NEXT: movl sc32, %ecx ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill @@ -433,7 +432,6 @@ define void @atomic_fetch_min32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: subl %edx, %ecx ; X86-NOCMOV-NEXT: movl %eax, %esi ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X86-NOCMOV-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: jle .LBB7_4 ; X86-NOCMOV-NEXT: # %bb.3: # %atomicrmw.start @@ -454,7 +452,7 @@ define void @atomic_fetch_min32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: jne .LBB7_2 ; X86-NOCMOV-NEXT: jmp .LBB7_1 ; X86-NOCMOV-NEXT: .LBB7_2: # %atomicrmw.end -; X86-NOCMOV-NEXT: addl $24, %esp +; X86-NOCMOV-NEXT: addl $20, %esp ; X86-NOCMOV-NEXT: popl %esi ; X86-NOCMOV-NEXT: popl %ebx ; X86-NOCMOV-NEXT: retl @@ -516,7 +514,7 @@ define void @atomic_fetch_umax32(i32 %x) nounwind { ; X86-NOCMOV: # %bb.0: ; X86-NOCMOV-NEXT: pushl %ebx ; X86-NOCMOV-NEXT: pushl %esi -; X86-NOCMOV-NEXT: subl $24, %esp +; X86-NOCMOV-NEXT: subl $20, %esp ; X86-NOCMOV-NEXT: movl {{[0-9]+}}(%esp), %eax ; X86-NOCMOV-NEXT: movl sc32, %ecx ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill @@ -529,7 +527,6 @@ define void @atomic_fetch_umax32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: subl %edx, %ecx ; X86-NOCMOV-NEXT: movl %eax, %esi ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X86-NOCMOV-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: ja .LBB8_4 ; X86-NOCMOV-NEXT: # %bb.3: # %atomicrmw.start @@ -550,7 +547,7 @@ define void @atomic_fetch_umax32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: jne .LBB8_2 ; X86-NOCMOV-NEXT: jmp .LBB8_1 ; X86-NOCMOV-NEXT: .LBB8_2: # %atomicrmw.end -; X86-NOCMOV-NEXT: addl $24, %esp +; X86-NOCMOV-NEXT: addl $20, %esp ; X86-NOCMOV-NEXT: popl %esi ; X86-NOCMOV-NEXT: popl %ebx ; X86-NOCMOV-NEXT: retl @@ -612,7 +609,7 @@ define void @atomic_fetch_umin32(i32 %x) nounwind { ; X86-NOCMOV: # %bb.0: ; X86-NOCMOV-NEXT: pushl %ebx ; X86-NOCMOV-NEXT: pushl %esi -; X86-NOCMOV-NEXT: subl $24, %esp +; X86-NOCMOV-NEXT: subl $20, %esp ; X86-NOCMOV-NEXT: movl {{[0-9]+}}(%esp), %eax ; X86-NOCMOV-NEXT: movl sc32, %ecx ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill @@ -625,7 +622,6 @@ define void @atomic_fetch_umin32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: subl %edx, %ecx ; X86-NOCMOV-NEXT: movl %eax, %esi ; X86-NOCMOV-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X86-NOCMOV-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; X86-NOCMOV-NEXT: jbe .LBB9_4 ; X86-NOCMOV-NEXT: # %bb.3: # %atomicrmw.start @@ -646,7 +642,7 @@ define void @atomic_fetch_umin32(i32 %x) nounwind { ; X86-NOCMOV-NEXT: jne .LBB9_2 ; X86-NOCMOV-NEXT: jmp .LBB9_1 ; X86-NOCMOV-NEXT: .LBB9_2: # %atomicrmw.end -; X86-NOCMOV-NEXT: addl $24, %esp +; X86-NOCMOV-NEXT: addl $20, %esp ; X86-NOCMOV-NEXT: popl %esi ; X86-NOCMOV-NEXT: popl %ebx ; X86-NOCMOV-NEXT: retl @@ -660,17 +656,13 @@ define void @atomic_fetch_cmpxchg32() nounwind { ; X64-NEXT: xorl %eax, %eax ; X64-NEXT: movl $1, %ecx ; X64-NEXT: lock cmpxchgl %ecx, {{.*}}(%rip) -; X64-NEXT: movl %eax, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill ; X64-NEXT: retq ; ; X86-LABEL: atomic_fetch_cmpxchg32: ; X86: # %bb.0: -; X86-NEXT: pushl %eax ; X86-NEXT: xorl %eax, %eax ; X86-NEXT: movl $1, %ecx ; X86-NEXT: lock cmpxchgl %ecx, sc32 -; X86-NEXT: movl %eax, (%esp) # 4-byte Spill -; X86-NEXT: popl %eax ; X86-NEXT: retl %t1 = cmpxchg i32* @sc32, i32 0, i32 1 acquire acquire ret void @@ -695,16 +687,12 @@ define void @atomic_fetch_swap32(i32 %x) nounwind { ; X64-LABEL: atomic_fetch_swap32: ; X64: # %bb.0: ; X64-NEXT: xchgl %edi, {{.*}}(%rip) -; X64-NEXT: movl %edi, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill ; X64-NEXT: retq ; ; X86-LABEL: atomic_fetch_swap32: ; X86: # %bb.0: -; X86-NEXT: pushl %eax ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax ; X86-NEXT: xchgl %eax, sc32 -; X86-NEXT: movl %eax, (%esp) # 4-byte Spill -; X86-NEXT: popl %eax ; X86-NEXT: retl %t1 = atomicrmw xchg i32* @sc32, i32 %x acquire ret void @@ -715,28 +703,23 @@ define void @atomic_fetch_swapf32(float %x) nounwind { ; X64: # %bb.0: ; X64-NEXT: movd %xmm0, %eax ; X64-NEXT: xchgl %eax, {{.*}}(%rip) -; X64-NEXT: movl %eax, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill ; X64-NEXT: retq ; ; X86-CMOV-LABEL: atomic_fetch_swapf32: ; X86-CMOV: # %bb.0: -; X86-CMOV-NEXT: pushl %eax ; X86-CMOV-NEXT: movss {{.*#+}} xmm0 = mem[0],zero,zero,zero ; X86-CMOV-NEXT: movd %xmm0, %eax ; X86-CMOV-NEXT: xchgl %eax, fsc32 -; X86-CMOV-NEXT: movl %eax, (%esp) # 4-byte Spill -; X86-CMOV-NEXT: popl %eax ; X86-CMOV-NEXT: retl ; ; X86-NOCMOV-LABEL: atomic_fetch_swapf32: ; X86-NOCMOV: # %bb.0: -; X86-NOCMOV-NEXT: subl $8, %esp +; X86-NOCMOV-NEXT: pushl %eax ; X86-NOCMOV-NEXT: flds {{[0-9]+}}(%esp) -; X86-NOCMOV-NEXT: fstps {{[0-9]+}}(%esp) -; X86-NOCMOV-NEXT: movl {{[0-9]+}}(%esp), %eax +; X86-NOCMOV-NEXT: fstps (%esp) +; X86-NOCMOV-NEXT: movl (%esp), %eax ; X86-NOCMOV-NEXT: xchgl %eax, fsc32 -; X86-NOCMOV-NEXT: movl %eax, (%esp) # 4-byte Spill -; X86-NOCMOV-NEXT: addl $8, %esp +; X86-NOCMOV-NEXT: popl %eax ; X86-NOCMOV-NEXT: retl %t1 = atomicrmw xchg float* @fsc32, float %x acquire ret void diff --git a/llvm/test/CodeGen/X86/atomic64.ll b/llvm/test/CodeGen/X86/atomic64.ll index 11bd6e05558..0149851ea46 100644 --- a/llvm/test/CodeGen/X86/atomic64.ll +++ b/llvm/test/CodeGen/X86/atomic64.ll @@ -18,7 +18,7 @@ define void @atomic_fetch_add64() nounwind { ; I486-LABEL: atomic_fetch_add64: ; I486: # %bb.0: # %entry ; I486-NEXT: pushl %esi -; I486-NEXT: subl $56, %esp +; I486-NEXT: subl $48, %esp ; I486-NEXT: leal sc64, %eax ; I486-NEXT: movl %esp, %ecx ; I486-NEXT: movl $2, 12(%ecx) @@ -55,9 +55,7 @@ define void @atomic_fetch_add64() nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_add_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $56, %esp +; I486-NEXT: addl $48, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl entry: @@ -81,7 +79,7 @@ define void @atomic_fetch_sub64() nounwind { ; I486-LABEL: atomic_fetch_sub64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $56, %esp +; I486-NEXT: subl $48, %esp ; I486-NEXT: leal sc64, %eax ; I486-NEXT: movl %esp, %ecx ; I486-NEXT: movl $2, 12(%ecx) @@ -118,9 +116,7 @@ define void @atomic_fetch_sub64() nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_sub_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $56, %esp +; I486-NEXT: addl $48, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw sub i64* @sc64, i64 1 acquire @@ -158,7 +154,7 @@ define void @atomic_fetch_and64() nounwind { ; I486-LABEL: atomic_fetch_and64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $44, %esp +; I486-NEXT: subl $36, %esp ; I486-NEXT: leal sc64, %eax ; I486-NEXT: movl %esp, %ecx ; I486-NEXT: movl $2, 12(%ecx) @@ -185,9 +181,7 @@ define void @atomic_fetch_and64() nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_and_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $44, %esp +; I486-NEXT: addl $36, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw and i64* @sc64, i64 3 acquire @@ -223,7 +217,7 @@ define void @atomic_fetch_or64() nounwind { ; I486-LABEL: atomic_fetch_or64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $44, %esp +; I486-NEXT: subl $36, %esp ; I486-NEXT: leal sc64, %eax ; I486-NEXT: movl %esp, %ecx ; I486-NEXT: movl $2, 12(%ecx) @@ -250,9 +244,7 @@ define void @atomic_fetch_or64() nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_or_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $44, %esp +; I486-NEXT: addl $36, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw or i64* @sc64, i64 3 acquire @@ -288,7 +280,7 @@ define void @atomic_fetch_xor64() nounwind { ; I486-LABEL: atomic_fetch_xor64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $44, %esp +; I486-NEXT: subl $36, %esp ; I486-NEXT: leal sc64, %eax ; I486-NEXT: movl %esp, %ecx ; I486-NEXT: movl $2, 12(%ecx) @@ -315,9 +307,7 @@ define void @atomic_fetch_xor64() nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_xor_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $44, %esp +; I486-NEXT: addl $36, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw xor i64* @sc64, i64 3 acquire @@ -351,7 +341,7 @@ define void @atomic_fetch_nand64(i64 %x) nounwind { ; I486-LABEL: atomic_fetch_nand64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $28, %esp +; I486-NEXT: subl $20, %esp ; I486-NEXT: movl {{[0-9]+}}(%esp), %eax ; I486-NEXT: movl {{[0-9]+}}(%esp), %ecx ; I486-NEXT: leal sc64, %edx @@ -362,9 +352,7 @@ define void @atomic_fetch_nand64(i64 %x) nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_fetch_nand_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $28, %esp +; I486-NEXT: addl $20, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw nand i64* @sc64, i64 %x acquire @@ -402,7 +390,7 @@ define void @atomic_fetch_max64(i64 %x) nounwind { ; I486-NEXT: pushl %edi ; I486-NEXT: pushl %esi ; I486-NEXT: andl $-8, %esp -; I486-NEXT: subl $80, %esp +; I486-NEXT: subl $72, %esp ; I486-NEXT: movl 12(%ebp), %eax ; I486-NEXT: movl 8(%ebp), %ecx ; I486-NEXT: movl sc64+4, %edx @@ -426,8 +414,6 @@ define void @atomic_fetch_max64(i64 %x) nounwind { ; I486-NEXT: movl %eax, %ebx ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ebx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: jge .LBB6_4 @@ -504,7 +490,7 @@ define void @atomic_fetch_min64(i64 %x) nounwind { ; I486-NEXT: pushl %edi ; I486-NEXT: pushl %esi ; I486-NEXT: andl $-8, %esp -; I486-NEXT: subl $80, %esp +; I486-NEXT: subl $72, %esp ; I486-NEXT: movl 12(%ebp), %eax ; I486-NEXT: movl 8(%ebp), %ecx ; I486-NEXT: movl sc64+4, %edx @@ -526,8 +512,6 @@ define void @atomic_fetch_min64(i64 %x) nounwind { ; I486-NEXT: movl %eax, %ebx ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %edi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ebx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: jge .LBB7_4 @@ -604,7 +588,7 @@ define void @atomic_fetch_umax64(i64 %x) nounwind { ; I486-NEXT: pushl %edi ; I486-NEXT: pushl %esi ; I486-NEXT: andl $-8, %esp -; I486-NEXT: subl $80, %esp +; I486-NEXT: subl $72, %esp ; I486-NEXT: movl 12(%ebp), %eax ; I486-NEXT: movl 8(%ebp), %ecx ; I486-NEXT: movl sc64+4, %edx @@ -626,8 +610,6 @@ define void @atomic_fetch_umax64(i64 %x) nounwind { ; I486-NEXT: movl %eax, %ebx ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %edi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ebx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: jb .LBB8_4 @@ -704,7 +686,7 @@ define void @atomic_fetch_umin64(i64 %x) nounwind { ; I486-NEXT: pushl %edi ; I486-NEXT: pushl %esi ; I486-NEXT: andl $-8, %esp -; I486-NEXT: subl $80, %esp +; I486-NEXT: subl $72, %esp ; I486-NEXT: movl 12(%ebp), %eax ; I486-NEXT: movl 8(%ebp), %ecx ; I486-NEXT: movl sc64+4, %edx @@ -726,8 +708,6 @@ define void @atomic_fetch_umin64(i64 %x) nounwind { ; I486-NEXT: movl %eax, %ebx ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %edi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: movl %ebx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: jae .LBB9_4 @@ -780,7 +760,6 @@ define void @atomic_fetch_cmpxchg64() nounwind { ; X64-NEXT: # kill: def $rax killed $eax ; X64-NEXT: movl $1, %ecx ; X64-NEXT: lock cmpxchgq %rcx, {{.*}}(%rip) -; X64-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; X64-NEXT: retq ; ; I486-LABEL: atomic_fetch_cmpxchg64: @@ -802,7 +781,6 @@ define void @atomic_fetch_cmpxchg64() nounwind { ; I486-NEXT: movl $sc64, (%edx) ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_compare_exchange_8 -; I486-NEXT: movb %al, {{[-0-9]+}}(%e{{[sb]}}p) # 1-byte Spill ; I486-NEXT: movl %ebp, %esp ; I486-NEXT: popl %ebp ; I486-NEXT: retl @@ -841,13 +819,12 @@ define void @atomic_fetch_swap64(i64 %x) nounwind { ; X64-LABEL: atomic_fetch_swap64: ; X64: # %bb.0: ; X64-NEXT: xchgq %rdi, {{.*}}(%rip) -; X64-NEXT: movq %rdi, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; X64-NEXT: retq ; ; I486-LABEL: atomic_fetch_swap64: ; I486: # %bb.0: ; I486-NEXT: pushl %esi -; I486-NEXT: subl $28, %esp +; I486-NEXT: subl $20, %esp ; I486-NEXT: movl {{[0-9]+}}(%esp), %eax ; I486-NEXT: movl {{[0-9]+}}(%esp), %ecx ; I486-NEXT: leal sc64, %edx @@ -858,9 +835,7 @@ define void @atomic_fetch_swap64(i64 %x) nounwind { ; I486-NEXT: movl $sc64, (%esi) ; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_exchange_8 -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: addl $28, %esp +; I486-NEXT: addl $20, %esp ; I486-NEXT: popl %esi ; I486-NEXT: retl %t1 = atomicrmw xchg i64* @sc64, i64 %x acquire @@ -872,7 +847,6 @@ define void @atomic_fetch_swapf64(double %x) nounwind { ; X64: # %bb.0: ; X64-NEXT: movq %xmm0, %rax ; X64-NEXT: xchgq %rax, {{.*}}(%rip) -; X64-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; X64-NEXT: retq ; ; I486-LABEL: atomic_fetch_swapf64: @@ -881,7 +855,7 @@ define void @atomic_fetch_swapf64(double %x) nounwind { ; I486-NEXT: movl %esp, %ebp ; I486-NEXT: pushl %esi ; I486-NEXT: andl $-8, %esp -; I486-NEXT: subl $48, %esp +; I486-NEXT: subl $40, %esp ; I486-NEXT: fldl 8(%ebp) ; I486-NEXT: leal fsc64, %eax ; I486-NEXT: fstpl {{[0-9]+}}(%esp) @@ -894,8 +868,6 @@ define void @atomic_fetch_swapf64(double %x) nounwind { ; I486-NEXT: movl $fsc64, (%esi) ; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: calll __atomic_exchange_8 -; I486-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; I486-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill ; I486-NEXT: leal -4(%ebp), %esp ; I486-NEXT: popl %esi ; I486-NEXT: popl %ebp diff --git a/llvm/test/CodeGen/X86/atomic6432.ll b/llvm/test/CodeGen/X86/atomic6432.ll index 19a50ebc2de..74c8f4b7111 100644 --- a/llvm/test/CodeGen/X86/atomic6432.ll +++ b/llvm/test/CodeGen/X86/atomic6432.ll @@ -816,16 +816,14 @@ define void @atomic_fetch_cmpxchg64() nounwind { ; X32-LABEL: atomic_fetch_cmpxchg64: ; X32: # %bb.0: ; X32-NEXT: pushl %ebx -; X32-NEXT: subl $12, %esp +; X32-NEXT: pushl %eax ; X32-NEXT: xorl %eax, %eax ; X32-NEXT: movl $1, %ebx -; X32-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X32-NEXT: movl {{[-0-9]+}}(%e{{[sb]}}p), %edx # 4-byte Reload -; X32-NEXT: movl {{[-0-9]+}}(%e{{[sb]}}p), %ecx # 4-byte Reload +; X32-NEXT: movl %eax, (%esp) # 4-byte Spill +; X32-NEXT: movl (%esp), %edx # 4-byte Reload +; X32-NEXT: movl (%esp), %ecx # 4-byte Reload ; X32-NEXT: lock cmpxchg8b sc64 -; X32-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; X32-NEXT: movl %edx, (%esp) # 4-byte Spill -; X32-NEXT: addl $12, %esp +; X32-NEXT: addl $4, %esp ; X32-NEXT: popl %ebx ; X32-NEXT: retl %t1 = cmpxchg i64* @sc64, i64 0, i64 1 acquire acquire diff --git a/llvm/test/CodeGen/X86/avx512-mask-zext-bugfix.ll b/llvm/test/CodeGen/X86/avx512-mask-zext-bugfix.ll index fed87ebf6eb..7638c4cc0dd 100755 --- a/llvm/test/CodeGen/X86/avx512-mask-zext-bugfix.ll +++ b/llvm/test/CodeGen/X86/avx512-mask-zext-bugfix.ll @@ -17,8 +17,8 @@ declare i32 @check_mask16(i16 zeroext %res_mask, i16 zeroext %exp_mask, i8* %fna define void @test_xmm(i32 %shift, i32 %mulp, <2 x i64> %a,i8* %arraydecay,i8* %fname){ ; CHECK-LABEL: test_xmm: ; CHECK: ## %bb.0: -; CHECK-NEXT: subq $72, %rsp -; CHECK-NEXT: .cfi_def_cfa_offset 80 +; CHECK-NEXT: subq $56, %rsp +; CHECK-NEXT: .cfi_def_cfa_offset 64 ; CHECK-NEXT: vpmovw2m %xmm0, %k0 ; CHECK-NEXT: movl $2, %esi ; CHECK-NEXT: movl $8, %eax @@ -50,17 +50,16 @@ define void @test_xmm(i32 %shift, i32 %mulp, <2 x i64> %a,i8* %arraydecay,i8* %f ; CHECK-NEXT: movl {{[-0-9]+}}(%r{{[sb]}}p), %edx ## 4-byte Reload ; CHECK-NEXT: movl %eax, {{[-0-9]+}}(%r{{[sb]}}p) ## 4-byte Spill ; CHECK-NEXT: kmovw %k1, {{[-0-9]+}}(%r{{[sb]}}p) ## 2-byte Spill -; CHECK-NEXT: movw %r8w, {{[-0-9]+}}(%r{{[sb]}}p) ## 2-byte Spill +; CHECK-NEXT: movw %r8w, (%rsp) ## 2-byte Spill ; CHECK-NEXT: callq _calc_expected_mask_val ; CHECK-NEXT: movw %ax, %r8w -; CHECK-NEXT: movw {{[-0-9]+}}(%r{{[sb]}}p), %r10w ## 2-byte Reload +; CHECK-NEXT: movw (%rsp), %r10w ## 2-byte Reload ; CHECK-NEXT: movzwl %r10w, %edi ; CHECK-NEXT: movzwl %r8w, %esi ; CHECK-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rdx ## 8-byte Reload ; CHECK-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rcx ## 8-byte Reload ; CHECK-NEXT: callq _check_mask16 -; CHECK-NEXT: movl %eax, {{[-0-9]+}}(%r{{[sb]}}p) ## 4-byte Spill -; CHECK-NEXT: addq $72, %rsp +; CHECK-NEXT: addq $56, %rsp ; CHECK-NEXT: retq %d2 = bitcast <2 x i64> %a to <8 x i16> %m2 = call i8 @llvm.x86.avx512.cvtw2mask.128(<8 x i16> %d2) diff --git a/llvm/test/CodeGen/X86/pr11415.ll b/llvm/test/CodeGen/X86/pr11415.ll index 6c32a2206a7..b3d9b2ff483 100644 --- a/llvm/test/CodeGen/X86/pr11415.ll +++ b/llvm/test/CodeGen/X86/pr11415.ll @@ -12,7 +12,6 @@ ; CHECK-NEXT: #APP ; CHECK-NEXT: #NO_APP ; CHECK-NEXT: movq %rdx, %rax -; CHECK-NEXT: movq %rdx, -8(%rsp) ; CHECK-NEXT: ret define i64 @foo() { diff --git a/llvm/test/CodeGen/X86/pr30430.ll b/llvm/test/CodeGen/X86/pr30430.ll index a81e26c51a1..4422d408db4 100644 --- a/llvm/test/CodeGen/X86/pr30430.ll +++ b/llvm/test/CodeGen/X86/pr30430.ll @@ -116,14 +116,6 @@ define <16 x float> @makefloat(float %f1, float %f2, float %f3, float %f4, float ; CHECK-NEXT: vinsertf64x4 $1, %ymm1, %zmm24, %zmm24 ; CHECK-NEXT: vmovaps %zmm24, {{[0-9]+}}(%rsp) ; CHECK-NEXT: vmovaps {{[0-9]+}}(%rsp), %zmm0 -; CHECK-NEXT: vmovss %xmm8, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm9, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm10, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm11, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm12, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm13, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm14, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill -; CHECK-NEXT: vmovss %xmm15, (%rsp) # 4-byte Spill ; CHECK-NEXT: movq %rbp, %rsp ; CHECK-NEXT: popq %rbp ; CHECK-NEXT: .cfi_def_cfa %rsp, 8 diff --git a/llvm/test/CodeGen/X86/pr32284.ll b/llvm/test/CodeGen/X86/pr32284.ll index acbdf0e084b..cd8c27abd9d 100644 --- a/llvm/test/CodeGen/X86/pr32284.ll +++ b/llvm/test/CodeGen/X86/pr32284.ll @@ -186,8 +186,8 @@ define void @f1() { ; 686-O0-NEXT: .cfi_def_cfa_offset 16 ; 686-O0-NEXT: pushl %esi ; 686-O0-NEXT: .cfi_def_cfa_offset 20 -; 686-O0-NEXT: subl $24, %esp -; 686-O0-NEXT: .cfi_def_cfa_offset 44 +; 686-O0-NEXT: subl $1, %esp +; 686-O0-NEXT: .cfi_def_cfa_offset 21 ; 686-O0-NEXT: .cfi_offset %esi, -20 ; 686-O0-NEXT: .cfi_offset %edi, -16 ; 686-O0-NEXT: .cfi_offset %ebx, -12 @@ -198,7 +198,7 @@ define void @f1() { ; 686-O0-NEXT: xorl $208307499, %eax # imm = 0xC6A852B ; 686-O0-NEXT: xorl $-2, %ecx ; 686-O0-NEXT: orl %ecx, %eax -; 686-O0-NEXT: setne {{[0-9]+}}(%esp) +; 686-O0-NEXT: setne (%esp) ; 686-O0-NEXT: movl var_5, %ecx ; 686-O0-NEXT: movl %ecx, %edx ; 686-O0-NEXT: sarl $31, %edx @@ -220,12 +220,7 @@ define void @f1() { ; 686-O0-NEXT: movzbl %bl, %ebp ; 686-O0-NEXT: movl %ebp, _ZN8struct_210member_2_0E ; 686-O0-NEXT: movl $0, _ZN8struct_210member_2_0E+4 -; 686-O0-NEXT: movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; 686-O0-NEXT: movl %esi, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; 686-O0-NEXT: movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; 686-O0-NEXT: movl %edx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill -; 686-O0-NEXT: movl %edi, (%esp) # 4-byte Spill -; 686-O0-NEXT: addl $24, %esp +; 686-O0-NEXT: addl $1, %esp ; 686-O0-NEXT: .cfi_def_cfa_offset 20 ; 686-O0-NEXT: popl %esi ; 686-O0-NEXT: .cfi_def_cfa_offset 16 diff --git a/llvm/test/CodeGen/X86/pr32484.ll b/llvm/test/CodeGen/X86/pr32484.ll index eddbcabd3cf..ef504eee6e8 100644 --- a/llvm/test/CodeGen/X86/pr32484.ll +++ b/llvm/test/CodeGen/X86/pr32484.ll @@ -11,7 +11,6 @@ define void @foo() { ; CHECK-NEXT: pcmpeqd %xmm1, %xmm1 ; CHECK-NEXT: # implicit-def: $rax ; CHECK-NEXT: movdqu %xmm1, (%rax) -; CHECK-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp) # 16-byte Spill ; CHECK-NEXT: .LBB0_2: ; CHECK-NEXT: retq indirectbr i8* undef, [label %9, label %1] diff --git a/llvm/test/CodeGen/X86/pr34592.ll b/llvm/test/CodeGen/X86/pr34592.ll index 12b72566c8d..e97114b9114 100644 --- a/llvm/test/CodeGen/X86/pr34592.ll +++ b/llvm/test/CodeGen/X86/pr34592.ll @@ -10,7 +10,7 @@ define <16 x i64> @pluto(<16 x i64> %arg, <16 x i64> %arg1, <16 x i64> %arg2, <1 ; CHECK-NEXT: movq %rsp, %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: andq $-32, %rsp -; CHECK-NEXT: subq $320, %rsp # imm = 0x140 +; CHECK-NEXT: subq $128, %rsp ; CHECK-NEXT: vmovaps 240(%rbp), %ymm8 ; CHECK-NEXT: vmovaps 208(%rbp), %ymm9 ; CHECK-NEXT: vmovaps 176(%rbp), %ymm10 @@ -48,14 +48,8 @@ define <16 x i64> @pluto(<16 x i64> %arg, <16 x i64> %arg1, <16 x i64> %arg2, <1 ; CHECK-NEXT: vpblendd {{.*#+}} ymm5 = ymm7[0,1,2,3,4,5],ymm5[6,7] ; CHECK-NEXT: vmovaps %ymm1, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill ; CHECK-NEXT: vmovaps %ymm5, %ymm1 -; CHECK-NEXT: vmovaps %ymm3, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill +; CHECK-NEXT: vmovaps %ymm3, (%rsp) # 32-byte Spill ; CHECK-NEXT: vmovaps %ymm9, %ymm3 -; CHECK-NEXT: vmovaps %ymm10, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill -; CHECK-NEXT: vmovaps %ymm12, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill -; CHECK-NEXT: vmovaps %ymm13, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill -; CHECK-NEXT: vmovaps %ymm14, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill -; CHECK-NEXT: vmovaps %ymm15, {{[-0-9]+}}(%r{{[sb]}}p) # 32-byte Spill -; CHECK-NEXT: vmovaps %ymm4, (%rsp) # 32-byte Spill ; CHECK-NEXT: movq %rbp, %rsp ; CHECK-NEXT: popq %rbp ; CHECK-NEXT: .cfi_def_cfa %rsp, 8 diff --git a/llvm/test/CodeGen/X86/pr34653.ll b/llvm/test/CodeGen/X86/pr34653.ll index 733249770be..98d7de3f31a 100644 --- a/llvm/test/CodeGen/X86/pr34653.ll +++ b/llvm/test/CodeGen/X86/pr34653.ll @@ -12,7 +12,7 @@ define void @pr34653() { ; CHECK-NEXT: movq %rsp, %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: andq $-512, %rsp # imm = 0xFE00 -; CHECK-NEXT: subq $2048, %rsp # imm = 0x800 +; CHECK-NEXT: subq $1536, %rsp # imm = 0x600 ; CHECK-NEXT: leaq {{[0-9]+}}(%rsp), %rdi ; CHECK-NEXT: callq test ; CHECK-NEXT: vmovupd {{[0-9]+}}(%rsp), %xmm0 @@ -147,38 +147,6 @@ define void @pr34653() { ; CHECK-NEXT: vmovsd %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-NEXT: vmovsd {{[-0-9]+}}(%r{{[sb]}}p), %xmm0 # 8-byte Reload ; CHECK-NEXT: # xmm0 = mem[0],zero -; CHECK-NEXT: vmovsd %xmm1, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm3, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm5, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm7, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm9, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm11, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm13, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm15, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm16, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm17, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm18, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm19, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm20, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm21, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm22, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm23, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm24, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm25, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm26, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm27, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm2, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm4, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm6, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm8, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm10, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm12, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm14, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm28, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm29, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm30, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm31, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill -; CHECK-NEXT: vmovsd %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill ; CHECK-NEXT: movq %rbp, %rsp ; CHECK-NEXT: popq %rbp ; CHECK-NEXT: .cfi_def_cfa %rsp, 8 diff --git a/llvm/test/CodeGen/X86/swifterror.ll b/llvm/test/CodeGen/X86/swifterror.ll index cb0597f7151..6d7c13836a5 100644 --- a/llvm/test/CodeGen/X86/swifterror.ll +++ b/llvm/test/CodeGen/X86/swifterror.ll @@ -434,23 +434,22 @@ define swiftcc float @conditionally_forward_swifterror(%swift_error** swifterror ; CHECK-APPLE: retq ; CHECK-O0-LABEL: conditionally_forward_swifterror: -; CHECK-O0: subq $24, %rsp -; CHECK-O0: movq %r12, [[REG1:%[a-z0-9]+]] +; CHECK-O0: pushq [[REG1:%[a-z0-9]+]] +; CHECK-O0: movq %r12, [[REG1]] ; CHECK-O0: cmpl $0, %edi -; CHECK-O0-DAG: movq [[REG1]], [[STK:[0-9]+]](%rsp) -; CHECK-O0-DAG: movq %r12, [[STK2:[0-9]+]](%rsp) +; CHECK-O0-DAG: movq %r12, (%rsp) ; CHECK-O0: je -; CHECK-O0: movq [[STK2]](%rsp), [[REG:%[a-z0-9]+]] +; CHECK-O0: movq (%rsp), [[REG:%[a-z0-9]+]] ; CHECK-O0: movq [[REG]], %r12 ; CHECK-O0: callq _moo -; CHECK-O0: addq $24, %rsp +; CHECK-O0: popq [[REG1]] ; CHECK-O0: retq -; CHECK-O0: movq [[STK2]](%rsp), [[REG:%[a-z0-9]+]] +; CHECK-O0: movq (%rsp), [[REG:%[a-z0-9]+]] ; CHECK-O0: xorps %xmm0, %xmm0 ; CHECK-O0: movq [[REG]], %r12 -; CHECK-O0: addq $24, %rsp +; CHECK-O0: popq [[REG1]] ; CHECK-O0: retq entry: %cond = icmp ne i32 %cc, 0 |