add wii power/reset button support, wiimote power button support

This commit is contained in:
dborth 2008-11-17 00:09:31 +00:00
parent 91c2756420
commit 59c0c77853
19 changed files with 187 additions and 118 deletions

View File

@ -22,7 +22,7 @@
#include "menudraw.h" #include "menudraw.h"
#include "gcunzip.h" #include "gcunzip.h"
#include "fceuconfig.h" #include "fceugx.h"
u64 dvddir = 0; // offset of currently selected file or folder u64 dvddir = 0; // offset of currently selected file or folder
int dvddirlength = 0; // length of currently selected file or folder int dvddirlength = 0; // length of currently selected file or folder

View File

@ -15,7 +15,7 @@
#include <string.h> #include <string.h>
#include "common.h" #include "common.h"
#include "fceuconfig.h" #include "fceugx.h"
struct SGCSettings GCSettings; struct SGCSettings GCSettings;

View File

@ -15,65 +15,4 @@
void DefaultSettings (); void DefaultSettings ();
#define VERSIONNUM "2.0.6"
#define VERSIONSTR "FCE Ultra GX 2.0.6"
#define PREF_FILE_NAME "FCEUGX.xml"
#define NOTSILENT 0
#define SILENT 1
enum {
METHOD_AUTO,
METHOD_SD,
METHOD_USB,
METHOD_DVD,
METHOD_SMB,
METHOD_MC_SLOTA,
METHOD_MC_SLOTB
};
enum {
FILE_ROM,
FILE_RAM,
FILE_STATE,
FILE_FDSBIOS,
FILE_CHEAT,
FILE_PREF
};
struct SGCSettings{
int AutoLoad;
int AutoSave;
int LoadMethod; // For ROMS: Auto, SD, DVD, USB, Network (SMB)
int SaveMethod; // For SRAM, Freeze, Prefs: Auto, SD, Memory Card Slot A, Memory Card Slot B, USB, SMB
char LoadFolder[200]; // Path to game files
char SaveFolder[200]; // Path to save files
char CheatFolder[200]; // Path to cheat files
char gcip[16];
char gwip[16];
char mask[16];
char smbip[16];
char smbuser[20];
char smbpwd[20];
char smbgcid[20];
char smbsvid[20];
char smbshare[20];
int Zoom; // 0 - off, 1 - on
float ZoomLevel; // zoom amount
int VerifySaves;
int render; // 0 - original, 1 - filtered, 2 - unfiltered
int widescreen;
int hideoverscan;
int currpal;
int timing;
int FSDisable;
int zapper;
int crosshair;
int slimit;
};
extern struct SGCSettings GCSettings;
extern int ConfigRequested;
extern int frameskip;
#endif #endif

View File

