[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Analysis / BasicAA / must-and-partial.ll
blob5d3dcd1e52395d2f13e7e58f8f836903d2ca443e
1 ; RUN: opt < %s -aa-pipeline=basic-aa -passes=aa-eval -print-all-alias-modref-info 2>&1 | FileCheck %s
3 ; When merging MustAlias and PartialAlias, merge to PartialAlias
4 ; instead of MayAlias.
7 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
9 ; CHECK: PartialAlias:  i16* %base, i8* %phi
10 define i8 @test0(ptr %base, i1 %x) {
11 entry:
12   %baseplusone = getelementptr i8, ptr %base, i64 1
13   br i1 %x, label %red, label %green
14 red:
15   br label %green
16 green:
17   %phi = phi ptr [ %baseplusone, %red ], [ %base, %entry ]
18   store i8 0, ptr %phi
20   store i16 -1, ptr %base
22   %loaded = load i8, ptr %phi
23   ret i8 %loaded
26 ; CHECK: PartialAlias:  i16* %base, i8* %sel
27 define i8 @test1(ptr %base, i1 %x) {
28 entry:
29   %baseplusone = getelementptr i8, ptr %base, i64 1
30   %sel = select i1 %x, ptr %baseplusone, ptr %base
31   store i8 0, ptr %sel
33   store i16 -1, ptr %base
35   %loaded = load i8, ptr %sel
36   ret i8 %loaded