1 //===-- AnalysisTest.cpp ---------------------------------------*- C++ -*-===//
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 //===----------------------------------------------------------------------===//
14 #include "llvm/Support/TargetRegistry.h"
15 #include "llvm/Support/TargetSelect.h"
16 #include "gmock/gmock.h"
17 #include "gtest/gtest.h"
24 using testing::UnorderedElementsAre
;
26 class AnalysisTest
: public ::testing::Test
{
29 const std::string TT
= "powerpc64le-unknown-linux";
31 const llvm::Target
*const TheTarget
=
32 llvm::TargetRegistry::lookupTarget(TT
, error
);
34 llvm::errs() << error
<< "\n";
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
;
45 } else if (Name
== "ALUE") {
47 } else if (Name
== "ALUO") {
49 } else if (Name
== "IP_AGEN") {
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();
66 std::unique_ptr
<const llvm::MCSubtargetInfo
> STI
;
70 uint16_t IPAGENIdx
= 0;
73 TEST_F(AnalysisTest
, ComputeIdealizedProcResPressure_2ALU
) {
75 computeIdealizedProcResPressure(STI
->getSchedModel(), {{ALUIdx
, 2}});
76 EXPECT_THAT(Pressure
, UnorderedElementsAre(Pair(ALUIdx
, 2.0)));
79 TEST_F(AnalysisTest
, ComputeIdealizedProcResPressure_1ALUE
) {
81 computeIdealizedProcResPressure(STI
->getSchedModel(), {{ALUEIdx
, 2}});
82 EXPECT_THAT(Pressure
, UnorderedElementsAre(Pair(ALUEIdx
, 2.0)));
85 TEST_F(AnalysisTest
, ComputeIdealizedProcResPressure_1ALU1IPAGEN
) {
87 computeIdealizedProcResPressure(STI
->getSchedModel(), {{ALUIdx
, 1}, {IPAGENIdx
, 1}});
88 EXPECT_THAT(Pressure
, UnorderedElementsAre(Pair(ALUIdx
, 1.0),Pair(IPAGENIdx
, 1)));
91 } // namespace exegesis