annotate llvm/unittests/CodeGen/TestAsmPrinter.cpp @ 235:edfff9242030 cbc-llvm13

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 21 Jul 2021 11:30:30 +0900
parents 2e18cbf3894f
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 //===--- unittests/CodeGen/TestAsmPrinter.cpp -------------------*- C++ -*-===//
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 //
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 //
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 #include "TestAsmPrinter.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 #include "llvm/ADT/Triple.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 #include "llvm/CodeGen/AsmPrinter.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "llvm/MC/MCAsmInfo.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 #include "llvm/MC/MCContext.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 #include "llvm/Support/TargetRegistry.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 #include "llvm/Target/TargetLoweringObjectFile.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 #include "llvm/Target/TargetMachine.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 using namespace llvm;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 using ::testing::StrictMock;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 // Note: a non-const reference argument cannot be passed through
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 // testing::StrictMock, thus, we pass a pointer and dereference it here.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 MockMCStreamer::MockMCStreamer(MCContext *Ctx) : MCStreamer(*Ctx) {}
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 MockMCStreamer::~MockMCStreamer() = default;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 TestAsmPrinter::TestAsmPrinter() = default;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 TestAsmPrinter::~TestAsmPrinter() = default;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 llvm::Expected<std::unique_ptr<TestAsmPrinter>>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 TestAsmPrinter::create(const std::string &TripleStr, uint16_t DwarfVersion,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 dwarf::DwarfFormat DwarfFormat) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 std::string ErrorStr;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 const Target *TheTarget = TargetRegistry::lookupTarget(TripleStr, ErrorStr);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 if (!TheTarget)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 return std::unique_ptr<TestAsmPrinter>();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 std::unique_ptr<TestAsmPrinter> TestPrinter(new TestAsmPrinter);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 if (llvm::Error E =
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 TestPrinter->init(TheTarget, TripleStr, DwarfVersion, DwarfFormat))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 return std::move(E);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 return std::move(TestPrinter);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 // Note:: based on dwarfgen::Generator::init() from
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 // llvm/unittests/DebugInfo/DWARF/DwarfGenerator.cpp
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 llvm::Error TestAsmPrinter::init(const Target *TheTarget, StringRef TripleName,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 uint16_t DwarfVersion,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 dwarf::DwarfFormat DwarfFormat) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 TM.reset(TheTarget->createTargetMachine(TripleName, "", "", TargetOptions(),
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 None));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 if (!TM)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 return make_error<StringError>("no target machine for target " + TripleName,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 inconvertibleErrorCode());
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 Triple TheTriple(TripleName);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 MC.reset(new MCContext(TheTriple, TM->getMCAsmInfo(), TM->getMCRegisterInfo(),
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 TM->getMCSubtargetInfo()));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 TM->getObjFileLowering()->Initialize(*MC, *TM);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 MC->setObjectFileInfo(TM->getObjFileLowering());
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 MS = new StrictMock<MockMCStreamer>(MC.get());
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 Asm.reset(
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 TheTarget->createAsmPrinter(*TM, std::unique_ptr<MockMCStreamer>(MS)));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 if (!Asm)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 return make_error<StringError>("no asm printer for target " + TripleName,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 inconvertibleErrorCode());
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 // Set the DWARF version correctly on all classes that we use.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 MC->setDwarfVersion(DwarfVersion);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 Asm->setDwarfVersion(DwarfVersion);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 // Set the DWARF format.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 MC->setDwarfFormat(DwarfFormat);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 return Error::success();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 void TestAsmPrinter::setDwarfUsesRelocationsAcrossSections(bool Enable) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 struct HackMCAsmInfo : MCAsmInfo {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 void setDwarfUsesRelocationsAcrossSections(bool Enable) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 DwarfUsesRelocationsAcrossSections = Enable;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 };
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 static_cast<HackMCAsmInfo *>(const_cast<MCAsmInfo *>(TM->getMCAsmInfo()))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 ->setDwarfUsesRelocationsAcrossSections(Enable);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90 }