1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=corei7 | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; Make sure that values of illegal types are not scalarized between basic blocks. 4*9880d681SAndroid Build Coastguard Worker;CHECK-LABEL: test: 5*9880d681SAndroid Build Coastguard Worker;CHECK-NOT: pinsrw 6*9880d681SAndroid Build Coastguard Worker;CHECK-NOT: pextrb 7*9880d681SAndroid Build Coastguard Worker;CHECK: ret 8*9880d681SAndroid Build Coastguard Workerdefine void @test(i1 %cond) { 9*9880d681SAndroid Build Coastguard WorkerENTRY: 10*9880d681SAndroid Build Coastguard Worker br label %LOOP 11*9880d681SAndroid Build Coastguard WorkerLOOP: 12*9880d681SAndroid Build Coastguard Worker %vec1 = phi <4 x i1> [ %vec1_or_2, %LOOP ], [ zeroinitializer, %ENTRY ] 13*9880d681SAndroid Build Coastguard Worker %vec2 = phi <4 x i1> [ %vec2_and_1, %LOOP ], [ zeroinitializer, %ENTRY ] 14*9880d681SAndroid Build Coastguard Worker %vec1_or_2 = or <4 x i1> %vec1, %vec2 15*9880d681SAndroid Build Coastguard Worker %vec2_and_1 = and <4 x i1> %vec2, %vec1 16*9880d681SAndroid Build Coastguard Worker br i1 %cond, label %LOOP, label %EXIT 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard WorkerEXIT: 19*9880d681SAndroid Build Coastguard Worker ret void 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker 22