diff options
author | Subv <subv2112@gmail.com> | 2018-05-19 23:52:49 +0200 |
---|---|---|
committer | Subv <subv2112@gmail.com> | 2018-05-19 23:52:49 +0200 |
commit | c50393e06677e868d6a014d6ebe67057e8bdf9a7 (patch) | |
tree | 38e58c277810edebb1588591a3acf063e8ce203c /src | |
parent | Merge pull request #436 from bunnei/multi-core (diff) | |
download | yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar.gz yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar.bz2 yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar.lz yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar.xz yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.tar.zst yuzu-c50393e06677e868d6a014d6ebe67057e8bdf9a7.zip |
Diffstat (limited to 'src')
-rw-r--r-- | src/yuzu/debugger/wait_tree.cpp | 26 | ||||
-rw-r--r-- | src/yuzu/debugger/wait_tree.h | 11 |
2 files changed, 37 insertions, 0 deletions
diff --git a/src/yuzu/debugger/wait_tree.cpp b/src/yuzu/debugger/wait_tree.cpp index 8b074db5a..017bef13c 100644 --- a/src/yuzu/debugger/wait_tree.cpp +++ b/src/yuzu/debugger/wait_tree.cpp @@ -98,6 +98,30 @@ std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeMutexInfo::GetChildren() cons return list; } +WaitTreeCallstack::WaitTreeCallstack(const Kernel::Thread& thread) : thread(thread) {} + +QString WaitTreeCallstack::GetText() const { + return tr("Call stack"); +} + +std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeCallstack::GetChildren() const { + std::vector<std::unique_ptr<WaitTreeItem>> list; + + constexpr size_t BaseRegister = 29; + u64 base_pointer = thread.context.cpu_registers[BaseRegister]; + + while (base_pointer != 0) { + u64 lr = Memory::Read64(base_pointer + sizeof(u64)); + if (lr == 0) + break; + list.push_back( + std::make_unique<WaitTreeText>(tr("0x%1").arg(lr - sizeof(u32), 16, 16, QChar('0')))); + base_pointer = Memory::Read64(base_pointer); + } + + return list; +} + WaitTreeWaitObject::WaitTreeWaitObject(const Kernel::WaitObject& o) : object(o) {} bool WaitTreeExpandableItem::IsExpandable() const { @@ -269,6 +293,8 @@ std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeThread::GetChildren() const { thread.IsSleepingOnWaitAll())); } + list.push_back(std::make_unique<WaitTreeCallstack>(thread)); + return list; } diff --git a/src/yuzu/debugger/wait_tree.h b/src/yuzu/debugger/wait_tree.h index 300ba9ae4..10fc9e968 100644 --- a/src/yuzu/debugger/wait_tree.h +++ b/src/yuzu/debugger/wait_tree.h @@ -73,6 +73,17 @@ private: Kernel::SharedPtr<Kernel::Thread> owner; }; +class WaitTreeCallstack : public WaitTreeExpandableItem { + Q_OBJECT +public: + explicit WaitTreeCallstack(const Kernel::Thread& thread); + QString GetText() const override; + std::vector<std::unique_ptr<WaitTreeItem>> GetChildren() const override; + +private: + const Kernel::Thread& thread; +}; + class WaitTreeWaitObject : public WaitTreeExpandableItem { Q_OBJECT public: |