diff options
| author | 2019-02-27 11:22:26 -0500 | |
|---|---|---|
| committer | 2019-02-27 11:22:26 -0500 | |
| commit | eb5a3dd1c7b4c69c708924208acd2077ff08308f (patch) | |
| tree | 2e7d700cd854170203772883d6b66b108c7a428e /src/core/hle/kernel/process.cpp | |
| parent | Merge pull request #2168 from lioncash/cubeb (diff) | |
| parent | kernel/handle_table: Make local variables as const where applicable (diff) | |
| download | yuzu-eb5a3dd1c7b4c69c708924208acd2077ff08308f.tar.gz yuzu-eb5a3dd1c7b4c69c708924208acd2077ff08308f.tar.xz yuzu-eb5a3dd1c7b4c69c708924208acd2077ff08308f.zip | |
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) { | |||
| 99 | vm_manager.Reset(metadata.GetAddressSpaceType()); | 99 | vm_manager.Reset(metadata.GetAddressSpaceType()); |
| 100 | 100 | ||
| 101 | const auto& caps = metadata.GetKernelCapabilities(); | 101 | const auto& caps = metadata.GetKernelCapabilities(); |
| 102 | return capabilities.InitializeForUserProcess(caps.data(), caps.size(), vm_manager); | 102 | const auto capability_init_result = |
| 103 | capabilities.InitializeForUserProcess(caps.data(), caps.size(), vm_manager); | ||
| 104 | if (capability_init_result.IsError()) { | ||
| 105 | return capability_init_result; | ||
| 106 | } | ||
| 107 | |||
| 108 | return handle_table.SetSize(capabilities.GetHandleTableSize()); | ||
| 103 | } | 109 | } |
| 104 | 110 | ||
| 105 | void Process::Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size) { | 111 | void Process::Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size) { |