aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/SparcV9/SparcV9StackSlots.cpp
blob: 10cccd3c58d9cc574555ff239648a5dec15b1b54 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
//===- StackSlots.cpp  - Specialize LLVM code for target machine ---------===//
//
// This pass adds 2 empty slots at the top of function stack.  These two slots
// are later used during code reoptimization for spilling the register values
// when rewriting branches.
//
//===----------------------------------------------------------------------===//

#include "llvm/CodeGen/StackSlots.h"
#include "llvm/Target/TargetMachine.h"
#include "llvm/Target/MachineInstrInfo.h"
#include "llvm/Constant.h"
#include "llvm/Function.h"
#include "llvm/DerivedTypes.h"
#include "llvm/Pass.h"
#include "llvm/CodeGen/MachineFunction.h"

class StackSlots : public FunctionPass {
  const TargetMachine &Target;
public:
  StackSlots (const TargetMachine &T) : Target(T) {}

  const char *getPassName() const {
    return "Stack Slot Insertion for profiling code";
  }

  virtual void getAnalysisUsage(AnalysisUsage &AU) const {
    AU.setPreservesCFG();
  }

  bool runOnFunction(Function &F) {
    const Type *PtrInt = PointerType::get(Type::IntTy);
    unsigned Size = Target.DataLayout.getTypeSize(PtrInt);

    MachineFunction &mcInfo = MachineFunction::get(&F);
    Value *V = Constant::getNullValue(Type::IntTy);
    mcInfo.allocateLocalVar(Target, V, 2*Size);
    return true;
  }
};

Pass *createStackSlotsPass(const TargetMachine &Target) {
  return new StackSlots(Target);
}