annotate lld/ELF/Writer.h @ 192:d7606dcf6fce

Added tag llvm10 for changeset 0572611fdcc8
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 14 Dec 2020 18:01:34 +0900
parents 1d019706d866
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===- Writer.h -------------------------------------------------*- C++ -*-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #ifndef LLD_ELF_WRITER_H
anatofuz
parents:
diff changeset
10 #define LLD_ELF_WRITER_H
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 #include "Config.h"
anatofuz
parents:
diff changeset
13 #include "llvm/ADT/ArrayRef.h"
anatofuz
parents:
diff changeset
14 #include "llvm/ADT/StringRef.h"
anatofuz
parents:
diff changeset
15 #include <cstdint>
anatofuz
parents:
diff changeset
16 #include <memory>
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 namespace lld {
anatofuz
parents:
diff changeset
19 namespace elf {
anatofuz
parents:
diff changeset
20 class InputFile;
anatofuz
parents:
diff changeset
21 class OutputSection;
anatofuz
parents:
diff changeset
22 class InputSectionBase;
anatofuz
parents:
diff changeset
23 void copySectionsIntoPartitions();
anatofuz
parents:
diff changeset
24 template <class ELFT> void createSyntheticSections();
anatofuz
parents:
diff changeset
25 void combineEhSections();
anatofuz
parents:
diff changeset
26 template <class ELFT> void writeResult();
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 // This describes a program header entry.
anatofuz
parents:
diff changeset
29 // Each contains type, access flags and range of output sections that will be
anatofuz
parents:
diff changeset
30 // placed in it.
anatofuz
parents:
diff changeset
31 struct PhdrEntry {
anatofuz
parents:
diff changeset
32 PhdrEntry(unsigned type, unsigned flags)
anatofuz
parents:
diff changeset
33 : p_align(type == llvm::ELF::PT_LOAD ? config->maxPageSize : 0),
anatofuz
parents:
diff changeset
34 p_type(type), p_flags(flags) {}
anatofuz
parents:
diff changeset
35 void add(OutputSection *sec);
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 uint64_t p_paddr = 0;
anatofuz
parents:
diff changeset
38 uint64_t p_vaddr = 0;
anatofuz
parents:
diff changeset
39 uint64_t p_memsz = 0;
anatofuz
parents:
diff changeset
40 uint64_t p_filesz = 0;
anatofuz
parents:
diff changeset
41 uint64_t p_offset = 0;
anatofuz
parents:
diff changeset
42 uint32_t p_align = 0;
anatofuz
parents:
diff changeset
43 uint32_t p_type = 0;
anatofuz
parents:
diff changeset
44 uint32_t p_flags = 0;
anatofuz
parents:
diff changeset
45
anatofuz
parents:
diff changeset
46 OutputSection *firstSec = nullptr;
anatofuz
parents:
diff changeset
47 OutputSection *lastSec = nullptr;
anatofuz
parents:
diff changeset
48 bool hasLMA = false;
anatofuz
parents:
diff changeset
49
anatofuz
parents:
diff changeset
50 uint64_t lmaOffset = 0;
anatofuz
parents:
diff changeset
51 };
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53 void addReservedSymbols();
anatofuz
parents:
diff changeset
54 llvm::StringRef getOutputSectionName(const InputSectionBase *s);
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 template <class ELFT> uint32_t calcMipsEFlags();
anatofuz
parents:
diff changeset
57
anatofuz
parents:
diff changeset
58 uint8_t getMipsFpAbiFlag(uint8_t oldFlag, uint8_t newFlag,
anatofuz
parents:
diff changeset
59 llvm::StringRef fileName);
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 bool isMipsN32Abi(const InputFile *f);
anatofuz
parents:
diff changeset
62 bool isMicroMips();
anatofuz
parents:
diff changeset
63 bool isMipsR6();
anatofuz
parents:
diff changeset
64 } // namespace elf
anatofuz
parents:
diff changeset
65 } // namespace lld
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 #endif