2013-09-05 04:09:15 +02:00
|
|
|
/**
|
2013-09-26 23:34:48 +02:00
|
|
|
* Copyright (C) 2013 citra Emulator
|
2013-08-30 05:35:09 +02:00
|
|
|
*
|
2013-09-26 23:34:48 +02:00
|
|
|
* @file citra.cpp
|
2013-08-30 05:35:09 +02:00
|
|
|
* @author ShizZy <shizzy247@gmail.com>
|
2013-09-05 04:09:15 +02:00
|
|
|
* @date 2013-09-04
|
2013-08-30 05:35:09 +02:00
|
|
|
* @brief Main entry point
|
|
|
|
*
|
|
|
|
* @section LICENSE
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details at
|
|
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
|
|
*
|
|
|
|
* Official project repository can be found at:
|
|
|
|
* http://code.google.com/p/gekko-gc-emu/
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "common.h"
|
2013-09-18 04:57:59 +02:00
|
|
|
#include "log_manager.h"
|
2013-09-08 19:17:27 +02:00
|
|
|
#include "file_util.h"
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-10-03 23:47:31 +02:00
|
|
|
#include "system.h"
|
2014-04-01 04:25:55 +02:00
|
|
|
#include "core.h"
|
|
|
|
#include "loader.h"
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-05 04:09:15 +02:00
|
|
|
#include "emu_window/emu_window_glfw.h"
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-26 23:34:48 +02:00
|
|
|
#include "citra.h"
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2014-04-01 04:25:55 +02:00
|
|
|
#define E_ERR -1
|
|
|
|
|
2013-08-30 05:35:09 +02:00
|
|
|
//#define PLAY_FIFO_RECORDING
|
|
|
|
|
|
|
|
/// Application entry point
|
|
|
|
int __cdecl main(int argc, char **argv) {
|
2013-09-09 03:55:37 +02:00
|
|
|
//u32 tight_loop;
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-26 23:34:48 +02:00
|
|
|
printf("citra starting...\n");
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-08 19:17:27 +02:00
|
|
|
std::string program_dir = File::GetCurrentDir();
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-18 04:57:59 +02:00
|
|
|
LogManager::Init();
|
|
|
|
|
2013-09-19 04:35:45 +02:00
|
|
|
EmuWindow_GLFW* emu_window = new EmuWindow_GLFW;
|
2013-09-18 04:57:59 +02:00
|
|
|
|
2013-10-03 23:47:31 +02:00
|
|
|
System::Init(emu_window);
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2014-04-01 04:25:55 +02:00
|
|
|
//if (E_OK != Core::Init(emu_window)) {
|
2013-09-05 04:09:15 +02:00
|
|
|
// LOG_ERROR(TMASTER, "core initialization failed, exiting...");
|
|
|
|
// core::Kill();
|
|
|
|
// exit(1);
|
|
|
|
//}
|
|
|
|
|
|
|
|
//// Load a game or die...
|
|
|
|
//if (E_OK == dvd::LoadBootableFile(common::g_config->default_boot_file())) {
|
|
|
|
// if (common::g_config->enable_auto_boot()) {
|
|
|
|
// core::Start();
|
|
|
|
// } else {
|
|
|
|
// LOG_ERROR(TMASTER, "Autoboot required in no-GUI mode... Exiting!\n");
|
|
|
|
// }
|
|
|
|
//} else {
|
|
|
|
// LOG_ERROR(TMASTER, "Failed to load a bootable file... Exiting!\n");
|
|
|
|
// exit(E_ERR);
|
|
|
|
//}
|
|
|
|
//// run the game
|
|
|
|
//while(core::SYS_DIE != core::g_state) {
|
|
|
|
// if (core::SYS_RUNNING == core::g_state) {
|
|
|
|
// if(!(cpu->is_on)) {
|
|
|
|
// cpu->Start(); // Initialize and start CPU.
|
|
|
|
// } else {
|
|
|
|
// for(tight_loop = 0; tight_loop < 10000; ++tight_loop) {
|
|
|
|
// cpu->execStep();
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// } else if (core::SYS_HALTED == core::g_state) {
|
|
|
|
// core::Stop();
|
|
|
|
// }
|
|
|
|
//}
|
|
|
|
//core::Kill();
|
|
|
|
|
2014-04-01 04:25:55 +02:00
|
|
|
std::string boot_filename = "homebrew.elf";
|
|
|
|
std::string error_str;
|
|
|
|
|
|
|
|
bool res = Loader::LoadFile(boot_filename, &error_str);
|
|
|
|
|
|
|
|
if (!res) {
|
|
|
|
ERROR_LOG(BOOT, "Failed to load ROM: %s", error_str.c_str());
|
|
|
|
}
|
|
|
|
for (int tight_loop = 0; tight_loop < 10000; ++tight_loop) {
|
|
|
|
Core::SingleStep();
|
|
|
|
}
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2014-04-01 04:25:55 +02:00
|
|
|
delete emu_window;
|
2013-08-30 05:35:09 +02:00
|
|
|
|
2013-09-05 04:09:15 +02:00
|
|
|
return 0;
|
2013-08-30 05:35:09 +02:00
|
|
|
}
|