| 
									
										
											  
											
												chore: make yuzu REUSE compliant
[REUSE] is a specification that aims at making file copyright
information consistent, so that it can be both human and machine
readable. It basically requires that all files have a header containing
copyright and licensing information. When this isn't possible, like
when dealing with binary assets, generated files or embedded third-party
dependencies, it is permitted to insert copyright information in the
`.reuse/dep5` file.
Oh, and it also requires that all the licenses used in the project are
present in the `LICENSES` folder, that's why the diff is so huge.
This can be done automatically with `reuse download --all`.
The `reuse` tool also contains a handy subcommand that analyzes the
project and tells whether or not the project is (still) compliant,
`reuse lint`.
Following REUSE has a few advantages over the current approach:
- Copyright information is easy to access for users / downstream
- Files like `dist/license.md` do not need to exist anymore, as
  `.reuse/dep5` is used instead
- `reuse lint` makes it easy to ensure that copyright information of
  files like binary assets / images is always accurate and up to date
To add copyright information of files that didn't have it I looked up
who committed what and when, for each file. As yuzu contributors do not
have to sign a CLA or similar I couldn't assume that copyright ownership
was of the "yuzu Emulator Project", so I used the name and/or email of
the commit author instead.
[REUSE]: https://reuse.software
Follow-up to 01cf05bc75b1e47beb08937439f3ed9339e7b254
											
										 
											2022-05-15 02:06:02 +02:00
										 |  |  | // SPDX-FileCopyrightText: 2015 Citra Emulator Project
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: GPL-2.0-or-later
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 14:42:28 -04:00
										 |  |  | #include <array>
 | 
					
						
							| 
									
										
										
										
											2015-06-21 15:44:11 +01:00
										 |  |  | #include <cstddef>
 | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  | #include <list>
 | 
					
						
							| 
									
										
										
										
											2022-06-06 12:56:01 -04:00
										 |  |  | #include <map>
 | 
					
						
							| 
									
										
										
										
											2015-06-21 15:44:11 +01:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2015-05-08 17:53:19 -03:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  | #include "core/hle/kernel/k_address_arbiter.h"
 | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  | #include "core/hle/kernel/k_auto_object.h"
 | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  | #include "core/hle/kernel/k_condition_variable.h"
 | 
					
						
							| 
									
										
										
										
											2021-04-24 02:40:31 -07:00
										 |  |  | #include "core/hle/kernel/k_handle_table.h"
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  | #include "core/hle/kernel/k_page_table.h"
 | 
					
						
							| 
									
										
										
										
											2020-12-21 22:36:53 -08:00
										 |  |  | #include "core/hle/kernel/k_synchronization_object.h"
 | 
					
						
							| 
									
										
										
										
											2022-03-11 17:14:17 -08:00
										 |  |  | #include "core/hle/kernel/k_thread_local_page.h"
 | 
					
						
							| 
									
										
										
										
											2022-01-14 16:33:24 -08:00
										 |  |  | #include "core/hle/kernel/k_worker_task.h"
 | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  | #include "core/hle/kernel/process_capability.h"
 | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  | #include "core/hle/kernel/slab_helpers.h"
 | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  | #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; | 
					
						
							| 
									
										
										
										
											2021-01-30 20:40:49 +11:00
										 |  |  | class KResourceLimit; | 
					
						
							| 
									
										
										
										
											2020-12-30 23:01:08 -08:00
										 |  |  | class KThread; | 
					
						
							| 
									
										
										
										
											2021-09-25 23:01:53 +08:00
										 |  |  | class KSharedMemoryInfo; | 
					
						
							| 
									
										
										
										
											2019-06-05 14:32:33 -04:00
										 |  |  | class TLSPage; | 
					
						
							| 
									
										
										
										
											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, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  | enum class ProcessActivity : u32 { | 
					
						
							|  |  |  |     Runnable, | 
					
						
							|  |  |  |     Paused, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 12:56:01 -04:00
										 |  |  | enum class DebugWatchpointType : u8 { | 
					
						
							|  |  |  |     None = 0, | 
					
						
							|  |  |  |     Read = 1 << 0, | 
					
						
							|  |  |  |     Write = 1 << 1, | 
					
						
							|  |  |  |     ReadOrWrite = Read | Write, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | DECLARE_ENUM_FLAG_OPERATORS(DebugWatchpointType); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct DebugWatchpoint { | 
					
						
							|  |  |  |     VAddr start_address; | 
					
						
							|  |  |  |     VAddr end_address; | 
					
						
							|  |  |  |     DebugWatchpointType type; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-14 16:33:24 -08:00
										 |  |  | class KProcess final : public KAutoObjectWithSlabHeapAndContainer<KProcess, KWorkerTask> { | 
					
						
							| 
									
										
										
										
											2021-04-23 22:04:28 -07:00
										 |  |  |     KERNEL_AUTOOBJECT_TRAITS(KProcess, KSynchronizationObject); | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2021-05-08 12:11:36 -04:00
										 |  |  |     explicit KProcess(KernelCore& kernel_); | 
					
						
							| 
									
										
										
										
											2021-04-23 22:04:28 -07:00
										 |  |  |     ~KProcess() override; | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-05 17:47:00 -07:00
										 |  |  |     enum class State { | 
					
						
							| 
									
										
										
										
											2022-10-18 19:13:20 -07:00
										 |  |  |         Created = static_cast<u32>(Svc::ProcessState::Created), | 
					
						
							|  |  |  |         CreatedAttached = static_cast<u32>(Svc::ProcessState::CreatedAttached), | 
					
						
							|  |  |  |         Running = static_cast<u32>(Svc::ProcessState::Running), | 
					
						
							|  |  |  |         Crashed = static_cast<u32>(Svc::ProcessState::Crashed), | 
					
						
							|  |  |  |         RunningAttached = static_cast<u32>(Svc::ProcessState::RunningAttached), | 
					
						
							|  |  |  |         Terminating = static_cast<u32>(Svc::ProcessState::Terminating), | 
					
						
							|  |  |  |         Terminated = static_cast<u32>(Svc::ProcessState::Terminated), | 
					
						
							|  |  |  |         DebugBreak = static_cast<u32>(Svc::ProcessState::DebugBreak), | 
					
						
							| 
									
										
										
										
											2022-09-05 17:47:00 -07:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-10 00:28:33 -04:00
										 |  |  |     // Used to determine how process IDs are assigned.
 | 
					
						
							|  |  |  |     enum class ProcessType { | 
					
						
							|  |  |  |         KernelInternal, | 
					
						
							|  |  |  |         Userland, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  |     static constexpr std::size_t RANDOM_ENTROPY_SIZE = 4; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     static Result Initialize(KProcess* process, Core::System& system, std::string process_name, | 
					
						
							|  |  |  |                              ProcessType type, KResourceLimit* res_limit); | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 22:19:12 -04:00
										 |  |  |     /// Gets a reference to the process' page table.
 | 
					
						
							| 
									
										
										
										
											2021-02-12 17:58:31 -08:00
										 |  |  |     KPageTable& PageTable() { | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |         return page_table; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 22:19:12 -04:00
										 |  |  |     /// Gets const a reference to the process' page table.
 | 
					
						
							| 
									
										
										
										
											2021-02-12 17:58:31 -08:00
										 |  |  |     const KPageTable& PageTable() const { | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |         return page_table; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |     /// Gets a reference to the process' handle table.
 | 
					
						
							| 
									
										
										
										
											2021-04-24 02:40:31 -07:00
										 |  |  |     KHandleTable& GetHandleTable() { | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |         return handle_table; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a const reference to the process' handle table.
 | 
					
						
							| 
									
										
										
										
											2021-04-24 02:40:31 -07:00
										 |  |  |     const KHandleTable& GetHandleTable() const { | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |         return handle_table; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result SignalToAddress(VAddr address) { | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |         return condition_var.SignalToAddress(address); | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result WaitForAddress(Handle handle, VAddr address, u32 tag) { | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |         return condition_var.WaitForAddress(handle, address, tag); | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |     void SignalConditionVariable(u64 cv_key, int32_t count) { | 
					
						
							|  |  |  |         return condition_var.Signal(cv_key, count); | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result WaitConditionVariable(VAddr address, u64 cv_key, u32 tag, s64 ns) { | 
					
						
							| 
									
										
										
										
											2022-10-14 22:55:51 -07:00
										 |  |  |         R_RETURN(condition_var.Wait(address, cv_key, tag, ns)); | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result SignalAddressArbiter(VAddr address, Svc::SignalType signal_type, s32 value, s32 count) { | 
					
						
							| 
									
										
										
										
											2022-10-14 22:55:51 -07:00
										 |  |  |         R_RETURN(address_arbiter.SignalToAddress(address, signal_type, value, count)); | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result WaitAddressArbiter(VAddr address, Svc::ArbitrationType arb_type, s32 value, | 
					
						
							|  |  |  |                               s64 timeout) { | 
					
						
							| 
									
										
										
										
											2022-10-14 22:55:51 -07:00
										 |  |  |         R_RETURN(address_arbiter.WaitForAddress(address, arb_type, value, timeout)); | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     VAddr GetProcessLocalRegionAddress() const { | 
					
						
							|  |  |  |         return plr_address; | 
					
						
							| 
									
										
										
										
											2019-07-07 04:19:16 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     /// Gets the current status of the process
 | 
					
						
							| 
									
										
										
										
											2022-09-05 17:47:00 -07:00
										 |  |  |     State GetState() const { | 
					
						
							|  |  |  |         return state; | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// 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; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-03 14:15:51 -04:00
										 |  |  |     /// Gets the program ID corresponding to this process.
 | 
					
						
							|  |  |  |     u64 GetProgramID() const { | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |         return program_id; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the resource limit descriptor for this process
 | 
					
						
							| 
									
										
										
										
											2021-04-20 21:28:11 -07:00
										 |  |  |     KResourceLimit* 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
 | 
					
						
							| 
									
										
										
										
											2021-01-03 01:49:18 -08:00
										 |  |  |     u8 GetIdealCoreId() const { | 
					
						
							| 
									
										
										
										
											2018-12-27 21:14:59 -05:00
										 |  |  |         return ideal_core; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-03 01:49:18 -08:00
										 |  |  |     /// Checks if the specified thread priority is valid.
 | 
					
						
							|  |  |  |     bool CheckThreadPriority(s32 prio) const { | 
					
						
							|  |  |  |         return ((1ULL << prio) & GetPriorityMask()) != 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-07 09:42:54 -07:00
										 |  |  |     /// Gets the amount of secure memory to allocate for memory management.
 | 
					
						
							|  |  |  |     u32 GetSystemResourceSize() const { | 
					
						
							|  |  |  |         return system_resource_size; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-07 11:48:11 -07:00
										 |  |  |     /// Gets the amount of secure memory currently in use for memory management.
 | 
					
						
							|  |  |  |     u32 GetSystemResourceUsage() const { | 
					
						
							|  |  |  |         // On hardware, this returns the amount of system resource memory that has
 | 
					
						
							|  |  |  |         // been used by the kernel. This is problematic for Yuzu to emulate, because
 | 
					
						
							|  |  |  |         // system resource memory is used for page tables -- and yuzu doesn't really
 | 
					
						
							|  |  |  |         // have a way to calculate how much memory is required for page tables for
 | 
					
						
							|  |  |  |         // the current process at any given time.
 | 
					
						
							|  |  |  |         // TODO: Is this even worth implementing? Games may retrieve this value via
 | 
					
						
							|  |  |  |         // an SDK function that gets used + available system resource size for debug
 | 
					
						
							|  |  |  |         // or diagnostic purposes. However, it seems unlikely that a game would make
 | 
					
						
							|  |  |  |         // decisions based on how much system memory is dedicated to its page tables.
 | 
					
						
							|  |  |  |         // Is returning a value other than zero wise?
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 19:13:46 -04:00
										 |  |  |     /// Whether this process is an AArch64 or AArch32 process.
 | 
					
						
							|  |  |  |     bool Is64BitProcess() const { | 
					
						
							|  |  |  |         return is_64bit_process; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |     [[nodiscard]] bool IsSuspended() const { | 
					
						
							|  |  |  |         return is_suspended; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SetSuspended(bool suspended) { | 
					
						
							|  |  |  |         is_suspended = suspended; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-28 11:54:41 -08:00
										 |  |  |     /// Gets the process schedule count, used for thread yelding
 | 
					
						
							| 
									
										
										
										
											2020-12-06 00:25:58 -08:00
										 |  |  |     s64 GetScheduledCount() const { | 
					
						
							| 
									
										
										
										
											2020-11-28 11:54:41 -08:00
										 |  |  |         return schedule_count; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Increments the process schedule count, used for thread yielding.
 | 
					
						
							| 
									
										
										
										
											2020-12-06 00:25:58 -08:00
										 |  |  |     void IncrementScheduledCount() { | 
					
						
							| 
									
										
										
										
											2020-11-28 11:54:41 -08:00
										 |  |  |         ++schedule_count; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-22 21:09:45 -08:00
										 |  |  |     void IncrementRunningThreadCount(); | 
					
						
							|  |  |  |     void DecrementRunningThreadCount(); | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void SetRunningThread(s32 core, KThread* thread, u64 idle_count) { | 
					
						
							|  |  |  |         running_threads[core] = thread; | 
					
						
							|  |  |  |         running_thread_idle_counts[core] = idle_count; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void ClearRunningThread(KThread* thread) { | 
					
						
							|  |  |  |         for (size_t i = 0; i < running_threads.size(); ++i) { | 
					
						
							|  |  |  |             if (running_threads[i] == thread) { | 
					
						
							|  |  |  |                 running_threads[i] = nullptr; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] KThread* GetRunningThread(s32 core) const { | 
					
						
							|  |  |  |         return running_threads[core]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool ReleaseUserException(KThread* thread); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] KThread* GetPinnedThread(s32 core_id) const { | 
					
						
							|  |  |  |         ASSERT(0 <= core_id && core_id < static_cast<s32>(Core::Hardware::NUM_CPU_CORES)); | 
					
						
							| 
									
										
										
										
											2021-12-05 23:57:09 -08:00
										 |  |  |         return pinned_threads[core_id]; | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-09 18:20:20 -04:00
										 |  |  |     /// Retrieves the total physical memory available to this process in bytes.
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     u64 GetTotalPhysicalMemoryAvailable(); | 
					
						
							| 
									
										
										
										
											2019-06-09 18:20:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Retrieves the total physical memory available to this process in bytes,
 | 
					
						
							| 
									
										
										
										
											2019-07-07 11:48:11 -07:00
										 |  |  |     /// without the size of the personal system resource heap added to it.
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     u64 GetTotalPhysicalMemoryAvailableWithoutSystemResource(); | 
					
						
							| 
									
										
										
										
											2019-06-09 18:20:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-28 22:59:17 -04:00
										 |  |  |     /// Retrieves the total physical memory used by this process in bytes.
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     u64 GetTotalPhysicalMemoryUsed(); | 
					
						
							| 
									
										
										
										
											2019-03-28 22:59:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-09 18:20:20 -04:00
										 |  |  |     /// Retrieves the total physical memory used by this process in bytes,
 | 
					
						
							| 
									
										
										
										
											2019-07-07 11:48:11 -07:00
										 |  |  |     /// without the size of the personal system resource heap added to it.
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     u64 GetTotalPhysicalMemoryUsedWithoutSystemResource(); | 
					
						
							| 
									
										
										
										
											2019-06-09 18:20:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  |     /// Gets the list of all threads created with this process as their owner.
 | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  |     std::list<KThread*>& GetThreadList() { | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  |         return thread_list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Registers a thread as being created under this process,
 | 
					
						
							|  |  |  |     /// adding it to this process' thread list.
 | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  |     void RegisterThread(KThread* thread); | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Unregisters a thread from this process, removing it
 | 
					
						
							|  |  |  |     /// from this process' thread list.
 | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  |     void UnregisterThread(KThread* thread); | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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.
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result Reset(); | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |      * @returns ResultSuccess if all relevant metadata was able to be | 
					
						
							| 
									
										
										
										
											2018-12-19 23:50:20 -05:00
										 |  |  |      *          loaded and parsed. Otherwise, an error code is returned. | 
					
						
							| 
									
										
										
										
											2015-05-08 18:11:06 -03:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result LoadFromMetadata(const FileSys::ProgramMetadata& metadata, std::size_t code_size); | 
					
						
							| 
									
										
										
										
											2015-05-08 18:11:06 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2019-04-09 17:03:04 -04:00
										 |  |  |      * Starts the main application thread for this process. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param main_thread_priority The priority for the main thread. | 
					
						
							|  |  |  |      * @param stack_size           The stack size for the main thread in bytes. | 
					
						
							| 
									
										
										
										
											2015-05-08 18:11:06 -03:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-04-09 17:03:04 -04:00
										 |  |  |     void Run(s32 main_thread_priority, u64 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(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 22:19:12 -04:00
										 |  |  |     void LoadModule(CodeSet code_set, VAddr base_addr); | 
					
						
							| 
									
										
										
										
											2017-09-24 11:12:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-29 02:49:07 -04:00
										 |  |  |     bool IsInitialized() const override { | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  |         return is_initialized; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static void PostDestroy([[maybe_unused]] uintptr_t arg) {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-29 02:49:07 -04:00
										 |  |  |     void Finalize() override; | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-29 02:49:07 -04:00
										 |  |  |     u64 GetId() const override { | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  |         return GetProcessID(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-12-21 22:36:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-29 02:49:07 -04:00
										 |  |  |     bool IsSignaled() const override; | 
					
						
							| 
									
										
										
										
											2021-01-16 00:25:29 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-14 16:33:24 -08:00
										 |  |  |     void DoWorkerTaskImpl(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result SetActivity(ProcessActivity activity); | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-29 21:40:38 -08:00
										 |  |  |     void PinCurrentThread(s32 core_id); | 
					
						
							|  |  |  |     void UnpinCurrentThread(s32 core_id); | 
					
						
							| 
									
										
										
										
											2021-11-10 23:02:45 -08:00
										 |  |  |     void UnpinThread(KThread* thread); | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-24 22:54:37 -08:00
										 |  |  |     KLightLock& GetStateLock() { | 
					
						
							|  |  |  |         return state_lock; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result AddSharedMemory(KSharedMemory* shmem, VAddr address, size_t size); | 
					
						
							| 
									
										
										
										
											2021-04-30 14:53:22 -07:00
										 |  |  |     void RemoveSharedMemory(KSharedMemory* shmem, VAddr address, size_t size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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.
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     [[nodiscard]] Result CreateThreadLocalRegion(VAddr* out); | 
					
						
							| 
									
										
										
										
											2018-09-21 01:26:29 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Frees a used TLS slot identified by the given address
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result DeleteThreadLocalRegion(VAddr addr); | 
					
						
							| 
									
										
										
										
											2018-09-21 01:26:29 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 12:56:01 -04:00
										 |  |  |     ///////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  |     // Debug watchpoint management
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Attempts to insert a watchpoint into a free slot. Returns false if none are available.
 | 
					
						
							|  |  |  |     bool InsertWatchpoint(Core::System& system, VAddr addr, u64 size, DebugWatchpointType type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Attempts to remove the watchpoint specified by the given parameters.
 | 
					
						
							|  |  |  |     bool RemoveWatchpoint(Core::System& system, VAddr addr, u64 size, DebugWatchpointType type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const std::array<DebugWatchpoint, Core::Hardware::NUM_WATCHPOINTS>& GetWatchpoints() const { | 
					
						
							|  |  |  |         return watchpoints; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 01:26:29 -04:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |     void PinThread(s32 core_id, KThread* thread) { | 
					
						
							|  |  |  |         ASSERT(0 <= core_id && core_id < static_cast<s32>(Core::Hardware::NUM_CPU_CORES)); | 
					
						
							|  |  |  |         ASSERT(thread != nullptr); | 
					
						
							| 
									
										
										
										
											2021-12-05 23:57:09 -08:00
										 |  |  |         ASSERT(pinned_threads[core_id] == nullptr); | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |         pinned_threads[core_id] = thread; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void UnpinThread(s32 core_id, KThread* thread) { | 
					
						
							|  |  |  |         ASSERT(0 <= core_id && core_id < static_cast<s32>(Core::Hardware::NUM_CPU_CORES)); | 
					
						
							|  |  |  |         ASSERT(thread != nullptr); | 
					
						
							| 
									
										
										
										
											2021-12-05 23:57:09 -08:00
										 |  |  |         ASSERT(pinned_threads[core_id] == thread); | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |         pinned_threads[core_id] = nullptr; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-14 22:55:51 -07:00
										 |  |  |     void FinalizeHandleTable() { | 
					
						
							|  |  |  |         // Finalize the table.
 | 
					
						
							|  |  |  |         handle_table.Finalize(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Note that the table is finalized.
 | 
					
						
							|  |  |  |         is_handle_table_initialized = false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-05 17:47:00 -07:00
										 |  |  |     void ChangeState(State new_state); | 
					
						
							| 
									
										
										
										
											2018-12-04 19:08:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-07 04:13:56 -04:00
										 |  |  |     /// Allocates the main thread stack for the process, given the stack size in bytes.
 | 
					
						
							| 
									
										
										
										
											2022-06-25 22:44:19 -05:00
										 |  |  |     Result AllocateMainThreadStack(std::size_t stack_size); | 
					
						
							| 
									
										
										
										
											2019-03-28 18:30:58 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 22:19:12 -04:00
										 |  |  |     /// Memory manager for this process
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     KPageTable page_table; | 
					
						
							| 
									
										
										
										
											2019-03-28 18:52:45 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  |     /// Current status of the process
 | 
					
						
							| 
									
										
										
										
											2022-09-05 17:47:00 -07:00
										 |  |  |     State state{}; | 
					
						
							| 
									
										
										
										
											2018-09-21 02:06:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// 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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-07 09:42:54 -07:00
										 |  |  |     /// Specifies additional memory to be reserved for the process's memory management by the
 | 
					
						
							|  |  |  |     /// system. When this is non-zero, secure memory is allocated and used for page table allocation
 | 
					
						
							|  |  |  |     /// instead of using the normal global page tables/memory block management.
 | 
					
						
							|  |  |  |     u32 system_resource_size = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  |     /// Resource limit descriptor for this process
 | 
					
						
							| 
									
										
										
										
											2021-04-20 21:28:11 -07:00
										 |  |  |     KResourceLimit* resource_limit{}; | 
					
						
							| 
									
										
										
										
											2018-09-29 18:47:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     VAddr system_resource_address{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-10-25 18:42:50 -04:00
										 |  |  |     /// Total running time for the process in ticks.
 | 
					
						
							| 
									
										
										
										
											2022-04-01 18:40:52 -04:00
										 |  |  |     std::atomic<u64> total_process_running_time_ticks = 0; | 
					
						
							| 
									
										
										
										
											2018-10-25 18:42:50 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  |     /// Per-process handle table for storing created object handles in.
 | 
					
						
							| 
									
										
										
										
											2021-04-24 02:40:31 -07:00
										 |  |  |     KHandleTable handle_table; | 
					
						
							| 
									
										
										
										
											2018-10-20 14:34:41 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  |     /// Per-process address arbiter.
 | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |     KAddressArbiter address_arbiter; | 
					
						
							| 
									
										
										
										
											2019-03-07 18:48:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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.
 | 
					
						
							| 
									
										
										
										
											2020-12-30 01:14:02 -08:00
										 |  |  |     KConditionVariable condition_var; | 
					
						
							| 
									
										
										
										
											2019-03-14 00:29:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-07 04:19:16 -04:00
										 |  |  |     /// Address indicating the location of the process' dedicated TLS region.
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     VAddr plr_address = 0; | 
					
						
							| 
									
										
										
										
											2019-07-07 04:19:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  |     /// Random values for svcGetInfo RandomEntropy
 | 
					
						
							| 
									
										
										
										
											2019-06-05 15:08:01 -04:00
										 |  |  |     std::array<u64, RANDOM_ENTROPY_SIZE> random_entropy{}; | 
					
						
							| 
									
										
										
										
											2018-11-13 12:25:43 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  |     /// List of threads that are running with this process as their owner.
 | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  |     std::list<KThread*> thread_list; | 
					
						
							| 
									
										
										
										
											2019-03-20 18:53:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-25 23:01:53 +08:00
										 |  |  |     /// List of shared memory that are running with this process as their owner.
 | 
					
						
							|  |  |  |     std::list<KSharedMemoryInfo*> shared_memory_list; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 22:19:12 -04:00
										 |  |  |     /// Address of the top of the main thread's stack
 | 
					
						
							|  |  |  |     VAddr main_thread_stack_top{}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Size of the main thread's stack
 | 
					
						
							|  |  |  |     std::size_t main_thread_stack_size{}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Memory usage capacity for the process
 | 
					
						
							|  |  |  |     std::size_t memory_usage_capacity{}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Process total image size
 | 
					
						
							|  |  |  |     std::size_t image_size{}; | 
					
						
							| 
									
										
										
										
											2020-07-15 13:23:12 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-28 11:54:41 -08:00
										 |  |  |     /// Schedule count of this process
 | 
					
						
							|  |  |  |     s64 schedule_count{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     size_t memory_release_hint{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-21 22:36:53 -08:00
										 |  |  |     bool is_signaled{}; | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  |     bool is_suspended{}; | 
					
						
							| 
									
										
										
										
											2022-10-02 14:26:30 -07:00
										 |  |  |     bool is_immortal{}; | 
					
						
							|  |  |  |     bool is_handle_table_initialized{}; | 
					
						
							| 
									
										
										
										
											2021-04-03 22:22:36 -07:00
										 |  |  |     bool is_initialized{}; | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-22 21:09:45 -08:00
										 |  |  |     std::atomic<u16> num_running_threads{}; | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     std::array<KThread*, Core::Hardware::NUM_CPU_CORES> running_threads{}; | 
					
						
							|  |  |  |     std::array<u64, Core::Hardware::NUM_CPU_CORES> running_thread_idle_counts{}; | 
					
						
							|  |  |  |     std::array<KThread*, Core::Hardware::NUM_CPU_CORES> pinned_threads{}; | 
					
						
							| 
									
										
										
										
											2022-06-06 12:56:01 -04:00
										 |  |  |     std::array<DebugWatchpoint, Core::Hardware::NUM_WATCHPOINTS> watchpoints{}; | 
					
						
							|  |  |  |     std::map<VAddr, u64> debug_page_refcounts; | 
					
						
							| 
									
										
										
										
											2021-01-20 13:42:27 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     KThread* exception_thread{}; | 
					
						
							| 
									
										
										
										
											2020-12-21 22:36:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-24 22:54:37 -08:00
										 |  |  |     KLightLock state_lock; | 
					
						
							| 
									
										
										
										
											2022-06-13 18:36:30 -04:00
										 |  |  |     KLightLock list_lock; | 
					
						
							| 
									
										
										
										
											2022-03-11 17:14:17 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     using TLPTree = | 
					
						
							|  |  |  |         Common::IntrusiveRedBlackTreeBaseTraits<KThreadLocalPage>::TreeType<KThreadLocalPage>; | 
					
						
							|  |  |  |     using TLPIterator = TLPTree::iterator; | 
					
						
							|  |  |  |     TLPTree fully_used_tlp_tree; | 
					
						
							|  |  |  |     TLPTree partially_used_tlp_tree; | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-01 14:38:34 -05:00
										 |  |  | } // namespace Kernel
 |