| Jim Laskey | 0e83541 | 2006-09-07 22:05:02 +0000 | [diff] [blame] | 1 | //===-- PPCTargetAsmInfo.cpp - PPC asm properties ---------------*- C++ -*-===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
| Chris Lattner | f3ebc3f | 2007-12-29 20:36:04 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
| Jim Laskey | 0e83541 | 2006-09-07 22:05:02 +0000 | [diff] [blame] | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file contains the declarations of the DarwinTargetAsmInfo properties. | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 |  | 
|  | 14 | #include "PPCTargetAsmInfo.h" | 
|  | 15 | #include "PPCTargetMachine.h" | 
| Chris Lattner | 0d23645 | 2006-10-05 00:35:50 +0000 | [diff] [blame] | 16 | #include "llvm/Function.h" | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 17 | #include "llvm/Support/Dwarf.h" | 
|  | 18 |  | 
| Jim Laskey | 0e83541 | 2006-09-07 22:05:02 +0000 | [diff] [blame] | 19 | using namespace llvm; | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 20 | using namespace llvm::dwarf; | 
| Jim Laskey | 0e83541 | 2006-09-07 22:05:02 +0000 | [diff] [blame] | 21 |  | 
| Anton Korobeynikov | 5b5d8bc | 2008-08-08 18:23:25 +0000 | [diff] [blame] | 22 | PPCDarwinTargetAsmInfo::PPCDarwinTargetAsmInfo(const PPCTargetMachine &TM): | 
| Anton Korobeynikov | 87001fd | 2008-09-25 21:00:33 +0000 | [diff] [blame] | 23 | PPCTargetAsmInfo<DarwinTargetAsmInfo>(TM) { | 
| Jim Laskey | c3de9b4 | 2007-02-01 16:31:34 +0000 | [diff] [blame] | 24 | PCSymbol = "."; | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 25 | CommentString = ";"; | 
|  | 26 | GlobalPrefix = "_"; | 
|  | 27 | PrivateGlobalPrefix = "L"; | 
| Dale Johannesen | f080225 | 2008-09-09 01:21:22 +0000 | [diff] [blame] | 28 | LessPrivateGlobalPrefix = "l"; | 
| Dale Johannesen | 355b74a | 2008-06-03 18:09:06 +0000 | [diff] [blame] | 29 | StringConstantPrefix = "\1LC"; | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 30 | ConstantPoolSection = "\t.const\t"; | 
|  | 31 | JumpTableDataSection = ".const"; | 
|  | 32 | CStringSection = "\t.cstring"; | 
| Evan Cheng | 0e083d0 | 2007-01-30 08:04:53 +0000 | [diff] [blame] | 33 | if (TM.getRelocationModel() == Reloc::Static) { | 
|  | 34 | StaticCtorsSection = ".constructor"; | 
|  | 35 | StaticDtorsSection = ".destructor"; | 
|  | 36 | } else { | 
|  | 37 | StaticCtorsSection = ".mod_init_func"; | 
|  | 38 | StaticDtorsSection = ".mod_term_func"; | 
|  | 39 | } | 
| Rafael Espindola | cda011b | 2008-12-03 11:01:37 +0000 | [diff] [blame] | 40 | HasSingleParameterDotFile = false; | 
| Dale Johannesen | 59a2250 | 2008-01-15 23:24:56 +0000 | [diff] [blame] | 41 | SwitchToSectionDirective = "\t.section "; | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 42 | UsedDirective = "\t.no_dead_strip\t"; | 
| Dale Johannesen | 7ecb3b7 | 2008-01-10 02:03:30 +0000 | [diff] [blame] | 43 | WeakDefDirective = "\t.weak_definition "; | 
|  | 44 | WeakRefDirective = "\t.weak_reference "; | 
| Dale Johannesen | 2ff66f0 | 2008-01-11 00:54:37 +0000 | [diff] [blame] | 45 | HiddenDirective = "\t.private_extern "; | 
| Dale Johannesen | eadbf4b | 2007-12-19 21:54:36 +0000 | [diff] [blame] | 46 | SupportsExceptionHandling = true; | 
| Bill Wendling | 66c22e8 | 2007-09-11 23:55:40 +0000 | [diff] [blame] | 47 | NeedsIndirectEncoding = true; | 
| Nicolas Geoffray | 80c741e | 2007-12-21 12:19:44 +0000 | [diff] [blame] | 48 | NeedsSet = true; | 
| Nick Lewycky | d954dcd | 2007-11-04 17:32:10 +0000 | [diff] [blame] | 49 | BSSSection = 0; | 
| Nicolas Geoffray | 80c741e | 2007-12-21 12:19:44 +0000 | [diff] [blame] | 50 |  | 
|  | 51 | DwarfEHFrameSection = | 
|  | 52 | ".section __TEXT,__eh_frame,coalesced,no_toc+strip_static_syms+live_support"; | 
|  | 53 | DwarfExceptionSection = ".section __DATA,__gcc_except_tab"; | 
| Dale Johannesen | 7ecb3b7 | 2008-01-10 02:03:30 +0000 | [diff] [blame] | 54 | GlobalEHDirective = "\t.globl\t"; | 
|  | 55 | SupportsWeakOmittedEHFrame = false; | 
| Nick Lewycky | 5805c46 | 2007-07-25 03:48:45 +0000 | [diff] [blame] | 56 |  | 
|  | 57 | DwarfAbbrevSection = ".section __DWARF,__debug_abbrev,regular,debug"; | 
|  | 58 | DwarfInfoSection = ".section __DWARF,__debug_info,regular,debug"; | 
|  | 59 | DwarfLineSection = ".section __DWARF,__debug_line,regular,debug"; | 
|  | 60 | DwarfFrameSection = ".section __DWARF,__debug_frame,regular,debug"; | 
|  | 61 | DwarfPubNamesSection = ".section __DWARF,__debug_pubnames,regular,debug"; | 
|  | 62 | DwarfPubTypesSection = ".section __DWARF,__debug_pubtypes,regular,debug"; | 
|  | 63 | DwarfStrSection = ".section __DWARF,__debug_str,regular,debug"; | 
|  | 64 | DwarfLocSection = ".section __DWARF,__debug_loc,regular,debug"; | 
|  | 65 | DwarfARangesSection = ".section __DWARF,__debug_aranges,regular,debug"; | 
|  | 66 | DwarfRangesSection = ".section __DWARF,__debug_ranges,regular,debug"; | 
|  | 67 | DwarfMacInfoSection = ".section __DWARF,__debug_macinfo,regular,debug"; | 
| Chris Lattner | c1ea85b | 2007-01-18 01:15:58 +0000 | [diff] [blame] | 68 |  | 
|  | 69 | // In non-PIC modes, emit a special label before jump tables so that the | 
|  | 70 | // linker can perform more accurate dead code stripping. | 
|  | 71 | if (TM.getRelocationModel() != Reloc::PIC_) { | 
|  | 72 | // Emit a local label that is preserved until the linker runs. | 
|  | 73 | JumpTableSpecialLabelPrefix = "l"; | 
|  | 74 | } | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 75 | } | 
|  | 76 |  | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 77 | /// PreferredEHDataFormat - This hook allows the target to select data | 
|  | 78 | /// format used for encoding pointers in exception handling data. Reason is | 
|  | 79 | /// 0 for data, 1 for code labels, 2 for function pointers. Global is true | 
|  | 80 | /// if the symbol can be relocated. | 
| Anton Korobeynikov | bc780e3 | 2008-07-19 21:44:57 +0000 | [diff] [blame] | 81 | unsigned | 
|  | 82 | PPCDarwinTargetAsmInfo::PreferredEHDataFormat(DwarfEncoding::Target Reason, | 
|  | 83 | bool Global) const { | 
| Anton Korobeynikov | 0e8b146 | 2008-02-29 22:09:08 +0000 | [diff] [blame] | 84 | if (Reason == DwarfEncoding::Functions && Global) | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 85 | return (DW_EH_PE_pcrel | DW_EH_PE_indirect | DW_EH_PE_sdata4); | 
| Anton Korobeynikov | 0e8b146 | 2008-02-29 22:09:08 +0000 | [diff] [blame] | 86 | else if (Reason == DwarfEncoding::CodeLabels || !Global) | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 87 | return DW_EH_PE_pcrel; | 
|  | 88 | else | 
|  | 89 | return DW_EH_PE_absptr; | 
|  | 90 | } | 
|  | 91 |  | 
| Rafael Espindola | 770b4b8 | 2008-12-19 10:55:56 +0000 | [diff] [blame] | 92 | const char * | 
|  | 93 | PPCDarwinTargetAsmInfo::getEHGlobalPrefix() const | 
|  | 94 | { | 
|  | 95 | const PPCSubtarget* Subtarget = &TM.getSubtarget<PPCSubtarget>(); | 
|  | 96 | if (Subtarget->getDarwinVers() > 9) | 
|  | 97 | return PrivateGlobalPrefix; | 
|  | 98 | else | 
|  | 99 | return ""; | 
|  | 100 | } | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 101 |  | 
| Anton Korobeynikov | c9ad17c | 2008-08-08 18:23:49 +0000 | [diff] [blame] | 102 | PPCLinuxTargetAsmInfo::PPCLinuxTargetAsmInfo(const PPCTargetMachine &TM) : | 
| Anton Korobeynikov | 87001fd | 2008-09-25 21:00:33 +0000 | [diff] [blame] | 103 | PPCTargetAsmInfo<ELFTargetAsmInfo>(TM) { | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 104 | CommentString = "#"; | 
|  | 105 | GlobalPrefix = ""; | 
| Rafael Espindola | 770b4b8 | 2008-12-19 10:55:56 +0000 | [diff] [blame] | 106 | PrivateGlobalPrefix = ".L"; | 
| Evan Cheng | 83af119 | 2008-02-12 19:25:12 +0000 | [diff] [blame] | 107 | ConstantPoolSection = "\t.section .rodata.cst4\t"; | 
|  | 108 | JumpTableDataSection = ".section .rodata.cst4"; | 
| Anton Korobeynikov | c3f3aea | 2008-08-16 12:58:46 +0000 | [diff] [blame] | 109 | CStringSection = ".rodata.str"; | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 110 | StaticCtorsSection = ".section\t.ctors,\"aw\",@progbits"; | 
|  | 111 | StaticDtorsSection = ".section\t.dtors,\"aw\",@progbits"; | 
|  | 112 | UsedDirective = "\t# .no_dead_strip\t"; | 
|  | 113 | WeakRefDirective = "\t.weak\t"; | 
| Nick Lewycky | d954dcd | 2007-11-04 17:32:10 +0000 | [diff] [blame] | 114 | BSSSection = "\t.section\t\".sbss\",\"aw\",@nobits"; | 
| Nick Lewycky | 5805c46 | 2007-07-25 03:48:45 +0000 | [diff] [blame] | 115 |  | 
| Anton Korobeynikov | 16d5d3f | 2008-08-16 12:59:02 +0000 | [diff] [blame] | 116 | // PPC/Linux normally uses named section for BSS. | 
|  | 117 | BSSSection_  = getNamedSection("\t.bss", | 
|  | 118 | SectionFlags::Writeable | SectionFlags::BSS, | 
|  | 119 | /* Override */ true); | 
|  | 120 |  | 
| Nicolas Geoffray | 80c741e | 2007-12-21 12:19:44 +0000 | [diff] [blame] | 121 | // Debug Information | 
|  | 122 | AbsoluteDebugSectionOffsets = true; | 
|  | 123 | SupportsDebugInformation = true; | 
| Nick Lewycky | 5805c46 | 2007-07-25 03:48:45 +0000 | [diff] [blame] | 124 | DwarfAbbrevSection =  "\t.section\t.debug_abbrev,\"\",@progbits"; | 
|  | 125 | DwarfInfoSection =    "\t.section\t.debug_info,\"\",@progbits"; | 
|  | 126 | DwarfLineSection =    "\t.section\t.debug_line,\"\",@progbits"; | 
|  | 127 | DwarfFrameSection =   "\t.section\t.debug_frame,\"\",@progbits"; | 
|  | 128 | DwarfPubNamesSection ="\t.section\t.debug_pubnames,\"\",@progbits"; | 
|  | 129 | DwarfPubTypesSection ="\t.section\t.debug_pubtypes,\"\",@progbits"; | 
|  | 130 | DwarfStrSection =     "\t.section\t.debug_str,\"\",@progbits"; | 
|  | 131 | DwarfLocSection =     "\t.section\t.debug_loc,\"\",@progbits"; | 
|  | 132 | DwarfARangesSection = "\t.section\t.debug_aranges,\"\",@progbits"; | 
|  | 133 | DwarfRangesSection =  "\t.section\t.debug_ranges,\"\",@progbits"; | 
|  | 134 | DwarfMacInfoSection = "\t.section\t.debug_macinfo,\"\",@progbits"; | 
| Nicolas Geoffray | 80c741e | 2007-12-21 12:19:44 +0000 | [diff] [blame] | 135 |  | 
| Nicolas Geoffray | 80c741e | 2007-12-21 12:19:44 +0000 | [diff] [blame] | 136 | PCSymbol = "."; | 
|  | 137 |  | 
|  | 138 | // Set up DWARF directives | 
|  | 139 | HasLEB128 = true;  // Target asm supports leb128 directives (little-endian) | 
|  | 140 |  | 
|  | 141 | // Exceptions handling | 
|  | 142 | if (!TM.getSubtargetImpl()->isPPC64()) | 
|  | 143 | SupportsExceptionHandling = true; | 
|  | 144 | AbsoluteEHSectionOffsets = false; | 
|  | 145 | DwarfEHFrameSection = "\t.section\t.eh_frame,\"aw\",@progbits"; | 
|  | 146 | DwarfExceptionSection = "\t.section\t.gcc_except_table,\"a\",@progbits"; | 
| Jim Laskey | 28663c7 | 2006-12-21 20:26:09 +0000 | [diff] [blame] | 147 | } | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 148 |  | 
|  | 149 | /// PreferredEHDataFormat - This hook allows the target to select data | 
|  | 150 | /// format used for encoding pointers in exception handling data. Reason is | 
|  | 151 | /// 0 for data, 1 for code labels, 2 for function pointers. Global is true | 
|  | 152 | /// if the symbol can be relocated. | 
| Anton Korobeynikov | bc780e3 | 2008-07-19 21:44:57 +0000 | [diff] [blame] | 153 | unsigned | 
|  | 154 | PPCLinuxTargetAsmInfo::PreferredEHDataFormat(DwarfEncoding::Target Reason, | 
|  | 155 | bool Global) const { | 
| Anton Korobeynikov | d73396b | 2008-02-27 23:49:15 +0000 | [diff] [blame] | 156 | // We really need to write something here. | 
|  | 157 | return TargetAsmInfo::PreferredEHDataFormat(Reason, Global); | 
|  | 158 | } | 
| Anton Korobeynikov | d2aded0 | 2008-10-05 08:53:29 +0000 | [diff] [blame] | 159 |  | 
|  | 160 | // Instantiate default implementation. | 
|  | 161 | TEMPLATE_INSTANTIATION(class PPCTargetAsmInfo<TargetAsmInfo>); |