xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2011-04-19-sclr-bb.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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