llvm-6502/test/Transforms/LICM/2011-04-06-HoistMissedASTUpdate.ll
Eli Friedman f03bb260c9 Move "atomic" and "volatile" designations on instructions after the opcode
of the instruction.

Note that this change affects the existing non-atomic load and store
instructions; the parser now accepts both forms, and the change is noted
in the release notes.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@137527 91177308-0d34-0410-b5e6-96231b3b80d8
2011-08-12 22:50:01 +00:00

33 lines
757 B
LLVM

; RUN: opt < %s -basicaa -licm -S | FileCheck %s
; PR9630
@g_39 = external global i16, align 2
declare i32* @func_84(i32** nocapture) nounwind readonly
declare i32** @func_108(i32*** nocapture) nounwind readonly
define void @func() nounwind {
entry:
br label %for.body4.lr.ph
for.body4.lr.ph:
br label %for.body4
; CHECK: for.body4:
; CHECK: load volatile i16* @g_39
for.body4:
%l_612.11 = phi i32* [ undef, %for.body4.lr.ph ], [ %call19, %for.body4 ]
%tmp7 = volatile load i16* @g_39, align 2
%call = call i32** @func_108(i32*** undef)
%call19 = call i32* @func_84(i32** %call)
br i1 false, label %for.body4, label %for.cond.loopexit
for.cond.loopexit:
br i1 false, label %for.body4.lr.ph, label %for.end26
for.end26:
ret void
}