diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/hle/kernel/shared_memory.cpp | 6 | ||||
| -rw-r--r-- | src/core/hle/kernel/shared_memory.h | 6 | ||||
| -rw-r--r-- | src/core/hle/kernel/svc.cpp | 13 |
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 { | |||
| 17 | SharedMemory::SharedMemory(KernelCore& kernel) : Object{kernel} {} | 17 | SharedMemory::SharedMemory(KernelCore& kernel) : Object{kernel} {} |
| 18 | SharedMemory::~SharedMemory() = default; | 18 | SharedMemory::~SharedMemory() = default; |
| 19 | 19 | ||
| 20 | SharedPtr<SharedMemory> SharedMemory::Create(KernelCore& kernel, SharedPtr<Process> owner_process, | 20 | SharedPtr<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; |