diff options
author | Lioncash <mathew1800@gmail.com> | 2019-03-28 23:30:58 +0100 |
---|---|---|
committer | Lioncash <mathew1800@gmail.com> | 2019-03-28 23:45:06 +0100 |
commit | 5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e (patch) | |
tree | 54b555ab1521f9776d1247b0a108485030594a34 /src/core/hle | |
parent | kernel/process: Make Run's stack size parameter a u64 (diff) | |
download | yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar.gz yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar.bz2 yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar.lz yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar.xz yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.tar.zst yuzu-5d4ab5ec2fe36fa06d3adccb66261a4a8077c74e.zip |
Diffstat (limited to 'src/core/hle')
-rw-r--r-- | src/core/hle/kernel/process.cpp | 8 | ||||
-rw-r--r-- | src/core/hle/kernel/process.h | 3 |
2 files changed, 7 insertions, 4 deletions
diff --git a/src/core/hle/kernel/process.cpp b/src/core/hle/kernel/process.cpp index f18789a60..bb2673732 100644 --- a/src/core/hle/kernel/process.cpp +++ b/src/core/hle/kernel/process.cpp @@ -110,15 +110,15 @@ ResultCode Process::LoadFromMetadata(const FileSys::ProgramMetadata& metadata) { void Process::Run(VAddr entry_point, s32 main_thread_priority, u64 stack_size) { // The kernel always ensures that the given stack size is page aligned. - stack_size = Common::AlignUp(stack_size, Memory::PAGE_SIZE); + main_thread_stack_size = Common::AlignUp(stack_size, Memory::PAGE_SIZE); // Allocate and map the main thread stack // TODO(bunnei): This is heap area that should be allocated by the kernel and not mapped as part // of the user address space. + const VAddr mapping_address = vm_manager.GetTLSIORegionEndAddress() - main_thread_stack_size; vm_manager - .MapMemoryBlock(vm_manager.GetTLSIORegionEndAddress() - stack_size, - std::make_shared<std::vector<u8>>(stack_size, 0), 0, stack_size, - MemoryState::Stack) + .MapMemoryBlock(mapping_address, std::make_shared<std::vector<u8>>(main_thread_stack_size), + 0, main_thread_stack_size, MemoryState::Stack) .Unwrap(); vm_manager.LogLayout(); diff --git a/src/core/hle/kernel/process.h b/src/core/hle/kernel/process.h index db14dd4b4..ee559fe4c 100644 --- a/src/core/hle/kernel/process.h +++ b/src/core/hle/kernel/process.h @@ -247,6 +247,9 @@ private: /// Memory manager for this process. Kernel::VMManager vm_manager; + /// Size of the main thread's stack in bytes. + u64 main_thread_stack_size = 0; + /// Current status of the process ProcessStatus status; |