| 
									
										
										
										
											2018-01-20 15:48:37 -05:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 14:58:59 +01:00
										 |  |  | #include <algorithm>
 | 
					
						
							|  |  |  | #include <initializer_list>
 | 
					
						
							| 
									
										
										
										
											2015-06-21 13:40:28 +01:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2015-06-21 14:58:59 +01:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2017-03-08 20:21:31 -05:00
										 |  |  | #include <utility>
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2016-11-26 23:13:40 -05:00
										 |  |  | #include <boost/optional.hpp>
 | 
					
						
							| 
									
										
										
										
											2015-05-06 04:06:12 -03:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2015-01-06 21:30:40 +00:00
										 |  |  | #include "common/file_util.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | #include "core/file_sys/vfs.h"
 | 
					
						
							| 
									
										
										
										
											2017-09-26 18:17:47 -05:00
										 |  |  | #include "core/hle/kernel/kernel.h"
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 14:58:59 +01:00
										 |  |  | namespace Kernel { | 
					
						
							|  |  |  | struct AddressMapping; | 
					
						
							| 
									
										
										
										
											2017-09-26 18:17:47 -05:00
										 |  |  | class Process; | 
					
						
							|  |  |  | } // namespace Kernel
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | namespace Loader { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | /// File types supported by CTR
 | 
					
						
							|  |  |  | enum class FileType { | 
					
						
							|  |  |  |     Error, | 
					
						
							|  |  |  |     Unknown, | 
					
						
							|  |  |  |     ELF, | 
					
						
							| 
									
										
										
										
											2017-09-24 11:08:31 -04:00
										 |  |  |     NSO, | 
					
						
							| 
									
										
										
										
											2017-10-05 23:30:08 -04:00
										 |  |  |     NRO, | 
					
						
							| 
									
										
										
										
											2018-06-21 11:16:23 -04:00
										 |  |  |     NCA, | 
					
						
							| 
									
										
										
										
											2018-01-20 14:59:17 -05:00
										 |  |  |     DeconstructedRomDirectory, | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-31 18:28:37 -07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Identifies the type of a bootable file based on the magic value in its header. | 
					
						
							|  |  |  |  * @param file open file | 
					
						
							|  |  |  |  * @return FileType of file | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | FileType IdentifyFile(FileSys::VirtualFile file); | 
					
						
							| 
									
										
										
										
											2015-08-31 18:28:37 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Identifies the type of a bootable file based on the magic value in its header. | 
					
						
							|  |  |  |  * @param file_name path to file | 
					
						
							|  |  |  |  * @return FileType of file. Note: this will return FileType::Unknown if it is unable to determine | 
					
						
							|  |  |  |  * a filetype, and will never return FileType::Error. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | FileType IdentifyFile(const std::string& file_name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |  * Guess the type of a bootable file from its name | 
					
						
							|  |  |  |  * @param name String name of bootable file | 
					
						
							| 
									
										
										
										
											2015-08-31 18:28:37 -07:00
										 |  |  |  * @return FileType of file. Note: this will return FileType::Unknown if it is unable to determine | 
					
						
							|  |  |  |  * a filetype, and will never return FileType::Error. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | FileType GuessFromFilename(const std::string& name); | 
					
						
							| 
									
										
										
										
											2015-08-31 18:28:37 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert a FileType into a string which can be displayed to the user. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char* GetFileTypeString(FileType type); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | /// Return type for functions in Loader namespace
 | 
					
						
							|  |  |  | enum class ResultStatus { | 
					
						
							|  |  |  |     Success, | 
					
						
							|  |  |  |     Error, | 
					
						
							|  |  |  |     ErrorInvalidFormat, | 
					
						
							|  |  |  |     ErrorNotImplemented, | 
					
						
							|  |  |  |     ErrorNotLoaded, | 
					
						
							| 
									
										
										
										
											2014-06-18 23:53:22 -04:00
										 |  |  |     ErrorNotUsed, | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     ErrorAlreadyLoaded, | 
					
						
							| 
									
										
										
										
											2014-07-04 20:32:06 -04:00
										 |  |  |     ErrorMemoryAllocationFailed, | 
					
						
							| 
									
										
										
										
											2015-10-10 21:50:10 -04:00
										 |  |  |     ErrorEncrypted, | 
					
						
							| 
									
										
										
										
											2018-04-06 17:06:32 +02:00
										 |  |  |     ErrorUnsupportedArch, | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Interface for loading an application
 | 
					
						
							|  |  |  | class AppLoader : NonCopyable { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |     AppLoader(FileSys::VirtualFile file) : file(std::move(file)) {} | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     virtual ~AppLoader() {} | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-17 23:30:44 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Returns the type of this file | 
					
						
							|  |  |  |      * @return FileType corresponding to the loaded file | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual FileType GetFileType() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2017-09-26 18:17:47 -05:00
										 |  |  |      * Load the application and return the created Process instance | 
					
						
							|  |  |  |      * @param process The newly created process. | 
					
						
							|  |  |  |      * @return The status result of the operation. | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-09-26 18:17:47 -05:00
										 |  |  |     virtual ResultStatus Load(Kernel::SharedPtr<Kernel::Process>& process) = 0; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-19 20:40:04 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Loads the system mode that this application needs. | 
					
						
							| 
									
										
										
										
											2016-11-26 23:13:40 -05:00
										 |  |  |      * This function defaults to 2 (96MB allocated to the application) if it can't read the | 
					
						
							|  |  |  |      * information. | 
					
						
							| 
									
										
										
										
											2017-06-02 17:03:38 -04:00
										 |  |  |      * @returns A pair with the optional system mode, and and the status. | 
					
						
							| 
									
										
										
										
											2016-11-19 20:40:04 -05:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-03-08 20:21:31 -05:00
										 |  |  |     virtual std::pair<boost::optional<u32>, ResultStatus> LoadKernelSystemMode() { | 
					
						
							| 
									
										
										
										
											2016-11-26 23:13:40 -05:00
										 |  |  |         // 96MB allocated to the application.
 | 
					
						
							| 
									
										
										
										
											2017-03-08 20:21:31 -05:00
										 |  |  |         return std::make_pair(2, ResultStatus::Success); | 
					
						
							| 
									
										
										
										
											2016-11-19 20:40:04 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the code (typically .code section) of the application | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * @param buffer Reference to buffer to store data | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-07-11 19:16:33 -03:00
										 |  |  |     virtual ResultStatus ReadCode(std::vector<u8>& buffer) { | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2014-06-22 15:40:21 -04:00
										 |  |  |      * Get the icon (typically icon section) of the application | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * @param buffer Reference to buffer to store data | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-07-11 19:16:33 -03:00
										 |  |  |     virtual ResultStatus ReadIcon(std::vector<u8>& buffer) { | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2014-06-22 15:40:21 -04:00
										 |  |  |      * Get the banner (typically banner section) of the application | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * @param buffer Reference to buffer to store data | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-07-11 19:16:33 -03:00
										 |  |  |     virtual ResultStatus ReadBanner(std::vector<u8>& buffer) { | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2014-06-22 15:40:21 -04:00
										 |  |  |      * Get the logo (typically logo section) of the application | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * @param buffer Reference to buffer to store data | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-07-11 19:16:33 -03:00
										 |  |  |     virtual ResultStatus ReadLogo(std::vector<u8>& buffer) { | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 09:54:25 +00:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the program id of the application | 
					
						
							|  |  |  |      * @param out_program_id Reference to store program id into | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual ResultStatus ReadProgramId(u64& out_program_id) { | 
					
						
							|  |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * Get the RomFS of the application | 
					
						
							| 
									
										
										
										
											2015-07-10 00:55:23 +03:00
										 |  |  |      * Since the RomFS can be huge, we return a file reference instead of copying to a buffer | 
					
						
							| 
									
										
										
										
											2018-07-19 14:02:07 -04:00
										 |  |  |      * @param dir The directory containing the RomFS | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |      * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |     virtual ResultStatus ReadRomFS(FileSys::VirtualFile& dir) { | 
					
						
							| 
									
										
										
										
											2014-06-27 15:33:23 -04:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-01-06 21:30:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-25 00:17:38 -06:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the update RomFS of the application | 
					
						
							|  |  |  |      * Since the RomFS can be huge, we return a file reference instead of copying to a buffer | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |      * @param file The file containing the RomFS | 
					
						
							| 
									
										
										
										
											2017-09-25 00:17:38 -06:00
										 |  |  |      * @return ResultStatus result of function | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |     virtual ResultStatus ReadUpdateRomFS(FileSys::VirtualFile& file) { | 
					
						
							| 
									
										
										
										
											2017-09-25 00:17:38 -06:00
										 |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-01 19:51:44 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the title of the application | 
					
						
							|  |  |  |      * @param title Reference to store the application title into | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual ResultStatus ReadTitle(std::string& title) { | 
					
						
							|  |  |  |         return ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-06 21:30:40 +00:00
										 |  |  | protected: | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  |     FileSys::VirtualFile file; | 
					
						
							| 
									
										
										
										
											2015-07-11 19:16:33 -03:00
										 |  |  |     bool is_loaded = false; | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Common address mappings found in most games, used for binary formats that don't have this | 
					
						
							|  |  |  |  * information. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-05-08 18:12:25 -03:00
										 |  |  | extern const std::initializer_list<Kernel::AddressMapping> default_address_mappings; | 
					
						
							| 
									
										
										
										
											2015-05-04 00:01:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-17 23:06:33 +01:00
										 |  |  |  * Identifies a bootable file and return a suitable loader | 
					
						
							| 
									
										
										
										
											2018-07-19 14:02:07 -04:00
										 |  |  |  * @param file The bootable file | 
					
						
							|  |  |  |  * @return the best loader for this file | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | std::unique_ptr<AppLoader> GetLoader(FileSys::VirtualFile file); | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 18:17:47 -05:00
										 |  |  | } // namespace Loader
 |