Adding the MicroBlaze backend.
[oota-llvm.git] / lib / Target / MBlaze / MBlazeTargetObjectFile.h
1 //===-- llvm/Target/MBlazeTargetObjectFile.h - MBlaze Obj. Info -*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 #ifndef LLVM_TARGET_MBLAZE_TARGETOBJECTFILE_H
11 #define LLVM_TARGET_MBLAZE_TARGETOBJECTFILE_H
12
13 #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
14
15 namespace llvm {
16
17   class MBlazeTargetObjectFile : public TargetLoweringObjectFileELF {
18     const MCSection *SmallDataSection;
19     const MCSection *SmallBSSSection;
20   public:
21     
22     void Initialize(MCContext &Ctx, const TargetMachine &TM);
23
24     
25     /// IsGlobalInSmallSection - Return true if this global address should be
26     /// placed into small data/bss section.
27     bool IsGlobalInSmallSection(const GlobalValue *GV,
28                                 const TargetMachine &TM,
29                                 SectionKind Kind) const;
30
31     bool IsGlobalInSmallSection(const GlobalValue *GV,
32                                 const TargetMachine &TM) const;  
33     
34     const MCSection *SelectSectionForGlobal(const GlobalValue *GV,
35                                             SectionKind Kind,
36                                             Mangler *Mang,
37                                             const TargetMachine &TM) const;
38   };
39 } // end namespace llvm
40
41 #endif