summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar bunnei2014-08-28 18:07:45 -0400
committerGravatar bunnei2014-08-28 18:07:45 -0400
commit06864c93fdf41ed383aadc3a76c40cb4725051b0 (patch)
tree5b2f042cae820f5b8ad622731bc378247fac7788
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
-rw-r--r--src/citra_qt/main.cpp2
-rw-r--r--src/core/arm/interpreter/arm_interpreter.cpp2
-rw-r--r--src/core/hle/kernel/thread.cpp5
-rw-r--r--src/core/hle/service/srv.cpp4
-rw-r--r--src/core/loader/loader.cpp20
-rw-r--r--src/core/loader/loader.h1
6 files changed, 32 insertions, 2 deletions
diff --git a/src/citra_qt/main.cpp b/src/citra_qt/main.cpp
index a6b87f781..1bf9bc53c 100644
--- a/src/citra_qt/main.cpp
+++ b/src/citra_qt/main.cpp
@@ -150,7 +150,7 @@ void GMainWindow::BootGame(std::string filename)
150 150
151void GMainWindow::OnMenuLoadFile() 151void GMainWindow::OnMenuLoadFile()
152{ 152{
153 QString filename = QFileDialog::getOpenFileName(this, tr("Load file"), QString(), tr("3DS executable (*.elf *.axf *.cci *.cxi)")); 153 QString filename = QFileDialog::getOpenFileName(this, tr("Load file"), QString(), tr("3DS executable (*.elf *.axf *.bin *.cci *.cxi)"));
154 if (filename.size()) 154 if (filename.size())
155 BootGame(filename.toLatin1().data()); 155 BootGame(filename.toLatin1().data());
156} 156}
diff --git a/src/core/arm/interpreter/arm_interpreter.cpp b/src/core/arm/interpreter/arm_interpreter.cpp
index d35a3ae17..0842d2f8e 100644
--- a/src/core/arm/interpreter/arm_interpreter.cpp
+++ b/src/core/arm/interpreter/arm_interpreter.cpp
@@ -27,7 +27,7 @@ ARM_Interpreter::ARM_Interpreter() {
27 // Reset the core to initial state 27 // Reset the core to initial state
28 ARMul_CoProInit(state); 28 ARMul_CoProInit(state);
29 ARMul_Reset(state); 29 ARMul_Reset(state);
30 state->NextInstr = RESUME; 30 state->NextInstr = RESUME; // NOTE: This will be overwritten by LoadContext
31 state->Emulate = 3; 31 state->Emulate = 3;
32 32
33 state->pc = state->Reg[15] = 0x00000000; 33 state->pc = state->Reg[15] = 0x00000000;
diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp
index 554ec9756..8bd9ca1a1 100644
--- a/src/core/hle/kernel/thread.cpp
+++ b/src/core/hle/kernel/thread.cpp
@@ -117,6 +117,11 @@ void ResetThread(Thread* t, u32 arg, s32 lowest_priority) {
117 t->context.sp = t->stack_top; 117 t->context.sp = t->stack_top;
118 t->context.cpsr = 0x1F; // Usermode 118 t->context.cpsr = 0x1F; // Usermode
119 119
120 // TODO(bunnei): This instructs the CPU core to start the execution as if it is "resuming" a
121 // thread. This is somewhat Sky-Eye specific, and should be re-architected in the future to be
122 // agnostic of the CPU core.
123 t->context.mode = 8;
124
120 if (t->current_priority < lowest_priority) { 125 if (t->current_priority < lowest_priority) {
121 t->current_priority = t->initial_priority; 126 t->current_priority = t->initial_priority;
122 } 127 }
diff --git a/src/core/hle/service/srv.cpp b/src/core/hle/service/srv.cpp
index 8f8413d02..23be3cf2c 100644
--- a/src/core/hle/service/srv.cpp
+++ b/src/core/hle/service/srv.cpp
@@ -16,6 +16,10 @@ Handle g_event_handle = 0;
16 16
17void Initialize(Service::Interface* self) { 17void Initialize(Service::Interface* self) {
18 DEBUG_LOG(OSHLE, "called"); 18 DEBUG_LOG(OSHLE, "called");
19
20 u32* cmd_buff = Service::GetCommandBuffer();
21
22 cmd_buff[1] = 0; // No error
19} 23}
20 24
21void GetProcSemaphore(Service::Interface* self) { 25void GetProcSemaphore(Service::Interface* self) {
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
diff --git a/src/core/loader/loader.h b/src/core/loader/loader.h
index 4ba10de52..68f843005 100644
--- a/src/core/loader/loader.h
+++ b/src/core/loader/loader.h
@@ -21,6 +21,7 @@ enum class FileType {
21 CXI, 21 CXI,
22 CIA, 22 CIA,
23 ELF, 23 ELF,
24 BIN,
24}; 25};
25 26
26/// Return type for functions in Loader namespace 27/// Return type for functions in Loader namespace