mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-09 11:25:55 +00:00
StackColoring: don't clear an instruction's mem operand if the underlying
object is a PseudoSourceValue and PseudoSourceValue::isConstant returns true (i.e., points to memory that has a constant value). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@181751 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -42,6 +42,7 @@
|
|||||||
#include "llvm/CodeGen/MachineMemOperand.h"
|
#include "llvm/CodeGen/MachineMemOperand.h"
|
||||||
#include "llvm/CodeGen/MachineModuleInfo.h"
|
#include "llvm/CodeGen/MachineModuleInfo.h"
|
||||||
#include "llvm/CodeGen/MachineRegisterInfo.h"
|
#include "llvm/CodeGen/MachineRegisterInfo.h"
|
||||||
|
#include "llvm/CodeGen/PseudoSourceValue.h"
|
||||||
#include "llvm/CodeGen/SlotIndexes.h"
|
#include "llvm/CodeGen/SlotIndexes.h"
|
||||||
#include "llvm/DebugInfo.h"
|
#include "llvm/DebugInfo.h"
|
||||||
#include "llvm/IR/Function.h"
|
#include "llvm/IR/Function.h"
|
||||||
@@ -528,6 +529,10 @@ void StackColoring::remapInstructions(DenseMap<int, int> &SlotRemap) {
|
|||||||
if (!V)
|
if (!V)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
const PseudoSourceValue *PSV = dyn_cast<const PseudoSourceValue>(V);
|
||||||
|
if (PSV && PSV->isConstant(MFI))
|
||||||
|
continue;
|
||||||
|
|
||||||
// Climb up and find the original alloca.
|
// Climb up and find the original alloca.
|
||||||
V = GetUnderlyingObject(V);
|
V = GetUnderlyingObject(V);
|
||||||
// If we did not find one, or if the one that we found is not in our
|
// If we did not find one, or if the one that we found is not in our
|
||||||
|
39
test/CodeGen/Mips/stackcoloring.ll
Normal file
39
test/CodeGen/Mips/stackcoloring.ll
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
; RUN: llc -march=mipsel < %s | FileCheck %s
|
||||||
|
|
||||||
|
@g1 = external global i32*
|
||||||
|
|
||||||
|
; CHECK: foo1:
|
||||||
|
; CHECK: lw ${{[0-9]+}}, %got(g1)
|
||||||
|
; CHECK: # %for.body
|
||||||
|
; CHECK: # %for.end
|
||||||
|
|
||||||
|
define i32 @foo1() {
|
||||||
|
entry:
|
||||||
|
%b = alloca [16 x i32], align 4
|
||||||
|
%0 = bitcast [16 x i32]* %b to i8*
|
||||||
|
call void @llvm.lifetime.start(i64 64, i8* %0)
|
||||||
|
%arraydecay = getelementptr inbounds [16 x i32]* %b, i32 0, i32 0
|
||||||
|
br label %for.body
|
||||||
|
|
||||||
|
for.body: ; preds = %for.body, %entry
|
||||||
|
%i.05 = phi i32 [ 0, %entry ], [ %inc, %for.body ]
|
||||||
|
%v.04 = phi i32 [ 0, %entry ], [ %add, %for.body ]
|
||||||
|
%1 = load i32** @g1, align 4
|
||||||
|
%arrayidx = getelementptr inbounds i32* %1, i32 %i.05
|
||||||
|
%2 = load i32* %arrayidx, align 4
|
||||||
|
%call = call i32 @foo2(i32 %2, i32* %arraydecay)
|
||||||
|
%add = add nsw i32 %call, %v.04
|
||||||
|
%inc = add nsw i32 %i.05, 1
|
||||||
|
%exitcond = icmp eq i32 %inc, 10000
|
||||||
|
br i1 %exitcond, label %for.end, label %for.body
|
||||||
|
|
||||||
|
for.end: ; preds = %for.body
|
||||||
|
call void @llvm.lifetime.end(i64 64, i8* %0)
|
||||||
|
ret i32 %add
|
||||||
|
}
|
||||||
|
|
||||||
|
declare void @llvm.lifetime.start(i64, i8* nocapture)
|
||||||
|
|
||||||
|
declare i32 @foo2(i32, i32*)
|
||||||
|
|
||||||
|
declare void @llvm.lifetime.end(i64, i8* nocapture)
|
Reference in New Issue
Block a user