diff options
| author | 2018-12-12 16:24:23 -0500 | |
|---|---|---|
| committer | 2018-12-12 16:24:23 -0500 | |
| commit | 700075beb6fb68ec40ddf622a6b634377a5286c5 (patch) | |
| tree | 4197e8decd64b3974add609d6bc9983030c3ad96 /src/core/hle/kernel/svc.cpp | |
| parent | Merge pull request #1891 from DarkLordZach/istorage-getsize (diff) | |
| parent | Fix Process object leak on emulation stop (diff) | |
| download | yuzu-700075beb6fb68ec40ddf622a6b634377a5286c5.tar.gz yuzu-700075beb6fb68ec40ddf622a6b634377a5286c5.tar.xz yuzu-700075beb6fb68ec40ddf622a6b634377a5286c5.zip | |
Merge pull request #1890 from jschmer/master
Fix Process object leak on emulation stop
Diffstat (limited to 'src/core/hle/kernel/svc.cpp')
| -rw-r--r-- | src/core/hle/kernel/svc.cpp | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/src/core/hle/kernel/svc.cpp b/src/core/hle/kernel/svc.cpp index f43c7201c..8b0b3671a 100644 --- a/src/core/hle/kernel/svc.cpp +++ b/src/core/hle/kernel/svc.cpp | |||
| @@ -1487,9 +1487,9 @@ static ResultCode CreateTransferMemory(Handle* handle, VAddr addr, u64 size, u32 | |||
| 1487 | } | 1487 | } |
| 1488 | 1488 | ||
| 1489 | auto& kernel = Core::System::GetInstance().Kernel(); | 1489 | auto& kernel = Core::System::GetInstance().Kernel(); |
| 1490 | auto& handle_table = Core::CurrentProcess()->GetHandleTable(); | 1490 | auto process = kernel.CurrentProcess(); |
| 1491 | const auto shared_mem_handle = SharedMemory::Create( | 1491 | auto& handle_table = process->GetHandleTable(); |
| 1492 | kernel, handle_table.Get<Process>(CurrentProcess), size, perms, perms, addr); | 1492 | const auto shared_mem_handle = SharedMemory::Create(kernel, process, size, perms, perms, addr); |
| 1493 | 1493 | ||
| 1494 | CASCADE_RESULT(*handle, handle_table.Create(shared_mem_handle)); | 1494 | CASCADE_RESULT(*handle, handle_table.Create(shared_mem_handle)); |
| 1495 | return RESULT_SUCCESS; | 1495 | return RESULT_SUCCESS; |
| @@ -1599,10 +1599,9 @@ static ResultCode CreateSharedMemory(Handle* handle, u64 size, u32 local_permiss | |||
| 1599 | } | 1599 | } |
| 1600 | 1600 | ||
| 1601 | auto& kernel = Core::System::GetInstance().Kernel(); | 1601 | auto& kernel = Core::System::GetInstance().Kernel(); |
| 1602 | auto& handle_table = Core::CurrentProcess()->GetHandleTable(); | 1602 | auto process = kernel.CurrentProcess(); |
| 1603 | auto shared_mem_handle = | 1603 | auto& handle_table = process->GetHandleTable(); |
| 1604 | SharedMemory::Create(kernel, handle_table.Get<Process>(KernelHandle::CurrentProcess), size, | 1604 | auto shared_mem_handle = SharedMemory::Create(kernel, process, size, local_perms, remote_perms); |
| 1605 | local_perms, remote_perms); | ||
| 1606 | 1605 | ||
| 1607 | CASCADE_RESULT(*handle, handle_table.Create(shared_mem_handle)); | 1606 | CASCADE_RESULT(*handle, handle_table.Create(shared_mem_handle)); |
| 1608 | return RESULT_SUCCESS; | 1607 | return RESULT_SUCCESS; |