summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorGravatar Mat M2018-12-12 16:24:23 -0500
committerGravatar GitHub2018-12-12 16:24:23 -0500
commit700075beb6fb68ec40ddf622a6b634377a5286c5 (patch)
tree4197e8decd64b3974add609d6bc9983030c3ad96 /src/core
parentMerge pull request #1891 from DarkLordZach/istorage-getsize (diff)
parentFix Process object leak on emulation stop (diff)
downloadyuzu-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')
-rw-r--r--src/core/hle/kernel/shared_memory.cpp6
-rw-r--r--src/core/hle/kernel/shared_memory.h6
-rw-r--r--src/core/hle/kernel/svc.cpp13
3 files changed, 12 insertions, 13 deletions
diff --git a/src/core/hle/kernel/shared_memory.cpp b/src/core/hle/kernel/shared_memory.cpp
index d1ca60125..22d0c1dd5 100644
--- a/src/core/hle/kernel/shared_memory.cpp
+++ b/src/core/hle/kernel/shared_memory.cpp
@@ -17,13 +17,13 @@ namespace Kernel {
17SharedMemory::SharedMemory(KernelCore& kernel) : Object{kernel} {} 17SharedMemory::SharedMemory(KernelCore& kernel) : Object{kernel} {}
18SharedMemory::~SharedMemory() = default; 18SharedMemory::~SharedMemory() = default;
19 19
20SharedPtr<SharedMemory> SharedMemory::Create(KernelCore& kernel, SharedPtr<Process> owner_process, 20SharedPtr<SharedMemory> SharedMemory::Create(KernelCore& kernel, Process* owner_process, u64 size,
21 u64 size, MemoryPermission permissions, 21 MemoryPermission permissions,
22 MemoryPermission other_permissions, VAddr address, 22 MemoryPermission other_permissions, VAddr address,
23 MemoryRegion region, std::string name) { 23 MemoryRegion region, std::string name) {
24 SharedPtr<SharedMemory> shared_memory(new SharedMemory(kernel)); 24 SharedPtr<SharedMemory> shared_memory(new SharedMemory(kernel));
25 25
26 shared_memory->owner_process = std::move(owner_process); 26 shared_memory->owner_process = owner_process;
27 shared_memory->name = std::move(name); 27 shared_memory->name = std::move(name);
28 shared_memory->size = size; 28 shared_memory->size = size;
29 shared_memory->permissions = permissions; 29 shared_memory->permissions = permissions;
diff --git a/src/core/hle/kernel/shared_memory.h b/src/core/hle/kernel/shared_memory.h
index 0b48db699..dab2a6bea 100644
--- a/src/core/hle/kernel/shared_memory.h
+++ b/src/core/hle/kernel/shared_memory.h
@@ -45,8 +45,8 @@ public:
45 * linear heap. 45 * linear heap.
46 * @param name Optional object name, used for debugging purposes. 46 * @param name Optional object name, used for debugging purposes.
47 */ 47 */
48 static SharedPtr<SharedMemory> Create(KernelCore& kernel, SharedPtr<Process> owner_process, 48 static SharedPtr<SharedMemory> Create(KernelCore& kernel, Process* owner_process, u64 size,
49 u64 size, MemoryPermission permissions, 49 MemoryPermission permissions,
50 MemoryPermission other_permissions, VAddr address = 0, 50 MemoryPermission other_permissions, VAddr address = 0,
51 MemoryRegion region = MemoryRegion::BASE, 51 MemoryRegion region = MemoryRegion::BASE,
52 std::string name = "Unknown"); 52 std::string name = "Unknown");
@@ -139,7 +139,7 @@ private:
139 /// Permission restrictions applied to other processes mapping the block. 139 /// Permission restrictions applied to other processes mapping the block.
140 MemoryPermission other_permissions{}; 140 MemoryPermission other_permissions{};
141 /// Process that created this shared memory block. 141 /// Process that created this shared memory block.
142 SharedPtr<Process> owner_process; 142 Process* owner_process;
143 /// Address of shared memory block in the owner process if specified. 143 /// Address of shared memory block in the owner process if specified.
144 VAddr base_address = 0; 144 VAddr base_address = 0;
145 /// Name of shared memory object. 145 /// Name of shared memory object.
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;