diff options
author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2017-08-01 16:18:25 +0000 |
---|---|---|
committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2017-08-01 16:18:25 +0000 |
commit | 810677eba2355451ffae8bcc7a59b18b72828a42 (patch) | |
tree | ba6e1118fab751cdb5d0169acf83cae0ecfd8f8c /llvm/test/CodeGen/X86 | |
parent | b5a0af6b6eee77ecccb52d5a3efcc16f2baac70b (diff) | |
download | bcm5719-llvm-810677eba2355451ffae8bcc7a59b18b72828a42.tar.gz bcm5719-llvm-810677eba2355451ffae8bcc7a59b18b72828a42.zip |
[X86][SSSE3] Added missing PHADDS/PHSUBS/PSIGN intrinsic schedules
llvm-svn: 309699
Diffstat (limited to 'llvm/test/CodeGen/X86')
-rw-r--r-- | llvm/test/CodeGen/X86/ssse3-schedule.ll | 48 |
1 files changed, 10 insertions, 38 deletions
diff --git a/llvm/test/CodeGen/X86/ssse3-schedule.ll b/llvm/test/CodeGen/X86/ssse3-schedule.ll index dda218b8c63..86ce4c7b2d9 100644 --- a/llvm/test/CodeGen/X86/ssse3-schedule.ll +++ b/llvm/test/CodeGen/X86/ssse3-schedule.ll @@ -294,16 +294,8 @@ define <8 x i16> @test_phaddsw(<8 x i16> %a0, <8 x i16> %a1, <8 x i16> *%a2) { ; ; ATOM-LABEL: test_phaddsw: ; ATOM: # BB#0: -; ATOM-NEXT: phaddsw %xmm1, %xmm0 -; ATOM-NEXT: phaddsw (%rdi), %xmm0 -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] +; ATOM-NEXT: phaddsw %xmm1, %xmm0 # sched: [7:3.50] +; ATOM-NEXT: phaddsw (%rdi), %xmm0 # sched: [8:4.00] ; ATOM-NEXT: retq # sched: [79:39.50] ; ; SLM-LABEL: test_phaddsw: @@ -449,16 +441,8 @@ define <8 x i16> @test_phsubsw(<8 x i16> %a0, <8 x i16> %a1, <8 x i16> *%a2) { ; ; ATOM-LABEL: test_phsubsw: ; ATOM: # BB#0: -; ATOM-NEXT: phsubsw %xmm1, %xmm0 -; ATOM-NEXT: phsubsw (%rdi), %xmm0 -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] +; ATOM-NEXT: phsubsw %xmm1, %xmm0 # sched: [7:3.50] +; ATOM-NEXT: phsubsw (%rdi), %xmm0 # sched: [8:4.00] ; ATOM-NEXT: retq # sched: [79:39.50] ; ; SLM-LABEL: test_phsubsw: @@ -703,12 +687,8 @@ define <16 x i8> @test_psignb(<16 x i8> %a0, <16 x i8> %a1, <16 x i8> *%a2) { ; ; ATOM-LABEL: test_psignb: ; ATOM: # BB#0: -; ATOM-NEXT: psignb %xmm1, %xmm0 -; ATOM-NEXT: psignb (%rdi), %xmm0 -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] +; ATOM-NEXT: psignb %xmm1, %xmm0 # sched: [1:0.50] +; ATOM-NEXT: psignb (%rdi), %xmm0 # sched: [1:1.00] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] @@ -760,12 +740,8 @@ define <4 x i32> @test_psignd(<4 x i32> %a0, <4 x i32> %a1, <4 x i32> *%a2) { ; ; ATOM-LABEL: test_psignd: ; ATOM: # BB#0: -; ATOM-NEXT: psignd %xmm1, %xmm0 -; ATOM-NEXT: psignd (%rdi), %xmm0 -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] +; ATOM-NEXT: psignd %xmm1, %xmm0 # sched: [1:0.50] +; ATOM-NEXT: psignd (%rdi), %xmm0 # sched: [1:1.00] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] @@ -817,12 +793,8 @@ define <8 x i16> @test_psignw(<8 x i16> %a0, <8 x i16> %a1, <8 x i16> *%a2) { ; ; ATOM-LABEL: test_psignw: ; ATOM: # BB#0: -; ATOM-NEXT: psignw %xmm1, %xmm0 -; ATOM-NEXT: psignw (%rdi), %xmm0 -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] -; ATOM-NEXT: nop # sched: [1:0.50] +; ATOM-NEXT: psignw %xmm1, %xmm0 # sched: [1:0.50] +; ATOM-NEXT: psignw (%rdi), %xmm0 # sched: [1:1.00] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] ; ATOM-NEXT: nop # sched: [1:0.50] |