| Quentin Colombet | 90a646e | 2013-12-19 18:32:04 +0000 | [diff] [blame] | 1 | ; RUN: llc -mtriple x86_64-apple-darwin -O0 -o - < %s | FileCheck %s | 
|  | 2 | ; Make sure we only use the less significant bit of the value that feeds the | 
|  | 3 | ; select. Otherwise, we may account for a non-zero value whereas the | 
|  | 4 | ; lsb is zero. | 
|  | 5 | ; <rdar://problem/15651765> | 
|  | 6 |  | 
| Juergen Ributzka | 6ef06f9 | 2014-06-23 21:55:36 +0000 | [diff] [blame] | 7 | ; CHECK-LABEL: fastisel_select: | 
| Quentin Colombet | 90a646e | 2013-12-19 18:32:04 +0000 | [diff] [blame] | 8 | ; CHECK: subb {{%[a-z0-9]+}}, [[RES:%[a-z0-9]+]] | 
|  | 9 | ; CHECK: testb $1, [[RES]] | 
| Juergen Ributzka | 6ef06f9 | 2014-06-23 21:55:36 +0000 | [diff] [blame] | 10 | ; CHECK: cmovnel %edi, %esi | 
| Quentin Colombet | 90a646e | 2013-12-19 18:32:04 +0000 | [diff] [blame] | 11 | define i32 @fastisel_select(i1 %exchSub2211_, i1 %trunc_8766) { | 
|  | 12 | %shuffleInternal15257_8932 = sub i1 %exchSub2211_, %trunc_8766 | 
|  | 13 | %counter_diff1345 = select i1 %shuffleInternal15257_8932, i32 1204476887, i32 0 | 
|  | 14 | ret i32 %counter_diff1345 | 
|  | 15 | } | 
|  | 16 |  |