summaryrefslogtreecommitdiff
path: root/src/core/loader/loader.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2014-08-28 18:07:45 -0400
committerGravatar bunnei2014-08-28 18:07:45 -0400
commit06864c93fdf41ed383aadc3a76c40cb4725051b0 (patch)
tree5b2f042cae820f5b8ad622731bc378247fac7788 /src/core/loader/loader.cpp
parentMerge pull request #81 from yuriks/downgrade-shader (diff)
parentLoader: Added support for loading raw BIN executables. (diff)
downloadyuzu-06864c93fdf41ed383aadc3a76c40cb4725051b0.tar.gz
yuzu-06864c93fdf41ed383aadc3a76c40cb4725051b0.tar.xz
yuzu-06864c93fdf41ed383aadc3a76c40cb4725051b0.zip
Merge pull request #80 from bunnei/fix-latest-libctru
Fixes Citra for the latest changes made to the "refactor" branch of libctru. - For reference, see: https://github.com/smealum/ctrulib/tree/refactor/libctru
Diffstat (limited to 'src/core/loader/loader.cpp')
-rw-r--r--src/core/loader/loader.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/core/loader/loader.cpp b/src/core/loader/loader.cpp
index 2b42e3c64..365f5a277 100644
--- a/src/core/loader/loader.cpp
+++ b/src/core/loader/loader.cpp
@@ -9,6 +9,7 @@
9#include "core/loader/elf.h" 9#include "core/loader/elf.h"
10#include "core/loader/ncch.h" 10#include "core/loader/ncch.h"
11#include "core/hle/kernel/archive.h" 11#include "core/hle/kernel/archive.h"
12#include "core/mem_map.h"
12 13
13//////////////////////////////////////////////////////////////////////////////////////////////////// 14////////////////////////////////////////////////////////////////////////////////////////////////////
14 15
@@ -39,6 +40,9 @@ FileType IdentifyFile(const std::string &filename) {
39 else if (!strcasecmp(extension.c_str(), ".cci")) { 40 else if (!strcasecmp(extension.c_str(), ".cci")) {
40 return FileType::CCI; // TODO(bunnei): Do some filetype checking :p 41 return FileType::CCI; // TODO(bunnei): Do some filetype checking :p
41 } 42 }
43 else if (!strcasecmp(extension.c_str(), ".bin")) {
44 return FileType::BIN; // TODO(bunnei): Do some filetype checking :p
45 }
42 return FileType::Unknown; 46 return FileType::Unknown;
43} 47}
44 48
@@ -69,6 +73,22 @@ ResultStatus LoadFile(const std::string& filename) {
69 break; 73 break;
70 } 74 }
71 75
76 // Raw BIN file format...
77 case FileType::BIN:
78 {
79 INFO_LOG(LOADER, "Loading BIN file %s...", filename.c_str());
80
81 File::IOFile file(filename, "rb");
82
83 if (file.IsOpen()) {
84 file.ReadBytes(Memory::GetPointer(Memory::EXEFS_CODE_VADDR), (size_t)file.GetSize());
85 Kernel::LoadExec(Memory::EXEFS_CODE_VADDR);
86 } else {
87 return ResultStatus::Error;
88 }
89 return ResultStatus::Success;
90 }
91
72 // Error occurred durring IdentifyFile... 92 // Error occurred durring IdentifyFile...
73 case FileType::Error: 93 case FileType::Error:
74 94