vbagx/source/ngc/vba.cpp

284 lines
6.0 KiB
C++
Raw Normal View History

/****************************************************************************
2008-09-17 04:27:55 +02:00
* Visual Boy Advance GX
*
* Tantric September 2008
*
* vba.cpp
*
* This file controls overall program flow. Most things start and end here!
***************************************************************************/
#include <gccore.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ogcsys.h>
#include <unistd.h>
#include <wiiuse/wpad.h>
#ifdef HW_RVL
extern "C" {
#include <di/di.h>
}
#endif
2009-04-08 09:08:12 +02:00
#include "FreeTypeGX.h"
#include "gba/Sound.h"
#include "vba.h"
#include "vbasupport.h"
#include "preferences.h"
#include "audio.h"
#include "dvd.h"
2008-12-24 08:52:35 +01:00
#include "networkop.h"
2009-04-08 09:08:12 +02:00
#include "filebrowser.h"
#include "fileop.h"
#include "menu.h"
#include "input.h"
#include "video.h"
#include "vbaconfig.h"
#include "wiiusbsupport.h"
extern int emulating;
2008-10-18 22:40:48 +02:00
int ConfigRequested = 0;
int ShutdownRequested = 0;
int ResetRequested = 0;
2009-04-08 09:08:12 +02:00
int ExitRequested = 0;
char appPath[1024];
2009-04-08 09:08:12 +02:00
FreeTypeGX *fontSystem;
/****************************************************************************
* Shutdown / Reboot / Exit
***************************************************************************/
static void ExitCleanup()
2008-12-18 19:58:30 +01:00
{
#ifdef HW_RVL
ShutoffRumble();
StopWiiKeyboard();
#endif
2009-04-08 09:08:12 +02:00
ShutdownAudio();
StopGX();
2008-12-24 08:52:35 +01:00
LWP_SuspendThread (devicethread);
2008-12-18 19:58:30 +01:00
UnmountAllFAT();
#ifdef HW_RVL
DI_Close();
#endif
}
#ifdef HW_DOL
#define PSOSDLOADID 0x7c6000a6
int *psoid = (int *) 0x80001800;
void (*PSOReload) () = (void (*)()) 0x80001800;
#endif
2009-04-08 09:08:12 +02:00
void ExitApp()
{
2008-12-18 19:58:30 +01:00
ExitCleanup();
2009-04-08 09:08:12 +02:00
if(GCSettings.ExitAction == 0) // Exit to Loader
{
#ifdef HW_RVL
exit(0);
#else
if (psoid[0] == PSOSDLOADID)
PSOReload ();
#endif
}
else if(GCSettings.ExitAction == 1) // Exit to Menu
{
#ifdef HW_RVL
SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
#else
#define SOFTRESET_ADR ((volatile u32*)0xCC003024)
*SOFTRESET_ADR = 0x00000000;
#endif
}
else // Shutdown Wii
{
SYS_ResetSystem(SYS_POWEROFF, 0, 0);
}
}
#ifdef HW_RVL
void ShutdownCB()
{
ConfigRequested = 1;
ShutdownRequested = 1;
}
void ResetCB()
{
ResetRequested = 1;
}
void ShutdownWii()
{
2008-12-18 19:58:30 +01:00
ExitCleanup();
SYS_ResetSystem(SYS_POWEROFF, 0, 0);
}
#endif
#ifdef HW_DOL
2008-10-21 10:09:18 +02:00
/****************************************************************************
* ipl_set_config
* lowlevel Qoob Modchip disable
***************************************************************************/
static void ipl_set_config(unsigned char c)
2008-10-21 10:09:18 +02:00
{
volatile unsigned long* exi = (volatile unsigned long*)0xCC006800;
unsigned long val,addr;
addr=0xc0000000;
val = c << 24;
exi[0] = ((((exi[0]) & 0x405) | 256) | 48); //select IPL
//write addr of IPL
exi[0 * 5 + 4] = addr;
exi[0 * 5 + 3] = ((4 - 1) << 4) | (1 << 2) | 1;
while (exi[0 * 5 + 3] & 1);
//write the ipl we want to send
exi[0 * 5 + 4] = val;
exi[0 * 5 + 3] = ((4 - 1) << 4) | (1 << 2) | 1;
while (exi[0 * 5 + 3] & 1);
exi[0] &= 0x405; //deselect IPL
}
#endif
2008-10-21 10:09:18 +02:00
static void CreateAppPath(char origpath[])
{
#ifdef HW_DOL
snprintf(appPath, 1024, GCSettings.SaveFolder);
#else
char path[1024];
strcpy(path, origpath); // make a copy so we don't mess up original
char * loc;
int pos = -1;
loc = strrchr(path,'/');
if (loc != NULL)
*loc = 0; // strip file name
loc = strchr(path,'/'); // looking for / from fat:/
if (loc != NULL)
pos = loc - path + 1;
if(pos >= 0 && pos < 1024)
sprintf(appPath, &(path[pos]));
#endif
}
/****************************************************************************
* main
*
* Program entry
****************************************************************************/
int main(int argc, char *argv[])
{
2008-10-21 10:09:18 +02:00
#ifdef HW_DOL
ipl_set_config(6); // disable Qoob modchip
#endif
#ifdef HW_RVL
2009-02-20 10:36:05 +01:00
DI_Close();
DI_Init(); // first
#endif
InitDeviceThread();
2009-02-20 10:36:05 +01:00
VIDEO_Init();
PAD_Init();
#ifdef HW_RVL
WPAD_Init();
2009-02-20 10:36:05 +01:00
#endif
2009-04-08 09:08:12 +02:00
InitializeVideo();
2009-02-20 10:36:05 +01:00
ResetVideo_Menu (); // change to menu video mode
#ifdef HW_RVL
// read wiimote accelerometer and IR data
WPAD_SetDataFormat(WPAD_CHAN_ALL,WPAD_FMT_BTNS_ACC_IR);
2009-04-08 09:08:12 +02:00
WPAD_SetVRes(WPAD_CHAN_ALL,screenwidth,screenheight);
// Wii Power/Reset buttons
WPAD_SetPowerButtonCallback((WPADShutdownCallback)ShutdownCB);
SYS_SetPowerCallback(ShutdownCB);
SYS_SetResetCallback(ResetCB);
#endif
2009-04-08 09:08:12 +02:00
MountAllFAT(); // Initialize libFAT for SD and USB
// Initialize DVD subsystem (GameCube only)
2008-09-26 10:10:36 +02:00
#ifdef HW_DOL
DVD_Init ();
#endif
2009-04-08 09:08:12 +02:00
SetDVDDriveType(); // Check if DVD drive belongs to a Wii
InitialiseSound();
InitialisePalette();
2009-04-08 09:08:12 +02:00
DefaultSettings (); // Set defaults
2009-04-08 09:08:12 +02:00
// Initialize font system
fontSystem = new FreeTypeGX();
fontSystem->loadFont(font_ttf, font_ttf_size, 0);
fontSystem->setCompatibilityMode(FTGX_COMPATIBILITY_DEFAULT_TEVOP_GX_PASSCLR | FTGX_COMPATIBILITY_DEFAULT_VTXDESC_GX_NONE);
InitGUIThreads();
// store path app was loaded from
2008-11-26 08:39:09 +01:00
sprintf(appPath, "vbagx");
if(argc > 0 && argv[0] != NULL)
CreateAppPath(argv[0]);
StartWiiKeyboardMouse();
2008-10-21 09:17:07 +02:00
while(1) // main loop
{
#ifdef HW_RVL
if(ShutdownRequested)
ShutdownWii();
#endif
// go back to checking if devices were inserted/removed
// since we're entering the menu
LWP_ResumeThread (devicethread);
2009-04-08 09:08:12 +02:00
ConfigRequested = 1;
SwitchAudioMode(1);
if(!ROMLoaded)
MainMenu(MENU_GAMESELECTION);
else
MainMenu(MENU_GAME);
ConfigRequested = 0;
SwitchAudioMode(0);
2008-10-18 22:40:48 +02:00
// stop checking if devices were removed/inserted
// since we're starting emulation again
LWP_SuspendThread (devicethread);
2008-10-24 08:16:15 +02:00
ResetVideo_Emu();
2008-10-21 09:17:07 +02:00
while (emulating) // emulation loop
{
emulator.emuMain(emulator.emuCount);
2008-10-18 22:40:48 +02:00
if(ResetRequested)
{
emulator.emuReset(); // reset game
ResetRequested = 0;
}
2008-10-18 22:40:48 +02:00
if(ConfigRequested)
{
2009-04-08 09:08:12 +02:00
TakeScreenshot();
ResetVideo_Menu();
break; // leave emulation loop
2008-10-18 22:40:48 +02:00
}
2009-04-08 09:08:12 +02:00
} // emulation loop
} // main loop
}