You've already forked linux-packaging-mono
acceptance-tests
data
debian
docs
external
Newtonsoft.Json
api-doc-tools
api-snapshot
aspnetwebstack
bdwgc
binary-reference-assemblies
bockbuild
boringssl
cecil
cecil-legacy
corefx
corert
helix-binaries
ikdasm
ikvm
illinker-test-assets
linker
llvm-project
clang
clang-tools-extra
compiler-rt
eng
libcxx
libcxxabi
libunwind
lld
lldb
cmake
docs
examples
include
lit
lldb.xcodeproj
lldb.xcworkspace
packages
resources
scripts
source
API
Breakpoint
Commands
Core
DataFormatters
Expression
Host
Initialization
Interpreter
Plugins
Symbol
Target
ABI.cpp
CMakeLists.txt
CPPLanguageRuntime.cpp
ExecutionContext.cpp
FileAction.cpp
InstrumentationRuntime.cpp
InstrumentationRuntimeStopInfo.cpp
JITLoader.cpp
JITLoaderList.cpp
Language.cpp
LanguageRuntime.cpp
Memory.cpp
MemoryHistory.cpp
ModuleCache.cpp
ObjCLanguageRuntime.cpp
OperatingSystem.cpp
PathMappingList.cpp
Platform.cpp
Process.cpp.REMOVED.git-id
ProcessInfo.cpp
ProcessLaunchInfo.cpp
Queue.cpp
QueueItem.cpp
QueueList.cpp
RegisterContext.cpp
RegisterNumber.cpp
SectionLoadHistory.cpp
SectionLoadList.cpp
StackFrame.cpp
StackFrameList.cpp
StackID.cpp
StopInfo.cpp
StructuredDataPlugin.cpp
SystemRuntime.cpp
Target.cpp.REMOVED.git-id
TargetList.cpp
Thread.cpp
ThreadCollection.cpp
ThreadList.cpp
ThreadPlan.cpp
ThreadPlanBase.cpp
ThreadPlanCallFunction.cpp
ThreadPlanCallFunctionUsingABI.cpp
ThreadPlanCallOnFunctionExit.cpp
ThreadPlanCallUserExpression.cpp
ThreadPlanPython.cpp
ThreadPlanRunToAddress.cpp
ThreadPlanShouldStopHere.cpp
ThreadPlanStepInRange.cpp
ThreadPlanStepInstruction.cpp
ThreadPlanStepOut.cpp
ThreadPlanStepOverBreakpoint.cpp
ThreadPlanStepOverRange.cpp
ThreadPlanStepRange.cpp
ThreadPlanStepThrough.cpp
ThreadPlanStepUntil.cpp
ThreadPlanTracer.cpp
ThreadSpec.cpp
UnixSignals.cpp
UnwindAssembly.cpp
Utility
CMakeLists.txt
lldb.cpp
third_party
tools
unittests
utils
www
.arcconfig
.clang-format
.gitignore
CMakeLists.txt
CODE_OWNERS.txt
INSTALL.txt
LICENSE.TXT
use_lldb_suite_root.py
llvm
nuget
openmp
polly
Directory.Build.props
Directory.Build.targets
NuGet.config
azure-pipelines.yml
build.cmd
build.sh
dir.common.props
global.json
llvm.proj
mxe-Win64.cmake.in
nuget-buildtasks
nunit-lite
roslyn-binaries
rx
xunit-binaries
how-to-bump-roslyn-binaries.md
ikvm-native
llvm
m4
man
mcs
mono
msvc
netcore
po
runtime
samples
scripts
support
tools
COPYING.LIB
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
code_of_conduct.md
compile
config.guess
config.h.in
config.rpath
config.sub
configure.REMOVED.git-id
configure.ac.REMOVED.git-id
depcomp
install-sh
ltmain.sh.REMOVED.git-id
missing
mkinstalldirs
mono-uninstalled.pc.in
test-driver
winconfig.h
104 lines
3.5 KiB
C++
104 lines
3.5 KiB
C++
![]() |
//===-- StackID.cpp ---------------------------------------------*- C++ -*-===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is distributed under the University of Illinois Open Source
|
||
|
// License. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
// C Includes
|
||
|
// C++ Includes
|
||
|
// Other libraries and framework includes
|
||
|
// Project includes
|
||
|
#include "lldb/Target/StackID.h"
|
||
|
#include "lldb/Symbol/Block.h"
|
||
|
#include "lldb/Symbol/Symbol.h"
|
||
|
#include "lldb/Symbol/SymbolContext.h"
|
||
|
#include "lldb/Utility/Stream.h"
|
||
|
|
||
|
using namespace lldb_private;
|
||
|
|
||
|
void StackID::Dump(Stream *s) {
|
||
|
s->Printf("StackID (pc = 0x%16.16" PRIx64 ", cfa = 0x%16.16" PRIx64
|
||
|
", symbol_scope = %p",
|
||
|
m_pc, m_cfa, static_cast<void *>(m_symbol_scope));
|
||
|
if (m_symbol_scope) {
|
||
|
SymbolContext sc;
|
||
|
|
||
|
m_symbol_scope->CalculateSymbolContext(&sc);
|
||
|
if (sc.block)
|
||
|
s->Printf(" (Block {0x%8.8" PRIx64 "})", sc.block->GetID());
|
||
|
else if (sc.symbol)
|
||
|
s->Printf(" (Symbol{0x%8.8x})", sc.symbol->GetID());
|
||
|
}
|
||
|
s->PutCString(") ");
|
||
|
}
|
||
|
|
||
|
bool lldb_private::operator==(const StackID &lhs, const StackID &rhs) {
|
||
|
if (lhs.GetCallFrameAddress() != rhs.GetCallFrameAddress())
|
||
|
return false;
|
||
|
|
||
|
SymbolContextScope *lhs_scope = lhs.GetSymbolContextScope();
|
||
|
SymbolContextScope *rhs_scope = rhs.GetSymbolContextScope();
|
||
|
|
||
|
// Only compare the PC values if both symbol context scopes are nullptr
|
||
|
if (lhs_scope == nullptr && rhs_scope == nullptr)
|
||
|
return lhs.GetPC() == rhs.GetPC();
|
||
|
|
||
|
return lhs_scope == rhs_scope;
|
||
|
}
|
||
|
|
||
|
bool lldb_private::operator!=(const StackID &lhs, const StackID &rhs) {
|
||
|
if (lhs.GetCallFrameAddress() != rhs.GetCallFrameAddress())
|
||
|
return true;
|
||
|
|
||
|
SymbolContextScope *lhs_scope = lhs.GetSymbolContextScope();
|
||
|
SymbolContextScope *rhs_scope = rhs.GetSymbolContextScope();
|
||
|
|
||
|
if (lhs_scope == nullptr && rhs_scope == nullptr)
|
||
|
return lhs.GetPC() != rhs.GetPC();
|
||
|
|
||
|
return lhs_scope != rhs_scope;
|
||
|
}
|
||
|
|
||
|
bool lldb_private::operator<(const StackID &lhs, const StackID &rhs) {
|
||
|
const lldb::addr_t lhs_cfa = lhs.GetCallFrameAddress();
|
||
|
const lldb::addr_t rhs_cfa = rhs.GetCallFrameAddress();
|
||
|
|
||
|
// FIXME: We are assuming that the stacks grow downward in memory. That's not
|
||
|
// necessary, but true on
|
||
|
// all the machines we care about at present. If this changes, we'll have to
|
||
|
// deal with that. The ABI is the
|
||
|
// agent who knows this ordering, but the StackID has no access to the ABI.
|
||
|
// The most straightforward way
|
||
|
// to handle this is to add a "m_grows_downward" bool to the StackID, and set
|
||
|
// it in the constructor.
|
||
|
// But I'm not going to waste a bool per StackID on this till we need it.
|
||
|
|
||
|
if (lhs_cfa != rhs_cfa)
|
||
|
return lhs_cfa < rhs_cfa;
|
||
|
|
||
|
SymbolContextScope *lhs_scope = lhs.GetSymbolContextScope();
|
||
|
SymbolContextScope *rhs_scope = rhs.GetSymbolContextScope();
|
||
|
|
||
|
if (lhs_scope != nullptr && rhs_scope != nullptr) {
|
||
|
// Same exact scope, lhs is not less than (younger than rhs)
|
||
|
if (lhs_scope == rhs_scope)
|
||
|
return false;
|
||
|
|
||
|
SymbolContext lhs_sc;
|
||
|
SymbolContext rhs_sc;
|
||
|
lhs_scope->CalculateSymbolContext(&lhs_sc);
|
||
|
rhs_scope->CalculateSymbolContext(&rhs_sc);
|
||
|
|
||
|
// Items with the same function can only be compared
|
||
|
if (lhs_sc.function == rhs_sc.function && lhs_sc.function != nullptr &&
|
||
|
lhs_sc.block != nullptr && rhs_sc.function != nullptr &&
|
||
|
rhs_sc.block != nullptr) {
|
||
|
return rhs_sc.block->Contains(lhs_sc.block);
|
||
|
}
|
||
|
}
|
||
|
return false;
|
||
|
}
|