// Copyright 2014 Citra Emulator Project // Licensed under GPLv2 or any later version // Refer to the license.txt file included. #pragma once #include #include "common/common_types.h" #include "common/swap.h" #include "core/file_sys/ncch_container.h" #include "core/loader/loader.h" namespace Loader { /// Loads an NCCH file (e.g. from a CCI, or the first NCCH in a CXI) class AppLoader_NCCH final : public AppLoader { public: AppLoader_NCCH(FileUtil::IOFile&& file, const std::string& filepath) : AppLoader(std::move(file)), base_ncch(filepath), overlay_ncch(&base_ncch), filepath(filepath) {} /** * Returns the type of the file * @param file FileUtil::IOFile open file * @return FileType found, or FileType::Error if this loader doesn't know it */ static FileType IdentifyType(FileUtil::IOFile& file); FileType GetFileType() override { return IdentifyType(file); } ResultStatus Load(std::shared_ptr& process) override; std::pair, ResultStatus> LoadCoreVersion() override; /** * Loads the Exheader and returns the system mode for this application. * @returns A pair with the optional system mode, and and the status. */ std::pair, ResultStatus> LoadKernelMemoryMode() override; std::pair, ResultStatus> LoadNew3dsHwCapabilities() override; ResultStatus IsExecutable(bool& out_executable) override; ResultStatus ReadCode(std::vector& buffer) override; ResultStatus ReadIcon(std::vector& buffer) override; ResultStatus ReadBanner(std::vector& buffer) override; ResultStatus ReadLogo(std::vector& buffer) override; ResultStatus ReadProgramId(u64& out_program_id) override; ResultStatus ReadExtdataId(u64& out_extdata_id) override; ResultStatus ReadRomFS(std::shared_ptr& romfs_file) override; ResultStatus ReadUpdateRomFS(std::shared_ptr& romfs_file) override; ResultStatus DumpRomFS(const std::string& target_path) override; ResultStatus DumpUpdateRomFS(const std::string& target_path) override; ResultStatus ReadTitle(std::string& title) override; private: /** * Loads .code section into memory for booting * @param process The newly created process * @return ResultStatus result of function */ ResultStatus LoadExec(std::shared_ptr& process); /// Reads the region lockout info in the SMDH and send it to CFG service /// If an SMDH is not present, the program ID is compared against a list /// of known system titles to determine the region. void ParseRegionLockoutInfo(u64 program_id); /// Detects whether the NCCH contains GBA Virtual Console. bool IsGbaVirtualConsole(std::span code); FileSys::NCCHContainer base_ncch; FileSys::NCCHContainer update_ncch; FileSys::NCCHContainer* overlay_ncch; std::string filepath; }; } // namespace Loader