xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/bc-extract.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86-64 -mattr=+sse4.2 |  FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine float @extractFloat1() nounwind {
5*9880d681SAndroid Build Coastguard Workerentry:
6*9880d681SAndroid Build Coastguard Worker  ; CHECK: 1065353216
7*9880d681SAndroid Build Coastguard Worker  %tmp0 = bitcast <1 x double> <double 0x000000003F800000> to <2 x float>
8*9880d681SAndroid Build Coastguard Worker  %tmp1 = extractelement <2 x float> %tmp0, i32 0
9*9880d681SAndroid Build Coastguard Worker  ret float %tmp1
10*9880d681SAndroid Build Coastguard Worker}
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Workerdefine float @extractFloat2() nounwind {
13*9880d681SAndroid Build Coastguard Workerentry:
14*9880d681SAndroid Build Coastguard Worker  ; CHECK: xorps	%xmm0, %xmm0
15*9880d681SAndroid Build Coastguard Worker  %tmp4 = bitcast <1 x double> <double 0x000000003F800000> to <2 x float>
16*9880d681SAndroid Build Coastguard Worker  %tmp5 = extractelement <2 x float> %tmp4, i32 1
17*9880d681SAndroid Build Coastguard Worker  ret float %tmp5
18*9880d681SAndroid Build Coastguard Worker}
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Workerdefine i32 @extractInt2() nounwind {
21*9880d681SAndroid Build Coastguard Workerentry:
22*9880d681SAndroid Build Coastguard Worker  ; CHECK: xorl	%eax, %eax
23*9880d681SAndroid Build Coastguard Worker  %tmp4 = bitcast <1 x i64> <i64 256> to <2 x i32>
24*9880d681SAndroid Build Coastguard Worker  %tmp5 = extractelement <2 x i32> %tmp4, i32 1
25*9880d681SAndroid Build Coastguard Worker  ret i32 %tmp5
26*9880d681SAndroid Build Coastguard Worker}
27*9880d681SAndroid Build Coastguard Worker
28