[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / NewGVN / nomemlocation.ll
blob0f716b30801b25dfab641ea1a8f92544651e2861
1 ; RUN: opt < %s -S -p='newgvn' | FileCheck %s
2 ; MemorySSA should be able to handle a clobber query with an empty MemoryLocation.
4 ; CHECK: @userread
5 define ptr @userread(ptr %p) {
6 entry:
7   br label %loop
9 loop:                                             ; preds = %loop, %entry
10 ; 2 = MemoryPhi({entry,liveOnEntry},{loop,1})
11   %pos = phi i64 [ 1, %entry ], [ %diff, %loop ]
12   %gep = getelementptr inbounds i8, ptr %p, i64 %pos
13 ; MemoryUse(2)
14   %ld = load ptr, ptr %gep, align 8
15 ; 1 = MemoryDef(2)->2
16   %readval = call i64 @fread(ptr noundef nonnull %gep, i64 noundef 1, i64 noundef %pos, ptr noundef %ld)
17   %readvalispos = icmp eq i64 %readval, %pos
18   call void @llvm.assume(i1 %readvalispos)
19   %diff = sub i64 0, %pos
20   br label %loop
23 declare noundef i64 @fread(ptr nocapture noundef %0, i64 noundef %1, i64 noundef %2, ptr nocapture noundef %3) local_unnamed_addr #0
24 declare void @llvm.assume(i1 %cond)
26 attributes #0 = { nofree nounwind "frame-pointer"="non-leaf" "no-trapping-math"="true" "prefer-vector-width"="128" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+aes,+cmov,+crc32,+cx16,+cx8,+fxsr,+mmx,+pclmul,+popcnt,+sse,+sse2,+sse3,+sse4.1,+sse4.2,+ssse3,+x87" "tune-cpu"="generic" }