diff options
| author | 2018-09-20 17:22:42 -0400 | |
|---|---|---|
| committer | 2018-09-20 17:22:42 -0400 | |
| commit | 1e35d8fa8f4757f91174e1c82992b7f078cf3f91 (patch) | |
| tree | 8f5b0c3ebaae6d6d7727290642706ec0135e98ff | |
| parent | Merge pull request #1358 from DarkLordZach/temp-storage (diff) | |
| parent | arm_dynarmic: Halt when BRK encountered (diff) | |
| download | yuzu-1e35d8fa8f4757f91174e1c82992b7f078cf3f91.tar.gz yuzu-1e35d8fa8f4757f91174e1c82992b7f078cf3f91.tar.xz yuzu-1e35d8fa8f4757f91174e1c82992b7f078cf3f91.zip | |
Merge pull request #1362 from MerryMage/dynarmic
externals: Update dynarmic to 171d116
| m--------- | externals/dynarmic | 0 | ||||
| -rw-r--r-- | src/core/arm/dynarmic/arm_dynarmic.cpp | 12 |
2 files changed, 12 insertions, 0 deletions
diff --git a/externals/dynarmic b/externals/dynarmic | |||
| Subproject 959446573f3adfcba173ef4b0011a4a280f18eb | Subproject 171d11659d760a4d4674d3a90698fe31ea407e2 | ||
diff --git a/src/core/arm/dynarmic/arm_dynarmic.cpp b/src/core/arm/dynarmic/arm_dynarmic.cpp index 3f072c51f..32cd5746e 100644 --- a/src/core/arm/dynarmic/arm_dynarmic.cpp +++ b/src/core/arm/dynarmic/arm_dynarmic.cpp | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #include "core/core.h" | 12 | #include "core/core.h" |
| 13 | #include "core/core_cpu.h" | 13 | #include "core/core_cpu.h" |
| 14 | #include "core/core_timing.h" | 14 | #include "core/core_timing.h" |
| 15 | #include "core/gdbstub/gdbstub.h" | ||
| 15 | #include "core/hle/kernel/process.h" | 16 | #include "core/hle/kernel/process.h" |
| 16 | #include "core/hle/kernel/svc.h" | 17 | #include "core/hle/kernel/svc.h" |
| 17 | #include "core/memory.h" | 18 | #include "core/memory.h" |
| @@ -79,6 +80,17 @@ public: | |||
| 79 | case Dynarmic::A64::Exception::SendEventLocal: | 80 | case Dynarmic::A64::Exception::SendEventLocal: |
| 80 | case Dynarmic::A64::Exception::Yield: | 81 | case Dynarmic::A64::Exception::Yield: |
| 81 | return; | 82 | return; |
| 83 | case Dynarmic::A64::Exception::Breakpoint: | ||
| 84 | if (GDBStub::IsServerEnabled()) { | ||
| 85 | parent.jit->HaltExecution(); | ||
| 86 | parent.SetPC(pc); | ||
| 87 | Kernel::Thread* thread = Kernel::GetCurrentThread(); | ||
| 88 | parent.SaveContext(thread->context); | ||
| 89 | GDBStub::Break(); | ||
| 90 | GDBStub::SendTrap(thread, 5); | ||
| 91 | return; | ||
| 92 | } | ||
| 93 | [[fallthrough]]; | ||
| 82 | default: | 94 | default: |
| 83 | ASSERT_MSG(false, "ExceptionRaised(exception = {}, pc = {:X})", | 95 | ASSERT_MSG(false, "ExceptionRaised(exception = {}, pc = {:X})", |
| 84 | static_cast<std::size_t>(exception), pc); | 96 | static_cast<std::size_t>(exception), pc); |