| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | // Copyright 2015 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 14:42:28 -04:00
										 |  |  | #include <array>
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | #include <bitset>
 | 
					
						
							| 
									
										
										
										
											2015-06-21 15:44:11 +01:00
										 |  |  | #include <cstddef>
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2018-01-01 14:38:34 -05:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | #include <boost/container/static_vector.hpp>
 | 
					
						
							| 
									
										
										
										
											2015-05-08 17:53:19 -03:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  | #include "core/hle/kernel/address_arbiter.h"
 | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  | #include "core/hle/kernel/handle_table.h"
 | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  | #include "core/hle/kernel/mutex.h"
 | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  | #include "core/hle/kernel/process_capability.h"
 | 
					
						
							| 
									
										
										
										
											2015-07-17 23:19:16 -03:00
										 |  |  | #include "core/hle/kernel/vm_manager.h"
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  | #include "core/hle/kernel/wait_object.h"
 | 
					
						
							|  |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  | namespace Core { | 
					
						
							|  |  |  | class System; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 20:09:32 -04:00
										 |  |  | namespace FileSys { | 
					
						
							|  |  |  | class ProgramMetadata; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | class KernelCore; | 
					
						
							| 
									
										
										
										
											2018-10-13 14:31:46 -04:00
										 |  |  | class ResourceLimit; | 
					
						
							| 
									
										
										
										
											2018-12-31 18:09:41 -05:00
										 |  |  | class Thread; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 12:40:09 -04:00
										 |  |  | struct CodeSet; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-08 17:53:19 -03:00
										 |  |  | enum class MemoryRegion : u16 { | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  |     APPLICATION = 1, | 
					
						
							|  |  |  |     SYSTEM = 2, | 
					
						
							|  |  |  |     BASE = 3, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-13 14:31:46 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Indicates the status of a Process instance. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @note These match the values as used by kernel, | 
					
						
							|  |  |  |  *       so new entries should only be added if RE | 
					
						
							|  |  |  |  *       shows that a new value has been introduced. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | enum class ProcessStatus { | 
					
						
							|  |  |  |     Created, | 
					
						
							|  |  |  |     CreatedWithDebuggerAttached, | 
					
						
							|  |  |  |     Running, | 
					
						
							|  |  |  |     WaitingForDebuggerToAttach, | 
					
						
							|  |  |  |     DebuggerAttached, | 
					
						
							|  |  |  |     Exiting, | 
					
						
							|  |  |  |     Exited, | 
					
						
							|  |  |  |     DebugBreak, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2015-07-09 22:52:15 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  | class Process final : public WaitObject { | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-12-18 22:53:58 -05:00
										 |  |  |     enum : u64 { | 
					
						
							|  |  |  |         /// Lowest allowed process ID for a kernel initial process.
 | 
					
						
							|  |  |  |         InitialKIPIDMin = 1, | 
					
						
							|  |  |  |         /// Highest allowed process ID for a kernel initial process.
 | 
					
						
							|  |  |  |         InitialKIPIDMax = 80, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /// Lowest allowed process ID for a userland process.
 | 
					
						
							|  |  |  |         ProcessIDMin = 81, | 
					
						
							|  |  |  |         /// Highest allowed process ID for a userland process.
 | 
					
						
							|  |  |  |         ProcessIDMax = 0xFFFFFFFFFFFFFFFF, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  |     static constexpr std::size_t RANDOM_ENTROPY_SIZE = 4; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     static SharedPtr<Process> Create(Core::System& system, std::string&& name); | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     std::string GetTypeName() const override { | 
					
						
							|  |  |  |         return "Process"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     std::string GetName() const override { | 
					
						
							| 
									
										
										
										
											2017-09-30 14:15:09 -04:00
										 |  |  |         return name; | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static const HandleType HANDLE_TYPE = HandleType::Process; | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     HandleType GetHandleType() const override { | 
					
						
							|  |  |  |         return HANDLE_TYPE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     /// Gets a reference to the process' memory manager.
 | 
					
						
							|  |  |  |     Kernel::VMManager& VMManager() { | 
					
						
							|  |  |  |         return vm_manager; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a const reference to the process' memory manager.
 | 
					
						
							|  |  |  |     const Kernel::VMManager& VMManager() const { | 
					
						
							|  |  |  |         return vm_manager; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |     /// Gets a reference to the process' handle table.
 | 
					
						
							|  |  |  |     HandleTable& GetHandleTable() { | 
					
						
							|  |  |  |         return handle_table; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a const reference to the process' handle table.
 | 
					
						
							|  |  |  |     const HandleTable& GetHandleTable() const { | 
					
						
							|  |  |  |         return handle_table; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     /// Gets a reference to the process' address arbiter.
 | 
					
						
							|  |  |  |     AddressArbiter& GetAddressArbiter() { | 
					
						
							|  |  |  |         return address_arbiter; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a const reference to the process' address arbiter.
 | 
					
						
							|  |  |  |     const AddressArbiter& GetAddressArbiter() const { | 
					
						
							|  |  |  |         return address_arbiter; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  |     /// Gets a reference to the process' mutex lock.
 | 
					
						
							|  |  |  |     Mutex& GetMutex() { | 
					
						
							|  |  |  |         return mutex; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a const reference to the process' mutex lock
 | 
					
						
							|  |  |  |     const Mutex& GetMutex() const { | 
					
						
							|  |  |  |         return mutex; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     /// Gets the current status of the process
 | 
					
						
							|  |  |  |     ProcessStatus GetStatus() const { | 
					
						
							|  |  |  |         return status; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the unique ID that identifies this particular process.
 | 
					
						
							| 
									
										
										
										
											2018-12-18 22:16:53 -05:00
										 |  |  |     u64 GetProcessID() const { | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |         return process_id; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     /// Gets the title ID corresponding to this process.
 | 
					
						
							|  |  |  |     u64 GetTitleID() const { | 
					
						
							|  |  |  |         return program_id; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the resource limit descriptor for this process
 | 
					
						
							| 
									
										
										
										
											2018-12-04 00:29:15 -05:00
										 |  |  |     SharedPtr<ResourceLimit> GetResourceLimit() const; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-27 21:14:59 -05:00
										 |  |  |     /// Gets the ideal CPU core ID for this process
 | 
					
						
							|  |  |  |     u8 GetIdealCore() const { | 
					
						
							|  |  |  |         return ideal_core; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-30 21:09:00 -05:00
										 |  |  |     /// Gets the bitmask of allowed cores that this process' threads can run on.
 | 
					
						
							|  |  |  |     u64 GetCoreMask() const { | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |         return capabilities.GetCoreMask(); | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the bitmask of allowed thread priorities.
 | 
					
						
							| 
									
										
										
										
											2018-12-30 21:09:00 -05:00
										 |  |  |     u64 GetPriorityMask() const { | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |         return capabilities.GetPriorityMask(); | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u32 IsVirtualMemoryEnabled() const { | 
					
						
							|  |  |  |         return is_virtual_address_memory_enabled; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 19:13:46 -04:00
										 |  |  |     /// Whether this process is an AArch64 or AArch32 process.
 | 
					
						
							|  |  |  |     bool Is64BitProcess() const { | 
					
						
							|  |  |  |         return is_64bit_process; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-25 18:42:50 -04:00
										 |  |  |     /// Gets the total running time of the process instance in ticks.
 | 
					
						
							|  |  |  |     u64 GetCPUTimeTicks() const { | 
					
						
							|  |  |  |         return total_process_running_time_ticks; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Updates the total running time, adding the given ticks to it.
 | 
					
						
							|  |  |  |     void UpdateCPUTimeTicks(u64 ticks) { | 
					
						
							|  |  |  |         total_process_running_time_ticks += ticks; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  |     /// Gets 8 bytes of random data for svcGetInfo RandomEntropy
 | 
					
						
							|  |  |  |     u64 GetRandomEntropy(std::size_t index) const { | 
					
						
							|  |  |  |         return random_entropy.at(index); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  |     /// Clears the signaled state of the process if and only if it's signaled.
 | 
					
						
							|  |  |  |     ///
 | 
					
						
							|  |  |  |     /// @pre The process must not be already terminated. If this is called on a
 | 
					
						
							|  |  |  |     ///      terminated process, then ERR_INVALID_STATE will be returned.
 | 
					
						
							|  |  |  |     ///
 | 
					
						
							|  |  |  |     /// @pre The process must be in a signaled state. If this is called on a
 | 
					
						
							|  |  |  |     ///      process instance that is not signaled, ERR_INVALID_STATE will be
 | 
					
						
							|  |  |  |     ///      returned.
 | 
					
						
							|  |  |  |     ResultCode ClearSignalState(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-22 20:09:32 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Loads process-specifics configuration info with metadata provided | 
					
						
							|  |  |  |      * by an executable. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |      * @param metadata The provided metadata to load process specific info from. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @returns RESULT_SUCCESS if all relevant metadata was able to be | 
					
						
							|  |  |  |      *          loaded and parsed. Otherwise, an error code is returned. | 
					
						
							| 
									
										
										
										
											2015-05-08 18:11:06 -03:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |     ResultCode LoadFromMetadata(const FileSys::ProgramMetadata& metadata); | 
					
						
							| 
									
										
										
										
											2015-05-08 18:11:06 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Applies address space changes and launches the process main thread. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-09-30 14:15:09 -04:00
										 |  |  |     void Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size); | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Prepares a process for termination by stopping all of its threads | 
					
						
							|  |  |  |      * and clearing any other resources. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void PrepareForTermination(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-12 11:36:31 -04:00
										 |  |  |     void LoadModule(CodeSet module_, VAddr base_addr); | 
					
						
							| 
									
										
										
										
											2017-09-24 11:12:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-17 23:19:16 -03:00
										 |  |  |     ///////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2018-12-27 18:31:31 -05:00
										 |  |  |     // Thread-local storage management
 | 
					
						
							| 
									
										
										
										
											2015-07-17 23:19:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 01:26:29 -04:00
										 |  |  |     // Marks the next available region as used and returns the address of the slot.
 | 
					
						
							|  |  |  |     VAddr MarkNextAvailableTLSSlotAsUsed(Thread& thread); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Frees a used TLS slot identified by the given address
 | 
					
						
							|  |  |  |     void FreeTLSSlot(VAddr tls_address); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2019-03-12 19:03:26 -04:00
										 |  |  |     explicit Process(Core::System& system); | 
					
						
							| 
									
										
										
										
											2018-09-21 01:26:29 -04:00
										 |  |  |     ~Process() override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  |     /// Checks if the specified thread should wait until this process is available.
 | 
					
						
							|  |  |  |     bool ShouldWait(Thread* thread) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Acquires/locks this process for the specified thread if it's available.
 | 
					
						
							|  |  |  |     void Acquire(Thread* thread) override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Changes the process status. If the status is different
 | 
					
						
							|  |  |  |     /// from the current process status, then this will trigger
 | 
					
						
							|  |  |  |     /// a process signal.
 | 
					
						
							|  |  |  |     void ChangeStatus(ProcessStatus new_status); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     /// Memory manager for this process.
 | 
					
						
							|  |  |  |     Kernel::VMManager vm_manager; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     /// Current status of the process
 | 
					
						
							|  |  |  |     ProcessStatus status; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// The ID of this process
 | 
					
						
							| 
									
										
										
										
											2018-12-18 22:16:53 -05:00
										 |  |  |     u64 process_id = 0; | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     /// Title ID corresponding to the process
 | 
					
						
							| 
									
										
										
										
											2018-12-18 22:16:53 -05:00
										 |  |  |     u64 program_id = 0; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Resource limit descriptor for this process
 | 
					
						
							|  |  |  |     SharedPtr<ResourceLimit> resource_limit; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-27 21:14:59 -05:00
										 |  |  |     /// The ideal CPU core for this process, threads are scheduled on this core by default.
 | 
					
						
							|  |  |  |     u8 ideal_core = 0; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     u32 is_virtual_address_memory_enabled = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-19 17:12:48 -05:00
										 |  |  |     /// The Thread Local Storage area is allocated as processes create threads,
 | 
					
						
							|  |  |  |     /// each TLS area is 0x200 bytes, so one page (0x1000) is split up in 8 parts, and each part
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     /// holds the TLS for a specific thread. This vector contains which parts are in use for each
 | 
					
						
							|  |  |  |     /// page as a bitmask.
 | 
					
						
							| 
									
										
										
										
											2016-04-19 17:12:48 -05:00
										 |  |  |     /// This vector will grow as more pages are allocated for new threads.
 | 
					
						
							|  |  |  |     std::vector<std::bitset<8>> tls_slots; | 
					
						
							| 
									
										
										
										
											2015-07-17 23:19:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |     /// Contains the parsed process capability descriptors.
 | 
					
						
							|  |  |  |     ProcessCapabilities capabilities; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 19:13:46 -04:00
										 |  |  |     /// Whether or not this process is AArch64, or AArch32.
 | 
					
						
							|  |  |  |     /// By default, we currently assume this is true, unless otherwise
 | 
					
						
							|  |  |  |     /// specified by metadata provided to the process during loading.
 | 
					
						
							|  |  |  |     bool is_64bit_process = true; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  |     /// Whether or not this process is signaled. This occurs
 | 
					
						
							|  |  |  |     /// upon the process changing to a different state.
 | 
					
						
							|  |  |  |     bool is_signaled = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-25 18:42:50 -04:00
										 |  |  |     /// Total running time for the process in ticks.
 | 
					
						
							|  |  |  |     u64 total_process_running_time_ticks = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |     /// Per-process handle table for storing created object handles in.
 | 
					
						
							|  |  |  |     HandleTable handle_table; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     /// Per-process address arbiter.
 | 
					
						
							|  |  |  |     AddressArbiter address_arbiter; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  |     /// The per-process mutex lock instance used for handling various
 | 
					
						
							|  |  |  |     /// forms of services, such as lock arbitration, and condition
 | 
					
						
							|  |  |  |     /// variable related facilities.
 | 
					
						
							|  |  |  |     Mutex mutex; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  |     /// Random values for svcGetInfo RandomEntropy
 | 
					
						
							|  |  |  |     std::array<u64, RANDOM_ENTROPY_SIZE> random_entropy; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-12 19:03:26 -04:00
										 |  |  |     /// System context
 | 
					
						
							|  |  |  |     Core::System& system; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Name of this process
 | 
					
						
							| 
									
										
										
										
											2017-09-30 14:15:09 -04:00
										 |  |  |     std::string name; | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-01 14:38:34 -05:00
										 |  |  | } // namespace Kernel
 |