| Sanjay Patel | 5e7b7b7 | 2017-06-12 17:31:36 +0000 | [diff] [blame] | 1 | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 2 | ; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s --check-prefix=X64 |
| 3 | |
| 4 | define i32 @neg_lshr_signbit(i32 %x) { |
| 5 | ; X64-LABEL: neg_lshr_signbit: |
| Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 6 | ; X64: # %bb.0: |
| Sanjay Patel | 00fc7a6 | 2016-10-14 14:26:47 +0000 | [diff] [blame] | 7 | ; X64-NEXT: sarl $31, %edi |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 8 | ; X64-NEXT: movl %edi, %eax |
| 9 | ; X64-NEXT: retq |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 10 | %sh = lshr i32 %x, 31 |
| 11 | %neg = sub i32 0, %sh |
| 12 | ret i32 %neg |
| 13 | } |
| 14 | |
| 15 | define i64 @neg_ashr_signbit(i64 %x) { |
| 16 | ; X64-LABEL: neg_ashr_signbit: |
| Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 17 | ; X64: # %bb.0: |
| Sanjay Patel | 00fc7a6 | 2016-10-14 14:26:47 +0000 | [diff] [blame] | 18 | ; X64-NEXT: shrq $63, %rdi |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 19 | ; X64-NEXT: movq %rdi, %rax |
| 20 | ; X64-NEXT: retq |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 21 | %sh = ashr i64 %x, 63 |
| 22 | %neg = sub i64 0, %sh |
| 23 | ret i64 %neg |
| 24 | } |
| 25 | |
| 26 | define <4 x i32> @neg_ashr_signbit_vec(<4 x i32> %x) { |
| 27 | ; X64-LABEL: neg_ashr_signbit_vec: |
| Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 28 | ; X64: # %bb.0: |
| Sanjay Patel | 00fc7a6 | 2016-10-14 14:26:47 +0000 | [diff] [blame] | 29 | ; X64-NEXT: psrld $31, %xmm0 |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 30 | ; X64-NEXT: retq |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 31 | %sh = ashr <4 x i32> %x, <i32 31, i32 31, i32 31, i32 31> |
| 32 | %neg = sub <4 x i32> zeroinitializer, %sh |
| 33 | ret <4 x i32> %neg |
| 34 | } |
| 35 | |
| 36 | define <8 x i16> @neg_lshr_signbit_vec(<8 x i16> %x) { |
| 37 | ; X64-LABEL: neg_lshr_signbit_vec: |
| Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 38 | ; X64: # %bb.0: |
| Sanjay Patel | 00fc7a6 | 2016-10-14 14:26:47 +0000 | [diff] [blame] | 39 | ; X64-NEXT: psraw $15, %xmm0 |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 40 | ; X64-NEXT: retq |
| Sanjay Patel | 7b4e4af | 2016-10-14 14:14:40 +0000 | [diff] [blame] | 41 | %sh = lshr <8 x i16> %x, <i16 15, i16 15, i16 15, i16 15, i16 15, i16 15, i16 15, i16 15> |
| 42 | %neg = sub <8 x i16> zeroinitializer, %sh |
| 43 | ret <8 x i16> %neg |
| 44 | } |
| 45 | |