[CodeGenPrepare] Handle all debug calls in dupRetToEnableTailCallOpts()
[llvm-complete.git] / unittests / tools / llvm-exegesis / PowerPC / AnalysisTest.cpp
bloba7d2c6d95e649809f357b8c5c7486b3e0386cabf
1 //===-- AnalysisTest.cpp ---------------------------------------*- 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 #include "Analysis.h"
11 #include <cassert>
12 #include <memory>
14 #include "llvm/Support/TargetRegistry.h"
15 #include "llvm/Support/TargetSelect.h"
16 #include "gmock/gmock.h"
17 #include "gtest/gtest.h"
19 namespace llvm{
20 namespace exegesis {
21 namespace {
23 using testing::Pair;
24 using testing::UnorderedElementsAre;
26 class AnalysisTest : public ::testing::Test {
27 protected:
28 AnalysisTest() {
29 const std::string TT = "powerpc64le-unknown-linux";
30 std::string error;
31 const llvm::Target *const TheTarget =
32 llvm::TargetRegistry::lookupTarget(TT, error);
33 if (!TheTarget) {
34 llvm::errs() << error << "\n";
35 return;
37 STI.reset(TheTarget->createMCSubtargetInfo(TT, "pwr9", ""));
39 // Compute the ProxResIdx of ports uses in tests.
40 const auto &SM = STI->getSchedModel();
41 for (unsigned I = 0, E = SM.getNumProcResourceKinds(); I < E; ++I) {
42 const std::string Name = SM.getProcResource(I)->Name;
43 if (Name == "ALU") {
44 ALUIdx = I;
45 } else if (Name == "ALUE") {
46 ALUEIdx = I;
47 } else if (Name == "ALUO") {
48 ALUOIdx = I;
49 } else if (Name == "IP_AGEN") {
50 IPAGENIdx = I;
53 EXPECT_NE(ALUIdx, 0);
54 EXPECT_NE(ALUEIdx, 0);
55 EXPECT_NE(ALUOIdx, 0);
56 EXPECT_NE(IPAGENIdx, 0);
59 static void SetUpTestCase() {
60 LLVMInitializePowerPCTargetInfo();
61 LLVMInitializePowerPCTarget();
62 LLVMInitializePowerPCTargetMC();
65 protected:
66 std::unique_ptr<const llvm::MCSubtargetInfo> STI;
67 uint16_t ALUIdx = 0;
68 uint16_t ALUEIdx = 0;
69 uint16_t ALUOIdx = 0;
70 uint16_t IPAGENIdx = 0;
73 TEST_F(AnalysisTest, ComputeIdealizedProcResPressure_2ALU) {
74 const auto Pressure =
75 computeIdealizedProcResPressure(STI->getSchedModel(), {{ALUIdx, 2}});
76 EXPECT_THAT(Pressure, UnorderedElementsAre(Pair(ALUIdx, 2.0)));
79 TEST_F(AnalysisTest, ComputeIdealizedProcResPressure_1ALUE) {
80 const auto Pressure =
81 computeIdealizedProcResPressure(STI->getSchedModel(), {{ALUEIdx, 2}});
82 EXPECT_THAT(Pressure, UnorderedElementsAre(Pair(ALUEIdx, 2.0)));
85 TEST_F(AnalysisTest, ComputeIdealizedProcResPressure_1ALU1IPAGEN) {
86 const auto Pressure =
87 computeIdealizedProcResPressure(STI->getSchedModel(), {{ALUIdx, 1}, {IPAGENIdx, 1}});
88 EXPECT_THAT(Pressure, UnorderedElementsAre(Pair(ALUIdx, 1.0),Pair(IPAGENIdx, 1)));
90 } // namespace
91 } // namespace exegesis
92 } // namespace llvm