xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/pr26350.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -disable-constant-hoisting < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128"
3*9880d681SAndroid Build Coastguard Workertarget triple = "i386-unknown-linux-gnu"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker@d = global i32 8, align 4
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workerdefine i32 @main() {
8*9880d681SAndroid Build Coastguard Workerentry:
9*9880d681SAndroid Build Coastguard Worker  %load = load i32, i32* @d, align 4
10*9880d681SAndroid Build Coastguard Worker  %conv1 = zext i32 %load to i64
11*9880d681SAndroid Build Coastguard Worker  %shl = shl i64 %conv1, 1
12*9880d681SAndroid Build Coastguard Worker  %mul = and i64 %shl, 4294967312
13*9880d681SAndroid Build Coastguard Worker  %cmp = icmp ugt i64 4294967295, %mul
14*9880d681SAndroid Build Coastguard Worker  %zext = zext i1 %cmp to i32
15*9880d681SAndroid Build Coastguard Worker  ret i32 %zext
16*9880d681SAndroid Build Coastguard Worker}
17*9880d681SAndroid Build Coastguard Worker; CHECK: main:
18*9880d681SAndroid Build Coastguard Worker; CHECK:   movl    d, %[[load:.*]]
19*9880d681SAndroid Build Coastguard Worker; CHECK:   movl    %[[load]], %[[copy:.*]]
20*9880d681SAndroid Build Coastguard Worker; CHECK:   shrl    $31, %[[copy]]
21*9880d681SAndroid Build Coastguard Worker; CHECK:   addl    %[[load]], %[[load]]
22