[AMDGPU][AsmParser][NFC] Translate parsed MIMG instructions to MCInsts automatically.
[llvm-project.git] / lld / ELF / AArch64ErrataFix.h
blobfa34beb5d7a84c93af90f7b34a265ce8a295fef6
1 //===- AArch64ErrataFix.h ---------------------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #ifndef LLD_ELF_AARCH64ERRATAFIX_H
10 #define LLD_ELF_AARCH64ERRATAFIX_H
12 #include "lld/Common/LLVM.h"
13 #include "llvm/ADT/DenseMap.h"
14 #include <vector>
16 namespace lld::elf {
18 class Defined;
19 class InputSection;
20 class InputSectionDescription;
21 class Patch843419Section;
23 class AArch64Err843419Patcher {
24 public:
25 // return true if Patches have been added to the OutputSections.
26 bool createFixes();
28 private:
29 std::vector<Patch843419Section *>
30 patchInputSectionDescription(InputSectionDescription &isd);
32 void insertPatches(InputSectionDescription &isd,
33 std::vector<Patch843419Section *> &patches);
35 void init();
37 // A cache of the mapping symbols defined by the InputSection sorted in order
38 // of ascending value with redundant symbols removed. These describe
39 // the ranges of code and data in an executable InputSection.
40 llvm::DenseMap<InputSection *, std::vector<const Defined *>> sectionMap;
42 bool initialized = false;
45 } // namespace lld::elf
47 #endif