Merge pull request #2687 from lioncash/tls-process
kernel/process: Allocate the process' TLS region during initialization
This commit is contained in:
		@@ -184,19 +184,11 @@ ResultCode Process::LoadFromMetadata(const FileSys::ProgramMetadata& metadata) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Process::Run(s32 main_thread_priority, u64 stack_size) {
 | 
			
		||||
    // The kernel always ensures that the given stack size is page aligned.
 | 
			
		||||
    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(mapping_address, std::make_shared<std::vector<u8>>(main_thread_stack_size),
 | 
			
		||||
                        0, main_thread_stack_size, MemoryState::Stack)
 | 
			
		||||
        .Unwrap();
 | 
			
		||||
    AllocateMainThreadStack(stack_size);
 | 
			
		||||
    tls_region_address = CreateTLSRegion();
 | 
			
		||||
 | 
			
		||||
    vm_manager.LogLayout();
 | 
			
		||||
 | 
			
		||||
    ChangeStatus(ProcessStatus::Running);
 | 
			
		||||
 | 
			
		||||
    SetupMainThread(*this, kernel, main_thread_priority);
 | 
			
		||||
@@ -226,6 +218,9 @@ void Process::PrepareForTermination() {
 | 
			
		||||
    stop_threads(system.Scheduler(2).GetThreadList());
 | 
			
		||||
    stop_threads(system.Scheduler(3).GetThreadList());
 | 
			
		||||
 | 
			
		||||
    FreeTLSRegion(tls_region_address);
 | 
			
		||||
    tls_region_address = 0;
 | 
			
		||||
 | 
			
		||||
    ChangeStatus(ProcessStatus::Exited);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -325,4 +320,16 @@ void Process::ChangeStatus(ProcessStatus new_status) {
 | 
			
		||||
    WakeupAllWaitingThreads();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Process::AllocateMainThreadStack(u64 stack_size) {
 | 
			
		||||
    // The kernel always ensures that the given stack size is page aligned.
 | 
			
		||||
    main_thread_stack_size = Common::AlignUp(stack_size, Memory::PAGE_SIZE);
 | 
			
		||||
 | 
			
		||||
    // Allocate and map the main thread stack
 | 
			
		||||
    const VAddr mapping_address = vm_manager.GetTLSIORegionEndAddress() - main_thread_stack_size;
 | 
			
		||||
    vm_manager
 | 
			
		||||
        .MapMemoryBlock(mapping_address, std::make_shared<std::vector<u8>>(main_thread_stack_size),
 | 
			
		||||
                        0, main_thread_stack_size, MemoryState::Stack)
 | 
			
		||||
        .Unwrap();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace Kernel
 | 
			
		||||
 
 | 
			
		||||
@@ -135,6 +135,11 @@ public:
 | 
			
		||||
        return mutex;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /// Gets the address to the process' dedicated TLS region.
 | 
			
		||||
    VAddr GetTLSRegionAddress() const {
 | 
			
		||||
        return tls_region_address;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /// Gets the current status of the process
 | 
			
		||||
    ProcessStatus GetStatus() const {
 | 
			
		||||
        return status;
 | 
			
		||||
@@ -296,6 +301,9 @@ private:
 | 
			
		||||
    /// a process signal.
 | 
			
		||||
    void ChangeStatus(ProcessStatus new_status);
 | 
			
		||||
 | 
			
		||||
    /// Allocates the main thread stack for the process, given the stack size in bytes.
 | 
			
		||||
    void AllocateMainThreadStack(u64 stack_size);
 | 
			
		||||
 | 
			
		||||
    /// Memory manager for this process.
 | 
			
		||||
    Kernel::VMManager vm_manager;
 | 
			
		||||
 | 
			
		||||
@@ -358,6 +366,9 @@ private:
 | 
			
		||||
    /// variable related facilities.
 | 
			
		||||
    Mutex mutex;
 | 
			
		||||
 | 
			
		||||
    /// Address indicating the location of the process' dedicated TLS region.
 | 
			
		||||
    VAddr tls_region_address = 0;
 | 
			
		||||
 | 
			
		||||
    /// Random values for svcGetInfo RandomEntropy
 | 
			
		||||
    std::array<u64, RANDOM_ENTROPY_SIZE> random_entropy{};
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -843,9 +843,7 @@ static ResultCode GetInfo(Core::System& system, u64* result, u64 info_id, u64 ha
 | 
			
		||||
            return RESULT_SUCCESS;
 | 
			
		||||
 | 
			
		||||
        case GetInfoType::UserExceptionContextAddr:
 | 
			
		||||
            LOG_WARNING(Kernel_SVC,
 | 
			
		||||
                        "(STUBBED) Attempted to query user exception context address, returned 0");
 | 
			
		||||
            *result = 0;
 | 
			
		||||
            *result = process->GetTLSRegionAddress();
 | 
			
		||||
            return RESULT_SUCCESS;
 | 
			
		||||
 | 
			
		||||
        case GetInfoType::TotalPhysicalMemoryAvailableWithoutSystemResource:
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user