Enable emitting of constant values in non-default address space as well. The APIs...
[oota-llvm.git] / lib / Target / PIC16 / PIC16TargetAsmInfo.cpp
1 //===-- PIC16TargetAsmInfo.cpp - PIC16 asm properties ---------------------===//
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 declarations of the PIC16TargetAsmInfo properties.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "PIC16TargetAsmInfo.h"
15 #include "PIC16TargetMachine.h"
16 #include "llvm/GlobalValue.h"
17
18 using namespace llvm;
19
20 PIC16TargetAsmInfo::
21 PIC16TargetAsmInfo(const PIC16TargetMachine &TM) 
22   : TargetAsmInfo(TM) {
23   CommentString = ";";
24   Data8bitsDirective = " db ";
25   Data16bitsDirective = " dw ";
26   Data32bitsDirective = " dl ";
27   RomData8bitsDirective = " dw ";
28   RomData16bitsDirective = " rom_di ";
29   RomData8bitsDirective = " rom_dl ";
30   ZeroDirective = NULL;
31   AsciiDirective = " dt ";
32   AscizDirective = NULL;
33   BSSSection_  = getNamedSection("udata.# UDATA",
34                               SectionFlags::Writeable | SectionFlags::BSS);
35   ReadOnlySection = getNamedSection("romdata.# ROMDATA", SectionFlags::None);
36   DataSection = getNamedSection("idata.# IDATA", SectionFlags::Writeable);
37   SwitchToSectionDirective = "";
38 }
39
40 const char *PIC16TargetAsmInfo::getData8bitsDirective(unsigned AddrSpace)
41                                                        const {
42       if (AddrSpace == PIC16ISD::ROM_SPACE)
43         return RomData8bitsDirective;
44       else 
45         return Data8bitsDirective; 
46   }
47
48 const char *PIC16TargetAsmInfo::getData16bitsDirective(unsigned AddrSpace)
49                                                        const {
50       if (AddrSpace == PIC16ISD::ROM_SPACE)
51         return RomData16bitsDirective;
52       else
53         return Data16bitsDirective;
54   }
55
56 const char *PIC16TargetAsmInfo::getData32bitsDirective(unsigned AddrSpace)
57                                                        const {
58       if (AddrSpace == PIC16ISD::ROM_SPACE)
59         return RomData32bitsDirective;
60       else
61         return Data32bitsDirective;
62   }
63