*removed all the switches at the end of menu.cpp
* removed duplicate 002 parameter in constructors * pass setting parameter directly to the patching functions instead of making another variable just for this * probably broke something
This commit is contained in:
parent
74fa0a40be
commit
444d2dbe79
11 changed files with 120 additions and 206 deletions
|
@ -2,8 +2,8 @@
|
||||||
<app version="1">
|
<app version="1">
|
||||||
<name> USB Loader GX</name>
|
<name> USB Loader GX</name>
|
||||||
<coder>USB Loader GX Team</coder>
|
<coder>USB Loader GX Team</coder>
|
||||||
<version>1.0 r983</version>
|
<version>1.0 r984</version>
|
||||||
<release_date>201009300328</release_date>
|
<release_date>201009300423</release_date>
|
||||||
<short_description>Loads games from USB-devices</short_description>
|
<short_description>Loads games from USB-devices</short_description>
|
||||||
<long_description>USB Loader GX is a libwiigui based USB iso loader with a wii-like GUI. You can install games to your HDDs and boot them with shorter loading times.
|
<long_description>USB Loader GX is a libwiigui based USB iso loader with a wii-like GUI. You can install games to your HDDs and boot them with shorter loading times.
|
||||||
The interactive GUI is completely controllable with WiiMote, Classic Controller or GC Controller.
|
The interactive GUI is completely controllable with WiiMote, Classic Controller or GC Controller.
|
||||||
|
|
124
source/menu.cpp
124
source/menu.cpp
|
@ -469,127 +469,9 @@ int MainMenu(int menu)
|
||||||
{
|
{
|
||||||
mload_close();
|
mload_close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 errorfixer002 = fix002;
|
u32 channel = 0;
|
||||||
|
|
||||||
switch (languageChoice)
|
|
||||||
{
|
|
||||||
case ConsoleLangDefault:
|
|
||||||
configbytes[0] = 0xCD;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case jap:
|
|
||||||
configbytes[0] = 0x00;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case eng:
|
|
||||||
configbytes[0] = 0x01;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ger:
|
|
||||||
configbytes[0] = 0x02;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case fren:
|
|
||||||
configbytes[0] = 0x03;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case esp:
|
|
||||||
configbytes[0] = 0x04;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case it:
|
|
||||||
configbytes[0] = 0x05;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case dut:
|
|
||||||
configbytes[0] = 0x06;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case schin:
|
|
||||||
configbytes[0] = 0x07;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case tchin:
|
|
||||||
configbytes[0] = 0x08;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case kor:
|
|
||||||
configbytes[0] = 0x09;
|
|
||||||
break;
|
|
||||||
//wenn nicht genau klar ist welches
|
|
||||||
default:
|
|
||||||
configbytes[0] = 0xCD;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
u8 videoselected = 0;
|
|
||||||
|
|
||||||
switch (videoChoice)
|
|
||||||
{
|
|
||||||
case discdefault:
|
|
||||||
videoselected = 0;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case pal50:
|
|
||||||
videoselected = 1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case pal60:
|
|
||||||
videoselected = 2;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ntsc:
|
|
||||||
videoselected = 3;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case systemdefault:
|
|
||||||
videoselected = 4;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case patch:
|
|
||||||
videoselected = 5;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
videoselected = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
u32 cheat = 0;
|
|
||||||
switch (ocarinaChoice)
|
|
||||||
{
|
|
||||||
case on:
|
|
||||||
cheat = 1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case off:
|
|
||||||
cheat = 0;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
cheat = 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
u8 vipatch = 0;
|
|
||||||
switch (viChoice)
|
|
||||||
{
|
|
||||||
case on:
|
|
||||||
vipatch = 1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case off:
|
|
||||||
vipatch = 0;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
vipatch = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
u32 channel = 0;
|
|
||||||
if (returnToLoaderGV)
|
if (returnToLoaderGV)
|
||||||
{
|
{
|
||||||
int idx = NandTitles.FindU32(Settings.returnTo);
|
int idx = NandTitles.FindU32(Settings.returnTo);
|
||||||
|
@ -602,7 +484,7 @@ int MainMenu(int menu)
|
||||||
|
|
||||||
gprintf("\tDisc_wiiBoot\n");
|
gprintf("\tDisc_wiiBoot\n");
|
||||||
|
|
||||||
ret = Disc_WiiBoot(Settings.dolpath, videoselected, cheat, vipatch, countrystrings, errorfixer002,
|
ret = Disc_WiiBoot(Settings.dolpath, videoChoice, languageChoice, ocarinaChoice, viChoice, countrystrings,
|
||||||
alternatedol, alternatedoloffset, channel, fix002);
|
alternatedol, alternatedoloffset, channel, fix002);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include "dolpatcher.h"
|
#include "dolpatcher.h"
|
||||||
#include "wip.h"
|
#include "wip.h"
|
||||||
#include "gecko.h"
|
#include "gecko.h"
|
||||||
|
#include "../settings/cfg.h"
|
||||||
|
|
||||||
/** Anti 002 fix for IOS 249 rev > 12 thanks to WiiPower **/
|
/** Anti 002 fix for IOS 249 rev > 12 thanks to WiiPower **/
|
||||||
bool Anti_002_fix(u8 * Address, int Size)
|
bool Anti_002_fix(u8 * Address, int Size)
|
||||||
|
@ -237,7 +238,7 @@ static bool Search_and_patch_Video_Modes(u8 * Address, u32 Size, GXRModeObj* Tab
|
||||||
void VideoModePatcher(u8 * dst, int len, u8 videoSelected)
|
void VideoModePatcher(u8 * dst, int len, u8 videoSelected)
|
||||||
{
|
{
|
||||||
GXRModeObj** table = NULL;
|
GXRModeObj** table = NULL;
|
||||||
if (videoSelected == 5) // patch
|
if (videoSelected == patch) // patch enum'd in cfg.h
|
||||||
|
|
||||||
{
|
{
|
||||||
switch (CONF_GetVideo())
|
switch (CONF_GetVideo())
|
||||||
|
|
|
@ -319,8 +319,48 @@ bool dogamehooks(void *addr, u32 len)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
void langpatcher(void *addr, u32 len)
|
void langpatcher(void *addr, u32 len, u8 languageChoice)
|
||||||
{
|
{
|
||||||
|
u8 ocarinaLangPatchByte = 1;
|
||||||
|
switch (languageChoice)
|
||||||
|
{
|
||||||
|
case jap:
|
||||||
|
ocarinaLangPatchByte = 0x00;
|
||||||
|
break;
|
||||||
|
case eng:
|
||||||
|
ocarinaLangPatchByte = 0x01;
|
||||||
|
break;
|
||||||
|
case ger:
|
||||||
|
ocarinaLangPatchByte = 0x02;
|
||||||
|
break;
|
||||||
|
case fren:
|
||||||
|
ocarinaLangPatchByte = 0x03;
|
||||||
|
break;
|
||||||
|
case esp:
|
||||||
|
ocarinaLangPatchByte = 0x04;
|
||||||
|
break;
|
||||||
|
case it:
|
||||||
|
ocarinaLangPatchByte = 0x05;
|
||||||
|
break;
|
||||||
|
case dut:
|
||||||
|
ocarinaLangPatchByte = 0x06;
|
||||||
|
break;
|
||||||
|
case schin:
|
||||||
|
ocarinaLangPatchByte = 0x07;
|
||||||
|
break;
|
||||||
|
case tchin:
|
||||||
|
ocarinaLangPatchByte = 0x08;
|
||||||
|
break;
|
||||||
|
case kor:
|
||||||
|
ocarinaLangPatchByte = 0x09;
|
||||||
|
break;
|
||||||
|
case ConsoleLangDefault:
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr + len;
|
void *addr_end = addr + len;
|
||||||
|
@ -330,10 +370,7 @@ void langpatcher(void *addr, u32 len)
|
||||||
|
|
||||||
if (memcmp(addr_start, langpatch, sizeof(langpatch)) == 0)
|
if (memcmp(addr_start, langpatch, sizeof(langpatch)) == 0)
|
||||||
{
|
{
|
||||||
if (configbytes[0] != 0xCD)
|
langvipatch((u32) addr_start, len, ocarinaLangPatchByte);
|
||||||
{
|
|
||||||
langvipatch((u32) addr_start, len, configbytes[0]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
addr_start += 4;
|
addr_start += 4;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,12 +29,12 @@ extern "C"
|
||||||
// Globals
|
// Globals
|
||||||
u32 hooktype;
|
u32 hooktype;
|
||||||
int patched;
|
int patched;
|
||||||
u8 configbytes[2];
|
//u8 configbytes[2];
|
||||||
u32 regionfree;
|
//u32 regionfree;
|
||||||
|
|
||||||
// Function prototypes
|
// Function prototypes
|
||||||
bool dogamehooks(void *addr, u32 len);
|
bool dogamehooks(void *addr, u32 len);
|
||||||
void langpatcher(void *addr, u32 len);
|
void langpatcher(void *addr, u32 len, u8 languageChoice);
|
||||||
void vidolpatcher(void *addr, u32 len);
|
void vidolpatcher(void *addr, u32 len);
|
||||||
void patchdebug(void *addr, u32 len);
|
void patchdebug(void *addr, u32 len);
|
||||||
|
|
||||||
|
|
|
@ -106,7 +106,7 @@ typedef struct _dolheader
|
||||||
|
|
||||||
static dolheader *dolfile;
|
static dolheader *dolfile;
|
||||||
|
|
||||||
u32 load_dol_image(void *dolstart, u8 videoSelected, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002)
|
u32 load_dol_image(void *dolstart, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002)
|
||||||
{
|
{
|
||||||
|
|
||||||
u32 i;
|
u32 i;
|
||||||
|
@ -120,7 +120,7 @@ u32 load_dol_image(void *dolstart, u8 videoSelected, u8 patchcountrystring, u8 v
|
||||||
|
|
||||||
ICInvalidateRange((void *) dolfile->text_start[i], dolfile->text_size[i]);
|
ICInvalidateRange((void *) dolfile->text_start[i], dolfile->text_size[i]);
|
||||||
memmove((void *) dolfile->text_start[i], dolstart + dolfile->text_pos[i], dolfile->text_size[i]);
|
memmove((void *) dolfile->text_start[i], dolstart + dolfile->text_pos[i], dolfile->text_size[i]);
|
||||||
gamepatches((void *) dolfile->text_start[i], dolfile->text_size[i], videoSelected, patchcountrystring,
|
gamepatches((void *) dolfile->text_start[i], dolfile->text_size[i], videoSelected, languageChoice, patchcountrystring,
|
||||||
vipatch, cheat, returnTo, fix002);
|
vipatch, cheat, returnTo, fix002);
|
||||||
Remove_001_Protection((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
Remove_001_Protection((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
||||||
}
|
}
|
||||||
|
@ -130,7 +130,7 @@ u32 load_dol_image(void *dolstart, u8 videoSelected, u8 patchcountrystring, u8 v
|
||||||
if ((!dolfile->data_size[i]) || (dolfile->data_start[i] < 0x100)) continue;
|
if ((!dolfile->data_size[i]) || (dolfile->data_start[i] < 0x100)) continue;
|
||||||
|
|
||||||
memmove((void *) dolfile->data_start[i], dolstart + dolfile->data_pos[i], dolfile->data_size[i]);
|
memmove((void *) dolfile->data_start[i], dolstart + dolfile->data_pos[i], dolfile->data_size[i]);
|
||||||
gamepatches((void *) dolfile->data_start[i], dolfile->data_size[i], videoSelected, patchcountrystring,
|
gamepatches((void *) dolfile->data_start[i], dolfile->data_size[i], videoSelected, languageChoice, patchcountrystring,
|
||||||
vipatch, cheat, returnTo, fix002);
|
vipatch, cheat, returnTo, fix002);
|
||||||
Remove_001_Protection((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
Remove_001_Protection((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
||||||
DCFlushRangeNoSync((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
DCFlushRangeNoSync((void *) dolfile->data_start[i], dolfile->data_size[i]);
|
||||||
|
@ -224,7 +224,7 @@ void __dvd_readidcb(s32 result)
|
||||||
{
|
{
|
||||||
dvddone = result;
|
dvddone = result;
|
||||||
}
|
}
|
||||||
u32 Load_Dol_from_disc(u32 doloffset, u8 videoSelected, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002)
|
u32 Load_Dol_from_disc(u32 doloffset, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
void *dol_header;
|
void *dol_header;
|
||||||
|
@ -265,7 +265,7 @@ u32 Load_Dol_from_disc(u32 doloffset, u8 videoSelected, u8 patchcountrystring, u
|
||||||
{
|
{
|
||||||
ret = WDVD_Read(offset, len, (doloffset << 2) + pos);
|
ret = WDVD_Read(offset, len, (doloffset << 2) + pos);
|
||||||
|
|
||||||
gamepatches(offset, len, videoSelected, patchcountrystring, vipatch, cheat, returnTo, fix002);
|
gamepatches(offset, len, videoSelected, languageChoice, patchcountrystring, vipatch, cheat, returnTo, fix002);
|
||||||
|
|
||||||
Remove_001_Protection(offset, len);
|
Remove_001_Protection(offset, len);
|
||||||
|
|
||||||
|
|
|
@ -8,11 +8,11 @@ extern "C"
|
||||||
|
|
||||||
/* not the full path is needed here, the path where the dol is */
|
/* not the full path is needed here, the path where the dol is */
|
||||||
|
|
||||||
bool Load_Dol(void **buffer, int* dollen, char * path, u8 videoSelected, u8 patchcountrystring, u8 vipatch,
|
bool Load_Dol(void **buffer, int* dollen, char * path, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch,
|
||||||
u8 cheat, u32 returnTo);
|
u8 cheat, u32 returnTo);
|
||||||
bool Remove_001_Protection(void *Address, int Size);
|
bool Remove_001_Protection(void *Address, int Size);
|
||||||
u32 load_dol_image(void * dolstart);
|
u32 load_dol_image(void * dolstart);
|
||||||
u32 Load_Dol_from_disc(u32 doloffset, u8 videoSelected, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo);
|
u32 Load_Dol_from_disc(u32 doloffset, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,7 @@ static u8 *appldr = (u8 *) 0x81200000;
|
||||||
/* Variables */
|
/* Variables */
|
||||||
static u32 buffer[0x20] ATTRIBUTE_ALIGN( 32 );
|
static u32 buffer[0x20] ATTRIBUTE_ALIGN( 32 );
|
||||||
|
|
||||||
void gamepatches( u8 * dst, int len, u8 videoSelected, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002 )
|
void gamepatches( u8 * dst, int len, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002 )
|
||||||
{
|
{
|
||||||
VideoModePatcher( dst, len, videoSelected );
|
VideoModePatcher( dst, len, videoSelected );
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ void gamepatches( u8 * dst, int len, u8 videoSelected, u8 patchcountrystring, u8
|
||||||
vidolpatcher( dst, len );
|
vidolpatcher( dst, len );
|
||||||
|
|
||||||
/*LANGUAGE PATCH - FISHEARS*/
|
/*LANGUAGE PATCH - FISHEARS*/
|
||||||
langpatcher( dst, len );
|
langpatcher( dst, len, languageChoice );
|
||||||
|
|
||||||
/*Thanks to WiiPower*/
|
/*Thanks to WiiPower*/
|
||||||
if ( patchcountrystring == 1 ) PatchCountryStrings( dst, len );
|
if ( patchcountrystring == 1 ) PatchCountryStrings( dst, len );
|
||||||
|
@ -59,8 +59,8 @@ void gamepatches( u8 * dst, int len, u8 videoSelected, u8 patchcountrystring, u8
|
||||||
PatchReturnTo( dst, len, returnTo );
|
PatchReturnTo( dst, len, returnTo );
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected, u8 vipatch, u8 patchcountrystring,
|
s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected, u8 languageChoice, u8 vipatch, u8 patchcountrystring,
|
||||||
u8 error002fix, u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
||||||
{
|
{
|
||||||
app_entry appldr_entry;
|
app_entry appldr_entry;
|
||||||
app_init appldr_init;
|
app_init appldr_init;
|
||||||
|
@ -71,10 +71,6 @@ s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected
|
||||||
s32 ret;
|
s32 ret;
|
||||||
gprintf("\nApploader_Run() started\n");
|
gprintf("\nApploader_Run() started\n");
|
||||||
|
|
||||||
//u32 geckoattached = usb_isgeckoalive(EXI_CHANNEL_1);
|
|
||||||
//if (geckoattached)usb_flush(EXI_CHANNEL_1);
|
|
||||||
geckoinit = InitGecko();
|
|
||||||
|
|
||||||
/* Read apploader header */
|
/* Read apploader header */
|
||||||
ret = WDVD_Read(buffer, 0x20, APPLDR_OFFSET);
|
ret = WDVD_Read(buffer, 0x20, APPLDR_OFFSET);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
|
@ -95,7 +91,7 @@ s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected
|
||||||
/* Initialize apploader */
|
/* Initialize apploader */
|
||||||
appldr_init(gprintf);
|
appldr_init(gprintf);
|
||||||
|
|
||||||
if (error002fix != 0)
|
if (fix002 != 0)
|
||||||
{
|
{
|
||||||
/* ERROR 002 fix (thanks to WiiPower for sharing this)*/
|
/* ERROR 002 fix (thanks to WiiPower for sharing this)*/
|
||||||
*(u32 *) 0x80003188 = *(u32 *) 0x80003140;
|
*(u32 *) 0x80003188 = *(u32 *) 0x80003140;
|
||||||
|
@ -114,7 +110,7 @@ s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected
|
||||||
WDVD_Read(dst, len, (u64) (offset << 2));
|
WDVD_Read(dst, len, (u64) (offset << 2));
|
||||||
|
|
||||||
if( !alternatedol )
|
if( !alternatedol )
|
||||||
gamepatches(dst, len, videoSelected, patchcountrystring, vipatch, cheat, returnTo, fix002 );
|
gamepatches(dst, len, videoSelected, languageChoice, patchcountrystring, vipatch, cheat, returnTo, fix002 );
|
||||||
|
|
||||||
DCFlushRange(dst, len);
|
DCFlushRange(dst, len);
|
||||||
}
|
}
|
||||||
|
@ -128,7 +124,7 @@ s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected
|
||||||
void *dolbuffer = NULL;
|
void *dolbuffer = NULL;
|
||||||
int dollen = 0;
|
int dollen = 0;
|
||||||
|
|
||||||
bool dolloaded = Load_Dol(&dolbuffer, &dollen, dolpath, videoSelected, patchcountrystring, vipatch, cheat, returnTo);
|
bool dolloaded = Load_Dol(&dolbuffer, &dollen, dolpath, videoSelected, languageChoice, patchcountrystring, vipatch, cheat, returnTo);
|
||||||
if (dolloaded)
|
if (dolloaded)
|
||||||
{
|
{
|
||||||
*entry = (entry_point) load_dol_image(dolbuffer);
|
*entry = (entry_point) load_dol_image(dolbuffer);
|
||||||
|
@ -141,7 +137,7 @@ s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected
|
||||||
wip_reset_counter();
|
wip_reset_counter();
|
||||||
FST_ENTRY *fst = (FST_ENTRY *) *(u32 *) 0x80000038;
|
FST_ENTRY *fst = (FST_ENTRY *) *(u32 *) 0x80000038;
|
||||||
|
|
||||||
*entry = (entry_point) Load_Dol_from_disc(fst[alternatedoloffset].fileoffset, videoSelected,
|
*entry = (entry_point) Load_Dol_from_disc(fst[alternatedoloffset].fileoffset, videoSelected, languageChoice,
|
||||||
patchcountrystring, vipatch, cheat, returnTo);
|
patchcountrystring, vipatch, cheat, returnTo);
|
||||||
|
|
||||||
if (*entry == 0) SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
|
if (*entry == 0) SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
|
||||||
|
|
|
@ -10,9 +10,9 @@ extern "C"
|
||||||
typedef void (*entry_point)(void);
|
typedef void (*entry_point)(void);
|
||||||
|
|
||||||
/* Prototypes */
|
/* Prototypes */
|
||||||
s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected, u8 vipatch,
|
s32 Apploader_Run(entry_point *entry, char * dolpath, u8 cheat, u8 videoSelected, u8 languageChoice, u8 vipatch,
|
||||||
u8 patchcountrystring, u8 error002fix, u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002);
|
u8 patchcountrystring, u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002);
|
||||||
void gamepatches( u8 * dst, int len, u8 videoSelected, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002 );
|
void gamepatches( u8 * dst, int len, u8 videoSelected, u8 languageChoice, u8 patchcountrystring, u8 vipatch, u8 cheat, u32 returnTo, u8 fix002 );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include "alternatedol.h"
|
#include "alternatedol.h"
|
||||||
#include "memory.h"
|
#include "memory.h"
|
||||||
#include "wbfs.h"
|
#include "wbfs.h"
|
||||||
|
#include "../settings/cfg.h"
|
||||||
#include "../gecko.h"
|
#include "../gecko.h"
|
||||||
#include "../fatmounter.h"
|
#include "../fatmounter.h"
|
||||||
|
|
||||||
|
@ -91,62 +92,59 @@ void __Disc_SetVMode(u8 videoselected)
|
||||||
|
|
||||||
switch (videoselected)
|
switch (videoselected)
|
||||||
{
|
{
|
||||||
case 0:
|
case pal50:
|
||||||
|
|
||||||
/* Select video mode */
|
|
||||||
switch (diskid[3])
|
|
||||||
{
|
|
||||||
/* PAL */
|
|
||||||
case 'P':
|
|
||||||
case 'D':
|
|
||||||
case 'F':
|
|
||||||
case 'I':
|
|
||||||
case 'S':
|
|
||||||
case 'H':
|
|
||||||
case 'X':
|
|
||||||
case 'Y':
|
|
||||||
case 'Z':
|
|
||||||
if (tvmode != CONF_VIDEO_PAL)
|
|
||||||
{
|
|
||||||
vmode_reg = 5;
|
|
||||||
vmode = (progressive) ? &TVNtsc480Prog : &TVEurgb60Hz480IntDf;
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* NTSC or unknown */
|
|
||||||
case 'E':
|
|
||||||
case 'J':
|
|
||||||
case 'K':
|
|
||||||
case 'W':
|
|
||||||
if (tvmode != CONF_VIDEO_NTSC)
|
|
||||||
{
|
|
||||||
vmode_reg = 0;
|
|
||||||
vmode = (progressive) ? &TVNtsc480Prog : &TVNtsc480IntDf;
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 1:
|
|
||||||
vmode = &TVPal528IntDf;
|
vmode = &TVPal528IntDf;
|
||||||
vmode_reg = (vmode->viTVMode) >> 2;
|
vmode_reg = (vmode->viTVMode) >> 2;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case pal60:
|
||||||
progressive = (CONF_GetProgressiveScan() > 0) && VIDEO_HaveComponentCable();
|
|
||||||
vmode = (progressive) ? &TVNtsc480Prog : &TVEurgb60Hz480IntDf;
|
vmode = (progressive) ? &TVNtsc480Prog : &TVEurgb60Hz480IntDf;
|
||||||
vmode_reg = (vmode->viTVMode) >> 2;
|
vmode_reg = (vmode->viTVMode) >> 2;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case ntsc:
|
||||||
progressive = (CONF_GetProgressiveScan() > 0) && VIDEO_HaveComponentCable();
|
|
||||||
vmode = (progressive) ? &TVNtsc480Prog : &TVNtsc480IntDf;
|
vmode = (progressive) ? &TVNtsc480Prog : &TVNtsc480IntDf;
|
||||||
vmode_reg = (vmode->viTVMode) >> 2;
|
vmode_reg = (vmode->viTVMode) >> 2;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case systemdefault:
|
||||||
// vmode = VIDEO_GetPreferredMode(NULL);
|
// vmode = VIDEO_GetPreferredMode(NULL);
|
||||||
break;
|
break;
|
||||||
}
|
case discdefault:
|
||||||
|
default:
|
||||||
|
/* Select video mode */
|
||||||
|
switch (diskid[3])
|
||||||
|
{
|
||||||
|
/* PAL */
|
||||||
|
case 'P':
|
||||||
|
case 'D':
|
||||||
|
case 'F':
|
||||||
|
case 'I':
|
||||||
|
case 'S':
|
||||||
|
case 'H':
|
||||||
|
case 'X':
|
||||||
|
case 'Y':
|
||||||
|
case 'Z':
|
||||||
|
if (tvmode != CONF_VIDEO_PAL)
|
||||||
|
{
|
||||||
|
vmode_reg = 5;
|
||||||
|
vmode = (progressive) ? &TVNtsc480Prog : &TVEurgb60Hz480IntDf;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* NTSC or unknown */
|
||||||
|
case 'E':
|
||||||
|
case 'J':
|
||||||
|
case 'K':
|
||||||
|
case 'W':
|
||||||
|
if (tvmode != CONF_VIDEO_NTSC)
|
||||||
|
{
|
||||||
|
vmode_reg = 0;
|
||||||
|
vmode = (progressive) ? &TVNtsc480Prog : &TVNtsc480IntDf;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
/* Set video mode register */
|
/* Set video mode register */
|
||||||
*Video_Mode = vmode_reg;
|
*Video_Mode = vmode_reg;
|
||||||
|
@ -286,8 +284,8 @@ s32 Disc_IsWii(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 Disc_BootPartition(u64 offset, char * dolpath, u8 videoselected, u8 cheat, u8 vipatch, u8 patchcountrystring,
|
s32 Disc_BootPartition(u64 offset, char * dolpath, u8 videoselected, u8 languageChoice, u8 cheat, u8 vipatch, u8 patchcountrystring,
|
||||||
u8 error002fix, u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
||||||
{
|
{
|
||||||
gprintf("booting partition IOS %u v%u\n", IOS_GetVersion(), IOS_GetRevision());
|
gprintf("booting partition IOS %u v%u\n", IOS_GetVersion(), IOS_GetRevision());
|
||||||
entry_point p_entry;
|
entry_point p_entry;
|
||||||
|
@ -311,7 +309,7 @@ s32 Disc_BootPartition(u64 offset, char * dolpath, u8 videoselected, u8 cheat, u
|
||||||
PoPPatch();
|
PoPPatch();
|
||||||
|
|
||||||
/* Run apploader */
|
/* Run apploader */
|
||||||
ret = Apploader_Run(&p_entry, dolpath, cheat, videoselected, vipatch, patchcountrystring, error002fix,
|
ret = Apploader_Run(&p_entry, dolpath, cheat, videoselected, languageChoice, vipatch, patchcountrystring,
|
||||||
alternatedol, alternatedoloffset, returnTo, fix002);
|
alternatedol, alternatedoloffset, returnTo, fix002);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
|
|
||||||
|
@ -386,7 +384,7 @@ s32 Disc_BootPartition(u64 offset, char * dolpath, u8 videoselected, u8 cheat, u
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 Disc_WiiBoot(char * dolpath, u8 videoselected, u8 cheat, u8 vipatch, u8 patchcountrystring, u8 error002fix,
|
s32 Disc_WiiBoot(char * dolpath, u8 videoselected, u8 languageChoice, u8 cheat, u8 vipatch, u8 patchcountrystring,
|
||||||
u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
u8 alternatedol, u32 alternatedoloffset, u32 returnTo, u8 fix002)
|
||||||
{
|
{
|
||||||
u64 offset;
|
u64 offset;
|
||||||
|
@ -397,7 +395,7 @@ s32 Disc_WiiBoot(char * dolpath, u8 videoselected, u8 cheat, u8 vipatch, u8 patc
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
|
|
||||||
/* Boot partition */
|
/* Boot partition */
|
||||||
return Disc_BootPartition(offset, dolpath, videoselected, cheat, vipatch, patchcountrystring, error002fix,
|
return Disc_BootPartition(offset, dolpath, videoselected, languageChoice, cheat, vipatch, patchcountrystring,
|
||||||
alternatedol, alternatedoloffset, returnTo, fix002);
|
alternatedol, alternatedoloffset, returnTo, fix002);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -50,8 +50,8 @@ extern "C"
|
||||||
s32 Disc_SetUSB(const u8 *);
|
s32 Disc_SetUSB(const u8 *);
|
||||||
s32 Disc_ReadHeader(void *);
|
s32 Disc_ReadHeader(void *);
|
||||||
s32 Disc_IsWii(void);
|
s32 Disc_IsWii(void);
|
||||||
s32 Disc_BootPartition(u64, char *, u8, u8, u8, u8, u8, u8, u32, u32 returnTo, u8 fix002);
|
s32 Disc_BootPartition(u64, char *, u8, u8 languageChoice, u8, u8, u8, u8, u32, u32 returnTo, u8 fix002);
|
||||||
s32 Disc_WiiBoot(char *, u8, u8, u8, u8, u8, u8, u32, u32 returnTo, u8 fix002);
|
s32 Disc_WiiBoot(char *, u8, u8 languageChoice, u8, u8, u8, u8, u32, u32 returnTo, u8 fix002);
|
||||||
s32 __Disc_FindPartition(u64 *outbuf);
|
s32 __Disc_FindPartition(u64 *outbuf);
|
||||||
void PatchCountryStrings(void *Address, int Size);
|
void PatchCountryStrings(void *Address, int Size);
|
||||||
s32 __Disc_FindPartition(u64 *outbuf);
|
s32 __Disc_FindPartition(u64 *outbuf);
|
||||||
|
|
Loading…
Add table
Reference in a new issue