diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/hle/kernel/process.cpp | 5 | ||||
| -rw-r--r-- | src/core/hle/kernel/thread.cpp | 2 | ||||
| -rw-r--r-- | src/core/loader/elf.cpp | 2 | ||||
| -rw-r--r-- | src/core/loader/nro.cpp | 2 | ||||
| -rw-r--r-- | src/core/loader/nso.cpp | 2 | ||||
| -rw-r--r-- | src/core/memory.h | 9 | 
6 files changed, 12 insertions, 10 deletions
| diff --git a/src/core/hle/kernel/process.cpp b/src/core/hle/kernel/process.cpp index 3694afc60..2cffec198 100644 --- a/src/core/hle/kernel/process.cpp +++ b/src/core/hle/kernel/process.cpp @@ -121,8 +121,9 @@ void Process::Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size) {      // TODO(bunnei): This is heap area that should be allocated by the kernel and not mapped as part      // of the user address space.      vm_manager -        .MapMemoryBlock(Memory::STACK_VADDR, std::make_shared<std::vector<u8>>(stack_size, 0), 0, -                        stack_size, MemoryState::Mapped) +        .MapMemoryBlock(Memory::STACK_AREA_VADDR_END - stack_size, +                        std::make_shared<std::vector<u8>>(stack_size, 0), 0, stack_size, +                        MemoryState::Mapped)          .Unwrap();      misc_memory_used += stack_size;      memory_region->used += stack_size; diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp index 145f50887..f3a8aa4aa 100644 --- a/src/core/hle/kernel/thread.cpp +++ b/src/core/hle/kernel/thread.cpp @@ -342,7 +342,7 @@ SharedPtr<Thread> SetupMainThread(VAddr entry_point, u32 priority,      // Initialize new "main" thread      auto thread_res = Thread::Create("main", entry_point, priority, 0, THREADPROCESSORID_0, -                                     Memory::STACK_VADDR_END, owner_process); +                                     Memory::STACK_AREA_VADDR_END, owner_process);      SharedPtr<Thread> thread = std::move(thread_res).Unwrap(); diff --git a/src/core/loader/elf.cpp b/src/core/loader/elf.cpp index 0ba8c6fd2..e9f462196 100644 --- a/src/core/loader/elf.cpp +++ b/src/core/loader/elf.cpp @@ -414,7 +414,7 @@ ResultStatus AppLoader_ELF::Load(Kernel::SharedPtr<Kernel::Process>& process) {      process->resource_limit =          Kernel::ResourceLimit::GetForCategory(Kernel::ResourceLimitCategory::APPLICATION); -    process->Run(codeset->entrypoint, 48, Memory::STACK_SIZE); +    process->Run(codeset->entrypoint, 48, Memory::DEFAULT_STACK_SIZE);      is_loaded = true;      return ResultStatus::Success; diff --git a/src/core/loader/nro.cpp b/src/core/loader/nro.cpp index 6dcd1ce48..b5133e4d6 100644 --- a/src/core/loader/nro.cpp +++ b/src/core/loader/nro.cpp @@ -137,7 +137,7 @@ ResultStatus AppLoader_NRO::Load(Kernel::SharedPtr<Kernel::Process>& process) {      process->address_mappings = default_address_mappings;      process->resource_limit =          Kernel::ResourceLimit::GetForCategory(Kernel::ResourceLimitCategory::APPLICATION); -    process->Run(base_addr, 48, Memory::STACK_SIZE); +    process->Run(base_addr, 48, Memory::DEFAULT_STACK_SIZE);      is_loaded = true;      return ResultStatus::Success; diff --git a/src/core/loader/nso.cpp b/src/core/loader/nso.cpp index 100aa022e..3bc10ed0d 100644 --- a/src/core/loader/nso.cpp +++ b/src/core/loader/nso.cpp @@ -165,7 +165,7 @@ ResultStatus AppLoader_NSO::Load(Kernel::SharedPtr<Kernel::Process>& process) {      process->address_mappings = default_address_mappings;      process->resource_limit =          Kernel::ResourceLimit::GetForCategory(Kernel::ResourceLimitCategory::APPLICATION); -    process->Run(Memory::PROCESS_IMAGE_VADDR, 48, Memory::STACK_SIZE); +    process->Run(Memory::PROCESS_IMAGE_VADDR, 48, Memory::DEFAULT_STACK_SIZE);      is_loaded = true;      return ResultStatus::Success; diff --git a/src/core/memory.h b/src/core/memory.h index 413a7b4e8..e9b8ca873 100644 --- a/src/core/memory.h +++ b/src/core/memory.h @@ -162,12 +162,13 @@ enum : VAddr {      TLS_AREA_VADDR = NEW_LINEAR_HEAP_VADDR_END,      TLS_ENTRY_SIZE = 0x200,      TLS_AREA_SIZE = 0x10000000, -    TLS_ADREA_VADDR_END = TLS_AREA_VADDR + TLS_AREA_SIZE, +    TLS_AREA_VADDR_END = TLS_AREA_VADDR + TLS_AREA_SIZE,      /// Application stack -    STACK_VADDR = TLS_ADREA_VADDR_END, -    STACK_SIZE = 0x10000, -    STACK_VADDR_END = STACK_VADDR + STACK_SIZE, +    STACK_AREA_VADDR = TLS_AREA_VADDR_END, +    STACK_AREA_SIZE = 0x10000000, +    STACK_AREA_VADDR_END = STACK_AREA_VADDR + STACK_AREA_SIZE, +    DEFAULT_STACK_SIZE = 0x100000,      /// Application heap      /// Size is confirmed to be a static value on fw 3.0.0 | 
