1 //===- llvm/unittest/CodeGen/AMDGPUMetadataTest.cpp -----------------------===//
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
7 //===----------------------------------------------------------------------===//
10 /// Test that amdgpu metadata that is added in a pass is read by the asm emitter
11 /// and stored in the ELF.
13 //===----------------------------------------------------------------------===//
15 #include "llvm/IR/LegacyPassManager.h"
16 #include "llvm/MC/TargetRegistry.h"
17 #include "llvm/Pass.h"
18 #include "llvm/Support/TargetSelect.h"
19 #include "llvm/Target/TargetMachine.h"
20 #include "gtest/gtest.h"
25 // Pass that adds global metadata
26 struct AddMetadataPass
: public ModulePass
{
27 std::string PalMDString
;
31 AddMetadataPass(std::string PalMDString
)
32 : ModulePass(ID
), PalMDString(PalMDString
) {}
33 bool runOnModule(Module
&M
) override
{
34 auto &Ctx
= M
.getContext();
35 auto *MD
= M
.getOrInsertNamedMetadata("amdgpu.pal.metadata.msgpack");
36 auto *PalMD
= MDString::get(Ctx
, PalMDString
);
37 auto *TMD
= MDTuple::get(Ctx
, {PalMD
});
42 char AddMetadataPass::ID
= 0;
43 } // end anonymous namespace
45 class AMDGPUSelectionDAGTest
: public testing::Test
{
47 static void SetUpTestCase() {
48 InitializeAllTargets();
49 InitializeAllTargetMCs();
52 void SetUp() override
{
54 const Target
*T
= TargetRegistry::lookupTarget("amdgcn--amdpal", Error
);
58 TargetOptions Options
;
59 TM
= std::unique_ptr
<LLVMTargetMachine
>(
60 static_cast<LLVMTargetMachine
*>(T
->createTargetMachine(
61 "amdgcn--amdpal", "gfx1010", "", Options
, std::nullopt
)));
66 std::unique_ptr
<Module
> M(new Module("TestModule", Context
));
67 M
->setDataLayout(TM
->createDataLayout());
69 legacy::PassManager PM
;
70 PM
.add(new AddMetadataPass(PalMDString
));
71 raw_svector_ostream
OutStream(Elf
);
72 if (TM
->addPassesToEmitFile(PM
, OutStream
, nullptr,
73 CodeGenFileType::ObjectFile
))
74 report_fatal_error("Target machine cannot emit a file of this type");
79 static std::string PalMDString
;
82 std::unique_ptr
<LLVMTargetMachine
> TM
;
83 std::unique_ptr
<Module
> M
;
84 SmallString
<1024> Elf
;
86 std::string
AMDGPUSelectionDAGTest::PalMDString
=
88 "amdpal.pipelines\x91\x81\xA4.api\xA6Vulkan";
90 TEST_F(AMDGPUSelectionDAGTest
, checkMetadata
) {
91 // Check that the string is contained in the ELF
92 EXPECT_NE(Elf
.find("Vulkan"), std::string::npos
);
95 } // end namespace llvm