MCSectionMachO.h revision ae7fb0b03ebc524e6c47f0262b8dc87810fee1a8
1//===- MCSectionMachO.h - MachO Machine Code Sections -----------*- 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 declares the MCSectionMachO class. 11// 12//===----------------------------------------------------------------------===// 13 14#ifndef LLVM_MC_MCSECTIONMACHO_H 15#define LLVM_MC_MCSECTIONMACHO_H 16 17#include "llvm/MC/MCSection.h" 18 19namespace llvm { 20 21/// MCSectionMachO - This represents a section on a Mach-O system (used by 22/// Mac OS X). On a Mac system, these are also described in 23/// /usr/include/mach-o/loader.h. 24class MCSectionMachO : public MCSection { 25 char SegmentName[16]; // Not necessarily null terminated! 26 char SectionName[16]; // Not necessarily null terminated! 27 28 /// TypeAndAttributes - This is the SECTION_TYPE and SECTION_ATTRIBUTES 29 /// field of a section, drawn from the enums below. 30 unsigned TypeAndAttributes; 31 32 /// Reserved2 - The 'reserved2' field of a section, used to represent the 33 /// size of stubs, for example. 34 unsigned Reserved2; 35 36 MCSectionMachO(StringRef Segment, StringRef Section, 37 unsigned TAA, unsigned reserved2, SectionKind K); 38 friend class MCContext; 39public: 40 41 /// These are the section type and attributes fields. A MachO section can 42 /// have only one Type, but can have any of the attributes specified. 43 enum { 44 // TypeAndAttributes bitmasks. 45 SECTION_TYPE = 0x000000FFU, 46 SECTION_ATTRIBUTES = 0xFFFFFF00U, 47 48 // Valid section types. 49 50 /// S_REGULAR - Regular section. 51 S_REGULAR = 0x00U, 52 /// S_ZEROFILL - Zero fill on demand section. 53 S_ZEROFILL = 0x01U, 54 /// S_CSTRING_LITERALS - Section with literal C strings. 55 S_CSTRING_LITERALS = 0x02U, 56 /// S_4BYTE_LITERALS - Section with 4 byte literals. 57 S_4BYTE_LITERALS = 0x03U, 58 /// S_8BYTE_LITERALS - Section with 8 byte literals. 59 S_8BYTE_LITERALS = 0x04U, 60 /// S_LITERAL_POINTERS - Section with pointers to literals. 61 S_LITERAL_POINTERS = 0x05U, 62 /// S_NON_LAZY_SYMBOL_POINTERS - Section with non-lazy symbol pointers. 63 S_NON_LAZY_SYMBOL_POINTERS = 0x06U, 64 /// S_LAZY_SYMBOL_POINTERS - Section with lazy symbol pointers. 65 S_LAZY_SYMBOL_POINTERS = 0x07U, 66 /// S_SYMBOL_STUBS - Section with symbol stubs, byte size of stub in 67 /// the Reserved2 field. 68 S_SYMBOL_STUBS = 0x08U, 69 /// S_SYMBOL_STUBS - Section with only function pointers for 70 /// initialization. 71 S_MOD_INIT_FUNC_POINTERS = 0x09U, 72 /// S_MOD_INIT_FUNC_POINTERS - Section with only function pointers for 73 /// termination. 74 S_MOD_TERM_FUNC_POINTERS = 0x0AU, 75 /// S_COALESCED - Section contains symbols that are to be coalesced. 76 S_COALESCED = 0x0BU, 77 /// S_GB_ZEROFILL - Zero fill on demand section (that can be larger than 4 78 /// gigabytes). 79 S_GB_ZEROFILL = 0x0CU, 80 /// S_INTERPOSING - Section with only pairs of function pointers for 81 /// interposing. 82 S_INTERPOSING = 0x0DU, 83 /// S_16BYTE_LITERALS - Section with only 16 byte literals. 84 S_16BYTE_LITERALS = 0x0EU, 85 /// S_DTRACE_DOF - Section contains DTrace Object Format. 86 S_DTRACE_DOF = 0x0FU, 87 /// S_LAZY_DYLIB_SYMBOL_POINTERS - Section with lazy symbol pointers to 88 /// lazy loaded dylibs. 89 S_LAZY_DYLIB_SYMBOL_POINTERS = 0x10U, 90 91 LAST_KNOWN_SECTION_TYPE = S_LAZY_DYLIB_SYMBOL_POINTERS, 92 93 94 // Valid section attributes. 95 96 /// S_ATTR_PURE_INSTRUCTIONS - Section contains only true machine 97 /// instructions. 98 S_ATTR_PURE_INSTRUCTIONS = 1U << 31, 99 /// S_ATTR_NO_TOC - Section contains coalesced symbols that are not to be 100 /// in a ranlib table of contents. 101 S_ATTR_NO_TOC = 1U << 30, 102 /// S_ATTR_STRIP_STATIC_SYMS - Ok to strip static symbols in this section 103 /// in files with the MY_DYLDLINK flag. 104 S_ATTR_STRIP_STATIC_SYMS = 1U << 29, 105 /// S_ATTR_NO_DEAD_STRIP - No dead stripping. 106 S_ATTR_NO_DEAD_STRIP = 1U << 28, 107 /// S_ATTR_LIVE_SUPPORT - Blocks are live if they reference live blocks. 108 S_ATTR_LIVE_SUPPORT = 1U << 27, 109 /// S_ATTR_SELF_MODIFYING_CODE - Used with i386 code stubs written on by 110 /// dyld. 111 S_ATTR_SELF_MODIFYING_CODE = 1U << 26, 112 /// S_ATTR_DEBUG - A debug section. 113 S_ATTR_DEBUG = 1U << 25, 114 /// S_ATTR_SOME_INSTRUCTIONS - Section contains some machine instructions. 115 S_ATTR_SOME_INSTRUCTIONS = 1U << 10, 116 /// S_ATTR_EXT_RELOC - Section has external relocation entries. 117 S_ATTR_EXT_RELOC = 1U << 9, 118 /// S_ATTR_LOC_RELOC - Section has local relocation entries. 119 S_ATTR_LOC_RELOC = 1U << 8 120 }; 121 122 StringRef getSegmentName() const { 123 // SegmentName is not necessarily null terminated! 124 if (SegmentName[15]) 125 return StringRef(SegmentName, 16); 126 return StringRef(SegmentName); 127 } 128 StringRef getSectionName() const { 129 // SectionName is not necessarily null terminated! 130 if (SectionName[15]) 131 return StringRef(SectionName, 16); 132 return StringRef(SectionName); 133 } 134 135 unsigned getTypeAndAttributes() const { return TypeAndAttributes; } 136 unsigned getStubSize() const { return Reserved2; } 137 138 unsigned getType() const { return TypeAndAttributes & SECTION_TYPE; } 139 bool hasAttribute(unsigned Value) const { 140 return (TypeAndAttributes & Value) != 0; 141 } 142 143 /// ParseSectionSpecifier - Parse the section specifier indicated by "Spec". 144 /// This is a string that can appear after a .section directive in a mach-o 145 /// flavored .s file. If successful, this fills in the specified Out 146 /// parameters and returns an empty string. When an invalid section 147 /// specifier is present, this returns a string indicating the problem. 148 static std::string ParseSectionSpecifier(StringRef Spec, // In. 149 StringRef &Segment, // Out. 150 StringRef &Section, // Out. 151 unsigned &TAA, // Out. 152 unsigned &StubSize); // Out. 153 154 virtual void PrintSwitchToSection(const MCAsmInfo &MAI, 155 raw_ostream &OS) const; 156}; 157 158} // end namespace llvm 159 160#endif 161