aboutsummaryrefslogtreecommitdiff
path: root/llvm/tools/llvm-profgen/ProfiledBinary.cpp
diff options
context:
space:
mode:
authorFangrui Song <i@maskray.me>2022-12-17 00:42:05 +0000
committerFangrui Song <i@maskray.me>2022-12-17 00:42:05 +0000
commit21c4dc7997b83e83f87c26a97c104dcdd95f1d0f (patch)
treed206072152eb158d6d0eb6c3b93abca9aeb101c6 /llvm/tools/llvm-profgen/ProfiledBinary.cpp
parent2e9c3fe6fcfd7b4672facec87dceb76ff3c83566 (diff)
downloadllvm-21c4dc7997b83e83f87c26a97c104dcdd95f1d0f.zip
llvm-21c4dc7997b83e83f87c26a97c104dcdd95f1d0f.tar.gz
llvm-21c4dc7997b83e83f87c26a97c104dcdd95f1d0f.tar.bz2
std::optional::value => operator*/operator->
value() has undesired exception checking semantics and calls __throw_bad_optional_access in libc++. Moreover, the API is unavailable without _LIBCPP_NO_EXCEPTIONS on older Mach-O platforms (see _LIBCPP_AVAILABILITY_BAD_OPTIONAL_ACCESS). This fixes clang.
Diffstat (limited to 'llvm/tools/llvm-profgen/ProfiledBinary.cpp')
-rw-r--r--llvm/tools/llvm-profgen/ProfiledBinary.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/llvm/tools/llvm-profgen/ProfiledBinary.cpp b/llvm/tools/llvm-profgen/ProfiledBinary.cpp
index 265d088..20837f2 100644
--- a/llvm/tools/llvm-profgen/ProfiledBinary.cpp
+++ b/llvm/tools/llvm-profgen/ProfiledBinary.cpp
@@ -101,7 +101,7 @@ BinarySizeContextTracker::getFuncSizeForContext(const ContextTrieNode *Node) {
PrevNode = CurrNode;
CurrNode = CurrNode->getChildContext(CallSiteLoc, Node->getFuncName());
if (CurrNode && CurrNode->getFunctionSize())
- Size = CurrNode->getFunctionSize().value();
+ Size = *CurrNode->getFunctionSize();
CallSiteLoc = Node->getCallSiteLoc();
Node = Node->getParentContext();
}
@@ -115,12 +115,12 @@ BinarySizeContextTracker::getFuncSizeForContext(const ContextTrieNode *Node) {
while (!Size && CurrNode && !CurrNode->getAllChildContext().empty()) {
CurrNode = &CurrNode->getAllChildContext().begin()->second;
if (CurrNode->getFunctionSize())
- Size = CurrNode->getFunctionSize().value();
+ Size = *CurrNode->getFunctionSize();
}
}
assert(Size && "We should at least find one context size.");
- return Size.value();
+ return *Size;
}
void BinarySizeContextTracker::trackInlineesOptimizedAway(