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