blob: 205e87876894b505edf7dfa7a8a6375a84d2e29b [file] [log] [blame]
Akira Hatanaka0bf3dfb2011-04-15 21:00:26 +00001//===-- llvm/Target/MipsTargetObjectFile.h - Mips Object Info --*- C++ -*-===//
Chris Lattnerb71b9092009-08-13 06:28:06 +00002//
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//
Akira Hatanaka0bf3dfb2011-04-15 21:00:26 +00008//===---------------------------------------------------------------------===//
Chris Lattnerb71b9092009-08-13 06:28:06 +00009
10#ifndef LLVM_TARGET_MIPS_TARGETOBJECTFILE_H
11#define LLVM_TARGET_MIPS_TARGETOBJECTFILE_H
12
Anton Korobeynikov362dd0b2010-02-15 22:37:53 +000013#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
Chris Lattnerb71b9092009-08-13 06:28:06 +000014
15namespace llvm {
16
17 class MipsTargetObjectFile : public TargetLoweringObjectFileELF {
18 const MCSection *SmallDataSection;
19 const MCSection *SmallBSSSection;
20 public:
Bruno Cardoso Lopes81092dc2011-03-04 17:51:39 +000021
Chris Lattnerb71b9092009-08-13 06:28:06 +000022 void Initialize(MCContext &Ctx, const TargetMachine &TM);
23
Bruno Cardoso Lopes81092dc2011-03-04 17:51:39 +000024
Chris Lattnerb71b9092009-08-13 06:28:06 +000025 /// IsGlobalInSmallSection - Return true if this global address should be
26 /// placed into small data/bss section.
27 bool IsGlobalInSmallSection(const GlobalValue *GV,
Akira Hatanaka0bf3dfb2011-04-15 21:00:26 +000028 const TargetMachine &TM,
29 SectionKind Kind) const;
Chris Lattnerb71b9092009-08-13 06:28:06 +000030 bool IsGlobalInSmallSection(const GlobalValue *GV,
Bruno Cardoso Lopes81092dc2011-03-04 17:51:39 +000031 const TargetMachine &TM) const;
32
Chris Lattnerb71b9092009-08-13 06:28:06 +000033 const MCSection *SelectSectionForGlobal(const GlobalValue *GV,
34 SectionKind Kind,
35 Mangler *Mang,
36 const TargetMachine &TM) const;
Bruno Cardoso Lopes81092dc2011-03-04 17:51:39 +000037
Chris Lattnerb71b9092009-08-13 06:28:06 +000038 // TODO: Classify globals as mips wishes.
39 };
40} // end namespace llvm
41
42#endif