xref: /llvm-project/llvm/test/Transforms/ConstantHoisting/ARM/apint-assert.ll (revision 8851ea64a5d01fbf406383f13fcba347e730bc2d)
1*8851ea64SNikita Popov; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
2*8851ea64SNikita Popov; RUN: opt -S -passes=consthoist -mtriple=armv4t-unknown-linux-gnueabi < %s | FileCheck %s
3*8851ea64SNikita Popov
4*8851ea64SNikita Popovdefine i1 @test(i32 %arg) optsize {
5*8851ea64SNikita Popov; CHECK-LABEL: define i1 @test(
6*8851ea64SNikita Popov; CHECK-SAME: i32 [[ARG:%.*]]) #[[ATTR0:[0-9]+]] {
7*8851ea64SNikita Popov; CHECK-NEXT:  [[ENTRY:.*:]]
8*8851ea64SNikita Popov; CHECK-NEXT:    [[CONST:%.*]] = bitcast i32 380633088 to i32
9*8851ea64SNikita Popov; CHECK-NEXT:    [[CONST_MAT:%.*]] = add i32 [[CONST]], -381681664
10*8851ea64SNikita Popov; CHECK-NEXT:    [[SHR_MASK:%.*]] = and i32 [[ARG]], [[CONST_MAT]]
11*8851ea64SNikita Popov; CHECK-NEXT:    [[CMP:%.*]] = icmp eq i32 [[SHR_MASK]], [[CONST]]
12*8851ea64SNikita Popov; CHECK-NEXT:    ret i1 [[CMP]]
13*8851ea64SNikita Popov;
14*8851ea64SNikita Popoventry:
15*8851ea64SNikita Popov  %shr.mask = and i32 %arg, -1048576
16*8851ea64SNikita Popov  %cmp = icmp eq i32 %shr.mask, 380633088
17*8851ea64SNikita Popov  ret i1 %cmp
18*8851ea64SNikita Popov}
19