@ -4,7 +4,7 @@
* *
* Tantric September 2008 * Tantric September 2008
* *
* fceugc.c * fceugx.c
* *
* This file controls overall program flow. Most things start and end here! * This file controls overall program flow. Most things start and end here!
****************************************************************************/ ****************************************************************************/
@ -20,6 +20,7 @@
#include "types.h" #include "types.h"
#include "fceugx.h"
#include "fceuconfig.h" #include "fceuconfig.h"
#include "fceuload.h" #include "fceuload.h"
#include "fceustate.h" #include "fceustate.h"
@ -28,6 +29,7 @@
#include "menudraw.h" #include "menudraw.h"
#include "menu.h" #include "menu.h"
#include "preferences.h" #include "preferences.h"
#include "fileop.h"
#include "gcaudio.h" #include "gcaudio.h"
#include "gcvideo.h" #include "gcvideo.h"
#include "pad.h" #include "pad.h"
@ -38,6 +40,8 @@
unsigned char * nesrom = NULL; unsigned char * nesrom = NULL;
int ConfigRequested = 0; int ConfigRequested = 0;
int ShutdownRequested = 0;
int ResetRequested = 0;
bool isWii; bool isWii;
uint8 *xbsave=NULL; uint8 *xbsave=NULL;
int frameskip = 0; int frameskip = 0;
@ -45,11 +49,65 @@ int frameskip = 0;
extern bool romLoaded; extern bool romLoaded;
extern int cleanSFMDATA(); extern int cleanSFMDATA();
extern void ResetNES(void); extern void PowerNES(void);
extern uint8 FDSBIOS[8192]; extern uint8 FDSBIOS[8192];
void FCEUD_Update(uint8 *XBuf, int32 *Buffer, int Count); void FCEUD_Update(uint8 *XBuf, int32 *Buffer, int Count);
/****************************************************************************
* Shutdown / Reboot / Exit
***************************************************************************/
#ifdef HW_DOL
#define PSOSDLOADID 0x7c6000a6
int *psoid = (int *) 0x80001800;
void (*PSOReload) () = (void (*)()) 0x80001800;
#endif
void Reboot()
{
UnmountAllFAT();
#ifdef HW_RVL
DI_Close();
SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
#else
#define SOFTRESET_ADR ((volatile u32*)0xCC003024)
*SOFTRESET_ADR = 0x00000000;
#endif
}
void ExitToLoader()
{
UnmountAllFAT();
// Exit to Loader
#ifdef HW_RVL
DI_Close();
exit(0);
#else // gamecube
if (psoid[0] == PSOSDLOADID)
PSOReload ();
#endif
}
#ifdef HW_RVL
void ShutdownCB()
{
ConfigRequested = 1;
ShutdownRequested = 1;
}
void ResetCB()
{
ResetRequested = 1;
}
void ShutdownWii()
{
UnmountAllFAT();
DI_Close();
SYS_ResetSystem(SYS_POWEROFF, 0, 0);
}
#endif
#ifdef HW_DOL
/**************************************************************************** /****************************************************************************
* ipl_set_config * ipl_set_config
* lowlevel Qoob Modchip disable * lowlevel Qoob Modchip disable
@ -73,6 +131,7 @@ void ipl_set_config(unsigned char c)
exi[0] &= 0x405; //deselect IPL exi[0] &= 0x405; //deselect IPL
} }
#endif
/**************************************************************************** /****************************************************************************
* main * main
@ -100,7 +159,15 @@ int main(int argc, char *argv[])
PAD_Init(); PAD_Init();
// Wii Power/Reset buttons
#ifdef HW_RVL
WPAD_SetPowerButtonCallback((WPADShutdownCallback)ShutdownCB);
SYS_SetPowerCallback(ShutdownCB);
SYS_SetResetCallback(ResetCB);
#endif
InitGCVideo (); InitGCVideo ();
ResetVideo_Menu (); // change to menu video mode
/*** Initialise freetype ***/ /*** Initialise freetype ***/
if (FT_Init ()) if (FT_Init ())
@ -119,9 +186,10 @@ int main(int argc, char *argv[])
nesrom = (unsigned char *)malloc(1024*1024*3); // 3 MB should be plenty nesrom = (unsigned char *)malloc(1024*1024*3); // 3 MB should be plenty
/*** Minimal Emulation Loop ***/ /*** Minimal Emulation Loop ***/
if ( !FCEUI_Initialize() ) { if ( !FCEUI_Initialize() )
printf("Unable to initialize system\n"); {
return 1; WaitPrompt((char *)"Unable to initialize FCE Ultra\n");
ExitToLoader();
} }
FCEUI_SetGameGenie(0); // 0 - OFF, 1 - ON FCEUI_SetGameGenie(0); // 0 - OFF, 1 - ON
@ -145,7 +213,11 @@ int main(int argc, char *argv[])
while (1) // main loop while (1) // main loop
{ {
ResetVideo_Menu(); #ifdef HW_RVL
if(ShutdownRequested)
ShutdownWii();
#endif
MainMenu(selectedMenu); MainMenu(selectedMenu);
selectedMenu = 2; // return to game menu from now on selectedMenu = 2; // return to game menu from now on
@ -174,8 +246,15 @@ int main(int argc, char *argv[])
FCEUD_Update(gfx, sound, ssize); FCEUD_Update(gfx, sound, ssize);
} }
if(ResetRequested)
{
PowerNES(); // reset game
ResetRequested = 0;
}
if(ConfigRequested) if(ConfigRequested)
{ {
ResetVideo_Menu();
if (GCSettings.AutoSave == 1) if (GCSettings.AutoSave == 1)
{ {
SaveRAM(GCSettings.SaveMethod, SILENT); SaveRAM(GCSettings.SaveMethod, SILENT);

80
source/ngc/fceugx.h Normal file
View File

@ -0,0 +1,80 @@
/****************************************************************************
* FCE Ultra 0.98.12
* Nintendo Wii/Gamecube Port
*
* Tantric September 2008
*
* fceugx.h
*
* This file controls overall program flow. Most things start and end here!
****************************************************************************/
#ifndef _FCEUGX_H_
#define _FCEUGX_H_
#define VERSIONNUM "2.0.6"
#define VERSIONSTR "FCE Ultra GX 2.0.6"
#define PREF_FILE_NAME "FCEUGX.xml"
#define NOTSILENT 0
#define SILENT 1
enum {
METHOD_AUTO,
METHOD_SD,
METHOD_USB,
METHOD_DVD,
METHOD_SMB,
METHOD_MC_SLOTA,
METHOD_MC_SLOTB
};
enum {
FILE_ROM,
FILE_RAM,
FILE_STATE,
FILE_FDSBIOS,
FILE_CHEAT,
FILE_PREF
};
struct SGCSettings{
int AutoLoad;
int AutoSave;
int LoadMethod; // For ROMS: Auto, SD, DVD, USB, Network (SMB)
int SaveMethod; // For SRAM, Freeze, Prefs: Auto, SD, Memory Card Slot A, Memory Card Slot B, USB, SMB
char LoadFolder[200]; // Path to game files
char SaveFolder[200]; // Path to save files
char CheatFolder[200]; // Path to cheat files
char gcip[16];
char gwip[16];
char mask[16];
char smbip[16];
char smbuser[20];
char smbpwd[20];
char smbgcid[20];
char smbsvid[20];
char smbshare[20];
int Zoom; // 0 - off, 1 - on
float ZoomLevel; // zoom amount
int VerifySaves;
int render; // 0 - original, 1 - filtered, 2 - unfiltered
int widescreen;
int hideoverscan;
int currpal;
int timing;
int FSDisable;
int zapper;
int crosshair;
int slimit;
};
void ExitToLoader();
void Reboot();
void ShutdownWii();
extern struct SGCSettings GCSettings;
extern int ConfigRequested;
extern int ShutdownRequested;
extern int frameskip;
#endif

View File

@ -24,11 +24,11 @@
#include "sound.h" #include "sound.h"
#include "file.h" #include "file.h"
#include "fceugx.h"
#include "gcaudio.h" #include "gcaudio.h"
#include "common.h" #include "common.h"
#include "pad.h" #include "pad.h"
#include "menudraw.h" #include "menudraw.h"
#include "fceuconfig.h"
#include "fileop.h" #include "fileop.h"
#include "filesel.h" #include "filesel.h"
#include "smbop.h" #include "smbop.h"

View File

@ -31,7 +31,7 @@
#include "general.h" #include "general.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "intl.h" #include "intl.h"
#include "menudraw.h" #include "menudraw.h"
#include "filesel.h" #include "filesel.h"

View File

@ -21,7 +21,7 @@
#include "state.h" #include "state.h"
#include "images/saveicon.h" #include "images/saveicon.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "intl.h" #include "intl.h"
#include "menudraw.h" #include "menudraw.h"
#include "filesel.h" #include "filesel.h"

View File

@ -17,7 +17,7 @@
#include <zlib.h> #include <zlib.h>
#include "common.h" #include "common.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "fileop.h" #include "fileop.h"
#include "gcunzip.h" #include "gcunzip.h"
#include "menudraw.h" #include "menudraw.h"

View File

@ -22,6 +22,7 @@
#define ROOTFATDIR "fat:/" #define ROOTFATDIR "fat:/"
void UnmountAllFAT();
bool ChangeFATInterface(int method, bool silent); bool ChangeFATInterface(int method, bool silent);
int ParseFATdirectory(int method); int ParseFATdirectory(int method);
int LoadFATSzFile(char * filepath, unsigned char * rbuffer); int LoadFATSzFile(char * filepath, unsigned char * rbuffer);

View File

@ -20,7 +20,7 @@
#endif #endif
#include "common.h" #include "common.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "dvd.h" #include "dvd.h"
#include "menudraw.h" #include "menudraw.h"
#include "filesel.h" #include "filesel.h"

View File

@ -19,7 +19,7 @@
#include "../sz/7zIn.h" #include "../sz/7zIn.h"
#include "../sz/7zExtract.h" #include "../sz/7zExtract.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "dvd.h" #include "dvd.h"
#include "smbop.h" #include "smbop.h"
#include "fileop.h" #include "fileop.h"

View File

@ -19,7 +19,7 @@
#include "driver.h" #include "driver.h"
#include "gcvideo.h" #include "gcvideo.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "menudraw.h" #include "menudraw.h"
#include "images/nesback.h" #include "images/nesback.h"

View File

@ -18,7 +18,7 @@
#include "common.h" #include "common.h"
#include "menudraw.h" #include "menudraw.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "menu.h" #include "menu.h"
#include "memcardop.h" #include "memcardop.h"
#include "fileop.h" #include "fileop.h"

View File

@ -21,6 +21,7 @@
#endif #endif
#include "common.h" #include "common.h"
#include "fceugx.h"
#include "fceuconfig.h" #include "fceuconfig.h"
#include "pad.h" #include "pad.h"
#include "button_mapping.h" #include "button_mapping.h"
@ -43,42 +44,6 @@ extern void PowerNES(void);
extern int menu; extern int menu;
extern bool romLoaded; extern bool romLoaded;
#define SOFTRESET_ADR ((volatile u32*)0xCC003024)
/****************************************************************************
* Reboot / Exit
****************************************************************************/
#ifndef HW_RVL
#define PSOSDLOADID 0x7c6000a6
int *psoid = (int *) 0x80001800;
void (*PSOReload) () = (void (*)()) 0x80001800;
#endif
void Reboot()
{
#ifdef HW_RVL
SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
#else
#define SOFTRESET_ADR ((volatile u32*)0xCC003024)
*SOFTRESET_ADR = 0x00000000;
#endif
}
void ExitToLoader()
{
// Exit to Loader
#ifdef HW_RVL
#ifdef WII_DVD
DI_Close();
#endif
exit(0);
#else // gamecube
if (psoid[0] == PSOSDLOADID)
PSOReload ();
#endif
}
/**************************************************************************** /****************************************************************************
* Load Manager * Load Manager
****************************************************************************/ ****************************************************************************/

View File

@ -20,7 +20,7 @@
#include <zlib.h> #include <zlib.h>
#include FT_FREETYPE_H #include FT_FREETYPE_H
#include "fceuconfig.h" #include "fceugx.h"
#include "gcvideo.h" #include "gcvideo.h"
#include "menudraw.h" #include "menudraw.h"
#include "filesel.h" #include "filesel.h"
@ -501,6 +501,11 @@ RunMenu (char items[][50], int maxitems, char *title, int fontsize, int x)
while (quit == 0) while (quit == 0)
{ {
#ifdef HW_RVL
if(ShutdownRequested)
ShutdownWii();
#endif
if (redraw) if (redraw)
{ {
DrawMenu (&items[0], title, maxitems, menu, fontsize, -1); DrawMenu (&items[0], title, maxitems, menu, fontsize, -1);

View File

@ -16,7 +16,7 @@
#include "fceu.h" #include "fceu.h"
#include "input.h" #include "input.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "pad.h" #include "pad.h"
#include "gcaudio.h" #include "gcaudio.h"
#include "menu.h" #include "menu.h"

View File

@ -20,7 +20,7 @@
#include "fileop.h" #include "fileop.h"
#include "smbop.h" #include "smbop.h"
#include "filesel.h" #include "filesel.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "pad.h" #include "pad.h"
extern const unsigned short saveicon[1024]; extern const unsigned short saveicon[1024];

View File

@ -20,7 +20,7 @@
#include <errno.h> #include <errno.h>
#include "common.h" #include "common.h"
#include "fceuconfig.h" #include "fceugx.h"
#include "smbop.h" #include "smbop.h"
#include "gcunzip.h" #include "gcunzip.h"
#include "menudraw.h" #include "menudraw.h"