Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Analysis / BasicAA / cas.ll
blob87772bfb44d50d0edbb7d244ded133bf6520c5e1
1 ; RUN: opt < %s -basicaa -gvn -S | grep load | count 1
3 @flag0 = internal global i32 zeroinitializer
4 @turn = internal global i32 zeroinitializer
7 define i32 @main() {
8   %a = load i32* @flag0
9         %b = tail call i32 @llvm.atomic.swap.i32.p0i32(i32* @turn, i32 1)
10   %c = load i32* @flag0
11         ret i32 %c
14 declare i32 @llvm.atomic.swap.i32.p0i32(i32*, i32) nounwind