2017-11-30 20:43:25 +08:00
|
|
|
//===-- MCObjectFileInfo.cpp - Object File Information --------------------===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2017-11-30 20:43:25 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "llvm/MC/MCObjectFileInfo.h"
|
|
|
|
#include "llvm/ADT/StringExtras.h"
|
|
|
|
#include "llvm/ADT/Triple.h"
|
|
|
|
#include "llvm/BinaryFormat/COFF.h"
|
|
|
|
#include "llvm/BinaryFormat/ELF.h"
|
|
|
|
#include "llvm/MC/MCAsmInfo.h"
|
|
|
|
#include "llvm/MC/MCContext.h"
|
|
|
|
#include "llvm/MC/MCSection.h"
|
|
|
|
#include "llvm/MC/MCSectionCOFF.h"
|
|
|
|
#include "llvm/MC/MCSectionELF.h"
|
|
|
|
#include "llvm/MC/MCSectionMachO.h"
|
|
|
|
#include "llvm/MC/MCSectionWasm.h"
|
2019-07-10 03:21:01 +08:00
|
|
|
#include "llvm/MC/MCSectionXCOFF.h"
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
static bool useCompactUnwind(const Triple &T) {
|
|
|
|
// Only on darwin.
|
|
|
|
if (!T.isOSDarwin())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// aarch64 always has it.
|
2019-09-12 18:22:23 +08:00
|
|
|
if (T.getArch() == Triple::aarch64 || T.getArch() == Triple::aarch64_32)
|
2017-11-30 20:43:25 +08:00
|
|
|
return true;
|
|
|
|
|
|
|
|
// armv7k always has it.
|
|
|
|
if (T.isWatchABI())
|
|
|
|
return true;
|
|
|
|
|
|
|
|
// Use it on newer version of OS X.
|
|
|
|
if (T.isMacOSX() && !T.isMacOSXVersionLT(10, 6))
|
|
|
|
return true;
|
|
|
|
|
|
|
|
// And the iOS simulator.
|
2020-01-07 17:32:39 +08:00
|
|
|
if (T.isiOS() && T.isX86())
|
2017-11-30 20:43:25 +08:00
|
|
|
return true;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void MCObjectFileInfo::initMachOMCObjectFileInfo(const Triple &T) {
|
|
|
|
// MachO
|
|
|
|
SupportsWeakOmittedEHFrame = false;
|
|
|
|
|
|
|
|
EHFrameSection = Ctx->getMachOSection(
|
|
|
|
"__TEXT", "__eh_frame",
|
|
|
|
MachO::S_COALESCED | MachO::S_ATTR_NO_TOC |
|
|
|
|
MachO::S_ATTR_STRIP_STATIC_SYMS | MachO::S_ATTR_LIVE_SUPPORT,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
|
2019-09-12 18:22:23 +08:00
|
|
|
if (T.isOSDarwin() &&
|
|
|
|
(T.getArch() == Triple::aarch64 || T.getArch() == Triple::aarch64_32))
|
2017-11-30 20:43:25 +08:00
|
|
|
SupportsCompactUnwindWithoutEHFrame = true;
|
|
|
|
|
|
|
|
if (T.isWatchABI())
|
|
|
|
OmitDwarfIfHaveCompactUnwind = true;
|
|
|
|
|
[MC] Move EH DWARF encodings from MC to CodeGen, NFC
Summary:
The TType encoding, LSDA encoding, and personality encoding are all
passed explicitly by CodeGen to the assembler through .cfi_* directives,
so only the AsmPrinter needs to know about them.
The FDE CFI encoding however, controls the encoding of the label
implicitly created by the .cfi_startproc directive. That directive seems
to be special in that it doesn't take an encoding, so the assembler just
has to know how to encode one DSO-local label reference from .eh_frame
to .text.
As a result, it looks like MC will continue to have to know when the
large code model is in use. Perhaps we could invent a '.cfi_startproc
[large]' flag so that this knowledge doesn't need to pollute the
assembler.
Reviewers: davide, lliu0, JDevlieghere
Subscribers: hiraditya, fedor.sergeev, llvm-commits
Differential Revision: https://reviews.llvm.org/D50533
llvm-svn: 339397
2018-08-10 06:24:04 +08:00
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_pcrel;
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
// .comm doesn't support alignment before Leopard.
|
|
|
|
if (T.isMacOSX() && T.isMacOSXVersionLT(10, 5))
|
|
|
|
CommDirectiveSupportsAlignment = false;
|
|
|
|
|
|
|
|
TextSection // .text
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__text",
|
|
|
|
MachO::S_ATTR_PURE_INSTRUCTIONS,
|
|
|
|
SectionKind::getText());
|
|
|
|
DataSection // .data
|
|
|
|
= Ctx->getMachOSection("__DATA", "__data", 0, SectionKind::getData());
|
|
|
|
|
|
|
|
// BSSSection might not be expected initialized on msvc.
|
|
|
|
BSSSection = nullptr;
|
|
|
|
|
|
|
|
TLSDataSection // .tdata
|
|
|
|
= Ctx->getMachOSection("__DATA", "__thread_data",
|
|
|
|
MachO::S_THREAD_LOCAL_REGULAR,
|
|
|
|
SectionKind::getData());
|
|
|
|
TLSBSSSection // .tbss
|
|
|
|
= Ctx->getMachOSection("__DATA", "__thread_bss",
|
|
|
|
MachO::S_THREAD_LOCAL_ZEROFILL,
|
|
|
|
SectionKind::getThreadBSS());
|
|
|
|
|
|
|
|
// TODO: Verify datarel below.
|
|
|
|
TLSTLVSection // .tlv
|
|
|
|
= Ctx->getMachOSection("__DATA", "__thread_vars",
|
|
|
|
MachO::S_THREAD_LOCAL_VARIABLES,
|
|
|
|
SectionKind::getData());
|
|
|
|
|
|
|
|
TLSThreadInitSection = Ctx->getMachOSection(
|
|
|
|
"__DATA", "__thread_init", MachO::S_THREAD_LOCAL_INIT_FUNCTION_POINTERS,
|
|
|
|
SectionKind::getData());
|
|
|
|
|
|
|
|
CStringSection // .cstring
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__cstring",
|
|
|
|
MachO::S_CSTRING_LITERALS,
|
|
|
|
SectionKind::getMergeable1ByteCString());
|
|
|
|
UStringSection
|
|
|
|
= Ctx->getMachOSection("__TEXT","__ustring", 0,
|
|
|
|
SectionKind::getMergeable2ByteCString());
|
|
|
|
FourByteConstantSection // .literal4
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__literal4",
|
|
|
|
MachO::S_4BYTE_LITERALS,
|
|
|
|
SectionKind::getMergeableConst4());
|
|
|
|
EightByteConstantSection // .literal8
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__literal8",
|
|
|
|
MachO::S_8BYTE_LITERALS,
|
|
|
|
SectionKind::getMergeableConst8());
|
|
|
|
|
|
|
|
SixteenByteConstantSection // .literal16
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__literal16",
|
|
|
|
MachO::S_16BYTE_LITERALS,
|
|
|
|
SectionKind::getMergeableConst16());
|
|
|
|
|
|
|
|
ReadOnlySection // .const
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__const", 0,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
|
|
|
|
// If the target is not powerpc, map the coal sections to the non-coal
|
|
|
|
// sections.
|
|
|
|
//
|
|
|
|
// "__TEXT/__textcoal_nt" => section "__TEXT/__text"
|
|
|
|
// "__TEXT/__const_coal" => section "__TEXT/__const"
|
|
|
|
// "__DATA/__datacoal_nt" => section "__DATA/__data"
|
|
|
|
Triple::ArchType ArchTy = T.getArch();
|
|
|
|
|
2018-04-11 04:16:35 +08:00
|
|
|
ConstDataSection // .const_data
|
|
|
|
= Ctx->getMachOSection("__DATA", "__const", 0,
|
|
|
|
SectionKind::getReadOnlyWithRel());
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
if (ArchTy == Triple::ppc || ArchTy == Triple::ppc64) {
|
|
|
|
TextCoalSection
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__textcoal_nt",
|
|
|
|
MachO::S_COALESCED |
|
|
|
|
MachO::S_ATTR_PURE_INSTRUCTIONS,
|
|
|
|
SectionKind::getText());
|
|
|
|
ConstTextCoalSection
|
|
|
|
= Ctx->getMachOSection("__TEXT", "__const_coal",
|
|
|
|
MachO::S_COALESCED,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
DataCoalSection = Ctx->getMachOSection(
|
|
|
|
"__DATA", "__datacoal_nt", MachO::S_COALESCED, SectionKind::getData());
|
2018-04-11 04:16:35 +08:00
|
|
|
ConstDataCoalSection = DataCoalSection;
|
2017-11-30 20:43:25 +08:00
|
|
|
} else {
|
|
|
|
TextCoalSection = TextSection;
|
|
|
|
ConstTextCoalSection = ReadOnlySection;
|
|
|
|
DataCoalSection = DataSection;
|
2018-04-11 04:16:35 +08:00
|
|
|
ConstDataCoalSection = ConstDataSection;
|
2017-11-30 20:43:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
DataCommonSection
|
|
|
|
= Ctx->getMachOSection("__DATA","__common",
|
|
|
|
MachO::S_ZEROFILL,
|
|
|
|
SectionKind::getBSS());
|
|
|
|
DataBSSSection
|
|
|
|
= Ctx->getMachOSection("__DATA","__bss", MachO::S_ZEROFILL,
|
|
|
|
SectionKind::getBSS());
|
|
|
|
|
|
|
|
|
|
|
|
LazySymbolPointerSection
|
|
|
|
= Ctx->getMachOSection("__DATA", "__la_symbol_ptr",
|
|
|
|
MachO::S_LAZY_SYMBOL_POINTERS,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
NonLazySymbolPointerSection
|
|
|
|
= Ctx->getMachOSection("__DATA", "__nl_symbol_ptr",
|
|
|
|
MachO::S_NON_LAZY_SYMBOL_POINTERS,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
|
|
|
ThreadLocalPointerSection
|
|
|
|
= Ctx->getMachOSection("__DATA", "__thread_ptr",
|
|
|
|
MachO::S_THREAD_LOCAL_VARIABLE_POINTERS,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
|
|
|
// Exception Handling.
|
|
|
|
LSDASection = Ctx->getMachOSection("__TEXT", "__gcc_except_tab", 0,
|
|
|
|
SectionKind::getReadOnlyWithRel());
|
|
|
|
|
|
|
|
COFFDebugSymbolsSection = nullptr;
|
|
|
|
COFFDebugTypesSection = nullptr;
|
2017-12-14 06:33:58 +08:00
|
|
|
COFFGlobalTypeHashesSection = nullptr;
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
if (useCompactUnwind(T)) {
|
|
|
|
CompactUnwindSection =
|
|
|
|
Ctx->getMachOSection("__LD", "__compact_unwind", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
|
2020-01-07 17:32:39 +08:00
|
|
|
if (T.isX86())
|
2017-11-30 20:43:25 +08:00
|
|
|
CompactUnwindDwarfEHFrameOnly = 0x04000000; // UNWIND_X86_64_MODE_DWARF
|
2019-09-12 18:22:23 +08:00
|
|
|
else if (T.getArch() == Triple::aarch64 || T.getArch() == Triple::aarch64_32)
|
2017-11-30 20:43:25 +08:00
|
|
|
CompactUnwindDwarfEHFrameOnly = 0x03000000; // UNWIND_ARM64_MODE_DWARF
|
|
|
|
else if (T.getArch() == Triple::arm || T.getArch() == Triple::thumb)
|
|
|
|
CompactUnwindDwarfEHFrameOnly = 0x04000000; // UNWIND_ARM_MODE_DWARF
|
|
|
|
}
|
|
|
|
|
|
|
|
// Debug Information.
|
2018-04-04 22:42:14 +08:00
|
|
|
DwarfDebugNamesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_names", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "debug_names_begin");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfAccelNamesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__apple_names", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "names_begin");
|
|
|
|
DwarfAccelObjCSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__apple_objc", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "objc_begin");
|
|
|
|
// 16 character section limit...
|
|
|
|
DwarfAccelNamespaceSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__apple_namespac", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "namespac_begin");
|
|
|
|
DwarfAccelTypesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__apple_types", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "types_begin");
|
|
|
|
|
|
|
|
DwarfSwiftASTSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__swift_ast", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
|
|
|
DwarfAbbrevSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_abbrev", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_abbrev");
|
|
|
|
DwarfInfoSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_info", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_info");
|
|
|
|
DwarfLineSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_line", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_line");
|
2018-02-07 04:29:21 +08:00
|
|
|
DwarfLineStrSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_line_str", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_line_str");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfFrameSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_frame", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfPubNamesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_pubnames", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfPubTypesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_pubtypes", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfGnuPubNamesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_gnu_pubn", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfGnuPubTypesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_gnu_pubt", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfStrSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_str", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "info_string");
|
|
|
|
DwarfStrOffSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_str_offs", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_str_off");
|
2018-10-20 16:55:51 +08:00
|
|
|
DwarfAddrSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_addr", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_info");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfLocSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_loc", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_debug_loc");
|
2018-10-26 19:25:12 +08:00
|
|
|
DwarfLoclistsSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_loclists", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "section_debug_loc");
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfARangesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_aranges", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfRangesSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_ranges", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "debug_range");
|
2018-07-13 02:18:21 +08:00
|
|
|
DwarfRnglistsSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_rnglists", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "debug_range");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfMacinfoSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_macinfo", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "debug_macinfo");
|
2020-04-03 15:14:09 +08:00
|
|
|
DwarfMacroSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_macro", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata(), "debug_macro");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfDebugInlineSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_inlined", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfCUIndexSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_cu_index", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfTUIndexSection =
|
|
|
|
Ctx->getMachOSection("__DWARF", "__debug_tu_index", MachO::S_ATTR_DEBUG,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
StackMapSection = Ctx->getMachOSection("__LLVM_STACKMAPS", "__llvm_stackmaps",
|
|
|
|
0, SectionKind::getMetadata());
|
|
|
|
|
|
|
|
FaultMapSection = Ctx->getMachOSection("__LLVM_FAULTMAPS", "__llvm_faultmaps",
|
|
|
|
0, SectionKind::getMetadata());
|
|
|
|
|
2019-03-27 09:13:59 +08:00
|
|
|
RemarksSection = Ctx->getMachOSection(
|
|
|
|
"__LLVM", "__remarks", MachO::S_ATTR_DEBUG, SectionKind::getMetadata());
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
TLSExtraDataSection = TLSTLVSection;
|
|
|
|
}
|
|
|
|
|
|
|
|
void MCObjectFileInfo::initELFMCObjectFileInfo(const Triple &T, bool Large) {
|
|
|
|
switch (T.getArch()) {
|
|
|
|
case Triple::mips:
|
|
|
|
case Triple::mipsel:
|
|
|
|
case Triple::mips64:
|
|
|
|
case Triple::mips64el:
|
2020-01-12 18:55:15 +08:00
|
|
|
// We cannot use DW_EH_PE_sdata8 for the large PositionIndependent case
|
|
|
|
// since there is no R_MIPS_PC64 relocation (only a 32-bit version).
|
|
|
|
if (PositionIndependent && !Large)
|
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_pcrel | dwarf::DW_EH_PE_sdata4;
|
|
|
|
else
|
|
|
|
FDECFIEncoding = Ctx->getAsmInfo()->getCodePointerSize() == 4
|
|
|
|
? dwarf::DW_EH_PE_sdata4
|
|
|
|
: dwarf::DW_EH_PE_sdata8;
|
2017-11-30 20:43:25 +08:00
|
|
|
break;
|
2018-03-24 08:07:38 +08:00
|
|
|
case Triple::ppc64:
|
|
|
|
case Triple::ppc64le:
|
2017-11-30 20:43:25 +08:00
|
|
|
case Triple::x86_64:
|
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_pcrel |
|
|
|
|
(Large ? dwarf::DW_EH_PE_sdata8 : dwarf::DW_EH_PE_sdata4);
|
|
|
|
break;
|
|
|
|
case Triple::bpfel:
|
|
|
|
case Triple::bpfeb:
|
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_sdata8;
|
|
|
|
break;
|
|
|
|
case Triple::hexagon:
|
[MC] Move EH DWARF encodings from MC to CodeGen, NFC
Summary:
The TType encoding, LSDA encoding, and personality encoding are all
passed explicitly by CodeGen to the assembler through .cfi_* directives,
so only the AsmPrinter needs to know about them.
The FDE CFI encoding however, controls the encoding of the label
implicitly created by the .cfi_startproc directive. That directive seems
to be special in that it doesn't take an encoding, so the assembler just
has to know how to encode one DSO-local label reference from .eh_frame
to .text.
As a result, it looks like MC will continue to have to know when the
large code model is in use. Perhaps we could invent a '.cfi_startproc
[large]' flag so that this knowledge doesn't need to pollute the
assembler.
Reviewers: davide, lliu0, JDevlieghere
Subscribers: hiraditya, fedor.sergeev, llvm-commits
Differential Revision: https://reviews.llvm.org/D50533
llvm-svn: 339397
2018-08-10 06:24:04 +08:00
|
|
|
FDECFIEncoding =
|
|
|
|
PositionIndependent ? dwarf::DW_EH_PE_pcrel : dwarf::DW_EH_PE_absptr;
|
2018-08-10 19:02:44 +08:00
|
|
|
break;
|
2017-11-30 20:43:25 +08:00
|
|
|
default:
|
[MC] Move EH DWARF encodings from MC to CodeGen, NFC
Summary:
The TType encoding, LSDA encoding, and personality encoding are all
passed explicitly by CodeGen to the assembler through .cfi_* directives,
so only the AsmPrinter needs to know about them.
The FDE CFI encoding however, controls the encoding of the label
implicitly created by the .cfi_startproc directive. That directive seems
to be special in that it doesn't take an encoding, so the assembler just
has to know how to encode one DSO-local label reference from .eh_frame
to .text.
As a result, it looks like MC will continue to have to know when the
large code model is in use. Perhaps we could invent a '.cfi_startproc
[large]' flag so that this knowledge doesn't need to pollute the
assembler.
Reviewers: davide, lliu0, JDevlieghere
Subscribers: hiraditya, fedor.sergeev, llvm-commits
Differential Revision: https://reviews.llvm.org/D50533
llvm-svn: 339397
2018-08-10 06:24:04 +08:00
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_pcrel | dwarf::DW_EH_PE_sdata4;
|
2017-11-30 20:43:25 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned EHSectionType = T.getArch() == Triple::x86_64
|
|
|
|
? ELF::SHT_X86_64_UNWIND
|
|
|
|
: ELF::SHT_PROGBITS;
|
|
|
|
|
|
|
|
// Solaris requires different flags for .eh_frame to seemingly every other
|
|
|
|
// platform.
|
|
|
|
unsigned EHSectionFlags = ELF::SHF_ALLOC;
|
|
|
|
if (T.isOSSolaris() && T.getArch() != Triple::x86_64)
|
|
|
|
EHSectionFlags |= ELF::SHF_WRITE;
|
|
|
|
|
|
|
|
// ELF
|
|
|
|
BSSSection = Ctx->getELFSection(".bss", ELF::SHT_NOBITS,
|
|
|
|
ELF::SHF_WRITE | ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
TextSection = Ctx->getELFSection(".text", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_EXECINSTR | ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
DataSection = Ctx->getELFSection(".data", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_WRITE | ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
ReadOnlySection =
|
|
|
|
Ctx->getELFSection(".rodata", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
TLSDataSection =
|
|
|
|
Ctx->getELFSection(".tdata", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_TLS | ELF::SHF_WRITE);
|
|
|
|
|
|
|
|
TLSBSSSection = Ctx->getELFSection(
|
|
|
|
".tbss", ELF::SHT_NOBITS, ELF::SHF_ALLOC | ELF::SHF_TLS | ELF::SHF_WRITE);
|
|
|
|
|
|
|
|
DataRelROSection = Ctx->getELFSection(".data.rel.ro", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_WRITE);
|
|
|
|
|
|
|
|
MergeableConst4Section =
|
|
|
|
Ctx->getELFSection(".rodata.cst4", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_MERGE, 4, "");
|
|
|
|
|
|
|
|
MergeableConst8Section =
|
|
|
|
Ctx->getELFSection(".rodata.cst8", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_MERGE, 8, "");
|
|
|
|
|
|
|
|
MergeableConst16Section =
|
|
|
|
Ctx->getELFSection(".rodata.cst16", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_MERGE, 16, "");
|
|
|
|
|
|
|
|
MergeableConst32Section =
|
|
|
|
Ctx->getELFSection(".rodata.cst32", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC | ELF::SHF_MERGE, 32, "");
|
|
|
|
|
|
|
|
// Exception Handling Sections.
|
|
|
|
|
|
|
|
// FIXME: We're emitting LSDA info into a readonly section on ELF, even though
|
|
|
|
// it contains relocatable pointers. In PIC mode, this is probably a big
|
|
|
|
// runtime hit for C++ apps. Either the contents of the LSDA need to be
|
|
|
|
// adjusted or this should be a data section.
|
|
|
|
LSDASection = Ctx->getELFSection(".gcc_except_table", ELF::SHT_PROGBITS,
|
|
|
|
ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
COFFDebugSymbolsSection = nullptr;
|
|
|
|
COFFDebugTypesSection = nullptr;
|
|
|
|
|
|
|
|
unsigned DebugSecType = ELF::SHT_PROGBITS;
|
|
|
|
|
|
|
|
// MIPS .debug_* sections should have SHT_MIPS_DWARF section type
|
|
|
|
// to distinguish among sections contain DWARF and ECOFF debug formats.
|
|
|
|
// Sections with ECOFF debug format are obsoleted and marked by SHT_PROGBITS.
|
2018-06-26 00:49:20 +08:00
|
|
|
if (T.isMIPS())
|
2017-11-30 20:43:25 +08:00
|
|
|
DebugSecType = ELF::SHT_MIPS_DWARF;
|
|
|
|
|
|
|
|
// Debug Info Sections.
|
|
|
|
DwarfAbbrevSection =
|
|
|
|
Ctx->getELFSection(".debug_abbrev", DebugSecType, 0);
|
|
|
|
DwarfInfoSection = Ctx->getELFSection(".debug_info", DebugSecType, 0);
|
|
|
|
DwarfLineSection = Ctx->getELFSection(".debug_line", DebugSecType, 0);
|
2018-02-07 04:29:21 +08:00
|
|
|
DwarfLineStrSection =
|
|
|
|
Ctx->getELFSection(".debug_line_str", DebugSecType,
|
|
|
|
ELF::SHF_MERGE | ELF::SHF_STRINGS, 1, "");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfFrameSection = Ctx->getELFSection(".debug_frame", DebugSecType, 0);
|
|
|
|
DwarfPubNamesSection =
|
|
|
|
Ctx->getELFSection(".debug_pubnames", DebugSecType, 0);
|
|
|
|
DwarfPubTypesSection =
|
|
|
|
Ctx->getELFSection(".debug_pubtypes", DebugSecType, 0);
|
|
|
|
DwarfGnuPubNamesSection =
|
|
|
|
Ctx->getELFSection(".debug_gnu_pubnames", DebugSecType, 0);
|
|
|
|
DwarfGnuPubTypesSection =
|
|
|
|
Ctx->getELFSection(".debug_gnu_pubtypes", DebugSecType, 0);
|
|
|
|
DwarfStrSection =
|
|
|
|
Ctx->getELFSection(".debug_str", DebugSecType,
|
|
|
|
ELF::SHF_MERGE | ELF::SHF_STRINGS, 1, "");
|
|
|
|
DwarfLocSection = Ctx->getELFSection(".debug_loc", DebugSecType, 0);
|
|
|
|
DwarfARangesSection =
|
|
|
|
Ctx->getELFSection(".debug_aranges", DebugSecType, 0);
|
|
|
|
DwarfRangesSection =
|
|
|
|
Ctx->getELFSection(".debug_ranges", DebugSecType, 0);
|
|
|
|
DwarfMacinfoSection =
|
|
|
|
Ctx->getELFSection(".debug_macinfo", DebugSecType, 0);
|
2020-04-03 15:14:09 +08:00
|
|
|
DwarfMacroSection = Ctx->getELFSection(".debug_macro", DebugSecType, 0);
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
// DWARF5 Experimental Debug Info
|
|
|
|
|
|
|
|
// Accelerator Tables
|
2018-04-04 22:42:14 +08:00
|
|
|
DwarfDebugNamesSection =
|
|
|
|
Ctx->getELFSection(".debug_names", ELF::SHT_PROGBITS, 0);
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfAccelNamesSection =
|
|
|
|
Ctx->getELFSection(".apple_names", ELF::SHT_PROGBITS, 0);
|
|
|
|
DwarfAccelObjCSection =
|
|
|
|
Ctx->getELFSection(".apple_objc", ELF::SHT_PROGBITS, 0);
|
|
|
|
DwarfAccelNamespaceSection =
|
|
|
|
Ctx->getELFSection(".apple_namespaces", ELF::SHT_PROGBITS, 0);
|
|
|
|
DwarfAccelTypesSection =
|
|
|
|
Ctx->getELFSection(".apple_types", ELF::SHT_PROGBITS, 0);
|
|
|
|
|
|
|
|
// String Offset and Address Sections
|
|
|
|
DwarfStrOffSection =
|
|
|
|
Ctx->getELFSection(".debug_str_offsets", DebugSecType, 0);
|
|
|
|
DwarfAddrSection = Ctx->getELFSection(".debug_addr", DebugSecType, 0);
|
2018-07-13 02:18:21 +08:00
|
|
|
DwarfRnglistsSection = Ctx->getELFSection(".debug_rnglists", DebugSecType, 0);
|
2018-10-26 19:25:12 +08:00
|
|
|
DwarfLoclistsSection = Ctx->getELFSection(".debug_loclists", DebugSecType, 0);
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
// Fission Sections
|
|
|
|
DwarfInfoDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_info.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfTypesDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_types.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfAbbrevDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_abbrev.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
|
|
|
DwarfStrDWOSection = Ctx->getELFSection(
|
|
|
|
".debug_str.dwo", DebugSecType,
|
|
|
|
ELF::SHF_MERGE | ELF::SHF_STRINGS | ELF::SHF_EXCLUDE, 1, "");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfLineDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_line.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfLocDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_loc.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
|
|
|
DwarfStrOffDWOSection = Ctx->getELFSection(".debug_str_offsets.dwo",
|
|
|
|
DebugSecType, ELF::SHF_EXCLUDE);
|
2018-07-13 02:18:21 +08:00
|
|
|
DwarfRnglistsDWOSection =
|
2018-09-22 15:36:20 +08:00
|
|
|
Ctx->getELFSection(".debug_rnglists.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2019-11-11 15:23:19 +08:00
|
|
|
DwarfMacinfoDWOSection =
|
|
|
|
Ctx->getELFSection(".debug_macinfo.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2020-05-30 13:41:09 +08:00
|
|
|
DwarfMacroDWOSection =
|
|
|
|
Ctx->getELFSection(".debug_macro.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
2017-11-30 20:43:25 +08:00
|
|
|
|
2019-11-23 22:34:36 +08:00
|
|
|
DwarfLoclistsDWOSection =
|
|
|
|
Ctx->getELFSection(".debug_loclists.dwo", DebugSecType, ELF::SHF_EXCLUDE);
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
// DWP Sections
|
|
|
|
DwarfCUIndexSection =
|
|
|
|
Ctx->getELFSection(".debug_cu_index", DebugSecType, 0);
|
|
|
|
DwarfTUIndexSection =
|
|
|
|
Ctx->getELFSection(".debug_tu_index", DebugSecType, 0);
|
|
|
|
|
|
|
|
StackMapSection =
|
|
|
|
Ctx->getELFSection(".llvm_stackmaps", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
FaultMapSection =
|
|
|
|
Ctx->getELFSection(".llvm_faultmaps", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
|
|
|
|
|
|
|
|
EHFrameSection =
|
|
|
|
Ctx->getELFSection(".eh_frame", EHSectionType, EHSectionFlags);
|
2017-11-30 21:05:14 +08:00
|
|
|
|
|
|
|
StackSizesSection = Ctx->getELFSection(".stack_sizes", ELF::SHT_PROGBITS, 0);
|
2017-11-30 20:43:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void MCObjectFileInfo::initCOFFMCObjectFileInfo(const Triple &T) {
|
2018-12-04 04:02:05 +08:00
|
|
|
EHFrameSection =
|
|
|
|
Ctx->getCOFFSection(".eh_frame", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getData());
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
// Set the `IMAGE_SCN_MEM_16BIT` flag when compiling for thumb mode. This is
|
|
|
|
// used to indicate to the linker that the text segment contains thumb instructions
|
|
|
|
// and to set the ISA selection bit for calls accordingly.
|
|
|
|
const bool IsThumb = T.getArch() == Triple::thumb;
|
|
|
|
|
|
|
|
CommDirectiveSupportsAlignment = true;
|
|
|
|
|
|
|
|
// COFF
|
|
|
|
BSSSection = Ctx->getCOFFSection(
|
|
|
|
".bss", COFF::IMAGE_SCN_CNT_UNINITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ | COFF::IMAGE_SCN_MEM_WRITE,
|
|
|
|
SectionKind::getBSS());
|
|
|
|
TextSection = Ctx->getCOFFSection(
|
|
|
|
".text",
|
|
|
|
(IsThumb ? COFF::IMAGE_SCN_MEM_16BIT : (COFF::SectionCharacteristics)0) |
|
|
|
|
COFF::IMAGE_SCN_CNT_CODE | COFF::IMAGE_SCN_MEM_EXECUTE |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getText());
|
|
|
|
DataSection = Ctx->getCOFFSection(
|
|
|
|
".data", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA | COFF::IMAGE_SCN_MEM_READ |
|
|
|
|
COFF::IMAGE_SCN_MEM_WRITE,
|
|
|
|
SectionKind::getData());
|
|
|
|
ReadOnlySection = Ctx->getCOFFSection(
|
|
|
|
".rdata", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA | COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
|
2018-12-18 16:32:37 +08:00
|
|
|
if (T.getArch() == Triple::x86_64 || T.getArch() == Triple::aarch64) {
|
2017-11-30 20:43:25 +08:00
|
|
|
// On Windows 64 with SEH, the LSDA is emitted into the .xdata section
|
|
|
|
LSDASection = nullptr;
|
|
|
|
} else {
|
|
|
|
LSDASection = Ctx->getCOFFSection(".gcc_except_table",
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
}
|
|
|
|
|
|
|
|
// Debug info.
|
|
|
|
COFFDebugSymbolsSection =
|
|
|
|
Ctx->getCOFFSection(".debug$S", (COFF::IMAGE_SCN_MEM_DISCARDABLE |
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ),
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
COFFDebugTypesSection =
|
|
|
|
Ctx->getCOFFSection(".debug$T", (COFF::IMAGE_SCN_MEM_DISCARDABLE |
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ),
|
|
|
|
SectionKind::getMetadata());
|
2017-12-14 06:33:58 +08:00
|
|
|
COFFGlobalTypeHashesSection = Ctx->getCOFFSection(
|
|
|
|
".debug$H",
|
|
|
|
(COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ),
|
|
|
|
SectionKind::getMetadata());
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
DwarfAbbrevSection = Ctx->getCOFFSection(
|
|
|
|
".debug_abbrev",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_abbrev");
|
|
|
|
DwarfInfoSection = Ctx->getCOFFSection(
|
|
|
|
".debug_info",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_info");
|
|
|
|
DwarfLineSection = Ctx->getCOFFSection(
|
|
|
|
".debug_line",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_line");
|
2018-02-07 04:29:21 +08:00
|
|
|
DwarfLineStrSection = Ctx->getCOFFSection(
|
|
|
|
".debug_line_str",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_line_str");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfFrameSection = Ctx->getCOFFSection(
|
|
|
|
".debug_frame",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfPubNamesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_pubnames",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfPubTypesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_pubtypes",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfGnuPubNamesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_gnu_pubnames",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfGnuPubTypesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_gnu_pubtypes",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfStrSection = Ctx->getCOFFSection(
|
|
|
|
".debug_str",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "info_string");
|
|
|
|
DwarfStrOffSection = Ctx->getCOFFSection(
|
|
|
|
".debug_str_offsets",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_str_off");
|
|
|
|
DwarfLocSection = Ctx->getCOFFSection(
|
|
|
|
".debug_loc",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_debug_loc");
|
2020-02-05 11:23:57 +08:00
|
|
|
DwarfLoclistsSection = Ctx->getCOFFSection(
|
|
|
|
".debug_loclists",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_debug_loclists");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfARangesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_aranges",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfRangesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_ranges",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_range");
|
2020-02-05 11:23:57 +08:00
|
|
|
DwarfRnglistsSection = Ctx->getCOFFSection(
|
|
|
|
".debug_rnglists",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_rnglists");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfMacinfoSection = Ctx->getCOFFSection(
|
|
|
|
".debug_macinfo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_macinfo");
|
2020-04-03 15:14:09 +08:00
|
|
|
DwarfMacroSection = Ctx->getCOFFSection(
|
|
|
|
".debug_macro",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_macro");
|
2019-12-04 21:02:39 +08:00
|
|
|
DwarfMacinfoDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_macinfo.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_macinfo.dwo");
|
2020-05-30 13:41:09 +08:00
|
|
|
DwarfMacroDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_macro.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_macro.dwo");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfInfoDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_info.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_info_dwo");
|
|
|
|
DwarfTypesDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_types.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_types_dwo");
|
|
|
|
DwarfAbbrevDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_abbrev.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_abbrev_dwo");
|
|
|
|
DwarfStrDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_str.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "skel_string");
|
|
|
|
DwarfLineDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_line.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfLocDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_loc.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "skel_loc");
|
|
|
|
DwarfStrOffDWOSection = Ctx->getCOFFSection(
|
|
|
|
".debug_str_offsets.dwo",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "section_str_off_dwo");
|
|
|
|
DwarfAddrSection = Ctx->getCOFFSection(
|
|
|
|
".debug_addr",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "addr_sec");
|
|
|
|
DwarfCUIndexSection = Ctx->getCOFFSection(
|
|
|
|
".debug_cu_index",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
DwarfTUIndexSection = Ctx->getCOFFSection(
|
|
|
|
".debug_tu_index",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
2018-04-04 22:42:14 +08:00
|
|
|
DwarfDebugNamesSection = Ctx->getCOFFSection(
|
|
|
|
".debug_names",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "debug_names_begin");
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfAccelNamesSection = Ctx->getCOFFSection(
|
|
|
|
".apple_names",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "names_begin");
|
|
|
|
DwarfAccelNamespaceSection = Ctx->getCOFFSection(
|
|
|
|
".apple_namespaces",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "namespac_begin");
|
|
|
|
DwarfAccelTypesSection = Ctx->getCOFFSection(
|
|
|
|
".apple_types",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "types_begin");
|
|
|
|
DwarfAccelObjCSection = Ctx->getCOFFSection(
|
|
|
|
".apple_objc",
|
|
|
|
COFF::IMAGE_SCN_MEM_DISCARDABLE | COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata(), "objc_begin");
|
|
|
|
|
|
|
|
DrectveSection = Ctx->getCOFFSection(
|
|
|
|
".drectve", COFF::IMAGE_SCN_LNK_INFO | COFF::IMAGE_SCN_LNK_REMOVE,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
|
|
|
PDataSection = Ctx->getCOFFSection(
|
|
|
|
".pdata", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA | COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getData());
|
|
|
|
|
|
|
|
XDataSection = Ctx->getCOFFSection(
|
|
|
|
".xdata", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA | COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getData());
|
|
|
|
|
|
|
|
SXDataSection = Ctx->getCOFFSection(".sxdata", COFF::IMAGE_SCN_LNK_INFO,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
2018-01-10 07:49:30 +08:00
|
|
|
GFIDsSection = Ctx->getCOFFSection(".gfids$y",
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
Add Windows Control Flow Guard checks (/guard:cf).
Summary:
A new function pass (Transforms/CFGuard/CFGuard.cpp) inserts CFGuard checks on
indirect function calls, using either the check mechanism (X86, ARM, AArch64) or
or the dispatch mechanism (X86-64). The check mechanism requires a new calling
convention for the supported targets. The dispatch mechanism adds the target as
an operand bundle, which is processed by SelectionDAG. Another pass
(CodeGen/CFGuardLongjmp.cpp) identifies and emits valid longjmp targets, as
required by /guard:cf. This feature is enabled using the `cfguard` CC1 option.
Reviewers: thakis, rnk, theraven, pcc
Subscribers: ychen, hans, metalcanine, dmajor, tomrittervg, alex, mehdi_amini, mgorny, javed.absar, kristof.beyls, hiraditya, steven_wu, dexonsmith, cfe-commits, llvm-commits
Tags: #clang, #llvm
Differential Revision: https://reviews.llvm.org/D65761
2019-10-28 21:22:19 +08:00
|
|
|
|
2020-10-01 17:07:40 +08:00
|
|
|
GIATsSection = Ctx->getCOFFSection(".giats$y",
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
|
|
|
|
Add Windows Control Flow Guard checks (/guard:cf).
Summary:
A new function pass (Transforms/CFGuard/CFGuard.cpp) inserts CFGuard checks on
indirect function calls, using either the check mechanism (X86, ARM, AArch64) or
or the dispatch mechanism (X86-64). The check mechanism requires a new calling
convention for the supported targets. The dispatch mechanism adds the target as
an operand bundle, which is processed by SelectionDAG. Another pass
(CodeGen/CFGuardLongjmp.cpp) identifies and emits valid longjmp targets, as
required by /guard:cf. This feature is enabled using the `cfguard` CC1 option.
Reviewers: thakis, rnk, theraven, pcc
Subscribers: ychen, hans, metalcanine, dmajor, tomrittervg, alex, mehdi_amini, mgorny, javed.absar, kristof.beyls, hiraditya, steven_wu, dexonsmith, cfe-commits, llvm-commits
Tags: #clang, #llvm
Differential Revision: https://reviews.llvm.org/D65761
2019-10-28 21:22:19 +08:00
|
|
|
GLJMPSection = Ctx->getCOFFSection(".gljmp$y",
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getMetadata());
|
2018-01-10 07:49:30 +08:00
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
TLSDataSection = Ctx->getCOFFSection(
|
|
|
|
".tls$", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA | COFF::IMAGE_SCN_MEM_READ |
|
|
|
|
COFF::IMAGE_SCN_MEM_WRITE,
|
|
|
|
SectionKind::getData());
|
|
|
|
|
|
|
|
StackMapSection = Ctx->getCOFFSection(".llvm_stackmaps",
|
|
|
|
COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
|
|
|
|
COFF::IMAGE_SCN_MEM_READ,
|
|
|
|
SectionKind::getReadOnly());
|
|
|
|
}
|
|
|
|
|
|
|
|
void MCObjectFileInfo::initWasmMCObjectFileInfo(const Triple &T) {
|
|
|
|
TextSection = Ctx->getWasmSection(".text", SectionKind::getText());
|
|
|
|
DataSection = Ctx->getWasmSection(".data", SectionKind::getData());
|
|
|
|
|
2018-05-11 01:38:35 +08:00
|
|
|
DwarfLineSection =
|
|
|
|
Ctx->getWasmSection(".debug_line", SectionKind::getMetadata());
|
2018-02-07 04:29:21 +08:00
|
|
|
DwarfLineStrSection =
|
|
|
|
Ctx->getWasmSection(".debug_line_str", SectionKind::getMetadata());
|
2018-05-11 01:38:35 +08:00
|
|
|
DwarfStrSection =
|
|
|
|
Ctx->getWasmSection(".debug_str", SectionKind::getMetadata());
|
|
|
|
DwarfLocSection =
|
|
|
|
Ctx->getWasmSection(".debug_loc", SectionKind::getMetadata());
|
|
|
|
DwarfAbbrevSection =
|
|
|
|
Ctx->getWasmSection(".debug_abbrev", SectionKind::getMetadata());
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfARangesSection = Ctx->getWasmSection(".debug_aranges", SectionKind::getMetadata());
|
2018-05-11 01:38:35 +08:00
|
|
|
DwarfRangesSection =
|
|
|
|
Ctx->getWasmSection(".debug_ranges", SectionKind::getMetadata());
|
|
|
|
DwarfMacinfoSection =
|
|
|
|
Ctx->getWasmSection(".debug_macinfo", SectionKind::getMetadata());
|
2020-04-03 15:14:09 +08:00
|
|
|
DwarfMacroSection =
|
|
|
|
Ctx->getWasmSection(".debug_macro", SectionKind::getMetadata());
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfCUIndexSection = Ctx->getWasmSection(".debug_cu_index", SectionKind::getMetadata());
|
|
|
|
DwarfTUIndexSection = Ctx->getWasmSection(".debug_tu_index", SectionKind::getMetadata());
|
2018-05-11 01:38:35 +08:00
|
|
|
DwarfInfoSection =
|
|
|
|
Ctx->getWasmSection(".debug_info", SectionKind::getMetadata());
|
2017-11-30 20:43:25 +08:00
|
|
|
DwarfFrameSection = Ctx->getWasmSection(".debug_frame", SectionKind::getMetadata());
|
|
|
|
DwarfPubNamesSection = Ctx->getWasmSection(".debug_pubnames", SectionKind::getMetadata());
|
|
|
|
DwarfPubTypesSection = Ctx->getWasmSection(".debug_pubtypes", SectionKind::getMetadata());
|
2020-08-08 12:23:11 +08:00
|
|
|
DwarfGnuPubNamesSection =
|
|
|
|
Ctx->getWasmSection(".debug_gnu_pubnames", SectionKind::getMetadata());
|
|
|
|
DwarfGnuPubTypesSection =
|
|
|
|
Ctx->getWasmSection(".debug_gnu_pubtypes", SectionKind::getMetadata());
|
2017-11-30 20:43:25 +08:00
|
|
|
|
2020-02-15 07:29:32 +08:00
|
|
|
DwarfDebugNamesSection =
|
|
|
|
Ctx->getWasmSection(".debug_names", SectionKind::getMetadata());
|
|
|
|
DwarfStrOffSection =
|
|
|
|
Ctx->getWasmSection(".debug_str_offsets", SectionKind::getMetadata());
|
|
|
|
DwarfAddrSection =
|
|
|
|
Ctx->getWasmSection(".debug_addr", SectionKind::getMetadata());
|
|
|
|
DwarfRnglistsSection =
|
|
|
|
Ctx->getWasmSection(".debug_rnglists", SectionKind::getMetadata());
|
|
|
|
DwarfLoclistsSection =
|
|
|
|
Ctx->getWasmSection(".debug_loclists", SectionKind::getMetadata());
|
|
|
|
|
2020-08-08 12:23:11 +08:00
|
|
|
// Fission Sections
|
|
|
|
DwarfInfoDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_info.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfTypesDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_types.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfAbbrevDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_abbrev.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfStrDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_str.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfLineDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_line.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfLocDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_loc.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfStrOffDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_str_offsets.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfRnglistsDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_rnglists.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfMacinfoDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_macinfo.dwo", SectionKind::getMetadata());
|
|
|
|
DwarfMacroDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_macro.dwo", SectionKind::getMetadata());
|
|
|
|
|
|
|
|
DwarfLoclistsDWOSection =
|
|
|
|
Ctx->getWasmSection(".debug_loclists.dwo", SectionKind::getMetadata());
|
|
|
|
|
|
|
|
// DWP Sections
|
|
|
|
DwarfCUIndexSection =
|
|
|
|
Ctx->getWasmSection(".debug_cu_index", SectionKind::getMetadata(), 0);
|
|
|
|
DwarfTUIndexSection =
|
|
|
|
Ctx->getWasmSection(".debug_tu_index", SectionKind::getMetadata(), 0);
|
|
|
|
|
Reland "[WebAssembly] LSDA info generation"
Summary:
This adds support for LSDA (exception table) generation for wasm EH.
Wasm EH mostly follows the structure of Itanium-style exception tables,
with one exception: a call site table entry in wasm EH corresponds to
not a call site but a landing pad.
In wasm EH, the VM is responsible for stack unwinding. After an
exception occurs and the stack is unwound, the control flow is
transferred to wasm 'catch' instruction by the VM, after which the
personality function is called from the compiler-generated code. (Refer
to WasmEHPrepare pass for more information on this part.)
This patch:
- Changes wasm.landingpad.index intrinsic to take a token argument, to
make this 1:1 match with a catchpad instruction
- Stores landingpad index info and catch type info MachineFunction in
before instruction selection
- Lowers wasm.lsda intrinsic to an MCSymbol pointing to the start of an
exception table
- Adds WasmException class with overridden methods for table generation
- Adds support for LSDA section in Wasm object writer
Reviewers: dschuff, sbc100, rnk
Subscribers: mgorny, jgravelle-google, sunfish, llvm-commits
Differential Revision: https://reviews.llvm.org/D52748
llvm-svn: 345345
2018-10-26 07:55:10 +08:00
|
|
|
// Wasm use data section for LSDA.
|
|
|
|
// TODO Consider putting each function's exception table in a separate
|
|
|
|
// section, as in -function-sections, to facilitate lld's --gc-section.
|
|
|
|
LSDASection = Ctx->getWasmSection(".rodata.gcc_except_table",
|
|
|
|
SectionKind::getReadOnlyWithRel());
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
// TODO: Define more sections.
|
|
|
|
}
|
|
|
|
|
2019-07-10 03:21:01 +08:00
|
|
|
void MCObjectFileInfo::initXCOFFMCObjectFileInfo(const Triple &T) {
|
|
|
|
// The default csect for program code. Functions without a specified section
|
|
|
|
// get placed into this csect. The choice of csect name is not a property of
|
|
|
|
// the ABI or object file format. For example, the XL compiler uses an unnamed
|
|
|
|
// csect for program code.
|
2020-08-12 03:26:19 +08:00
|
|
|
TextSection =
|
|
|
|
Ctx->getXCOFFSection(".text", XCOFF::StorageMappingClass::XMC_PR,
|
|
|
|
XCOFF::XTY_SD, SectionKind::getText());
|
[PowerPC][AIX] Adds support for writing the .data section in assembly files
Summary:
Adds support for generating the .data section in assembly files for global variables with a non-zero initialization. The support for writing the .data section in XCOFF object files will be added in a follow-on patch. Any relocations are not included in this patch.
Reviewers: hubert.reinterpretcast, sfertile, jasonliu, daltenty, Xiangling_L
Reviewed by: hubert.reinterpretcast
Subscribers: nemanjai, hiraditya, kbarton, MaskRay, jsji, wuzish, shchenz, DiggerLin, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D66154
llvm-svn: 369869
2019-08-25 23:17:25 +08:00
|
|
|
|
2020-08-12 03:26:19 +08:00
|
|
|
DataSection =
|
|
|
|
Ctx->getXCOFFSection(".data", XCOFF::StorageMappingClass::XMC_RW,
|
|
|
|
XCOFF::XTY_SD, SectionKind::getData());
|
2019-11-16 00:30:19 +08:00
|
|
|
|
2020-08-12 03:26:19 +08:00
|
|
|
ReadOnlySection =
|
|
|
|
Ctx->getXCOFFSection(".rodata", XCOFF::StorageMappingClass::XMC_RO,
|
|
|
|
XCOFF::XTY_SD, SectionKind::getReadOnly());
|
[NFC][XCOFF] Refactor Csect creation into TargetLoweringObjectFile
Summary:
We create a number of standard types of control sections in multiple places for
things like the function descriptors, external references and the TOC anchor
among others, so it is possible for their properties to be defined
inconsistently in different places. This refactor moves their creation and
properties into functions in the TargetLoweringObjectFile class hierarchy, where
functions for retrieving various special types of sections typically seem
to reside.
Note: There is one case in PPCISelLowering which is specific to function entry
points which we don't address since we don't have access to the TLOF there.
Reviewers: DiggerLin, jasonliu, hubert.reinterpretcast
Reviewed By: jasonliu, hubert.reinterpretcast
Subscribers: wuzish, nemanjai, hiraditya, kbarton, jsji, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D72347
2020-01-23 00:09:34 +08:00
|
|
|
|
2020-08-12 03:26:19 +08:00
|
|
|
TOCBaseSection =
|
|
|
|
Ctx->getXCOFFSection("TOC", XCOFF::StorageMappingClass::XMC_TC0,
|
|
|
|
XCOFF::XTY_SD, SectionKind::getData());
|
[NFC][XCOFF] Refactor Csect creation into TargetLoweringObjectFile
Summary:
We create a number of standard types of control sections in multiple places for
things like the function descriptors, external references and the TOC anchor
among others, so it is possible for their properties to be defined
inconsistently in different places. This refactor moves their creation and
properties into functions in the TargetLoweringObjectFile class hierarchy, where
functions for retrieving various special types of sections typically seem
to reside.
Note: There is one case in PPCISelLowering which is specific to function entry
points which we don't address since we don't have access to the TLOF there.
Reviewers: DiggerLin, jasonliu, hubert.reinterpretcast
Reviewed By: jasonliu, hubert.reinterpretcast
Subscribers: wuzish, nemanjai, hiraditya, kbarton, jsji, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D72347
2020-01-23 00:09:34 +08:00
|
|
|
|
|
|
|
// The TOC-base always has 0 size, but 4 byte alignment.
|
|
|
|
TOCBaseSection->setAlignment(Align(4));
|
2020-05-09 04:32:12 +08:00
|
|
|
|
|
|
|
// DWARF sections for XCOFF are not csects. They are special STYP_DWARF
|
|
|
|
// sections, and the individual DWARF sections are distinguished by their
|
|
|
|
// section subtype.
|
|
|
|
// TODO: Populate the DWARF sections appropriately.
|
|
|
|
DwarfAbbrevSection = nullptr; // SSUBTYP_DWABREV
|
|
|
|
DwarfInfoSection = nullptr; // SSUBTYP_DWINFO
|
|
|
|
DwarfLineSection = nullptr; // SSUBTYP_DWLINE
|
|
|
|
DwarfFrameSection = nullptr; // SSUBTYP_DWFRAME
|
|
|
|
DwarfPubNamesSection = nullptr; // SSUBTYP_DWPBNMS
|
|
|
|
DwarfPubTypesSection = nullptr; // SSUBTYP_DWPBTYP
|
|
|
|
DwarfStrSection = nullptr; // SSUBTYP_DWSTR
|
|
|
|
DwarfLocSection = nullptr; // SSUBTYP_DWLOC
|
|
|
|
DwarfARangesSection = nullptr; // SSUBTYP_DWARNGE
|
|
|
|
DwarfRangesSection = nullptr; // SSUBTYP_DWRNGES
|
|
|
|
DwarfMacinfoSection = nullptr; // SSUBTYP_DWMAC
|
2019-07-10 03:21:01 +08:00
|
|
|
}
|
|
|
|
|
2017-11-30 20:43:25 +08:00
|
|
|
void MCObjectFileInfo::InitMCObjectFileInfo(const Triple &TheTriple, bool PIC,
|
|
|
|
MCContext &ctx,
|
|
|
|
bool LargeCodeModel) {
|
|
|
|
PositionIndependent = PIC;
|
|
|
|
Ctx = &ctx;
|
|
|
|
|
|
|
|
// Common.
|
|
|
|
CommDirectiveSupportsAlignment = true;
|
|
|
|
SupportsWeakOmittedEHFrame = true;
|
|
|
|
SupportsCompactUnwindWithoutEHFrame = false;
|
|
|
|
OmitDwarfIfHaveCompactUnwind = false;
|
|
|
|
|
[MC] Move EH DWARF encodings from MC to CodeGen, NFC
Summary:
The TType encoding, LSDA encoding, and personality encoding are all
passed explicitly by CodeGen to the assembler through .cfi_* directives,
so only the AsmPrinter needs to know about them.
The FDE CFI encoding however, controls the encoding of the label
implicitly created by the .cfi_startproc directive. That directive seems
to be special in that it doesn't take an encoding, so the assembler just
has to know how to encode one DSO-local label reference from .eh_frame
to .text.
As a result, it looks like MC will continue to have to know when the
large code model is in use. Perhaps we could invent a '.cfi_startproc
[large]' flag so that this knowledge doesn't need to pollute the
assembler.
Reviewers: davide, lliu0, JDevlieghere
Subscribers: hiraditya, fedor.sergeev, llvm-commits
Differential Revision: https://reviews.llvm.org/D50533
llvm-svn: 339397
2018-08-10 06:24:04 +08:00
|
|
|
FDECFIEncoding = dwarf::DW_EH_PE_absptr;
|
2017-11-30 20:43:25 +08:00
|
|
|
|
|
|
|
CompactUnwindDwarfEHFrameOnly = 0;
|
|
|
|
|
|
|
|
EHFrameSection = nullptr; // Created on demand.
|
|
|
|
CompactUnwindSection = nullptr; // Used only by selected targets.
|
|
|
|
DwarfAccelNamesSection = nullptr; // Used only by selected targets.
|
|
|
|
DwarfAccelObjCSection = nullptr; // Used only by selected targets.
|
|
|
|
DwarfAccelNamespaceSection = nullptr; // Used only by selected targets.
|
|
|
|
DwarfAccelTypesSection = nullptr; // Used only by selected targets.
|
|
|
|
|
|
|
|
TT = TheTriple;
|
|
|
|
|
|
|
|
switch (TT.getObjectFormat()) {
|
|
|
|
case Triple::MachO:
|
|
|
|
Env = IsMachO;
|
|
|
|
initMachOMCObjectFileInfo(TT);
|
|
|
|
break;
|
|
|
|
case Triple::COFF:
|
|
|
|
if (!TT.isOSWindows())
|
|
|
|
report_fatal_error(
|
|
|
|
"Cannot initialize MC for non-Windows COFF object files.");
|
|
|
|
|
|
|
|
Env = IsCOFF;
|
|
|
|
initCOFFMCObjectFileInfo(TT);
|
|
|
|
break;
|
|
|
|
case Triple::ELF:
|
|
|
|
Env = IsELF;
|
|
|
|
initELFMCObjectFileInfo(TT, LargeCodeModel);
|
|
|
|
break;
|
|
|
|
case Triple::Wasm:
|
|
|
|
Env = IsWasm;
|
|
|
|
initWasmMCObjectFileInfo(TT);
|
|
|
|
break;
|
2020-06-19 19:43:35 +08:00
|
|
|
case Triple::GOFF:
|
|
|
|
report_fatal_error("Cannot initialize MC for GOFF object file format");
|
|
|
|
break;
|
2019-03-13 06:01:10 +08:00
|
|
|
case Triple::XCOFF:
|
|
|
|
Env = IsXCOFF;
|
2019-07-10 03:21:01 +08:00
|
|
|
initXCOFFMCObjectFileInfo(TT);
|
2019-03-13 06:01:10 +08:00
|
|
|
break;
|
2017-11-30 20:43:25 +08:00
|
|
|
case Triple::UnknownObjectFormat:
|
|
|
|
report_fatal_error("Cannot initialize MC for unknown object file format.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-10 03:06:09 +08:00
|
|
|
MCSection *MCObjectFileInfo::getDwarfComdatSection(const char *Name,
|
|
|
|
uint64_t Hash) const {
|
2018-08-01 20:53:06 +08:00
|
|
|
switch (TT.getObjectFormat()) {
|
|
|
|
case Triple::ELF:
|
2018-11-10 03:06:09 +08:00
|
|
|
return Ctx->getELFSection(Name, ELF::SHT_PROGBITS, ELF::SHF_GROUP, 0,
|
|
|
|
utostr(Hash));
|
2020-10-29 08:15:58 +08:00
|
|
|
case Triple::Wasm:
|
|
|
|
// FIXME: When using dwarf 5, the .debug_info section is used for type units
|
|
|
|
// but that section already exists, so attempting to get it as a comdate
|
|
|
|
// section triggers an assert.
|
|
|
|
return Ctx->getWasmSection(Name, SectionKind::getMetadata(), utostr(Hash),
|
|
|
|
MCContext::GenericSectionID);
|
2018-08-01 20:53:06 +08:00
|
|
|
case Triple::MachO:
|
|
|
|
case Triple::COFF:
|
2020-06-19 19:43:35 +08:00
|
|
|
case Triple::GOFF:
|
2019-03-13 06:01:10 +08:00
|
|
|
case Triple::XCOFF:
|
2018-08-01 20:53:06 +08:00
|
|
|
case Triple::UnknownObjectFormat:
|
2018-11-10 03:06:09 +08:00
|
|
|
report_fatal_error("Cannot get DWARF comdat section for this object file "
|
2018-08-01 20:53:06 +08:00
|
|
|
"format: not implemented.");
|
|
|
|
break;
|
|
|
|
}
|
2018-08-01 21:00:11 +08:00
|
|
|
llvm_unreachable("Unknown ObjectFormatType");
|
2017-11-30 20:43:25 +08:00
|
|
|
}
|
2018-06-22 18:53:47 +08:00
|
|
|
|
|
|
|
MCSection *
|
|
|
|
MCObjectFileInfo::getStackSizesSection(const MCSection &TextSec) const {
|
|
|
|
if (Env != IsELF)
|
|
|
|
return StackSizesSection;
|
|
|
|
|
|
|
|
const MCSectionELF &ElfSec = static_cast<const MCSectionELF &>(TextSec);
|
|
|
|
unsigned Flags = ELF::SHF_LINK_ORDER;
|
|
|
|
StringRef GroupName;
|
|
|
|
if (const MCSymbol *Group = ElfSec.getGroup()) {
|
|
|
|
GroupName = Group->getName();
|
|
|
|
Flags |= ELF::SHF_GROUP;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Ctx->getELFSection(".stack_sizes", ELF::SHT_PROGBITS, Flags, 0,
|
2020-02-15 13:14:31 +08:00
|
|
|
GroupName, MCSection::NonUniqueID,
|
|
|
|
cast<MCSymbolELF>(TextSec.getBeginSymbol()));
|
2018-06-22 18:53:47 +08:00
|
|
|
}
|
2020-09-15 01:16:44 +08:00
|
|
|
|
|
|
|
MCSection *
|
|
|
|
MCObjectFileInfo::getBBAddrMapSection(const MCSection &TextSec) const {
|
|
|
|
if (Env != IsELF)
|
|
|
|
return nullptr;
|
|
|
|
|
|
|
|
const MCSectionELF &ElfSec = static_cast<const MCSectionELF &>(TextSec);
|
|
|
|
unsigned Flags = ELF::SHF_LINK_ORDER;
|
|
|
|
StringRef GroupName;
|
|
|
|
if (const MCSymbol *Group = ElfSec.getGroup()) {
|
|
|
|
GroupName = Group->getName();
|
|
|
|
Flags |= ELF::SHF_GROUP;
|
|
|
|
}
|
|
|
|
|
2020-10-09 02:12:40 +08:00
|
|
|
return Ctx->getELFSection(".llvm_bb_addr_map", ELF::SHT_LLVM_BB_ADDR_MAP,
|
|
|
|
Flags, 0, GroupName, MCSection::NonUniqueID,
|
2020-09-15 01:16:44 +08:00
|
|
|
cast<MCSymbolELF>(TextSec.getBeginSymbol()));
|
|
|
|
}
|