forked from intel/llvm
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[CSSPGO] Consume pseudo-probe-based AutoFDO profile
This change enables pseudo-probe-based sample counts to be consumed by the sample profile loader under the regular `-fprofile-sample-use` switch with minimal adjustments to the existing sample file formats. After the counts are imported, a probe helper, aka, a `PseudoProbeManager` object, is automatically launched to verify the CFG checksum of every function in the current compilation against the corresponding checksum from the profile. Mismatched checksums will cause a function profile to be slipped. A `SampleProfileProber` pass is scheduled before any of the `SampleProfileLoader` instances so that the CFG checksums as well as probe mappings are available during the profile loading time. The `PseudoProbeManager` object is set up right after the profile reading is done. In the future a CFG-based fuzzy matching could be done in `PseudoProbeManager`. Samples will be applied only to pseudo probe instructions as well as probed callsites once the checksum verification goes through. Those instructions are processed in the same way that regular instructions would be processed in the line-number-based scenario. In other words, a function is processed in a regular way as if it was reduced to just containing pseudo probes (block probes and callsites). **Adjustment to profile format ** A CFG checksum field is being added to the existing AutoFDO profile formats. So far only the text format and the extended binary format are supported. For the text format, a new line like ``` !CFGChecksum: 12345 ``` is added to the end of the body sample lines. For the extended binary profile format, we introduce a metadata section to store the checksum map from function names to their CFG checksums. Differential Revision: https://reviews.llvm.org/D92347
- Loading branch information
Showing
19 changed files
with
654 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
//===- PseudoProbe.cpp - Pseudo Probe Helpers -----------------------------===// | ||
// | ||
// 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 | ||
// | ||
//===----------------------------------------------------------------------===// | ||
// | ||
// This file implements the helpers to manipulate pseudo probe IR intrinsic | ||
// calls. | ||
// | ||
//===----------------------------------------------------------------------===// | ||
|
||
#include "llvm/IR/PseudoProbe.h" | ||
#include "llvm/IR/DebugInfoMetadata.h" | ||
#include "llvm/IR/IRBuilder.h" | ||
#include "llvm/IR/Instruction.h" | ||
|
||
using namespace llvm; | ||
|
||
namespace llvm { | ||
|
||
Optional<PseudoProbe> extractProbeFromDiscriminator(const Instruction &Inst) { | ||
assert(isa<CallBase>(&Inst) && !isa<IntrinsicInst>(&Inst) && | ||
"Only call instructions should have pseudo probe encodes as their " | ||
"Dwarf discriminators"); | ||
if (const DebugLoc &DLoc = Inst.getDebugLoc()) { | ||
const DILocation *DIL = DLoc; | ||
auto Discriminator = DIL->getDiscriminator(); | ||
if (DILocation::isPseudoProbeDiscriminator(Discriminator)) { | ||
PseudoProbe Probe; | ||
Probe.Id = | ||
PseudoProbeDwarfDiscriminator::extractProbeIndex(Discriminator); | ||
Probe.Type = | ||
PseudoProbeDwarfDiscriminator::extractProbeType(Discriminator); | ||
Probe.Attr = | ||
PseudoProbeDwarfDiscriminator::extractProbeAttributes(Discriminator); | ||
return Probe; | ||
} | ||
} | ||
return None; | ||
} | ||
|
||
Optional<PseudoProbe> extractProbe(const Instruction &Inst) { | ||
if (const auto *II = dyn_cast<PseudoProbeInst>(&Inst)) { | ||
PseudoProbe Probe; | ||
Probe.Id = II->getIndex()->getZExtValue(); | ||
Probe.Type = (uint32_t)PseudoProbeType::Block; | ||
Probe.Attr = II->getAttributes()->getZExtValue(); | ||
return Probe; | ||
} | ||
|
||
if (isa<CallBase>(&Inst) && !isa<IntrinsicInst>(&Inst)) | ||
return extractProbeFromDiscriminator(Inst); | ||
|
||
return None; | ||
} | ||
} // namespace llvm |
Oops, something went wrong.