Subversion Repositories QNX 8.QNX8 LLVM/Clang compiler suite

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
14 pmbaty 1
//===- PseudoProbe.h - Pseudo Probe IR Helpers ------------------*- 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
//===----------------------------------------------------------------------===//
8
//
9
// Pseudo probe IR intrinsic and dwarf discriminator manipulation routines.
10
//
11
//===----------------------------------------------------------------------===//
12
 
13
#ifndef LLVM_IR_PSEUDOPROBE_H
14
#define LLVM_IR_PSEUDOPROBE_H
15
 
16
#include <cassert>
17
#include <cstdint>
18
#include <limits>
19
#include <optional>
20
 
21
namespace llvm {
22
 
23
class Instruction;
24
 
25
constexpr const char *PseudoProbeDescMetadataName = "llvm.pseudo_probe_desc";
26
 
27
enum class PseudoProbeReservedId { Invalid = 0, Last = Invalid };
28
 
29
enum class PseudoProbeType { Block = 0, IndirectCall, DirectCall };
30
 
31
enum class PseudoProbeAttributes {
32
  Reserved = 0x1,
33
  Sentinel = 0x2, // A place holder for split function entry address.
34
};
35
 
36
// The saturated distrution factor representing 100% for block probes.
37
constexpr static uint64_t PseudoProbeFullDistributionFactor =
38
    std::numeric_limits<uint64_t>::max();
39
 
40
struct PseudoProbeDwarfDiscriminator {
41
public:
42
  // The following APIs encodes/decodes per-probe information to/from a
43
  // 32-bit integer which is organized as:
44
  //  [2:0] - 0x7, this is reserved for regular discriminator,
45
  //          see DWARF discriminator encoding rule
46
  //  [18:3] - probe id
47
  //  [25:19] - probe distribution factor
48
  //  [28:26] - probe type, see PseudoProbeType
49
  //  [31:29] - reserved for probe attributes
50
  static uint32_t packProbeData(uint32_t Index, uint32_t Type, uint32_t Flags,
51
                                uint32_t Factor) {
52
    assert(Index <= 0xFFFF && "Probe index too big to encode, exceeding 2^16");
53
    assert(Type <= 0x7 && "Probe type too big to encode, exceeding 7");
54
    assert(Flags <= 0x7);
55
    assert(Factor <= 100 &&
56
           "Probe distribution factor too big to encode, exceeding 100");
57
    return (Index << 3) | (Factor << 19) | (Type << 26) | 0x7;
58
  }
59
 
60
  static uint32_t extractProbeIndex(uint32_t Value) {
61
    return (Value >> 3) & 0xFFFF;
62
  }
63
 
64
  static uint32_t extractProbeType(uint32_t Value) {
65
    return (Value >> 26) & 0x7;
66
  }
67
 
68
  static uint32_t extractProbeAttributes(uint32_t Value) {
69
    return (Value >> 29) & 0x7;
70
  }
71
 
72
  static uint32_t extractProbeFactor(uint32_t Value) {
73
    return (Value >> 19) & 0x7F;
74
  }
75
 
76
  // The saturated distrution factor representing 100% for callsites.
77
  constexpr static uint8_t FullDistributionFactor = 100;
78
};
79
 
80
struct PseudoProbe {
81
  uint32_t Id;
82
  uint32_t Type;
83
  uint32_t Attr;
84
  // Distribution factor that estimates the portion of the real execution count.
85
  // A saturated distribution factor stands for 1.0 or 100%. A pesudo probe has
86
  // a factor with the value ranged from 0.0 to 1.0.
87
  float Factor;
88
};
89
 
90
static inline bool isSentinelProbe(uint32_t Flags) {
91
  return Flags & (uint32_t)PseudoProbeAttributes::Sentinel;
92
}
93
 
94
std::optional<PseudoProbe> extractProbe(const Instruction &Inst);
95
 
96
void setProbeDistributionFactor(Instruction &Inst, float Factor);
97
} // end namespace llvm
98
 
99
#endif // LLVM_IR_PSEUDOPROBE_H