diff options
| author | 2018-08-04 01:19:01 -0400 | |
|---|---|---|
| committer | 2018-08-04 01:19:01 -0400 | |
| commit | d43dad001e8afa866eddc3d15bb5a6f47d797583 (patch) | |
| tree | 8732faeb184c2ce4a3b0b37bfd051dee136ff759 /src/core/hle/kernel/thread.cpp | |
| parent | Merge pull request #910 from lioncash/unused (diff) | |
| parent | kernel/thread: Fix potential crashes introduced in 26de4bb521b1ace7af76eff4f6... (diff) | |
| download | yuzu-d43dad001e8afa866eddc3d15bb5a6f47d797583.tar.gz yuzu-d43dad001e8afa866eddc3d15bb5a6f47d797583.tar.xz yuzu-d43dad001e8afa866eddc3d15bb5a6f47d797583.zip | |
Merge pull request #917 from lioncash/crash
kernel/thread: Fix potential crashes introduced in 26de4bb5
Diffstat (limited to 'src/core/hle/kernel/thread.cpp')
| -rw-r--r-- | src/core/hle/kernel/thread.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp index ea9554cbb..b9022feae 100644 --- a/src/core/hle/kernel/thread.cpp +++ b/src/core/hle/kernel/thread.cpp | |||
| @@ -339,6 +339,17 @@ ResultVal<SharedPtr<Thread>> Thread::Create(std::string name, VAddr entry_point, | |||
| 339 | tls_slots.emplace_back(0); // The page is completely available at the start | 339 | tls_slots.emplace_back(0); // The page is completely available at the start |
| 340 | available_page = tls_slots.size() - 1; | 340 | available_page = tls_slots.size() - 1; |
| 341 | available_slot = 0; // Use the first slot in the new page | 341 | available_slot = 0; // Use the first slot in the new page |
| 342 | |||
| 343 | // Allocate some memory from the end of the linear heap for this region. | ||
| 344 | const size_t offset = thread->tls_memory->size(); | ||
| 345 | thread->tls_memory->insert(thread->tls_memory->end(), Memory::PAGE_SIZE, 0); | ||
| 346 | |||
| 347 | auto& vm_manager = owner_process->vm_manager; | ||
| 348 | vm_manager.RefreshMemoryBlockMappings(thread->tls_memory.get()); | ||
| 349 | |||
| 350 | vm_manager.MapMemoryBlock(Memory::TLS_AREA_VADDR + available_page * Memory::PAGE_SIZE, | ||
| 351 | thread->tls_memory, 0, Memory::PAGE_SIZE, | ||
| 352 | MemoryState::ThreadLocal); | ||
| 342 | } | 353 | } |
| 343 | 354 | ||
| 344 | // Mark the slot as used | 355 | // Mark the slot as used |