[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / Analysis / ValueTracking / func-ptr-lsb.ll
blob0162f00fab67135b28fd9d4bec4537db91b20856
1 ; RUN: opt -instcombine -S < %s | FileCheck %s
3 target datalayout = "e-p:32:32-n32-S64"
5 ; CHECK-LABEL: @foo_ptr
6 ; CHECK: and
7 define i32 @foo_ptr() {
8 entry:
9   ; Even though the address of @foo is aligned, we cannot assume that the
10   ; pointer has the same alignment. This is not true for e.g. ARM targets
11   ; which store ARM/Thumb state in the LSB
12   ret i32 and (i32 ptrtoint (void ()* @foo to i32), i32 -4)
15 define internal void @foo() align 16 {
16 entry:
17   ret void