blob: 92116afc8a7061a1ee4bd399d3713c9a6c1903e5 [file] [log] [blame]
Sanjiv Gupta4394c232008-05-13 09:02:57 +00001//=====-- PIC16TargetAsmInfo.h - PIC16 asm properties ---------*- 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// This file contains the declaration of the PIC16TargetAsmInfo class.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef PIC16TARGETASMINFO_H
15#define PIC16TARGETASMINFO_H
16
Sanjiv Gupta960ae062009-05-06 08:02:01 +000017#include "PIC16.h"
Sanjiv Gupta4394c232008-05-13 09:02:57 +000018#include "llvm/Target/TargetAsmInfo.h"
Sanjiv Gupta960ae062009-05-06 08:02:01 +000019#include <vector>
20#include "llvm/Module.h"
21#define DataBankSize 80
Sanjiv Gupta4394c232008-05-13 09:02:57 +000022namespace llvm {
23
24 // Forward declaration.
25 class PIC16TargetMachine;
Sanjiv Gupta960ae062009-05-06 08:02:01 +000026 class GlobalVariable;
Sanjiv Gupta4394c232008-05-13 09:02:57 +000027
Sanjiv Gupta960ae062009-05-06 08:02:01 +000028 // PIC16 Splits the global data into mulitple udata and idata sections.
29 // Each udata and idata section needs to contain a list of globals that
30 // they contain, in order to avoid scanning over all the global values
31 // again and printing only those that match the current section.
32 // Keeping values inside the sections make printing a section much easier.
33 struct PIC16Section {
34 const Section *S_; // Connection to actual Section.
35 unsigned Size; // Total size of the objects contained.
Sanjiv Gupta7607eba2009-06-09 15:31:19 +000036 bool SectionPrinted;
Sanjiv Gupta960ae062009-05-06 08:02:01 +000037 std::vector<const GlobalVariable*> Items;
38
Sanjiv Gupta7607eba2009-06-09 15:31:19 +000039 PIC16Section (const Section *s) { S_ = s; Size = 0;
40 SectionPrinted = false;}
41 bool isPrinted() { return SectionPrinted ; }
42 void setPrintedStatus(bool status) { SectionPrinted = status ;}
Sanjiv Gupta960ae062009-05-06 08:02:01 +000043 };
44
Sanjiv Gupta4394c232008-05-13 09:02:57 +000045 struct PIC16TargetAsmInfo : public TargetAsmInfo {
Sanjiv Gupta960ae062009-05-06 08:02:01 +000046 std::string getSectionNameForSym(const std::string &Sym) const;
Sanjiv Gupta4394c232008-05-13 09:02:57 +000047 PIC16TargetAsmInfo(const PIC16TargetMachine &TM);
Sanjiv Gupta960ae062009-05-06 08:02:01 +000048 mutable std::vector<PIC16Section *> BSSSections;
49 mutable std::vector<PIC16Section *> IDATASections;
Sanjiv Gupta83adfb42009-05-12 17:07:27 +000050 mutable std::vector<PIC16Section *> AutosSections;
Sanjiv Guptab89d3db2009-07-06 10:18:37 +000051 mutable std::vector<PIC16Section *> ROSections;
Sanjiv Gupta4a71ae22009-05-13 15:13:17 +000052 mutable PIC16Section *ExternalVarDecls;
53 mutable PIC16Section *ExternalVarDefs;
Sanjiv Gupta258f8512009-05-10 05:23:47 +000054 virtual ~PIC16TargetAsmInfo();
55
56 private:
Sanjiv Gupta964a29f2009-01-30 04:25:10 +000057 const char *RomData8bitsDirective;
58 const char *RomData16bitsDirective;
59 const char *RomData32bitsDirective;
Sanjiv Gupta50aeb122009-02-02 16:53:06 +000060 const char *getRomDirective(unsigned size) const;
Chris Lattnerd2905432009-07-20 17:12:46 +000061 virtual const char *getDataASDirective(unsigned size, unsigned AS) const;
Sanjiv Gupta960ae062009-05-06 08:02:01 +000062 const Section *getBSSSectionForGlobal(const GlobalVariable *GV) const;
63 const Section *getIDATASectionForGlobal(const GlobalVariable *GV) const;
Sanjiv Gupta83adfb42009-05-12 17:07:27 +000064 const Section *getSectionForAuto(const GlobalVariable *GV) const;
Sanjiv Guptab89d3db2009-07-06 10:18:37 +000065 const Section *CreateBSSSectionForGlobal(const GlobalVariable *GV,
66 std::string Addr = "") const;
67 const Section *CreateIDATASectionForGlobal(const GlobalVariable *GV,
68 std::string Addr = "") const;
69 const Section *getROSectionForGlobal(const GlobalVariable *GV) const;
70 const Section *CreateROSectionForGlobal(const GlobalVariable *GV,
71 std::string Addr = "") const;
Sanjiv Gupta960ae062009-05-06 08:02:01 +000072 virtual const Section *SelectSectionForGlobal(const GlobalValue *GV) const;
Sanjiv Guptab89d3db2009-07-06 10:18:37 +000073 const Section * CreateSectionForGlobal(const GlobalValue *GV,
74 std::string Addr = "") const;
Sanjiv Gupta960ae062009-05-06 08:02:01 +000075 public:
76 void SetSectionForGVs(Module &M);
77 std::vector<PIC16Section *> getBSSSections() const {
78 return BSSSections;
79 }
80 std::vector<PIC16Section *> getIDATASections() const {
81 return IDATASections;
82 }
Sanjiv Gupta83adfb42009-05-12 17:07:27 +000083 std::vector<PIC16Section *> getAutosSections() const {
84 return AutosSections;
85 }
Sanjiv Guptab89d3db2009-07-06 10:18:37 +000086 std::vector<PIC16Section *> getROSections() const {
87 return ROSections;
88 }
89 virtual const Section* SectionForGlobal(const GlobalValue *GV) const;
Sanjiv Gupta4394c232008-05-13 09:02:57 +000090 };
91
92} // namespace llvm
93
94#endif