mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-30 13:16:07 +00:00

The `llvm-profdata order` command is used to compute a function order using traces from the input profile. Add the `--num-test-traces` flag to keep aside N traces to evalute this order. These test traces are assumed to be the actual function execution order in some experiment. The output is a number that represents how many page faults we got. Lower is better. I tested on a large profile I already had. ``` llvm-profdata order default.profdata --num-test-traces=30 # Ordered 149103 functions # Total area under the page fault curve: 2.271827e+09 ... ``` I also improved `TemporalProfTraceTy::createBPFunctionNodes()` in a few ways: * Simplified how `UN`s are computed * Change how the initial `Node` order is computed * Filter out rare and common `UN`s * Output vector is an aliased argument instead of a return These changes slightly improved the evaluation in my test. ``` llvm-profdata order default.profdata --num-test-traces=30 # Ordered 149103 functions # Total area under the page fault curve: 2.268586e+09 ... ```
62 lines
2.3 KiB
C++
62 lines
2.3 KiB
C++
//===- BPFunctionNodeTest.cpp - BPFunctionNode tests ----------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/ProfileData/InstrProf.h"
|
|
#include "llvm/Support/BalancedPartitioning.h"
|
|
#include "gmock/gmock.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
using testing::Field;
|
|
using testing::UnorderedElementsAre;
|
|
using testing::UnorderedElementsAreArray;
|
|
|
|
namespace llvm {
|
|
|
|
void PrintTo(const BPFunctionNode &Node, std::ostream *OS) {
|
|
raw_os_ostream ROS(*OS);
|
|
Node.dump(ROS);
|
|
}
|
|
|
|
TEST(BPFunctionNodeTest, Basic) {
|
|
auto NodeIs = [](BPFunctionNode::IDT Id,
|
|
ArrayRef<BPFunctionNode::UtilityNodeT> UNs) {
|
|
return AllOf(Field("Id", &BPFunctionNode::Id, Id),
|
|
Field("UtilityNodes", &BPFunctionNode::UtilityNodes,
|
|
UnorderedElementsAreArray(UNs)));
|
|
};
|
|
|
|
std::vector<BPFunctionNode> Nodes;
|
|
TemporalProfTraceTy::createBPFunctionNodes(
|
|
{TemporalProfTraceTy({0, 1, 2, 3})}, Nodes, /*RemoveOutlierUNs=*/false);
|
|
// Utility nodes that are too infrequent or too prevalent are filtered out.
|
|
EXPECT_THAT(Nodes,
|
|
UnorderedElementsAre(NodeIs(0, {0, 1, 2}), NodeIs(1, {1, 2}),
|
|
NodeIs(2, {2}), NodeIs(3, {2})));
|
|
|
|
Nodes.clear();
|
|
TemporalProfTraceTy::createBPFunctionNodes(
|
|
{TemporalProfTraceTy({0, 1, 2, 3, 4}), TemporalProfTraceTy({4, 2})},
|
|
Nodes, /*RemoveOutlierUNs=*/false);
|
|
|
|
EXPECT_THAT(Nodes,
|
|
UnorderedElementsAre(NodeIs(0, {0, 1, 2, 3}),
|
|
NodeIs(1, {1, 2, 3}), NodeIs(2, {2, 3, 5}),
|
|
NodeIs(3, {2, 3}), NodeIs(4, {3, 4, 5})));
|
|
|
|
Nodes.clear();
|
|
TemporalProfTraceTy::createBPFunctionNodes(
|
|
{TemporalProfTraceTy({0, 1, 2, 3, 4}), TemporalProfTraceTy({4, 2})},
|
|
Nodes, /*RemoveOutlierUNs=*/true);
|
|
|
|
EXPECT_THAT(Nodes, UnorderedElementsAre(NodeIs(0, {1}), NodeIs(1, {1}),
|
|
NodeIs(2, {5}), NodeIs(3, {}),
|
|
NodeIs(4, {5})));
|
|
}
|
|
|
|
} // end namespace llvm
|