| 
									
										
										
										
											2014-04-08 20:25:53 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-04-08 20:25:53 -04:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-20 20:34:41 +01:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | #include <thread>
 | 
					
						
							|  |  |  | #include <iostream>
 | 
					
						
							| 
									
										
										
										
											2016-04-05 13:29:55 +01:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-17 18:25:21 -03:00
										 |  |  | // This needs to be included before getopt.h because the latter #defines symbols used by it
 | 
					
						
							|  |  |  | #include "common/microprofile.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | #ifdef _MSC_VER
 | 
					
						
							|  |  |  | #include <getopt.h>
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #include <unistd.h>
 | 
					
						
							|  |  |  | #include <getopt.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-06 04:06:12 -03:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							| 
									
										
										
										
											2014-10-28 05:36:00 -02:00
										 |  |  | #include "common/logging/backend.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-06 20:00:08 -02:00
										 |  |  | #include "common/logging/filter.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-15 02:59:14 +00:00
										 |  |  | #include "common/scope_exit.h"
 | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-27 17:18:28 -04:00
										 |  |  | #include "core/settings.h"
 | 
					
						
							| 
									
										
										
										
											2014-04-08 20:15:08 -04:00
										 |  |  | #include "core/system.h"
 | 
					
						
							|  |  |  | #include "core/core.h"
 | 
					
						
							| 
									
										
										
										
											2015-10-21 22:19:55 -04:00
										 |  |  | #include "core/gdbstub/gdbstub.h"
 | 
					
						
							| 
									
										
										
										
											2014-06-16 18:03:13 -04:00
										 |  |  | #include "core/loader/loader.h"
 | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 17:06:13 -07:00
										 |  |  | #include "citra/config.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-01 17:24:18 +00:00
										 |  |  | #include "citra/emu_window/emu_window_sdl2.h"
 | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-18 21:21:33 -07:00
										 |  |  | #include "video_core/video_core.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void PrintHelp() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |     std::cout << "Usage: citra [options] <filename>" << std::endl; | 
					
						
							|  |  |  |     std::cout << "--help, -h            Display this information" << std::endl; | 
					
						
							|  |  |  |     std::cout << "--gdbport, -g number  Enable gdb stub on port number" << std::endl; | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | /// Application entry point
 | 
					
						
							| 
									
										
										
										
											2015-05-06 22:59:59 -03:00
										 |  |  | int main(int argc, char **argv) { | 
					
						
							| 
									
										
										
										
											2016-04-06 22:27:28 -04:00
										 |  |  |     Config config; | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |     int option_index = 0; | 
					
						
							| 
									
										
										
										
											2016-04-06 22:27:28 -04:00
										 |  |  |     bool use_gdbstub = Settings::values.use_gdbstub; | 
					
						
							|  |  |  |     u32 gdb_port = static_cast<u32>(Settings::values.gdbstub_port); | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |     char *endarg; | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |     std::string boot_filename; | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |     static struct option long_options[] = { | 
					
						
							|  |  |  |         { "help", no_argument, 0, 'h' }, | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |         { "gdbport", required_argument, 0, 'g' }, | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |         { 0, 0, 0, 0 } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (optind < argc) { | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |         char arg = getopt_long(argc, argv, ":hg:", long_options, &option_index); | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |         if (arg != -1) { | 
					
						
							|  |  |  |             switch (arg) { | 
					
						
							|  |  |  |             case 'h': | 
					
						
							|  |  |  |                 PrintHelp(); | 
					
						
							|  |  |  |                 return 0; | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |             case 'g': | 
					
						
							|  |  |  |                 errno = 0; | 
					
						
							|  |  |  |                 gdb_port = strtoul(optarg, &endarg, 0); | 
					
						
							| 
									
										
										
										
											2016-04-06 22:27:28 -04:00
										 |  |  |                 use_gdbstub = true; | 
					
						
							| 
									
										
										
										
											2016-04-06 07:01:00 -04:00
										 |  |  |                 if (endarg == optarg) errno = EINVAL; | 
					
						
							|  |  |  |                 if (errno != 0) { | 
					
						
							|  |  |  |                     perror("--gdbport"); | 
					
						
							|  |  |  |                     exit(1); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |             } | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             boot_filename = argv[optind]; | 
					
						
							|  |  |  |             optind++; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-06 20:00:08 -02:00
										 |  |  |     Log::Filter log_filter(Log::Level::Debug); | 
					
						
							| 
									
										
										
										
											2015-03-06 19:15:02 +01:00
										 |  |  |     Log::SetFilter(&log_filter); | 
					
						
							| 
									
										
										
										
											2013-09-17 22:57:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-17 18:25:21 -03:00
										 |  |  |     MicroProfileOnThreadCreate("EmuThread"); | 
					
						
							| 
									
										
										
										
											2016-03-15 02:59:14 +00:00
										 |  |  |     SCOPE_EXIT({ MicroProfileShutdown(); }); | 
					
						
							| 
									
										
										
										
											2015-08-17 18:25:21 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  |     if (boot_filename.empty()) { | 
					
						
							| 
									
										
										
										
											2014-12-05 23:53:49 -02:00
										 |  |  |         LOG_CRITICAL(Frontend, "Failed to load ROM: No ROM specified"); | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |         return -1; | 
					
						
							| 
									
										
										
										
											2014-05-04 15:47:42 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-06 20:00:08 -02:00
										 |  |  |     log_filter.ParseFilterString(Settings::values.log_filter); | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-11 15:20:05 +02:00
										 |  |  |     // Apply the command line arguments
 | 
					
						
							|  |  |  |     Settings::values.gdbstub_port = gdb_port; | 
					
						
							|  |  |  |     Settings::values.use_gdbstub = use_gdbstub; | 
					
						
							|  |  |  |     Settings::Apply(); | 
					
						
							| 
									
										
										
										
											2015-06-22 20:59:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-05 13:29:55 +01:00
										 |  |  |     std::unique_ptr<EmuWindow_SDL2> emu_window = std::make_unique<EmuWindow_SDL2>(); | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-15 02:59:14 +00:00
										 |  |  |     System::Init(emu_window.get()); | 
					
						
							|  |  |  |     SCOPE_EXIT({ System::Shutdown(); }); | 
					
						
							| 
									
										
										
										
											2014-03-31 22:25:55 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 17:06:13 -07:00
										 |  |  |     Loader::ResultStatus load_result = Loader::LoadFile(boot_filename); | 
					
						
							|  |  |  |     if (Loader::ResultStatus::Success != load_result) { | 
					
						
							| 
									
										
										
										
											2014-12-05 23:53:49 -02:00
										 |  |  |         LOG_CRITICAL(Frontend, "Failed to load ROM (Error %i)!", load_result); | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |         return -1; | 
					
						
							| 
									
										
										
										
											2014-03-31 22:25:55 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-04-07 00:53:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-15 18:48:02 -07:00
										 |  |  |     while (emu_window->IsOpen()) { | 
					
						
							| 
									
										
										
										
											2014-08-29 23:24:32 -04:00
										 |  |  |         Core::RunLoop(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-17 11:59:18 -04:00
										 |  |  |     return 0; | 
					
						
							| 
									
										
										
										
											2013-08-29 23:35:09 -04:00
										 |  |  | } |