mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-26 05:32:25 +00:00
f03bb260c9
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
33 lines
757 B
LLVM
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
|
|
}
|