forked from eden-emu/eden
		
	kernel/process: Add a data member to determine if a process is 64-bit or not.
This will be necessary for the implementation of svcGetThreadContext(), as the kernel checks whether or not the process that owns the thread that has it context being retrieved is a 64-bit or 32-bit process. If the process is 32-bit, then the upper 15 general-purpose registers and upper 16 vector registers are cleared to zero (as AArch32 only has 15 GPRs and 16 128-bit vector registers. not 31 general-purpose registers and 32 128-bit vector registers like AArch64).
This commit is contained in:
		
							parent
							
								
									9d8f4d934b
								
							
						
					
					
						commit
						7942c5ca0d
					
				
					 2 changed files with 11 additions and 0 deletions
				
			
		|  | @ -189,6 +189,11 @@ public: | |||
|         return is_virtual_address_memory_enabled; | ||||
|     } | ||||
| 
 | ||||
|     /// Whether this process is an AArch64 or AArch32 process.
 | ||||
|     bool Is64BitProcess() const { | ||||
|         return is_64bit_process; | ||||
|     } | ||||
| 
 | ||||
|     /**
 | ||||
|      * Loads process-specifics configuration info with metadata provided | ||||
|      * by an executable. | ||||
|  | @ -287,6 +292,11 @@ private: | |||
|     /// This vector will grow as more pages are allocated for new threads.
 | ||||
|     std::vector<std::bitset<8>> tls_slots; | ||||
| 
 | ||||
|     /// 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; | ||||
| 
 | ||||
|     std::string name; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash