diff options
| author | gdkchan <gab.dark.100@gmail.com> | 2018-10-20 19:07:52 -0300 |
|---|---|---|
| committer | Ac_K <Acoustik666@gmail.com> | 2018-10-20 22:07:52 +0000 |
| commit | 2cb8541462e3cc31e9a4ffe63f430168c0c747d1 (patch) | |
| tree | fa334b97c96e4541cf3bd6bc0913c70d57c4370d /Ryujinx.HLE/HOS/Process.cs | |
| parent | 0e1e094b7a8f0134831fc4cebdb0841b9c10fe6a (diff) | |
Print stack trace on invalid memory accesses (#461)
* Print stack trace on invalid memory accesses
* Rebased, change code region base address for 39-bits address space, print stack trace on break and undefined instructions too
Diffstat (limited to 'Ryujinx.HLE/HOS/Process.cs')
| -rw-r--r-- | Ryujinx.HLE/HOS/Process.cs | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/Ryujinx.HLE/HOS/Process.cs b/Ryujinx.HLE/HOS/Process.cs index 448f1afa..1d8bfeb8 100644 --- a/Ryujinx.HLE/HOS/Process.cs +++ b/Ryujinx.HLE/HOS/Process.cs @@ -67,6 +67,8 @@ namespace Ryujinx.HLE.HOS Memory = new AMemory(Device.Memory.RamPointer); + Memory.InvalidAccess += CpuInvalidAccessHandler; + MemoryManager = new KMemoryManager(this); TlsPages = new List<KTlsPageManager>(); @@ -283,11 +285,15 @@ namespace Ryujinx.HLE.HOS private void BreakHandler(object sender, AInstExceptionEventArgs e) { + PrintStackTraceForCurrentThread(); + throw new GuestBrokeExecutionException(); } private void UndefinedHandler(object sender, AInstUndefinedEventArgs e) { + PrintStackTraceForCurrentThread(); + throw new UndefinedInstructionException(e.Position, e.RawOpCode); } @@ -334,6 +340,24 @@ namespace Ryujinx.HLE.HOS return Translator; } + private void CpuInvalidAccessHandler(object sender, AInvalidAccessEventArgs e) + { + PrintStackTraceForCurrentThread(); + } + + private void PrintStackTraceForCurrentThread() + { + foreach (KThread Thread in Threads.Values) + { + if (Thread.Context.IsCurrentThread()) + { + PrintStackTrace(Thread.Context.ThreadState); + + break; + } + } + } + public void PrintStackTrace(AThreadState ThreadState) { StringBuilder Trace = new StringBuilder(); |
