diff options
| author | bunnei <bunneidev@gmail.com> | 2019-02-27 11:22:26 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-02-27 11:22:26 -0500 |
| commit | eb5a3dd1c7b4c69c708924208acd2077ff08308f (patch) | |
| tree | 2e7d700cd854170203772883d6b66b108c7a428e /src/core/hle/kernel/process.cpp | |
| parent | be1a1584fca26837932be42374815282ba5767f5 (diff) | |
| parent | d29f9e9709b3cab6448b43f00f4f0204680ceee5 (diff) | |
Merge pull request #2161 from lioncash/handle-table
kernel/handle_table: Allow process capabilities to limit the handle table size
Diffstat (limited to 'src/core/hle/kernel/process.cpp')
| -rw-r--r-- | src/core/hle/kernel/process.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/core/hle/kernel/process.cpp b/src/core/hle/kernel/process.cpp index c5aa19afa..8009150e0 100644 --- a/src/core/hle/kernel/process.cpp +++ b/src/core/hle/kernel/process.cpp @@ -99,7 +99,13 @@ ResultCode Process::LoadFromMetadata(const FileSys::ProgramMetadata& metadata) { vm_manager.Reset(metadata.GetAddressSpaceType()); const auto& caps = metadata.GetKernelCapabilities(); - return capabilities.InitializeForUserProcess(caps.data(), caps.size(), vm_manager); + const auto capability_init_result = + capabilities.InitializeForUserProcess(caps.data(), caps.size(), vm_manager); + if (capability_init_result.IsError()) { + return capability_init_result; + } + + return handle_table.SetSize(capabilities.GetHandleTableSize()); } void Process::Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size) { |
