mirror of
https://github.com/wiidev/usbloadergx.git
synced 2024-11-26 05:04:16 +01:00
The known alt dol is now automatically used when launching a game that requires it, if no dol was selected (setting a dol in game settings will override it). This includes the alt dol prompt that was added a few revisions ago for games that require choosing between different dols. Fixed dol name display in the game settings. Added check to prevent empty .gct file creation. The .gct code files can now be deleted from the Uninstall Menu.
This commit is contained in:
parent
75a4d33e4f
commit
370a332fcc
4
Makefile
4
Makefile
@ -105,12 +105,12 @@ $(BUILD):
|
|||||||
|
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
lang:
|
lang:
|
||||||
@[ -d $@ ] || mkdir -p $@
|
@[ -d build ] || mkdir -p build
|
||||||
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile language
|
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile language
|
||||||
|
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
all:
|
all:
|
||||||
@[ -d $@ ] || mkdir -p $@
|
@[ -d build ] || mkdir -p build
|
||||||
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile
|
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile
|
||||||
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile language
|
@make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile language
|
||||||
|
|
||||||
|
File diff suppressed because one or more lines are too long
@ -68,9 +68,8 @@ int CheatMenu(const char * gameID) {
|
|||||||
WindowPrompt(tr("Error"),tr("Cheatfile is blank"),tr("OK"));
|
WindowPrompt(tr("Error"),tr("Cheatfile is blank"),tr("OK"));
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
download = WindowPrompt(tr("Error"),tr("No Cheatfile found"),tr("OK"),tr("Download Now"));
|
download = WindowPrompt(tr("Error"),tr("No Cheatfile found"),tr("Download Now"),tr("Cancel"));
|
||||||
|
if (download==1)
|
||||||
if (download==0)
|
|
||||||
download = CodeDownload(gameID);
|
download = CodeDownload(gameID);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
@ -128,6 +127,9 @@ int CheatMenu(const char * gameID) {
|
|||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (x == 0) {
|
||||||
|
WindowPrompt(tr("Error"),tr("No cheats were selected"),tr("OK"));
|
||||||
|
} else {
|
||||||
subfoldercreate(Settings.Cheatcodespath);
|
subfoldercreate(Settings.Cheatcodespath);
|
||||||
string chtpath = Settings.Cheatcodespath;
|
string chtpath = Settings.Cheatcodespath;
|
||||||
string gctfname = chtpath + c.getGameID() + ".gct";
|
string gctfname = chtpath + c.getGameID() + ".gct";
|
||||||
@ -135,6 +137,7 @@ int CheatMenu(const char * gameID) {
|
|||||||
WindowPrompt(tr("GCT File created"),NULL,tr("OK"));
|
WindowPrompt(tr("GCT File created"),NULL,tr("OK"));
|
||||||
exit = true;
|
exit = true;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
} else WindowPrompt(tr("Error"),tr("Could not create GCT file"),tr("OK"));
|
} else WindowPrompt(tr("Error"),tr("Could not create GCT file"),tr("OK"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,6 +60,10 @@ string GCTCheats::getCheatComment(int nr) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int GCTCheats::createGCT(int nr,const char * filename) {
|
int GCTCheats::createGCT(int nr,const char * filename) {
|
||||||
|
|
||||||
|
if (nr == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
ofstream filestr;
|
ofstream filestr;
|
||||||
filestr.open(filename);
|
filestr.open(filename);
|
||||||
|
|
||||||
@ -91,6 +95,7 @@ int GCTCheats::createGCT(int nr,const char * filename) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int GCTCheats::createGCT(const char * chtbuffer,const char * filename) {
|
int GCTCheats::createGCT(const char * chtbuffer,const char * filename) {
|
||||||
|
|
||||||
ofstream filestr;
|
ofstream filestr;
|
||||||
filestr.open(filename);
|
filestr.open(filename);
|
||||||
|
|
||||||
@ -125,6 +130,9 @@ int GCTCheats::createGCT(const char * chtbuffer,const char * filename) {
|
|||||||
|
|
||||||
int GCTCheats::createGCT(int nr[],int cnt,const char * filename) {
|
int GCTCheats::createGCT(int nr[],int cnt,const char * filename) {
|
||||||
|
|
||||||
|
if (cnt == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
ofstream filestr;
|
ofstream filestr;
|
||||||
filestr.open(filename);
|
filestr.open(filename);
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "prompts/ProgressWindow.h"
|
#include "prompts/ProgressWindow.h"
|
||||||
#include "prompts/TitleBrowser.h"
|
#include "prompts/TitleBrowser.h"
|
||||||
#include "prompts/gameinfo.h"
|
#include "prompts/gameinfo.h"
|
||||||
|
#include "prompts/DiscBrowser.h"
|
||||||
#include "mload/mload.h"
|
#include "mload/mload.h"
|
||||||
#include "patches/patchcode.h"
|
#include "patches/patchcode.h"
|
||||||
#include "network/networkops.h"
|
#include "network/networkops.h"
|
||||||
@ -72,6 +73,7 @@ static lwp_t guithread = LWP_THREAD_NULL;
|
|||||||
static bool guiHalt = true;
|
static bool guiHalt = true;
|
||||||
static int ExitRequested = 0;
|
static int ExitRequested = 0;
|
||||||
static char gameregion[7];
|
static char gameregion[7];
|
||||||
|
static bool altdoldefault = true;
|
||||||
|
|
||||||
/*** Extern variables ***/
|
/*** Extern variables ***/
|
||||||
extern FreeTypeGX *fontClock;
|
extern FreeTypeGX *fontClock;
|
||||||
@ -717,7 +719,7 @@ int MenuDiscList() {
|
|||||||
|
|
||||||
WDVD_GetCoverStatus(&covert);//for detecting if i disc has been inserted
|
WDVD_GetCoverStatus(&covert);//for detecting if i disc has been inserted
|
||||||
|
|
||||||
// if the idiot is showing favoorites and don't have any
|
// if the idiot is showing favorites and don't have any
|
||||||
if (Settings.fave && !gameCnt) {
|
if (Settings.fave && !gameCnt) {
|
||||||
WindowPrompt(tr("No Favorites"),tr("You are choosing to display favorites and you do not have any selected."),tr("Back"));
|
WindowPrompt(tr("No Favorites"),tr("You are choosing to display favorites and you do not have any selected."),tr("Back"));
|
||||||
Settings.fave=!Settings.fave;
|
Settings.fave=!Settings.fave;
|
||||||
@ -1214,8 +1216,8 @@ int MenuDiscList() {
|
|||||||
snprintf (IDfull,sizeof(IDfull),"%c%c%c%c%c%c", header->id[0], header->id[1], header->id[2],header->id[3], header->id[4], header->id[5]);
|
snprintf (IDfull,sizeof(IDfull),"%c%c%c%c%c%c", header->id[0], header->id[1], header->id[2],header->id[3], header->id[4], header->id[5]);
|
||||||
struct Game_CFG* game_cfg = CFG_get_game_opt(header->id);
|
struct Game_CFG* game_cfg = CFG_get_game_opt(header->id);
|
||||||
if (game_cfg) {
|
if (game_cfg) {
|
||||||
ocarinaChoice = game_cfg->ocarina;
|
|
||||||
alternatedol = game_cfg->loadalternatedol;
|
alternatedol = game_cfg->loadalternatedol;
|
||||||
|
ocarinaChoice = game_cfg->ocarina;
|
||||||
} else {
|
} else {
|
||||||
alternatedol = off;
|
alternatedol = off;
|
||||||
ocarinaChoice = Settings.ocarina;
|
ocarinaChoice = Settings.ocarina;
|
||||||
@ -1230,17 +1232,17 @@ int MenuDiscList() {
|
|||||||
if (exeFile==NULL) {
|
if (exeFile==NULL) {
|
||||||
sprintf(nipple, "%s %s",nipple,tr("does not exist!"));
|
sprintf(nipple, "%s %s",nipple,tr("does not exist!"));
|
||||||
WindowPrompt(tr("Error"),nipple,tr("OK"));
|
WindowPrompt(tr("Error"),nipple,tr("OK"));
|
||||||
|
|
||||||
menu = MENU_CHECK;
|
menu = MENU_CHECK;
|
||||||
wiilight(0);
|
wiilight(0);
|
||||||
break;
|
break;
|
||||||
|
} else {
|
||||||
|
fclose(exeFile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ocarinaChoice != off) {
|
if (ocarinaChoice != off) {
|
||||||
/* Open gct File and check exist */
|
/* Open gct File and check exist */
|
||||||
sprintf(nipple, "%s%s.gct",Settings.Cheatcodespath,IDfull);
|
sprintf(nipple, "%s%s.gct",Settings.Cheatcodespath,IDfull);
|
||||||
exeFile = fopen (nipple ,"rb");
|
exeFile = fopen (nipple ,"rb");
|
||||||
|
|
||||||
if (exeFile==NULL) {
|
if (exeFile==NULL) {
|
||||||
sprintf(nipple, "%s %s",nipple,tr("does not exist! Loading game without cheats."));
|
sprintf(nipple, "%s %s",nipple,tr("does not exist! Loading game without cheats."));
|
||||||
WindowPrompt(tr("Error"),nipple,NULL,NULL,NULL,NULL,170);
|
WindowPrompt(tr("Error"),nipple,NULL,NULL,NULL,NULL,170);
|
||||||
@ -1248,6 +1250,7 @@ int MenuDiscList() {
|
|||||||
fseek (exeFile, 0, SEEK_END);
|
fseek (exeFile, 0, SEEK_END);
|
||||||
long size=ftell (exeFile);
|
long size=ftell (exeFile);
|
||||||
rewind (exeFile);
|
rewind (exeFile);
|
||||||
|
fclose(exeFile);
|
||||||
if (size>2056) {
|
if (size>2056) {
|
||||||
sprintf(nipple, "%s %s",nipple,tr("contains over 255 lines of code. It will produce unexpected results."));
|
sprintf(nipple, "%s %s",nipple,tr("contains over 255 lines of code. It will produce unexpected results."));
|
||||||
WindowPrompt(tr("Error"),nipple,NULL,NULL,NULL,NULL,170);
|
WindowPrompt(tr("Error"),nipple,NULL,NULL,NULL,NULL,170);
|
||||||
@ -1272,7 +1275,6 @@ int MenuDiscList() {
|
|||||||
|
|
||||||
CFG_save_game_num(header->id);
|
CFG_save_game_num(header->id);
|
||||||
}
|
}
|
||||||
SDCard_deInit();
|
|
||||||
menu = MENU_EXIT;
|
menu = MENU_EXIT;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1292,10 +1294,11 @@ int MenuDiscList() {
|
|||||||
if (exeFile==NULL) {
|
if (exeFile==NULL) {
|
||||||
sprintf(nipple, "%s %s",nipple,tr("does not exist! You Messed something up, Idiot."));
|
sprintf(nipple, "%s %s",nipple,tr("does not exist! You Messed something up, Idiot."));
|
||||||
WindowPrompt(tr("Error"),nipple,tr("OK"));
|
WindowPrompt(tr("Error"),nipple,tr("OK"));
|
||||||
|
|
||||||
menu = MENU_CHECK;
|
menu = MENU_CHECK;
|
||||||
wiilight(0);
|
wiilight(0);
|
||||||
break;
|
break;
|
||||||
|
} else {
|
||||||
|
fclose(exeFile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ocarinaChoice != off) {
|
if (ocarinaChoice != off) {
|
||||||
@ -1317,12 +1320,10 @@ int MenuDiscList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
SDCard_deInit();
|
|
||||||
wiilight(0);
|
wiilight(0);
|
||||||
returnHere = false;
|
returnHere = false;
|
||||||
menu = MENU_EXIT;
|
menu = MENU_EXIT;
|
||||||
|
|
||||||
|
|
||||||
} else if (choice == 2) {
|
} else if (choice == 2) {
|
||||||
wiilight(0);
|
wiilight(0);
|
||||||
HaltGui();
|
HaltGui();
|
||||||
@ -1398,6 +1399,39 @@ int MenuDiscList() {
|
|||||||
covertOld=covert;
|
covertOld=covert;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set alt dol default
|
||||||
|
if (menu == MENU_EXIT && altdoldefault) {
|
||||||
|
struct discHdr *header = &gameList[gameSelected];
|
||||||
|
struct Game_CFG* game_cfg = CFG_get_game_opt(header->id);
|
||||||
|
// use default only if no alt dol was selected manually
|
||||||
|
if (game_cfg) {
|
||||||
|
if (game_cfg->alternatedolstart != 0)
|
||||||
|
altdoldefault = false;
|
||||||
|
}
|
||||||
|
if (altdoldefault) {
|
||||||
|
int autodol = autoSelectDol((char*)header->id);
|
||||||
|
if (autodol>0) {
|
||||||
|
alternatedol = 2;
|
||||||
|
alternatedoloffset = autodol;
|
||||||
|
char temp[20];
|
||||||
|
sprintf(temp,"%d",autodol);
|
||||||
|
} else {
|
||||||
|
// alt dol menu for games that require more than a single alt dol
|
||||||
|
int autodol = autoSelectDolMenu((char*)header->id);
|
||||||
|
if (autodol>0) {
|
||||||
|
alternatedol = 2;
|
||||||
|
alternatedoloffset = autodol;
|
||||||
|
} else if (autodol == 0) { // if Cancel or B is pressed, don't launch game
|
||||||
|
menu = MENU_DISCLIST;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (menu == MENU_EXIT) {
|
||||||
|
SDCard_deInit();
|
||||||
|
}
|
||||||
|
|
||||||
HaltGui();
|
HaltGui();
|
||||||
mainWindow->RemoveAll();
|
mainWindow->RemoveAll();
|
||||||
mainWindow->Append(bgImg);
|
mainWindow->Append(bgImg);
|
||||||
@ -1412,6 +1446,7 @@ int MenuDiscList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* MenuInstall
|
* MenuInstall
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
@ -1891,7 +1926,6 @@ int MainMenu(int menu) {
|
|||||||
delete GameIDTxt;
|
delete GameIDTxt;
|
||||||
delete cover;
|
delete cover;
|
||||||
delete coverImg;
|
delete coverImg;
|
||||||
|
|
||||||
ShutdownAudio();
|
ShutdownAudio();
|
||||||
StopGX();
|
StopGX();
|
||||||
|
|
||||||
@ -1914,8 +1948,10 @@ int MainMenu(int menu) {
|
|||||||
fix002 = game_cfg->errorfix002;
|
fix002 = game_cfg->errorfix002;
|
||||||
iosChoice = game_cfg->ios;
|
iosChoice = game_cfg->ios;
|
||||||
countrystrings = game_cfg->patchcountrystrings;
|
countrystrings = game_cfg->patchcountrystrings;
|
||||||
|
if (!altdoldefault) {
|
||||||
alternatedol = game_cfg->loadalternatedol;
|
alternatedol = game_cfg->loadalternatedol;
|
||||||
alternatedoloffset = game_cfg->alternatedolstart;
|
alternatedoloffset = game_cfg->alternatedolstart;
|
||||||
|
}
|
||||||
reloadblock = game_cfg->iosreloadblock;
|
reloadblock = game_cfg->iosreloadblock;
|
||||||
} else {
|
} else {
|
||||||
videoChoice = Settings.video;
|
videoChoice = Settings.video;
|
||||||
@ -1929,8 +1965,10 @@ int MainMenu(int menu) {
|
|||||||
}
|
}
|
||||||
fix002 = Settings.error002;
|
fix002 = Settings.error002;
|
||||||
countrystrings = Settings.patchcountrystrings;
|
countrystrings = Settings.patchcountrystrings;
|
||||||
|
if (!altdoldefault) {
|
||||||
alternatedol = off;
|
alternatedol = off;
|
||||||
alternatedoloffset = 0;
|
alternatedoloffset = 0;
|
||||||
|
}
|
||||||
reloadblock = off;
|
reloadblock = off;
|
||||||
}
|
}
|
||||||
int ios2;
|
int ios2;
|
||||||
|
@ -64,11 +64,13 @@
|
|||||||
#define _SHIFTR(v, s, w) \
|
#define _SHIFTR(v, s, w) \
|
||||||
((u32)(((u32)(v) >> (s)) & ((0x01 << (w)) - 1)))
|
((u32)(((u32)(v) >> (s)) & ((0x01 << (w)) - 1)))
|
||||||
|
|
||||||
struct dicommand {
|
struct dicommand
|
||||||
|
{
|
||||||
u32 diReg[8];
|
u32 diReg[8];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct dicontext {
|
struct dicontext
|
||||||
|
{
|
||||||
lwp_node node;
|
lwp_node node;
|
||||||
dvdcallbacklow cb;
|
dvdcallbacklow cb;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -91,38 +93,43 @@ static char __di_fs[] ATTRIBUTE_ALIGN(32) = "/dev/di";
|
|||||||
|
|
||||||
extern u32 __IPC_ClntInit();
|
extern u32 __IPC_ClntInit();
|
||||||
|
|
||||||
static __inline__ lwp_node* __lwp_queue_head(lwp_queue *queue) {
|
static __inline__ lwp_node* __lwp_queue_head(lwp_queue *queue)
|
||||||
|
{
|
||||||
return (lwp_node*)queue;
|
return (lwp_node*)queue;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline__ lwp_node* __lwp_queue_tail(lwp_queue *queue) {
|
static __inline__ lwp_node* __lwp_queue_tail(lwp_queue *queue)
|
||||||
|
{
|
||||||
return (lwp_node*)&queue->perm_null;
|
return (lwp_node*)&queue->perm_null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static __inline__ void __lwp_queue_init_empty(lwp_queue *queue) {
|
static __inline__ void __lwp_queue_init_empty(lwp_queue *queue)
|
||||||
|
{
|
||||||
queue->first = __lwp_queue_tail(queue);
|
queue->first = __lwp_queue_tail(queue);
|
||||||
queue->perm_null = NULL;
|
queue->perm_null = NULL;
|
||||||
queue->last = __lwp_queue_head(queue);
|
queue->last = __lwp_queue_head(queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct dicontext* __dvd_getcontext(dvdcallbacklow cb) {
|
static struct dicontext* __dvd_getcontext(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
|
|
||||||
ctx = (struct dicontext*)__lwp_queue_get(&__di_contextq);
|
ctx = (struct dicontext*)__lwp_queue_get(&__di_contextq);
|
||||||
if (ctx!=NULL) ctx->cb = cb;
|
if(ctx!=NULL) ctx->cb = cb;
|
||||||
|
|
||||||
return ctx;
|
return ctx;
|
||||||
}
|
}
|
||||||
|
|
||||||
static s32 __dvd_iostransactionCB(s32 result,void *usrdata) {
|
static s32 __dvd_iostransactionCB(s32 result,void *usrdata)
|
||||||
|
{
|
||||||
struct dicontext *ctx = (struct dicontext*)usrdata;
|
struct dicontext *ctx = (struct dicontext*)usrdata;
|
||||||
|
|
||||||
__dvd_reqinprogress = 0;
|
__dvd_reqinprogress = 0;
|
||||||
|
|
||||||
if (ctx->cb!=NULL) {
|
if(ctx->cb!=NULL) {
|
||||||
__dvd_cbinprogress = 1;
|
__dvd_cbinprogress = 1;
|
||||||
if (result!=0) __dvd_readlength = 0;
|
if(result!=0) __dvd_readlength = 0;
|
||||||
ctx->cb(result);
|
ctx->cb(result);
|
||||||
__dvd_cbinprogress = 0;
|
__dvd_cbinprogress = 0;
|
||||||
}
|
}
|
||||||
@ -131,13 +138,14 @@ static s32 __dvd_iostransactionCB(s32 result,void *usrdata) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static s32 __dvd_ioscoverregisterCB(s32 result,void *usrdata) {
|
static s32 __dvd_ioscoverregisterCB(s32 result,void *usrdata)
|
||||||
|
{
|
||||||
struct dicontext *ctx = (struct dicontext*)usrdata;
|
struct dicontext *ctx = (struct dicontext*)usrdata;
|
||||||
|
|
||||||
__dvd_reqinprogress = 0;
|
__dvd_reqinprogress = 0;
|
||||||
__di_regvalcache[1] = __di_regbuffer[0];
|
__di_regvalcache[1] = __di_regbuffer[0];
|
||||||
|
|
||||||
if (ctx->cb!=NULL) {
|
if(ctx->cb!=NULL) {
|
||||||
__dvd_cbinprogress = 1;
|
__dvd_cbinprogress = 1;
|
||||||
ctx->cb(result);
|
ctx->cb(result);
|
||||||
__dvd_cbinprogress = 0;
|
__dvd_cbinprogress = 0;
|
||||||
@ -147,12 +155,13 @@ static s32 __dvd_ioscoverregisterCB(s32 result,void *usrdata) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static s32 __dvd_ioscovercloseCB(s32 result,void *usrdata) {
|
static s32 __dvd_ioscovercloseCB(s32 result,void *usrdata)
|
||||||
|
{
|
||||||
struct dicontext *ctx = (struct dicontext*)usrdata;
|
struct dicontext *ctx = (struct dicontext*)usrdata;
|
||||||
|
|
||||||
__dvd_reqinprogress = 0;
|
__dvd_reqinprogress = 0;
|
||||||
|
|
||||||
if (ctx->cb!=NULL) {
|
if(ctx->cb!=NULL) {
|
||||||
__dvd_cbinprogress = 1;
|
__dvd_cbinprogress = 1;
|
||||||
ctx->cb(result);
|
ctx->cb(result);
|
||||||
__dvd_cbinprogress = 0;
|
__dvd_cbinprogress = 0;
|
||||||
@ -162,19 +171,20 @@ static s32 __dvd_ioscovercloseCB(s32 result,void *usrdata) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowInit() {
|
s32 bwDVD_LowInit()
|
||||||
|
{
|
||||||
s32 i,ret = 0;
|
s32 i,ret = 0;
|
||||||
u32 ipclo,ipchi;
|
u32 ipclo,ipchi;
|
||||||
lwp_queue inactives;
|
lwp_queue inactives;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
|
|
||||||
if (__dvd_lowinitcalled==0) {
|
if(__dvd_lowinitcalled==0) {
|
||||||
ret = __IPC_ClntInit();
|
ret = __IPC_ClntInit();
|
||||||
if (ret<0) return ret;
|
if(ret<0) return ret;
|
||||||
|
|
||||||
ipclo = (((u32)IPC_GetBufferLo()+0x1f)&~0x1f);
|
ipclo = (((u32)IPC_GetBufferLo()+0x1f)&~0x1f);
|
||||||
ipchi = (u32)IPC_GetBufferHi();
|
ipchi = (u32)IPC_GetBufferHi();
|
||||||
if (ipchi>=(ipclo+(sizeof(struct dicommand)*DI_CMDCTX_CNT))) {
|
if(ipchi>=(ipclo+(sizeof(struct dicommand)*DI_CMDCTX_CNT))) {
|
||||||
__di_commands = (struct dicommand*)ipclo;
|
__di_commands = (struct dicommand*)ipclo;
|
||||||
IPC_SetBufferLo((void*)(ipclo+(sizeof(struct dicommand)*DI_CMDCTX_CNT)));
|
IPC_SetBufferLo((void*)(ipclo+(sizeof(struct dicommand)*DI_CMDCTX_CNT)));
|
||||||
|
|
||||||
@ -183,7 +193,7 @@ s32 bwDVD_LowInit() {
|
|||||||
i = 0;
|
i = 0;
|
||||||
__lwp_queue_init_empty(&__di_contextq);
|
__lwp_queue_init_empty(&__di_contextq);
|
||||||
__lwp_queue_initialize(&inactives,__di_contexts,DI_CMDCTX_CNT,sizeof(struct dicontext));
|
__lwp_queue_initialize(&inactives,__di_contexts,DI_CMDCTX_CNT,sizeof(struct dicontext));
|
||||||
while ((ctx=(struct dicontext*)__lwp_queue_get(&inactives))!=NULL) {
|
while((ctx=(struct dicontext*)__lwp_queue_get(&inactives))!=NULL) {
|
||||||
ctx->cmd = &__di_commands[i];
|
ctx->cmd = &__di_commands[i];
|
||||||
ctx->cb = NULL;
|
ctx->cb = NULL;
|
||||||
__lwp_queue_append(&__di_contextq,&ctx->node);
|
__lwp_queue_append(&__di_contextq,&ctx->node);
|
||||||
@ -193,7 +203,7 @@ s32 bwDVD_LowInit() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = IOS_Open(__di_fs,0);
|
ret = IOS_Open(__di_fs,0);
|
||||||
if (ret<0) return ret;
|
if(ret<0) return ret;
|
||||||
|
|
||||||
__dvd_fd = ret;
|
__dvd_fd = ret;
|
||||||
// __dvd_lowinitcalled = 1;
|
// __dvd_lowinitcalled = 1;
|
||||||
@ -203,7 +213,8 @@ s32 bwDVD_LowInit() {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb) {
|
s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -211,7 +222,7 @@ s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_INQUIRY<<24);
|
cmd->diReg[0] = (IOCTL_DI_INQUIRY<<24);
|
||||||
@ -220,7 +231,8 @@ s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb) {
|
s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret = 0;
|
s32 ret = 0;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -230,7 +242,7 @@ s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_READID<<24);
|
cmd->diReg[0] = (IOCTL_DI_READID<<24);
|
||||||
@ -241,18 +253,19 @@ s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
s32 bwDVD_LowRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
s32 bwDVD_LowRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
|
|
||||||
if (buf==NULL || ((u32)buf%32)!=0) return -1;
|
if(buf==NULL || ((u32)buf%32)!=0) return -1;
|
||||||
|
|
||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
__dvd_readlength = len;
|
__dvd_readlength = len;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_READ<<24);
|
cmd->diReg[0] = (IOCTL_DI_READ<<24);
|
||||||
@ -264,7 +277,8 @@ s32 bwDVD_LowRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// never got this function working, probably removed from wii
|
// never got this function working, probably removed from wii
|
||||||
s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -273,7 +287,7 @@ s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
|||||||
__dvd_readlength = len;
|
__dvd_readlength = len;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_READ_DVDVIDEO<<24);
|
cmd->diReg[0] = (IOCTL_DI_READ_DVDVIDEO<<24);
|
||||||
@ -286,7 +300,8 @@ s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
s32 bwDVD_LowStopLaser(dvdcallbacklow cb) {
|
s32 bwDVD_LowStopLaser(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -294,7 +309,7 @@ s32 bwDVD_LowStopLaser(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_STOPLASER<<24);
|
cmd->diReg[0] = (IOCTL_DI_STOPLASER<<24);
|
||||||
@ -304,7 +319,8 @@ s32 bwDVD_LowStopLaser(dvdcallbacklow cb) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// never got this function working, probably removed from wii
|
// never got this function working, probably removed from wii
|
||||||
s32 bwDVD_EnableVideo(dvdcallbacklow cb) {
|
s32 bwDVD_EnableVideo(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -312,7 +328,7 @@ s32 bwDVD_EnableVideo(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_ENABLE_DVD<<24);
|
cmd->diReg[0] = (IOCTL_DI_ENABLE_DVD<<24);
|
||||||
@ -321,7 +337,8 @@ s32 bwDVD_EnableVideo(dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowSeek(u32 offset,dvdcallbacklow cb) {
|
s32 bwDVD_LowSeek(u32 offset,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -329,7 +346,7 @@ s32 bwDVD_LowSeek(u32 offset,dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_SEEK<<24);
|
cmd->diReg[0] = (IOCTL_DI_SEEK<<24);
|
||||||
@ -339,7 +356,8 @@ s32 bwDVD_LowSeek(u32 offset,dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowOffset(u64 offset,dvdcallbacklow cb) {
|
s32 bwDVD_LowOffset(u64 offset,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
u32 *off = (u32*)(void*)(&offset);
|
u32 *off = (u32*)(void*)(&offset);
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
@ -348,19 +366,20 @@ s32 bwDVD_LowOffset(u64 offset,dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_OFFSET<<24);
|
cmd->diReg[0] = (IOCTL_DI_OFFSET<<24);
|
||||||
cmd->diReg[1] = 0;
|
cmd->diReg[1] = 0;
|
||||||
if (off[0]) cmd->diReg[1] = 1;
|
if(off[0]) cmd->diReg[1] = 1;
|
||||||
cmd->diReg[2] = off[1];
|
cmd->diReg[2] = off[1];
|
||||||
ret = IOS_IoctlAsync(__dvd_fd,IOCTL_DI_OFFSET,cmd->diReg,sizeof(struct dicommand),__di_regvalcache,0x20,__dvd_iostransactionCB,ctx);
|
ret = IOS_IoctlAsync(__dvd_fd,IOCTL_DI_OFFSET,cmd->diReg,sizeof(struct dicommand),__di_regvalcache,0x20,__dvd_iostransactionCB,ctx);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowPrepareCoverRegister(dvdcallbacklow cb) {
|
s32 bwDVD_LowPrepareCoverRegister(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -368,7 +387,7 @@ s32 bwDVD_LowPrepareCoverRegister(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_COVER<<24);
|
cmd->diReg[0] = (IOCTL_DI_COVER<<24);
|
||||||
@ -377,19 +396,20 @@ s32 bwDVD_LowPrepareCoverRegister(dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certificate_in,void *certificate_out,dvdcallbacklow cb) {
|
s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certificate_in,void *certificate_out,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
|
|
||||||
if (eticket!=NULL && ((u32)eticket%32)!=0) return -1;
|
if(eticket!=NULL && ((u32)eticket%32)!=0) return -1;
|
||||||
if (certificate_in!=NULL && ((u32)certificate_in%32)!=0) return -1;
|
if(certificate_in!=NULL && ((u32)certificate_in%32)!=0) return -1;
|
||||||
if (certificate_out!=NULL && ((u32)certificate_out%32)!=0) return -1;
|
if(certificate_out!=NULL && ((u32)certificate_out%32)!=0) return -1;
|
||||||
|
|
||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_OPENPART<<24);
|
cmd->diReg[0] = (IOCTL_DI_OPENPART<<24);
|
||||||
@ -399,11 +419,11 @@ s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certifi
|
|||||||
__di_iovector[0].len = sizeof(struct dicommand);
|
__di_iovector[0].len = sizeof(struct dicommand);
|
||||||
|
|
||||||
__di_iovector[1].data = eticket;
|
__di_iovector[1].data = eticket;
|
||||||
if (eticket==NULL) __di_iovector[1].len = 0;
|
if(eticket==NULL) __di_iovector[1].len = 0;
|
||||||
else __di_iovector[1].len = 676;
|
else __di_iovector[1].len = 676;
|
||||||
|
|
||||||
__di_iovector[2].data = certificate_in;
|
__di_iovector[2].data = certificate_in;
|
||||||
if (certificate_in==NULL) __di_iovector[2].len = 0;
|
if(certificate_in==NULL) __di_iovector[2].len = 0;
|
||||||
else __di_iovector[2].len = certin_len;
|
else __di_iovector[2].len = certin_len;
|
||||||
|
|
||||||
__di_iovector[3].data = certificate_out;
|
__di_iovector[3].data = certificate_out;
|
||||||
@ -415,7 +435,8 @@ s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certifi
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowClosePartition(dvdcallbacklow cb) {
|
s32 bwDVD_LowClosePartition(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -423,7 +444,7 @@ s32 bwDVD_LowClosePartition(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_CLOSEPART<<24);
|
cmd->diReg[0] = (IOCTL_DI_CLOSEPART<<24);
|
||||||
@ -432,7 +453,8 @@ s32 bwDVD_LowClosePartition(dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -441,7 +463,7 @@ s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
|||||||
__dvd_readlength = len;
|
__dvd_readlength = len;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_UNENCREAD<<24);
|
cmd->diReg[0] = (IOCTL_DI_UNENCREAD<<24);
|
||||||
@ -452,7 +474,8 @@ s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb) {
|
s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -460,7 +483,7 @@ s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_WAITCVRCLOSE<<24);
|
cmd->diReg[0] = (IOCTL_DI_WAITCVRCLOSE<<24);
|
||||||
@ -469,15 +492,16 @@ s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowResetNotify() {
|
s32 bwDVD_LowResetNotify()
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
|
|
||||||
if (__dvd_cbinprogress==1) return -1;
|
if(__dvd_cbinprogress==1) return -1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(NULL);
|
ctx = __dvd_getcontext(NULL);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_RESETNOTIFY<<24);
|
cmd->diReg[0] = (IOCTL_DI_RESETNOTIFY<<24);
|
||||||
@ -486,7 +510,8 @@ s32 bwDVD_LowResetNotify() {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowReset(dvdcallbacklow cb) {
|
s32 bwDVD_LowReset(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -495,7 +520,7 @@ s32 bwDVD_LowReset(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_RESET<<24);
|
cmd->diReg[0] = (IOCTL_DI_RESET<<24);
|
||||||
@ -506,7 +531,8 @@ s32 bwDVD_LowReset(dvdcallbacklow cb) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowStopMotor(u8 stop1,u8 stop2,dvdcallbacklow cb) {
|
s32 bwDVD_LowStopMotor(u8 stop1,u8 stop2,dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -514,7 +540,7 @@ s32 bwDVD_LowStopMotor(u8 stop1,u8 stop2,dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_STOPMOTOR<<24);
|
cmd->diReg[0] = (IOCTL_DI_STOPMOTOR<<24);
|
||||||
@ -526,7 +552,8 @@ s32 bwDVD_LowStopMotor(u8 stop1,u8 stop2,dvdcallbacklow cb) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_LowRequestError(dvdcallbacklow cb) {
|
s32 bwDVD_LowRequestError(dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -534,7 +561,7 @@ s32 bwDVD_LowRequestError(dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_REQERROR<<24);
|
cmd->diReg[0] = (IOCTL_DI_REQERROR<<24);
|
||||||
@ -544,7 +571,8 @@ s32 bwDVD_LowRequestError(dvdcallbacklow cb) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb) {
|
s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -552,7 +580,7 @@ s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_SETCRYPTMODE<<24);
|
cmd->diReg[0] = (IOCTL_DI_SETCRYPTMODE<<24);
|
||||||
@ -563,7 +591,8 @@ s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 bwDVD_SetOffset(u32 offset, dvdcallbacklow cb) {
|
s32 bwDVD_SetOffset(u32 offset, dvdcallbacklow cb)
|
||||||
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
struct dicontext *ctx;
|
struct dicontext *ctx;
|
||||||
struct dicommand *cmd;
|
struct dicommand *cmd;
|
||||||
@ -571,7 +600,7 @@ s32 bwDVD_SetOffset(u32 offset, dvdcallbacklow cb) {
|
|||||||
__dvd_reqinprogress = 1;
|
__dvd_reqinprogress = 1;
|
||||||
|
|
||||||
ctx = __dvd_getcontext(cb);
|
ctx = __dvd_getcontext(cb);
|
||||||
if (ctx==NULL) return IPC_ENOMEM;
|
if(ctx==NULL) return IPC_ENOMEM;
|
||||||
|
|
||||||
cmd = ctx->cmd;
|
cmd = ctx->cmd;
|
||||||
cmd->diReg[0] = (IOCTL_DI_SETOFFBASE<<24);
|
cmd->diReg[0] = (IOCTL_DI_SETOFFBASE<<24);
|
||||||
|
@ -27,27 +27,27 @@
|
|||||||
#include <ogc/dvd.h>
|
#include <ogc/dvd.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
typedef void (*dvdcallbacklow)(s32 result);
|
typedef void (*dvdcallbacklow)(s32 result);
|
||||||
|
|
||||||
s32 bwDVD_LowInit();
|
s32 bwDVD_LowInit();
|
||||||
s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb);
|
s32 bwDVD_LowInquiry(dvddrvinfo *info,dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb);
|
s32 bwDVD_LowReadID(dvddiskid *diskID,dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowClosePartition(dvdcallbacklow cb);
|
s32 bwDVD_LowClosePartition(dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certificate_in,void *certificate_out,dvdcallbacklow cb);
|
s32 bwDVD_LowOpenPartition(u32 offset,void *eticket,u32 certin_len,void *certificate_in,void *certificate_out,dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
s32 bwDVD_LowUnencryptedRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowReset(dvdcallbacklow cb);
|
s32 bwDVD_LowReset(dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb);
|
s32 bwDVD_LowWaitCoverClose(dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
s32 bwDVD_LowRead(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
||||||
s32 bwDVD_EnableVideo(dvdcallbacklow cb);
|
s32 bwDVD_EnableVideo(dvdcallbacklow cb);
|
||||||
s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
s32 bwDVD_LowReadVideo(void *buf,u32 len,u32 offset,dvdcallbacklow cb);
|
||||||
s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb);
|
s32 bwDVD_SetDecryption(s32 mode, dvdcallbacklow cb);
|
||||||
s32 bwDVD_SetOffset(u32 offset, dvdcallbacklow cb);
|
s32 bwDVD_SetOffset(u32 offset, dvdcallbacklow cb);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -37,7 +37,8 @@
|
|||||||
|
|
||||||
extern struct SSettings Settings;
|
extern struct SSettings Settings;
|
||||||
|
|
||||||
u32 do_sd_code(char *filename) {
|
u32 do_sd_code(char *filename)
|
||||||
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
u8 *filebuff;
|
u8 *filebuff;
|
||||||
u32 filesize;
|
u32 filesize;
|
||||||
@ -66,7 +67,7 @@ u32 do_sd_code(char *filename) {
|
|||||||
fseek(fp, 0, SEEK_SET);
|
fseek(fp, 0, SEEK_SET);
|
||||||
|
|
||||||
filebuff = (u8*) malloc (filesize);
|
filebuff = (u8*) malloc (filesize);
|
||||||
if (filebuff == 0) {
|
if(filebuff == 0){
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
sleep(2);
|
sleep(2);
|
||||||
USBDevice_deInit();
|
USBDevice_deInit();
|
||||||
@ -75,7 +76,7 @@ u32 do_sd_code(char *filename) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = fread(filebuff, 1, filesize, fp);
|
ret = fread(filebuff, 1, filesize, fp);
|
||||||
if (ret != filesize) {
|
if(ret != filesize){
|
||||||
free(filebuff);
|
free(filebuff);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
USBDevice_deInit();
|
USBDevice_deInit();
|
||||||
|
@ -23,11 +23,12 @@
|
|||||||
#define __FST_H__
|
#define __FST_H__
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C"
|
||||||
|
{
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//u32 do_fst(u32 fstlocation);
|
//u32 do_fst(u32 fstlocation);
|
||||||
u32 do_sd_code(char *filename);
|
u32 do_sd_code(char *filename);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -146,20 +146,23 @@ static const u32 wpadlibogc[5] = {
|
|||||||
0x90A402E0,0x806502E4,0x908502E4,0x2C030000,0x906402E4
|
0x90A402E0,0x806502E4,0x908502E4,0x2C030000,0x906402E4
|
||||||
};
|
};
|
||||||
|
|
||||||
void dogamehooks(void *addr, u32 len) {
|
void dogamehooks(void *addr, u32 len)
|
||||||
|
{
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr+len;
|
void *addr_end = addr+len;
|
||||||
|
|
||||||
while (addr_start < addr_end) {
|
while(addr_start < addr_end)
|
||||||
|
{
|
||||||
|
|
||||||
switch (hooktype) {
|
switch(hooktype)
|
||||||
|
{
|
||||||
|
|
||||||
case 0:
|
case 0:
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
if (memcmp(addr_start, viwiihooks, sizeof(viwiihooks))==0) {
|
if(memcmp(addr_start, viwiihooks, sizeof(viwiihooks))==0){
|
||||||
// printf("\n\n\n");
|
// printf("\n\n\n");
|
||||||
// printf("found at address %x\n", addr_start);
|
// printf("found at address %x\n", addr_start);
|
||||||
// sleep(2);
|
// sleep(2);
|
||||||
@ -169,7 +172,7 @@ void dogamehooks(void *addr, u32 len) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
case 2:
|
case 2:
|
||||||
if(memcmp(addr_start, kpadhooks, sizeof(kpadhooks))==0){
|
if(memcmp(addr_start, kpadhooks, sizeof(kpadhooks))==0){
|
||||||
patchhook((u32)addr_start, len);
|
patchhook((u32)addr_start, len);
|
||||||
@ -194,16 +197,16 @@ void dogamehooks(void *addr, u32 len) {
|
|||||||
patchhook3((u32)addr_start, len);
|
patchhook3((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
*/
|
*/
|
||||||
case 2:
|
case 2:
|
||||||
|
|
||||||
if (memcmp(addr_start, viwiihooks, sizeof(viwiihooks))==0) {
|
if(memcmp(addr_start, viwiihooks, sizeof(viwiihooks))==0){
|
||||||
patchhook2((u32)addr_start, len);
|
patchhook2((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
case 6:
|
case 6:
|
||||||
// jap region free
|
// jap region free
|
||||||
if(memcmp(addr_start, regionfreehooks, sizeof(regionfreehooks))==0){
|
if(memcmp(addr_start, regionfreehooks, sizeof(regionfreehooks))==0){
|
||||||
@ -265,14 +268,14 @@ void dogamehooks(void *addr, u32 len) {
|
|||||||
movedvdhooks((u32)addr_start, len);
|
movedvdhooks((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
*/
|
*/
|
||||||
// multidol
|
// multidol
|
||||||
case 3:
|
case 3:
|
||||||
|
|
||||||
if (memcmp(addr_start, multidolpatch1, sizeof(multidolpatch1))==0) {
|
if(memcmp(addr_start, multidolpatch1, sizeof(multidolpatch1))==0){
|
||||||
multidolpatchone((u32)addr_start, len);
|
multidolpatchone((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
if (memcmp(addr_start, multidolpatch2, sizeof(multidolpatch2))==0) {
|
if(memcmp(addr_start, multidolpatch2, sizeof(multidolpatch2))==0){
|
||||||
multidolpatchtwo((u32)addr_start, len);
|
multidolpatchtwo((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -282,13 +285,15 @@ void dogamehooks(void *addr, u32 len) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Not used yet, for patching DOL once loaded into memory and befor execution
|
// Not used yet, for patching DOL once loaded into memory and befor execution
|
||||||
void patchdol(void *addr, u32 len) {
|
void patchdol(void *addr, u32 len)
|
||||||
|
{
|
||||||
|
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr+len;
|
void *addr_end = addr+len;
|
||||||
|
|
||||||
while (addr_start < addr_end) {
|
while(addr_start < addr_end)
|
||||||
if (memcmp(addr_start, wpadlibogc, sizeof(wpadlibogc))==0) {
|
{
|
||||||
|
if(memcmp(addr_start, wpadlibogc, sizeof(wpadlibogc))==0) {
|
||||||
// printf("\n\n\n");
|
// printf("\n\n\n");
|
||||||
// printf("found at address %x\n", addr_start);
|
// printf("found at address %x\n", addr_start);
|
||||||
// sleep(10);
|
// sleep(10);
|
||||||
@ -300,15 +305,17 @@ void patchdol(void *addr, u32 len) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void langpatcher(void *addr, u32 len) {
|
void langpatcher(void *addr, u32 len)
|
||||||
|
{
|
||||||
|
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr+len;
|
void *addr_end = addr+len;
|
||||||
|
|
||||||
while (addr_start < addr_end) {
|
while(addr_start < addr_end)
|
||||||
|
{
|
||||||
|
|
||||||
if (memcmp(addr_start, langpatch, sizeof(langpatch))==0) {
|
if(memcmp(addr_start, langpatch, sizeof(langpatch))==0) {
|
||||||
if (configbytes[0] != 0xCD) {
|
if(configbytes[0] != 0xCD){
|
||||||
langvipatch((u32)addr_start, len, configbytes[0]);
|
langvipatch((u32)addr_start, len, configbytes[0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -316,14 +323,16 @@ void langpatcher(void *addr, u32 len) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void patchdebug(void *addr, u32 len) {
|
void patchdebug(void *addr, u32 len)
|
||||||
|
{
|
||||||
|
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr+len;
|
void *addr_end = addr+len;
|
||||||
|
|
||||||
while (addr_start < addr_end) {
|
while(addr_start < addr_end)
|
||||||
|
{
|
||||||
|
|
||||||
if (memcmp(addr_start, fwritepatch, sizeof(fwritepatch))==0) {
|
if(memcmp(addr_start, fwritepatch, sizeof(fwritepatch))==0) {
|
||||||
|
|
||||||
memcpy(addr_start,fwrite_patch_bin,fwrite_patch_bin_len);
|
memcpy(addr_start,fwrite_patch_bin,fwrite_patch_bin_len);
|
||||||
// apply patch
|
// apply patch
|
||||||
@ -332,13 +341,15 @@ void patchdebug(void *addr, u32 len) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void vidolpatcher(void *addr, u32 len) {
|
void vidolpatcher(void *addr, u32 len)
|
||||||
|
{
|
||||||
|
|
||||||
void *addr_start = addr;
|
void *addr_start = addr;
|
||||||
void *addr_end = addr+len;
|
void *addr_end = addr+len;
|
||||||
|
|
||||||
while (addr_start < addr_end) {
|
while(addr_start < addr_end)
|
||||||
if (memcmp(addr_start, vipatchcode, sizeof(vipatchcode))==0) {
|
{
|
||||||
|
if(memcmp(addr_start, vipatchcode, sizeof(vipatchcode))==0) {
|
||||||
vipatch((u32)addr_start, len);
|
vipatch((u32)addr_start, len);
|
||||||
}
|
}
|
||||||
addr_start += 4;
|
addr_start += 4;
|
||||||
|
@ -22,19 +22,20 @@
|
|||||||
#ifndef __PATCHCODE_H__
|
#ifndef __PATCHCODE_H__
|
||||||
#define __PATCHCODE_H__
|
#define __PATCHCODE_H__
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C"
|
||||||
|
{
|
||||||
#endif
|
#endif
|
||||||
// Globals
|
// Globals
|
||||||
u32 hooktype;
|
u32 hooktype;
|
||||||
int patched;
|
int patched;
|
||||||
u8 configbytes[2];
|
u8 configbytes[2];
|
||||||
u32 regionfree;
|
u32 regionfree;
|
||||||
|
|
||||||
// Function prototypes
|
// Function prototypes
|
||||||
void dogamehooks(void *addr, u32 len);
|
void dogamehooks(void *addr, u32 len);
|
||||||
void langpatcher(void *addr, u32 len);
|
void langpatcher(void *addr, u32 len);
|
||||||
void vidolpatcher(void *addr, u32 len);
|
void vidolpatcher(void *addr, u32 len);
|
||||||
void patchdebug(void *addr, u32 len);
|
void patchdebug(void *addr, u32 len);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,43 +1,43 @@
|
|||||||
|
|
||||||
# (c) Nuke www.usbgecko.com. Licensed under GPL V2
|
# (c) Nuke www.usbgecko.com. Licensed under GPL V2
|
||||||
.text
|
.text
|
||||||
#include "ppc.h"
|
#include "ppc.h"
|
||||||
|
|
||||||
|
|
||||||
.globl patchhook # r3 address
|
.globl patchhook # r3 address
|
||||||
patchhook:
|
patchhook:
|
||||||
mtctr r4
|
|
||||||
lis r6, 0x4E80
|
|
||||||
ori r6, r6, 0x0020 # blr
|
|
||||||
findblr:
|
|
||||||
lwz r5, 0(r3)
|
|
||||||
cmpw r6, r5
|
|
||||||
beq writebranch
|
|
||||||
addi r3, r3, 4 # next word
|
|
||||||
bdnz findblr # loop length
|
|
||||||
b exit # stop unhooked game hanging
|
|
||||||
|
|
||||||
writebranch:
|
|
||||||
lis r4, 0x8000 # 800018A0 hook location (source)
|
|
||||||
ori r4, r4, 0x18A8
|
|
||||||
subf r4, r3, r4 # subtract r3 from r4 and place in r4
|
|
||||||
lis r5, 0x3FF
|
|
||||||
ori r5, r5, 0xFFFF # 0x3FFFFFF
|
|
||||||
and r4, r4, r5
|
|
||||||
lis r5, 0x4800 # 0x48000000
|
|
||||||
or r4, r4, r5
|
|
||||||
stw r4, 0(r3) # result in r3
|
|
||||||
dcbf r0, r3 # data cache block flush
|
|
||||||
icbi r0, r3
|
|
||||||
exit:
|
|
||||||
blr # return
|
|
||||||
|
|
||||||
.globl patchhook2 # r3 address
|
|
||||||
patchhook2:
|
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4E80
|
lis r6, 0x4E80
|
||||||
ori r6, r6, 0x0020 # blr
|
ori r6, r6, 0x0020 # blr
|
||||||
findblr2:
|
findblr:
|
||||||
|
lwz r5, 0(r3)
|
||||||
|
cmpw r6, r5
|
||||||
|
beq writebranch
|
||||||
|
addi r3, r3, 4 # next word
|
||||||
|
bdnz findblr # loop length
|
||||||
|
b exit # stop unhooked game hanging
|
||||||
|
|
||||||
|
writebranch:
|
||||||
|
lis r4, 0x8000 # 800018A0 hook location (source)
|
||||||
|
ori r4, r4, 0x18A8
|
||||||
|
subf r4, r3, r4 # subtract r3 from r4 and place in r4
|
||||||
|
lis r5, 0x3FF
|
||||||
|
ori r5, r5, 0xFFFF # 0x3FFFFFF
|
||||||
|
and r4, r4, r5
|
||||||
|
lis r5, 0x4800 # 0x48000000
|
||||||
|
or r4, r4, r5
|
||||||
|
stw r4, 0(r3) # result in r3
|
||||||
|
dcbf r0, r3 # data cache block flush
|
||||||
|
icbi r0, r3
|
||||||
|
exit:
|
||||||
|
blr # return
|
||||||
|
|
||||||
|
.globl patchhook2 # r3 address
|
||||||
|
patchhook2:
|
||||||
|
mtctr r4
|
||||||
|
lis r6, 0x4E80
|
||||||
|
ori r6, r6, 0x0020 # blr
|
||||||
|
findblr2:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writebranch2
|
beq writebranch2
|
||||||
@ -45,7 +45,7 @@ blr # return
|
|||||||
bdnz findblr2 # loop length
|
bdnz findblr2 # loop length
|
||||||
b exit2 # stop unhooked game hanging
|
b exit2 # stop unhooked game hanging
|
||||||
|
|
||||||
writebranch2:
|
writebranch2:
|
||||||
lis r4, 0x8000 # 81700000 our temp patcher
|
lis r4, 0x8000 # 81700000 our temp patcher
|
||||||
ori r4, r4, 0x18a8
|
ori r4, r4, 0x18a8
|
||||||
subf r4, r3, r4 # subtract r3 from r4 and place in r4
|
subf r4, r3, r4 # subtract r3 from r4 and place in r4
|
||||||
@ -57,15 +57,15 @@ blr # return
|
|||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exit2:
|
exit2:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl patchhook3 # r3 address
|
.globl patchhook3 # r3 address
|
||||||
patchhook3:
|
patchhook3:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4BFF
|
lis r6, 0x4BFF
|
||||||
ori r6, r6, 0xE955 # blr
|
ori r6, r6, 0xE955 # blr
|
||||||
findbne:
|
findbne:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writebl
|
beq writebl
|
||||||
@ -73,21 +73,21 @@ blr # return
|
|||||||
bdnz findbne # loop length
|
bdnz findbne # loop length
|
||||||
b exit3 # stop unhooked game hanging
|
b exit3 # stop unhooked game hanging
|
||||||
|
|
||||||
writebl:
|
writebl:
|
||||||
lis r4, 0x4BFF # 81700000 our temp patcher
|
lis r4, 0x4BFF # 81700000 our temp patcher
|
||||||
ori r4, r4, 0xEA91
|
ori r4, r4, 0xEA91
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exit3:
|
exit3:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl patchhook4 # r3 address
|
.globl patchhook4 # r3 address
|
||||||
patchhook4:
|
patchhook4:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4082
|
lis r6, 0x4082
|
||||||
ori r6, r6, 0x001C # blr
|
ori r6, r6, 0x001C # blr
|
||||||
findregion:
|
findregion:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writebr
|
beq writebr
|
||||||
@ -95,21 +95,21 @@ blr # return
|
|||||||
bdnz findregion # loop length
|
bdnz findregion # loop length
|
||||||
b exit4 # stop unhooked game hanging
|
b exit4 # stop unhooked game hanging
|
||||||
|
|
||||||
writebr:
|
writebr:
|
||||||
lis r4, 0x4800
|
lis r4, 0x4800
|
||||||
ori r4, r4, 0x001C
|
ori r4, r4, 0x001C
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exit4:
|
exit4:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl multidolpatchone # r3 address
|
.globl multidolpatchone # r3 address
|
||||||
multidolpatchone:
|
multidolpatchone:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x3800
|
lis r6, 0x3800
|
||||||
ori r6, r6, 0x0001 # (li r0,1)
|
ori r6, r6, 0x0001 # (li r0,1)
|
||||||
findmulti:
|
findmulti:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writemulti
|
beq writemulti
|
||||||
@ -117,7 +117,7 @@ blr # return
|
|||||||
bdnz findmulti # loop length
|
bdnz findmulti # loop length
|
||||||
b exit5 # stop unhooked game hanging
|
b exit5 # stop unhooked game hanging
|
||||||
|
|
||||||
writemulti:
|
writemulti:
|
||||||
lis r4, 0x8170 # 81700000
|
lis r4, 0x8170 # 81700000
|
||||||
ori r4, r4, 0x0020
|
ori r4, r4, 0x0020
|
||||||
subf r18, r3, r4 # subf r18,(source),(dest)
|
subf r18, r3, r4 # subf r18,(source),(dest)
|
||||||
@ -131,15 +131,15 @@ blr # return
|
|||||||
sync
|
sync
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
isync
|
isync
|
||||||
exit5:
|
exit5:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl multidolpatchtwo # r3 address
|
.globl multidolpatchtwo # r3 address
|
||||||
multidolpatchtwo:
|
multidolpatchtwo:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x3F60
|
lis r6, 0x3F60
|
||||||
ori r6, r6, 0x8000 # (lis r27,-32768)
|
ori r6, r6, 0x8000 # (lis r27,-32768)
|
||||||
findmulti2:
|
findmulti2:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writemulti2
|
beq writemulti2
|
||||||
@ -147,7 +147,7 @@ blr # return
|
|||||||
bdnz findmulti2 # loop length
|
bdnz findmulti2 # loop length
|
||||||
b exit6 # stop unhooked game hanging
|
b exit6 # stop unhooked game hanging
|
||||||
|
|
||||||
writemulti2:
|
writemulti2:
|
||||||
lis r4, 0x8170 # 81700020
|
lis r4, 0x8170 # 81700020
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
subf r18, r3, r4 # subf r18,(source),(dest)
|
subf r18, r3, r4 # subf r18,(source),(dest)
|
||||||
@ -161,15 +161,15 @@ blr # return
|
|||||||
sync
|
sync
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
isync
|
isync
|
||||||
exit6:
|
exit6:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl langvipatch # r3 address, r4 len, r5 lang byte
|
.globl langvipatch # r3 address, r4 len, r5 lang byte
|
||||||
langvipatch:
|
langvipatch:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x8861
|
lis r6, 0x8861
|
||||||
ori r6, r6, 0x0008 # lbz r3, 8(sp)
|
ori r6, r6, 0x0008 # lbz r3, 8(sp)
|
||||||
findlang:
|
findlang:
|
||||||
lwz r7, 0(r3)
|
lwz r7, 0(r3)
|
||||||
cmpw r6, r7
|
cmpw r6, r7
|
||||||
beq patchlang
|
beq patchlang
|
||||||
@ -177,23 +177,23 @@ blr # return
|
|||||||
bdnz findlang # loop length
|
bdnz findlang # loop length
|
||||||
b exitlang # stop unhooked game hanging
|
b exitlang # stop unhooked game hanging
|
||||||
|
|
||||||
patchlang:
|
patchlang:
|
||||||
|
|
||||||
lis r4, 0x3860 # 0x38600001 li %r3, 1 # eng
|
lis r4, 0x3860 # 0x38600001 li %r3, 1 # eng
|
||||||
add r4, r4, r5
|
add r4, r4, r5
|
||||||
gofinal:
|
gofinal:
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitlang:
|
exitlang:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl vipatch # r3 address
|
.globl vipatch # r3 address
|
||||||
vipatch:
|
vipatch:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x5400
|
lis r6, 0x5400
|
||||||
ori r6, r6, 0xFFFE
|
ori r6, r6, 0xFFFE
|
||||||
findvi:
|
findvi:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq patchvi
|
beq patchvi
|
||||||
@ -201,7 +201,7 @@ blr # return
|
|||||||
bdnz findvi # loop length
|
bdnz findvi # loop length
|
||||||
b exitvi # stop unhooked game hanging
|
b exitvi # stop unhooked game hanging
|
||||||
|
|
||||||
patchvi:
|
patchvi:
|
||||||
lis r4, 0x8000
|
lis r4, 0x8000
|
||||||
ori r4, r4, 0x0003
|
ori r4, r4, 0x0003
|
||||||
lbz r5, 0(r4)
|
lbz r5, 0(r4)
|
||||||
@ -210,26 +210,26 @@ blr # return
|
|||||||
cmpwi r5, 0x4A
|
cmpwi r5, 0x4A
|
||||||
beq patchjap2 # JAP
|
beq patchjap2 # JAP
|
||||||
b exitvi
|
b exitvi
|
||||||
patchjap2:
|
patchjap2:
|
||||||
lis r4, 0x3800
|
lis r4, 0x3800
|
||||||
ori r4, r4, 0x0001
|
ori r4, r4, 0x0001
|
||||||
b gofinal2
|
b gofinal2
|
||||||
patchusa:
|
patchusa:
|
||||||
lis r4, 0x3800
|
lis r4, 0x3800
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
gofinal2:
|
gofinal2:
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitvi:
|
exitvi:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl regionfreejap # r3 address
|
.globl regionfreejap # r3 address
|
||||||
regionfreejap:
|
regionfreejap:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x2C1B
|
lis r6, 0x2C1B
|
||||||
ori r6, r6, 0x0000 # blr
|
ori r6, r6, 0x0000 # blr
|
||||||
findjap:
|
findjap:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writenop
|
beq writenop
|
||||||
@ -237,22 +237,22 @@ blr # return
|
|||||||
bdnz findjap # loop length
|
bdnz findjap # loop length
|
||||||
b exitjap # stop unhooked game hanging
|
b exitjap # stop unhooked game hanging
|
||||||
|
|
||||||
writenop:
|
writenop:
|
||||||
addi r3, r3, 4 # next word
|
addi r3, r3, 4 # next word
|
||||||
lis r4, 0x6000 # nop
|
lis r4, 0x6000 # nop
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitjap:
|
exitjap:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl regionfreeusa # r3 address
|
.globl regionfreeusa # r3 address
|
||||||
regionfreeusa:
|
regionfreeusa:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x281B
|
lis r6, 0x281B
|
||||||
ori r6, r6, 0x0001 # blr
|
ori r6, r6, 0x0001 # blr
|
||||||
findusa:
|
findusa:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writenop1
|
beq writenop1
|
||||||
@ -260,22 +260,22 @@ blr # return
|
|||||||
bdnz findusa # loop length
|
bdnz findusa # loop length
|
||||||
b exitusa # stop unhooked game hanging
|
b exitusa # stop unhooked game hanging
|
||||||
|
|
||||||
writenop1:
|
writenop1:
|
||||||
addi r3, r3, 4 # next word
|
addi r3, r3, 4 # next word
|
||||||
lis r4, 0x6000 # nop
|
lis r4, 0x6000 # nop
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitusa:
|
exitusa:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl regionfreepal # r3 address
|
.globl regionfreepal # r3 address
|
||||||
regionfreepal:
|
regionfreepal:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x281B
|
lis r6, 0x281B
|
||||||
ori r6, r6, 0x0002 # blr
|
ori r6, r6, 0x0002 # blr
|
||||||
findpal:
|
findpal:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writenop2
|
beq writenop2
|
||||||
@ -283,7 +283,7 @@ blr # return
|
|||||||
bdnz findpal # loop length
|
bdnz findpal # loop length
|
||||||
b exitpal # stop unhooked game hanging
|
b exitpal # stop unhooked game hanging
|
||||||
|
|
||||||
writenop2:
|
writenop2:
|
||||||
addi r3, r3, 4 # next word
|
addi r3, r3, 4 # next word
|
||||||
lis r4, 0x6000 # nop
|
lis r4, 0x6000 # nop
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
@ -293,7 +293,7 @@ blr # return
|
|||||||
|
|
||||||
lis r6, 0x4082
|
lis r6, 0x4082
|
||||||
ori r6, r6, 0x001C # bne loc_81377A2C
|
ori r6, r6, 0x001C # bne loc_81377A2C
|
||||||
findextra: #this is just the bne to b patch
|
findextra: #this is just the bne to b patch
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writeb
|
beq writeb
|
||||||
@ -301,22 +301,22 @@ blr # return
|
|||||||
bdnz findextra # loop length
|
bdnz findextra # loop length
|
||||||
b exitpal # stop unhooked game hanging
|
b exitpal # stop unhooked game hanging
|
||||||
|
|
||||||
writeb:
|
writeb:
|
||||||
addi r3, r3, 4 # next word
|
addi r3, r3, 4 # next word
|
||||||
lis r4, 0x4800
|
lis r4, 0x4800
|
||||||
ori r4, r4, 0x001c # b loc_81377A2C
|
ori r4, r4, 0x001c # b loc_81377A2C
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitpal:
|
exitpal:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl removehealthcheck # r3 address
|
.globl removehealthcheck # r3 address
|
||||||
removehealthcheck:
|
removehealthcheck:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4182
|
lis r6, 0x4182
|
||||||
ori r6, r6, 0x004C # blr
|
ori r6, r6, 0x004C # blr
|
||||||
findhe:
|
findhe:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writebhe
|
beq writebhe
|
||||||
@ -324,23 +324,23 @@ blr # return
|
|||||||
bdnz findhe # loop length
|
bdnz findhe # loop length
|
||||||
b exithe # stop unhooked game hanging
|
b exithe # stop unhooked game hanging
|
||||||
|
|
||||||
writebhe:
|
writebhe:
|
||||||
lis r4, 0x6000
|
lis r4, 0x6000
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exithe:
|
exithe:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.globl patchupdatecheck # r3 address
|
.globl patchupdatecheck # r3 address
|
||||||
patchupdatecheck:
|
patchupdatecheck:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4082
|
lis r6, 0x4082
|
||||||
ori r6, r6, 0x0020 # blr
|
ori r6, r6, 0x0020 # blr
|
||||||
finduc:
|
finduc:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writenopuc
|
beq writenopuc
|
||||||
@ -348,24 +348,24 @@ blr # return
|
|||||||
bdnz finduc # loop length
|
bdnz finduc # loop length
|
||||||
b exituc # stop unhooked game hanging
|
b exituc # stop unhooked game hanging
|
||||||
|
|
||||||
writenopuc:
|
writenopuc:
|
||||||
lis r4, 0x6000
|
lis r4, 0x6000
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exituc:
|
exituc:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.globl copyflagcheck1 # r3 address
|
.globl copyflagcheck1 # r3 address
|
||||||
copyflagcheck1:
|
copyflagcheck1:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x5400
|
lis r6, 0x5400
|
||||||
ori r6, r6, 0x07FF
|
ori r6, r6, 0x07FF
|
||||||
findncf1:
|
findncf1:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writencf1
|
beq writencf1
|
||||||
@ -373,21 +373,21 @@ blr # return
|
|||||||
bdnz findncf1 # loop length
|
bdnz findncf1 # loop length
|
||||||
b exitncf1 # stop unhooked game hanging
|
b exitncf1 # stop unhooked game hanging
|
||||||
|
|
||||||
writencf1:
|
writencf1:
|
||||||
lis r4, 0x7C00
|
lis r4, 0x7C00
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitncf1:
|
exitncf1:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl copyflagcheck2 # r3 address
|
.globl copyflagcheck2 # r3 address
|
||||||
copyflagcheck2:
|
copyflagcheck2:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x5400
|
lis r6, 0x5400
|
||||||
ori r6, r6, 0x07FF
|
ori r6, r6, 0x07FF
|
||||||
findncf2:
|
findncf2:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writencf2
|
beq writencf2
|
||||||
@ -395,37 +395,37 @@ blr # return
|
|||||||
bdnz findncf2 # loop length
|
bdnz findncf2 # loop length
|
||||||
b exitncf2 # stop unhooked game hanging
|
b exitncf2 # stop unhooked game hanging
|
||||||
|
|
||||||
writencf2:
|
writencf2:
|
||||||
lis r4, 0x7C00
|
lis r4, 0x7C00
|
||||||
ori r4, r4, 0x0000
|
ori r4, r4, 0x0000
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitncf2:
|
exitncf2:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
|
|
||||||
.globl copyflagcheck3 # r3 address
|
.globl copyflagcheck3 # r3 address
|
||||||
copyflagcheck3:
|
copyflagcheck3:
|
||||||
findncf3:
|
findncf3:
|
||||||
addi r3, r3, 20 # go back one dword (4 bytes)
|
addi r3, r3, 20 # go back one dword (4 bytes)
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
writencf3:
|
writencf3:
|
||||||
lis r4, 0x3860
|
lis r4, 0x3860
|
||||||
ori r4, r4, 0x0001 # li r3,1
|
ori r4, r4, 0x0001 # li r3,1
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitncf3:
|
exitncf3:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
|
|
||||||
.globl copyflagcheck4 # r3 address
|
.globl copyflagcheck4 # r3 address
|
||||||
copyflagcheck4:
|
copyflagcheck4:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x3BE0
|
lis r6, 0x3BE0
|
||||||
ori r6, r6, 0x0001 # li r31,1
|
ori r6, r6, 0x0001 # li r31,1
|
||||||
findncf4:
|
findncf4:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writencf4
|
beq writencf4
|
||||||
@ -433,21 +433,21 @@ blr # return
|
|||||||
bdnz findncf4 # loop length
|
bdnz findncf4 # loop length
|
||||||
b exitncf4 # stop unhooked game hanging
|
b exitncf4 # stop unhooked game hanging
|
||||||
|
|
||||||
writencf4:
|
writencf4:
|
||||||
lis r4, 0x3BE0
|
lis r4, 0x3BE0
|
||||||
ori r4, r4, 0x0000 # change this to 3BE00000 (li r31,0)
|
ori r4, r4, 0x0000 # change this to 3BE00000 (li r31,0)
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitncf4:
|
exitncf4:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl copyflagcheck5 # r3 address
|
.globl copyflagcheck5 # r3 address
|
||||||
copyflagcheck5:
|
copyflagcheck5:
|
||||||
mtctr r4
|
mtctr r4
|
||||||
lis r6, 0x4182
|
lis r6, 0x4182
|
||||||
ori r6, r6, 0x0024 # beq loc_8134AA60
|
ori r6, r6, 0x0024 # beq loc_8134AA60
|
||||||
findncf5:
|
findncf5:
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
cmpw r6, r5
|
cmpw r6, r5
|
||||||
beq writencf5
|
beq writencf5
|
||||||
@ -455,8 +455,8 @@ blr # return
|
|||||||
bdnz findncf5 # loop length
|
bdnz findncf5 # loop length
|
||||||
b exitncf5 # stop unhooked game hanging
|
b exitncf5 # stop unhooked game hanging
|
||||||
|
|
||||||
writencf5:
|
writencf5:
|
||||||
#addi r3, r3, 8 # skip 2
|
#addi r3, r3, 8 # skip 2
|
||||||
|
|
||||||
lis r4, 0x801D
|
lis r4, 0x801D
|
||||||
ori r4, r4, 0x0024 # change to 801D0024 (lwz r0,36(r29))
|
ori r4, r4, 0x0024 # change to 801D0024 (lwz r0,36(r29))
|
||||||
@ -487,22 +487,22 @@ blr # return
|
|||||||
stw r4, 0(r3)
|
stw r4, 0(r3)
|
||||||
dcbf r0, r3
|
dcbf r0, r3
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitncf5:
|
exitncf5:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
.globl movedvdhooks # r3 address
|
.globl movedvdhooks # r3 address
|
||||||
movedvdhooks:
|
movedvdhooks:
|
||||||
lis r6, 0x4182
|
lis r6, 0x4182
|
||||||
ori r6, r6, 0x0120 # beq loc_813A7938
|
ori r6, r6, 0x0120 # beq loc_813A7938
|
||||||
findmd1:
|
findmd1:
|
||||||
addi r3, r3, 4 # next word
|
addi r3, r3, 4 # next word
|
||||||
lwz r5, 0(r3)
|
lwz r5, 0(r3)
|
||||||
writemd1:
|
writemd1:
|
||||||
lis r4, 0x6000
|
lis r4, 0x6000
|
||||||
ori r4, r4, 0x0000 # nop
|
ori r4, r4, 0x0000 # nop
|
||||||
stw r4, 0(r3) # result in r3
|
stw r4, 0(r3) # result in r3
|
||||||
dcbf r0, r3 # data cache block flush
|
dcbf r0, r3 # data cache block flush
|
||||||
icbi r0, r3
|
icbi r0, r3
|
||||||
exitmd1:
|
exitmd1:
|
||||||
blr # return
|
blr # return
|
||||||
|
|
||||||
|
@ -205,11 +205,11 @@ int DiscBrowse(struct discHdr * header) {
|
|||||||
|
|
||||||
if (ret > 0) {
|
if (ret > 0) {
|
||||||
char temp[100];
|
char temp[100];
|
||||||
strncpy(temp, fstfiles(fst, ret), sizeof(temp));
|
strlcpy(temp, fstfiles(fst, ret), sizeof(temp));
|
||||||
choice = WindowPrompt(temp, tr("Load this dol as alternate dol?"), tr("OK"), tr("Cancel"));
|
choice = WindowPrompt(temp, tr("Load this dol as alternate dol?"), tr("OK"), tr("Cancel"));
|
||||||
if (choice) {
|
if (choice) {
|
||||||
//ret = offsetselect[ret];
|
//ret = offsetselect[ret];
|
||||||
snprintf(alternatedname, sizeof(alternatedname), "%s", temp);
|
strlcpy(alternatedname, temp, sizeof(alternatedname));
|
||||||
exit = true;
|
exit = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -232,7 +232,6 @@ int DiscBrowse(struct discHdr * header) {
|
|||||||
|
|
||||||
|
|
||||||
int autoSelectDol(const char *id) {
|
int autoSelectDol(const char *id) {
|
||||||
//still not done//
|
|
||||||
//////////ID6/////////////////
|
//////////ID6/////////////////
|
||||||
|
|
||||||
//Boogie
|
//Boogie
|
||||||
@ -271,38 +270,6 @@ int autoSelectDol(const char *id) {
|
|||||||
//Metal Slug Anthology
|
//Metal Slug Anthology
|
||||||
if (strcmp(id,"RMLP7U") == 0) return 56;//from isostar
|
if (strcmp(id,"RMLP7U") == 0) return 56;//from isostar
|
||||||
|
|
||||||
//Metroid Prime Trilogy
|
|
||||||
if (strcmp(id,"R3ME01") == 0) {
|
|
||||||
int choice = WindowPrompt(tr("Select a DOL"), 0, "Metroid Prime", "Metroid Prime 2", "Metroid Prime 3");
|
|
||||||
switch (choice) {
|
|
||||||
case 1:
|
|
||||||
choice = 780;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
choice = 781;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
choice = 782;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return choice;
|
|
||||||
}
|
|
||||||
if (strcmp(id,"R3MP01") == 0) {
|
|
||||||
int choice = WindowPrompt(tr("Select a DOL"), 0, "Metroid Prime", "Metroid Prime 2", "Metroid Prime 3");
|
|
||||||
switch (choice) {
|
|
||||||
case 1:
|
|
||||||
choice = 782;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
choice = 783;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
choice = 784;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return choice;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Mortal Kombat
|
//Mortal Kombat
|
||||||
if (strcmp(id,"RKMP5D") == 0) return 290;//from isostar
|
if (strcmp(id,"RKMP5D") == 0) return 290;//from isostar
|
||||||
if (strcmp(id,"RKME5D") == 0) return 290;//starstremr
|
if (strcmp(id,"RKME5D") == 0) return 290;//starstremr
|
||||||
@ -342,3 +309,41 @@ int autoSelectDol(const char *id) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int autoSelectDolMenu(const char *id) {
|
||||||
|
|
||||||
|
//Metroid Prime Trilogy
|
||||||
|
if (strcmp(id,"R3ME01") == 0) {
|
||||||
|
int choice = WindowPrompt(tr("Select a DOL"), 0, "Metroid Prime", "Metroid Prime 2", "Metroid Prime 3", tr("Cancel"));
|
||||||
|
switch (choice) {
|
||||||
|
case 1:
|
||||||
|
choice = 780;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
choice = 781;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
choice = 782;
|
||||||
|
default: // 0
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return choice;
|
||||||
|
}
|
||||||
|
if (strcmp(id,"R3MP01") == 0) {
|
||||||
|
int choice = WindowPrompt(tr("Select a DOL"), 0, "Metroid Prime", "Metroid Prime 2", "Metroid Prime 3", tr("Cancel"));
|
||||||
|
switch (choice) {
|
||||||
|
case 1:
|
||||||
|
choice = 782;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
choice = 783;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
choice = 784;
|
||||||
|
default: // 0
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return choice;
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
@ -10,5 +10,6 @@
|
|||||||
|
|
||||||
int DiscBrowse(struct discHdr * header);
|
int DiscBrowse(struct discHdr * header);
|
||||||
int autoSelectDol(const char *id);
|
int autoSelectDol(const char *id);
|
||||||
|
int autoSelectDolMenu(const char *id);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1957,7 +1957,7 @@ int GameSettings(struct discHdr * header) {
|
|||||||
alternatedol = game_cfg->loadalternatedol;
|
alternatedol = game_cfg->loadalternatedol;
|
||||||
alternatedoloffset = game_cfg->alternatedolstart;
|
alternatedoloffset = game_cfg->alternatedolstart;
|
||||||
reloadblock = game_cfg->iosreloadblock;
|
reloadblock = game_cfg->iosreloadblock;
|
||||||
strncpy(alternatedname, game_cfg->alternatedolname, sizeof(alternatedname));
|
strlcpy(alternatedname, game_cfg->alternatedolname, sizeof(alternatedname));
|
||||||
} else {
|
} else {
|
||||||
videoChoice = Settings.video;
|
videoChoice = Settings.video;
|
||||||
languageChoice = Settings.language;
|
languageChoice = Settings.language;
|
||||||
@ -1974,11 +1974,9 @@ int GameSettings(struct discHdr * header) {
|
|||||||
alternatedol = off;
|
alternatedol = off;
|
||||||
alternatedoloffset = 0;
|
alternatedoloffset = 0;
|
||||||
reloadblock = off;
|
reloadblock = off;
|
||||||
sprintf(alternatedname, " ");
|
strcpy(alternatedname, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ResumeGui();
|
ResumeGui();
|
||||||
|
|
||||||
while (MainButton1.GetEffect() > 0) usleep(50);
|
while (MainButton1.GetEffect() > 0) usleep(50);
|
||||||
@ -2187,16 +2185,21 @@ int GameSettings(struct discHdr * header) {
|
|||||||
snprintf(filename,sizeof(filename),"%c%c%c%c%c%c",header->id[0], header->id[1], header->id[2],
|
snprintf(filename,sizeof(filename),"%c%c%c%c%c%c",header->id[0], header->id[1], header->id[2],
|
||||||
header->id[3],header->id[4], header->id[5]);
|
header->id[3],header->id[4], header->id[5]);
|
||||||
int dolchoice = 0;
|
int dolchoice = 0;
|
||||||
|
//alt dol menu for games that require more than a single alt dol
|
||||||
|
int autodol = autoSelectDolMenu(filename);
|
||||||
|
if (autodol>0) {
|
||||||
|
alternatedoloffset = autodol;
|
||||||
|
snprintf(alternatedname, sizeof(alternatedname), "%s <%i>", tr("AUTO"),autodol);
|
||||||
|
} else if (autodol!=0) {
|
||||||
//check to see if we already know the offset of the correct dol
|
//check to see if we already know the offset of the correct dol
|
||||||
int autodol = autoSelectDol(filename);
|
int autodol = autoSelectDol(filename);
|
||||||
|
|
||||||
//if we do know that offset ask if they want to use it
|
//if we do know that offset ask if they want to use it
|
||||||
if (autodol>0) {
|
if (autodol>0) {
|
||||||
dolchoice = WindowPrompt(0,tr("Do you want to use the alt dol that is known to be correct?"),tr("Yes"),tr("Pick from a list"));
|
dolchoice = WindowPrompt(0,tr("Do you want to use the alt dol that is known to be correct?"),tr("Yes"),tr("Pick from a list"));
|
||||||
if (dolchoice==1) {
|
if (dolchoice==1) {
|
||||||
alternatedoloffset = autodol;
|
alternatedoloffset = autodol;
|
||||||
snprintf(alternatedname, sizeof(alternatedname), "%s <%i>", tr("AUTO"),autodol);
|
snprintf(alternatedname, sizeof(alternatedname), "%s <%i>", tr("AUTO"),autodol);
|
||||||
} else {//they want to search for the correct dol themselves
|
} else if (dolchoice!=0){//they want to search for the correct dol themselves
|
||||||
int res = DiscBrowse(header);
|
int res = DiscBrowse(header);
|
||||||
if ((res >= 0)&&(res !=696969)) {//if res==696969 they pressed the back button
|
if ((res >= 0)&&(res !=696969)) {//if res==696969 they pressed the back button
|
||||||
alternatedoloffset = res;
|
alternatedoloffset = res;
|
||||||
@ -2206,13 +2209,13 @@ int GameSettings(struct discHdr * header) {
|
|||||||
int res = DiscBrowse(header);
|
int res = DiscBrowse(header);
|
||||||
if ((res >= 0)&&(res !=696969)){
|
if ((res >= 0)&&(res !=696969)){
|
||||||
alternatedoloffset = res;
|
alternatedoloffset = res;
|
||||||
|
|
||||||
char tmp[170];
|
char tmp[170];
|
||||||
snprintf(tmp,sizeof(tmp),"%s %s - %i",tr("It seems that you have some information that will be helpful to us. Please pass this information along to the DEV team.") ,filename,alternatedoloffset);
|
snprintf(tmp,sizeof(tmp),"%s %s - %i",tr("It seems that you have some information that will be helpful to us. Please pass this information along to the DEV team.") ,filename,alternatedoloffset);
|
||||||
WindowPrompt(0,tmp,tr("Ok"));
|
WindowPrompt(0,tmp,tr("Ok"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case 10:
|
case 10:
|
||||||
reloadblock = (reloadblock+1) % 2;
|
reloadblock = (reloadblock+1) % 2;
|
||||||
@ -2281,6 +2284,7 @@ int GameSettings(struct discHdr * header) {
|
|||||||
options2.SetName(2,"%s", tr("Delete Boxart"));
|
options2.SetName(2,"%s", tr("Delete Boxart"));
|
||||||
options2.SetName(3,"%s", tr("Delete Discart"));
|
options2.SetName(3,"%s", tr("Delete Discart"));
|
||||||
options2.SetName(4,"%s", tr("Delete CheatTxt"));
|
options2.SetName(4,"%s", tr("Delete CheatTxt"));
|
||||||
|
options2.SetName(5,"%s", tr("Delete Cheat GCT"));
|
||||||
for (int i = 0; i <= MAXOPTIONS-1; i++) options2.SetValue(i, NULL);
|
for (int i = 0; i <= MAXOPTIONS-1; i++) options2.SetValue(i, NULL);
|
||||||
w.Append(&optionBrowser2);
|
w.Append(&optionBrowser2);
|
||||||
optionBrowser2.SetClickable(true);
|
optionBrowser2.SetClickable(true);
|
||||||
@ -2399,7 +2403,16 @@ int GameSettings(struct discHdr * header) {
|
|||||||
remove(tmp);
|
remove(tmp);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 5:
|
||||||
|
|
||||||
|
snprintf(tmp,sizeof(tmp),"%s%c%c%c%c%c%c.gct", Settings.Cheatcodespath, header->id[0], header->id[1], header->id[2],header->id[3], header->id[4], header->id[5]);
|
||||||
|
|
||||||
|
choice1 = WindowPrompt(tr("Delete"),tmp,tr("Yes"),tr("No"));
|
||||||
|
if (choice1==1) {
|
||||||
|
if (checkfile(tmp))
|
||||||
|
remove(tmp);
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
optionBrowser2.SetEffect(EFFECT_FADE, -20);
|
optionBrowser2.SetEffect(EFFECT_FADE, -20);
|
||||||
@ -2428,7 +2441,7 @@ int GameSettings(struct discHdr * header) {
|
|||||||
iosChoice = i249;
|
iosChoice = i249;
|
||||||
}
|
}
|
||||||
parentalcontrolChoice = 0;
|
parentalcontrolChoice = 0;
|
||||||
sprintf(alternatedname, " ");
|
strcpy(alternatedname, "");
|
||||||
CFG_forget_game_opt(header->id);
|
CFG_forget_game_opt(header->id);
|
||||||
/* commented because the database language now depends on the main language setting, this could be enabled again if there is a separate language setting for the database
|
/* commented because the database language now depends on the main language setting, this could be enabled again if there is a separate language setting for the database
|
||||||
// if default language is different than language from main settings, reload titles
|
// if default language is different than language from main settings, reload titles
|
||||||
|
@ -1016,7 +1016,7 @@ bool trimsplit(char *line, char *part1, char *part2, char delim, int size) {
|
|||||||
}
|
}
|
||||||
void cfg_parseline(char *line, void (*set_func)(char*, char*)) {
|
void cfg_parseline(char *line, void (*set_func)(char*, char*)) {
|
||||||
// split name = value
|
// split name = value
|
||||||
char tmp[200], name[200], val[200];
|
char tmp[300], name[200], val[200];
|
||||||
strcopy(tmp, line, sizeof(tmp));
|
strcopy(tmp, line, sizeof(tmp));
|
||||||
char *eq = strchr(tmp, '=');
|
char *eq = strchr(tmp, '=');
|
||||||
if (!eq) return;
|
if (!eq) return;
|
||||||
@ -1054,7 +1054,7 @@ void cfg_parsetitleline(char *line, void (*set_func)(char*, char*, u8)) {
|
|||||||
|
|
||||||
bool cfg_parsefile(char *fname, void (*set_func)(char*, char*)) {
|
bool cfg_parsefile(char *fname, void (*set_func)(char*, char*)) {
|
||||||
FILE *f;
|
FILE *f;
|
||||||
char line[200];
|
char line[300];
|
||||||
|
|
||||||
//printf("opening(%s)\n", fname);
|
//printf("opening(%s)\n", fname);
|
||||||
f = fopen(fname, "r");
|
f = fopen(fname, "r");
|
||||||
@ -1137,8 +1137,12 @@ void cfg_set_game_opt(struct Game_CFG *game, u8 *id) {
|
|||||||
game->iosreloadblock = reloadblock;
|
game->iosreloadblock = reloadblock;
|
||||||
game->patchcountrystrings = countrystrings;
|
game->patchcountrystrings = countrystrings;
|
||||||
game->loadalternatedol = alternatedol;
|
game->loadalternatedol = alternatedol;
|
||||||
|
if (game->loadalternatedol == 0) {
|
||||||
|
alternatedoloffset = 0;
|
||||||
|
strcpy(alternatedname, "");
|
||||||
|
}
|
||||||
game->alternatedolstart = alternatedoloffset;
|
game->alternatedolstart = alternatedoloffset;
|
||||||
strcpy(game->alternatedolname, alternatedname);
|
strlcpy(game->alternatedolname, alternatedname,sizeof(game->alternatedolname));
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Game_NUM* cfg_get_game_num(u8 *id) {
|
struct Game_NUM* cfg_get_game_num(u8 *id) {
|
||||||
@ -1254,7 +1258,7 @@ void game_set(char *name, char *val) {
|
|||||||
|
|
||||||
// parse val
|
// parse val
|
||||||
// first split options by ;
|
// first split options by ;
|
||||||
char opt[200], *p, *np;
|
char opt[300], *p, *np;
|
||||||
p = val;
|
p = val;
|
||||||
|
|
||||||
while (p) {
|
while (p) {
|
||||||
@ -1321,18 +1325,7 @@ void game_set(char *name, char *val) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (strcmp("alternatedolname", opt_name) == 0) {
|
if (strcmp("alternatedolname", opt_name) == 0) {
|
||||||
char temp3[40];
|
strlcpy(game->alternatedolname, opt_val, sizeof(game->alternatedolname));
|
||||||
int i = 0;
|
|
||||||
while (i < 40) {
|
|
||||||
|
|
||||||
if (opt_val[i] == ';')
|
|
||||||
break;
|
|
||||||
|
|
||||||
temp3[i] = opt_val[i];
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
temp3[i] = '\0';
|
|
||||||
strncpy(game->alternatedolname, temp3, 39);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// next opt
|
// next opt
|
||||||
|
Loading…
Reference in New Issue
Block a user