summaryrefslogtreecommitdiffstats
path: root/lib/Target/PIC16/MCSectionPIC16.h
blob: 352be99d71c2f2a7ee44728f45715c1fbc484237 (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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
//===- MCSectionPIC16.h - PIC16-specific section representation -*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file declares the MCSectionPIC16 class.
//
//===----------------------------------------------------------------------===//

#ifndef LLVM_PIC16SECTION_H
#define LLVM_PIC16SECTION_H

#include "llvm/MC/MCSection.h"

namespace llvm {

  /// MCSectionPIC16 - Represents a physical section in PIC16 COFF.
  /// Contains data objects.
  ///
  class MCSectionPIC16 : public MCSection {
    /// Name of the section to uniquely identify it.
    std::string Name;

    /// User can specify an address at which a section should be placed. 
    /// Negative value here means user hasn't specified any. 
    int Address; 

    /// Overlay information - Sections with same color can be overlaid on
    /// one another.
    int Color; 

    /// Conatined data objects.
    std::vector<const GlobalVariable *>Items;

    /// Total size of all data objects contained here.
    unsigned Size;
    
    MCSectionPIC16(const StringRef &name, SectionKind K, int addr, int color)
      : MCSection(K), Name(name), Address(addr), Color(color) {
    }
    
  public:
    /// Return the name of the section.
    const std::string &getName() const { return Name; }

    /// Return the Address of the section.
    int getAddress() const { return Address; }

    /// Return the Color of the section.
    int getColor() const { return Color; }

    /// PIC16 Terminology for section kinds is as below.
    /// UDATA - BSS
    /// IDATA - initialized data (equiv to Metadata) 
    /// ROMDATA - ReadOnly.
    /// UDATA_OVR - Sections that can be overlaid. Section of such type is
    ///             used to contain function autos an frame. We can think of
    ///             it as equiv to llvm ThreadBSS)
    /// So, let's have some convenience functions to Map PIC16 Section types 
    /// to SectionKind just for the sake of better readability.
    static SectionKind UDATA_Kind() { return SectionKind::getBSS(); } 
    static SectionKind IDATA_Kind() { return SectionKind::getMetadata(); }
    static SectionKind ROMDATA_Kind() { return SectionKind::getReadOnly(); }
    static SectionKind UDATA_OVR_Kind() { return SectionKind::getThreadBSS(); }

    // If we could just do getKind() == UDATA_Kind() ?
    bool isUDATA_Kind() { return getKind().isBSS(); }
    bool isIDATA_Kind() { return getKind().isMetadata(); }
    bool isROMDATA_Kind() { return getKind().isMetadata(); }
    bool isUDATA_OVR_Kind() { return getKind().isThreadBSS(); }

    /// This would be the only way to create a section. 
    static MCSectionPIC16 *Create(const StringRef &Name, SectionKind K, 
                                  int Address, int Color, MCContext &Ctx);
    
    /// Override this as PIC16 has its own way of printing switching
    /// to a section.
    virtual void PrintSwitchToSection(const MCAsmInfo &MAI,
                                      raw_ostream &OS) const;
  };

} // end namespace llvm

#endif
OpenPOWER on IntegriCloud