mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 17:39:16 +00:00
GVN: Preserve invariant.load metadata
If both instructions to be replaced are marked invariant the resulting instruction is invariant. rdar://13358910 Fix by Erik Eckstein! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@211801 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
db1c494276
commit
c2d93c4048
@ -1798,6 +1798,10 @@ static void patchReplacementInstruction(Instruction *I, Value *Repl) {
|
||||
case LLVMContext::MD_fpmath:
|
||||
ReplInst->setMetadata(Kind, MDNode::getMostGenericFPMath(IMD, ReplMD));
|
||||
break;
|
||||
case LLVMContext::MD_invariant_load:
|
||||
// Only set the !invariant.load if it is present in both instructions.
|
||||
ReplInst->setMetadata(Kind, IMD);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
30
test/Transforms/GVN/invariant-load.ll
Normal file
30
test/Transforms/GVN/invariant-load.ll
Normal file
@ -0,0 +1,30 @@
|
||||
; RUN: opt -basicaa -gvn -S < %s | FileCheck %s
|
||||
|
||||
define i32 @test1(i32* nocapture %p, i8* nocapture %q) {
|
||||
; CHECK-LABEL: test1
|
||||
; CHECK: %x = load i32* %p, align 4, !invariant.load !0
|
||||
; CHECK-NOT: %y = load
|
||||
entry:
|
||||
%x = load i32* %p, align 4, !invariant.load !0
|
||||
%conv = trunc i32 %x to i8
|
||||
store i8 %conv, i8* %q, align 1
|
||||
%y = load i32* %p, align 4, !invariant.load !0
|
||||
%add = add i32 %y, 1
|
||||
ret i32 %add
|
||||
}
|
||||
|
||||
define i32 @test2(i32* nocapture %p, i8* nocapture %q) {
|
||||
; CHECK-LABEL: test2
|
||||
; CHECK-NOT: !invariant.load
|
||||
; CHECK-NOT: %y = load
|
||||
entry:
|
||||
%x = load i32* %p, align 4
|
||||
%conv = trunc i32 %x to i8
|
||||
store i8 %conv, i8* %q, align 1
|
||||
%y = load i32* %p, align 4, !invariant.load !0
|
||||
%add = add i32 %y, 1
|
||||
ret i32 %add
|
||||
}
|
||||
|
||||
!0 = metadata !{ }
|
||||
|
Loading…
x
Reference in New Issue
Block a user