mirror of
https://github.com/Fledge68/WiiFlow_Lite.git
synced 2025-01-12 11:59:08 +01:00
Build for main svn r428
* Added nanddumper functions (Nand dumper not enabled yet) * Added an extended check for new installed games which is enabled by default Since the check takes some time you can bypass the check by setting: 'extended_list_check' in GENERAL section of wiiflow.ini to 'no' Todo: Add an extended check for removed games * Fixed a bug ISFS_Initialize() was called before reloading to cIOS * Fixed long wait time when installing a Wii game @ 100%
This commit is contained in:
parent
9607e68ef2
commit
3153ef3d2e
@ -1,6 +1,6 @@
|
|||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* Copyright (C) 2011 by Miigotu for wiiflow 2011
|
* Copyright (C) 2011 by Miigotu
|
||||||
* (C) 2012 by OverjoY for Wiiflow-mod
|
* (C) 2012 by OverjoY
|
||||||
*
|
*
|
||||||
* Rewritten code from Mighty Channels and Triiforce
|
* Rewritten code from Mighty Channels and Triiforce
|
||||||
*
|
*
|
||||||
@ -23,7 +23,7 @@
|
|||||||
* 3. This notice may not be removed or altered from any source
|
* 3. This notice may not be removed or altered from any source
|
||||||
* distribution.
|
* distribution.
|
||||||
*
|
*
|
||||||
* Nand/Emulation Handling Class
|
* Nand/Emulation Handling Class for Wiiflow
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
@ -39,7 +39,7 @@
|
|||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "gecko.h"
|
#include "gecko.h"
|
||||||
#include "mem2.hpp"
|
#include "mem2.hpp"
|
||||||
#include "smartptr.hpp"
|
#include "text.hpp"
|
||||||
|
|
||||||
u8 *confbuffer ATTRIBUTE_ALIGN(32);
|
u8 *confbuffer ATTRIBUTE_ALIGN(32);
|
||||||
u8 CCode[0x1008];
|
u8 CCode[0x1008];
|
||||||
@ -51,7 +51,8 @@ config_header *cfg_hdr;
|
|||||||
bool tbdec = false;
|
bool tbdec = false;
|
||||||
bool configloaded = false;
|
bool configloaded = false;
|
||||||
|
|
||||||
static NandDevice NandDeviceList[] = {
|
static NandDevice NandDeviceList[] =
|
||||||
|
{
|
||||||
{ "Disable", 0, 0x00, 0x00 },
|
{ "Disable", 0, 0x00, 0x00 },
|
||||||
{ "SD/SDHC Card", 1, 0xF0, 0xF1 },
|
{ "SD/SDHC Card", 1, 0xF0, 0xF1 },
|
||||||
{ "USB 2.0 Mass Storage Device", 2, 0xF2, 0xF3 },
|
{ "USB 2.0 Mass Storage Device", 2, 0xF2, 0xF3 },
|
||||||
@ -228,6 +229,45 @@ void Nand::__configshifttxt(char *str)
|
|||||||
*ctr = '\0';
|
*ctr = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Nand::__GetNameList(const char *source, namelist **entries, int *count)
|
||||||
|
{
|
||||||
|
u32 i, j, k, l;
|
||||||
|
u32 numentries = 0;
|
||||||
|
char *names;
|
||||||
|
char curentry[ISFS_MAXPATH];
|
||||||
|
char entrypath[ISFS_MAXPATH];
|
||||||
|
|
||||||
|
s32 ret = ISFS_ReadDir(source, NULL, &numentries);
|
||||||
|
names = (char *)MEM2_alloc((ISFS_MAXPATH) * numentries);
|
||||||
|
ret = ISFS_ReadDir(source, names, &numentries);
|
||||||
|
*count = numentries;
|
||||||
|
|
||||||
|
if(*entries)
|
||||||
|
MEM2_free(*entries);
|
||||||
|
|
||||||
|
*entries = (namelist *)MEM2_alloc(sizeof(namelist)*numentries);
|
||||||
|
|
||||||
|
for(i = 0, k = 0; i < numentries; i++)
|
||||||
|
{
|
||||||
|
for(j = 0; names[k] != 0; j++, k++)
|
||||||
|
curentry[j] = names[k];
|
||||||
|
|
||||||
|
curentry[j] = 0;
|
||||||
|
k++;
|
||||||
|
|
||||||
|
strcpy((*entries)[i].name, curentry);
|
||||||
|
|
||||||
|
if(source[strlen(source)-1] == '/')
|
||||||
|
snprintf(entrypath, sizeof(entrypath), "%s%s", source, curentry);
|
||||||
|
else
|
||||||
|
snprintf(entrypath, sizeof(entrypath), "%s/%s", source, curentry);
|
||||||
|
|
||||||
|
ret = ISFS_ReadDir(entrypath, NULL, &l);
|
||||||
|
(*entries)[i].type = ret < 0 ? 0 : 1;
|
||||||
|
}
|
||||||
|
MEM2_free(names);
|
||||||
|
}
|
||||||
|
|
||||||
s32 Nand::__configread(void)
|
s32 Nand::__configread(void)
|
||||||
{
|
{
|
||||||
confbuffer = (u8 *)MEM2_alloc(0x4000);
|
confbuffer = (u8 *)MEM2_alloc(0x4000);
|
||||||
@ -360,6 +400,67 @@ u32 Nand::__configsetsetting(const char *item, const char *val)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Nand::__FileExists(const char *path, ...)
|
||||||
|
{
|
||||||
|
FILE *f = fopen(path, "rb");
|
||||||
|
if (f != 0)
|
||||||
|
{
|
||||||
|
gprintf("File \"%s\" exists\n", path);
|
||||||
|
SAFE_CLOSE(f);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 Nand::__TestNandPath(const char *path)
|
||||||
|
{
|
||||||
|
if(!strncmp(path, "/import", 7)) return 0;
|
||||||
|
if(!strncmp(path, "/meta", 5)) return 0;
|
||||||
|
if(!strncmp(path, "/shared", 7) && !n_dumpwsc && !n_dumpwvc) return 1;
|
||||||
|
if(!strncmp(path, "/sys", 4)) return 0;
|
||||||
|
|
||||||
|
if(!strncmp(path, "/ticket/00000001/", 17))
|
||||||
|
{
|
||||||
|
const char *tmp = path + 17;
|
||||||
|
if(!strncmp(tmp, "00000002.tik", 8) && !n_dumpmen) return 1; // Menu
|
||||||
|
if(strncmp(tmp, "00000002.tik", 8) && !n_dumpios) return 1; // IOSs
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if(!strncmp(path, "/ticket/00010001/", 17))
|
||||||
|
{
|
||||||
|
const char *tmp = path + 17;
|
||||||
|
if(!strncmp(tmp, "48XXXXXX.tik", 2) && n_dumpwsc) return 0; // SC
|
||||||
|
if(strncmp(tmp, "48XXXXXX.tik", 2) && n_dumpwvc) return 0; // WW&VC
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if(!strncmp(path, "/ticket/00010002/", 17) && !n_dumpwsc) return 1; // SC
|
||||||
|
if(!strncmp(path, "/ticket/00010005/", 17) && !n_dumpwgs) return 1; // DLC?
|
||||||
|
if(!strncmp(path, "/ticket/00010008/", 17) && !n_dumpwsc) return 1; // Hidden SC
|
||||||
|
|
||||||
|
if(!strncmp(path, "/title/00000001/", 16))
|
||||||
|
{
|
||||||
|
const char *tmp = path + 16;
|
||||||
|
if(!strncmp(tmp, "00000002", 8) && n_dumpmen) return 0; // Menu
|
||||||
|
if(strncmp(tmp, "00000002", 8) && n_dumpios) return 0; // IOSs
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if(!strncmp(path, "/title/00010000/", 16) && !n_dumpwgs) return 1; // Saves
|
||||||
|
if(!strncmp(path, "/title/00010001/", 16))
|
||||||
|
{
|
||||||
|
const char *tmp = path + 16;
|
||||||
|
if(!strncmp(tmp, "48XXXXXX", 2) && n_dumpwsc) return 0; // SC
|
||||||
|
if(strncmp(tmp, "48XXXXXX", 2) && n_dumpwvc) return 0; // WW&VC
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if(!strncmp(path, "/title/00010002/", 16) && !n_dumpwsc) return 1; // SC
|
||||||
|
if(!strncmp(path, "/title/00010004/", 16) && !n_dumpwgs) return 1; // Saves
|
||||||
|
if(!strncmp(path, "/title/00010005/", 16) && !n_dumpwgs) return 1; // DLC
|
||||||
|
if(!strncmp(path, "/title/00010008/", 16) && !n_dumpwsc) return 1; // Hidden SC
|
||||||
|
|
||||||
|
if(!strncmp(path, "/tmp", 4)) return 0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
s32 Nand::__FlashNandFile(const char *source, const char *dest)
|
s32 Nand::__FlashNandFile(const char *source, const char *dest)
|
||||||
{
|
{
|
||||||
s32 ret;
|
s32 ret;
|
||||||
@ -374,7 +475,7 @@ s32 Nand::__FlashNandFile(const char *source, const char *dest)
|
|||||||
u32 fsize = ftell(file);
|
u32 fsize = ftell(file);
|
||||||
fseek(file, 0, SEEK_SET);
|
fseek(file, 0, SEEK_SET);
|
||||||
|
|
||||||
gprintf("Flashing: %s (%uKB) to nand: %s...", source, (fsize / 0x400)+1, dest);
|
gprintf("Flashing: %s (%uKB) to nand...", source, (fsize / 0x400)+1);
|
||||||
|
|
||||||
ISFS_Delete(dest);
|
ISFS_Delete(dest);
|
||||||
ISFS_CreateFile(dest, 0, 3, 3, 3);
|
ISFS_CreateFile(dest, 0, 3, 3, 3);
|
||||||
@ -425,6 +526,9 @@ s32 Nand::__FlashNandFile(const char *source, const char *dest)
|
|||||||
|
|
||||||
s32 Nand::__DumpNandFile(const char *source, const char *dest)
|
s32 Nand::__DumpNandFile(const char *source, const char *dest)
|
||||||
{
|
{
|
||||||
|
if(__TestNandPath(source))
|
||||||
|
return 0;
|
||||||
|
|
||||||
s32 fd = ISFS_Open(source, ISFS_OPEN_READ);
|
s32 fd = ISFS_Open(source, ISFS_OPEN_READ);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
{
|
{
|
||||||
@ -432,6 +536,9 @@ s32 Nand::__DumpNandFile(const char *source, const char *dest)
|
|||||||
return fd;
|
return fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(__FileExists(dest))
|
||||||
|
remove(dest);
|
||||||
|
|
||||||
FILE *file = fopen(dest, "wb");
|
FILE *file = fopen(dest, "wb");
|
||||||
if (!file)
|
if (!file)
|
||||||
{
|
{
|
||||||
@ -451,7 +558,7 @@ s32 Nand::__DumpNandFile(const char *source, const char *dest)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
gprintf("Dumping: %s (%uKB) from nand to %s...", source, (status->file_length / 0x400)+1, dest);
|
gprintf("Dumping: %s (%uKB)...", source, (status->file_length / 0x400)+1);
|
||||||
|
|
||||||
u8 *buffer = (u8 *)MEM2_alloc(BLOCK);
|
u8 *buffer = (u8 *)MEM2_alloc(BLOCK);
|
||||||
u32 toread = status->file_length;
|
u32 toread = status->file_length;
|
||||||
@ -492,16 +599,57 @@ s32 Nand::__DumpNandFile(const char *source, const char *dest)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Nand::__CreatePath(const char *path, ...)
|
s32 Nand::__DumpNandFolder(const char *source, const char *dest)
|
||||||
|
{
|
||||||
|
namelist *names = NULL;
|
||||||
|
int cnt, i;
|
||||||
|
char nsource[ISFS_MAXPATH];
|
||||||
|
char ndest[MAX_FAT_PATH];
|
||||||
|
|
||||||
|
__GetNameList(source, &names, &cnt);
|
||||||
|
|
||||||
|
for(i = 0; i < cnt; i++)
|
||||||
|
{
|
||||||
|
if(source[strlen(source)-1] == '/')
|
||||||
|
snprintf(nsource, sizeof(nsource), "%s%s", source, names[i].name);
|
||||||
|
else
|
||||||
|
snprintf(nsource, sizeof(nsource), "%s/%s", source, names[i].name);
|
||||||
|
|
||||||
|
if(!names[i].type)
|
||||||
|
{
|
||||||
|
Asciify2(nsource);
|
||||||
|
snprintf(ndest, sizeof(ndest), "%s%s", dest, nsource);
|
||||||
|
__DumpNandFile(nsource, ndest);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(!__TestNandPath(nsource))
|
||||||
|
{
|
||||||
|
CreatePath("%s%s", dest, nsource);
|
||||||
|
__DumpNandFolder(nsource, dest);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SAFE_FREE(names);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Nand::CreatePath(const char *path, ...)
|
||||||
{
|
{
|
||||||
char *folder = NULL;
|
char *folder = NULL;
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, path);
|
va_start(args, path);
|
||||||
if((vasprintf(&folder, path, args) >= 0) && folder)
|
if((vasprintf(&folder, path, args) >= 0) && folder)
|
||||||
{
|
{
|
||||||
DIR *d;
|
if(folder[strlen(folder)-1] == '/')
|
||||||
|
folder[strlen(folder)-1] = 0;
|
||||||
|
|
||||||
|
Asciify2(folder);
|
||||||
|
|
||||||
|
DIR *d;
|
||||||
d = opendir(folder);
|
d = opendir(folder);
|
||||||
|
|
||||||
if(!d)
|
if(!d)
|
||||||
{
|
{
|
||||||
gprintf("Creating folder: \"%s\"\n", folder);
|
gprintf("Creating folder: \"%s\"\n", folder);
|
||||||
@ -517,18 +665,45 @@ void Nand::__CreatePath(const char *path, ...)
|
|||||||
SAFE_FREE(folder);
|
SAFE_FREE(folder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s32 Nand::DoNandDump(const char *source, const char *dest, bool dumpios, bool dumpwgs, bool dumpwsc, bool dumpwvc, bool dumpmen)
|
||||||
|
{
|
||||||
|
n_dumpios = dumpios;
|
||||||
|
n_dumpwgs = dumpwgs;
|
||||||
|
n_dumpwsc = dumpwsc;
|
||||||
|
n_dumpwvc = dumpwvc;
|
||||||
|
n_dumpmen = dumpmen;
|
||||||
|
|
||||||
|
u32 temp = 0;
|
||||||
|
|
||||||
|
s32 ret = ISFS_ReadDir(source, NULL, &temp);
|
||||||
|
if(ret < 0)
|
||||||
|
{
|
||||||
|
char ndest[MAX_FAT_PATH];
|
||||||
|
snprintf(ndest, sizeof(ndest), "%s%s", dest, source);
|
||||||
|
CreatePath(dest);
|
||||||
|
|
||||||
|
__DumpNandFile(source, ndest);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
__DumpNandFolder(source, dest);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
s32 Nand::CreateConfig(const char *path)
|
s32 Nand::CreateConfig(const char *path)
|
||||||
{
|
{
|
||||||
__CreatePath(path);
|
CreatePath(path);
|
||||||
__CreatePath("%s/shared2", path);
|
CreatePath("%s/shared2", path);
|
||||||
__CreatePath("%s/shared2/sys", path);
|
CreatePath("%s/shared2/sys", path);
|
||||||
__CreatePath("%s/title", path);
|
CreatePath("%s/title", path);
|
||||||
__CreatePath("%s/title/00000001", path);
|
CreatePath("%s/title/00000001", path);
|
||||||
__CreatePath("%s/title/00000001/00000002", path);
|
CreatePath("%s/title/00000001/00000002", path);
|
||||||
__CreatePath("%s/title/00000001/00000002/data", path);
|
CreatePath("%s/title/00000001/00000002/data", path);
|
||||||
|
|
||||||
bzero(cfgpath, MAX_FAT_PATH);
|
bzero(cfgpath, MAX_FAT_PATH+1);
|
||||||
bzero(settxtpath, MAX_FAT_PATH);
|
bzero(settxtpath, MAX_FAT_PATH+1);
|
||||||
|
|
||||||
snprintf(cfgpath, sizeof(cfgpath), "%s%s", path, SYSCONFPATH);
|
snprintf(cfgpath, sizeof(cfgpath), "%s%s", path, SYSCONFPATH);
|
||||||
snprintf(settxtpath, sizeof(settxtpath), "%s%s", path, TXTPATH);
|
snprintf(settxtpath, sizeof(settxtpath), "%s%s", path, TXTPATH);
|
||||||
@ -603,4 +778,3 @@ s32 Nand::Do_Region_Change(string id)
|
|||||||
__configwrite();
|
__configwrite();
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
@ -21,7 +21,7 @@
|
|||||||
#define SYSCONFPATH "/shared2/sys/SYSCONF"
|
#define SYSCONFPATH "/shared2/sys/SYSCONF"
|
||||||
#define TXTPATH "/title/00000001/00000002/data/setting.txt"
|
#define TXTPATH "/title/00000001/00000002/data/setting.txt"
|
||||||
|
|
||||||
#define BLOCK 0x4000
|
#define BLOCK 2048
|
||||||
|
|
||||||
/* 'NAND Device' structure */
|
/* 'NAND Device' structure */
|
||||||
typedef struct nandDevice
|
typedef struct nandDevice
|
||||||
@ -39,6 +39,12 @@ typedef struct _config_header
|
|||||||
u16 noff[];
|
u16 noff[];
|
||||||
} config_header;
|
} config_header;
|
||||||
|
|
||||||
|
typedef struct _namelist
|
||||||
|
{
|
||||||
|
char name[ISFS_MAXPATH];
|
||||||
|
int type;
|
||||||
|
} namelist;
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
class Nand
|
class Nand
|
||||||
@ -60,9 +66,11 @@ class Nand
|
|||||||
u32 Get_Partition(void) { return Partition; };
|
u32 Get_Partition(void) { return Partition; };
|
||||||
|
|
||||||
void Set_NandPath(string path);
|
void Set_NandPath(string path);
|
||||||
|
void CreatePath(const char *path, ...);
|
||||||
|
|
||||||
s32 CreateConfig(const char *path);
|
s32 CreateConfig(const char *path);
|
||||||
s32 Do_Region_Change(string id);
|
s32 Do_Region_Change(string id);
|
||||||
|
s32 DoNandDump(const char *source, const char *dest, bool dumpios, bool dumpwgs, bool dumpwsc, bool dumpwvc, bool dumpmen);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Nand() : MountedDevice(0), EmuDevice(REAL_NAND), Disabled(true), Partition(0), FullMode(0x100), NandPath() {}
|
Nand() : MountedDevice(0), EmuDevice(REAL_NAND), Disabled(true), Partition(0), FullMode(0x100), NandPath() {}
|
||||||
@ -75,19 +83,26 @@ class Nand
|
|||||||
s32 Nand_Disable(void);
|
s32 Nand_Disable(void);
|
||||||
void __Dec_Enc_TB(void);
|
void __Dec_Enc_TB(void);
|
||||||
void __configshifttxt(char *str);
|
void __configshifttxt(char *str);
|
||||||
|
void __GetNameList(const char *source, namelist **entries, int *count);
|
||||||
s32 __configread(void);
|
s32 __configread(void);
|
||||||
s32 __configwrite(void);
|
s32 __configwrite(void);
|
||||||
u32 __configsetbyte(const char *item, u8 val);
|
u32 __configsetbyte(const char *item, u8 val);
|
||||||
u32 __configsetbigarray(const char *item, void *val, u32 size);
|
u32 __configsetbigarray(const char *item, void *val, u32 size);
|
||||||
u32 __configsetsetting(const char *item, const char *val);
|
u32 __configsetsetting(const char *item, const char *val);
|
||||||
|
bool __FileExists(const char *path, ...);
|
||||||
|
u32 __TestNandPath(const char *path);
|
||||||
s32 __FlashNandFile(const char *source, const char *dest);
|
s32 __FlashNandFile(const char *source, const char *dest);
|
||||||
s32 __DumpNandFile(const char *source, const char *dest);
|
s32 __DumpNandFile(const char *source, const char *dest);
|
||||||
void __CreatePath(const char *path, ...);
|
s32 __DumpNandFolder(const char *source, const char *dest);
|
||||||
|
|
||||||
|
|
||||||
u32 MountedDevice;
|
u32 MountedDevice;
|
||||||
u32 EmuDevice;
|
u32 EmuDevice;
|
||||||
bool Disabled;
|
bool Disabled;
|
||||||
|
bool n_dumpios;
|
||||||
|
bool n_dumpwgs;
|
||||||
|
bool n_dumpwsc;
|
||||||
|
bool n_dumpwvc;
|
||||||
|
bool n_dumpmen;
|
||||||
|
|
||||||
u32 Partition ATTRIBUTE_ALIGN(32);
|
u32 Partition ATTRIBUTE_ALIGN(32);
|
||||||
u32 FullMode ATTRIBUTE_ALIGN(32);
|
u32 FullMode ATTRIBUTE_ALIGN(32);
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
#define APP_NAME "WiiFlow"
|
#define APP_NAME "WiiFlow"
|
||||||
#define APP_VERSION "Mod 3.0"
|
#define APP_VERSION "Mod 3.1"
|
||||||
|
|
||||||
#define APPDATA_DIR "wiiflow"
|
#define APPDATA_DIR "wiiflow"
|
||||||
#define APPDATA_DIR2 "apps/wiiflow"
|
#define APPDATA_DIR2 "apps/wiiflow"
|
||||||
|
|
||||||
|
#define STDEMU_DIR "/wiiflow/nandemu"
|
||||||
#define GAMES_DIR "%s:/wbfs"
|
#define GAMES_DIR "%s:/wbfs"
|
||||||
#define HOMEBREW_DIR "%s:/apps"
|
#define HOMEBREW_DIR "%s:/apps"
|
||||||
#define DML_DIR "%s:/games"
|
#define DML_DIR "%s:/games"
|
||||||
@ -13,8 +14,8 @@
|
|||||||
#define TITLES_FILENAME "titles.ini"
|
#define TITLES_FILENAME "titles.ini"
|
||||||
#define CTITLES_FILENAME "custom_titles.ini"
|
#define CTITLES_FILENAME "custom_titles.ini"
|
||||||
|
|
||||||
#define DEVELOPERS "r-win, Miigotu, OverjoY, FIX94"
|
#define DEVELOPERS "r-win, OverjoY, FIX94"
|
||||||
#define PAST_DEVELOPERS "Hibernatus, Narolez, Hulk"
|
#define PAST_DEVELOPERS "Hibernatus, Narolez, Hulk, Miigotu"
|
||||||
#define LOADER_AUTHOR "Kwiirk, Waninkoko, Hermes"
|
#define LOADER_AUTHOR "Kwiirk, Waninkoko, Hermes"
|
||||||
#define GUI_AUTHOR "Hibernatus"
|
#define GUI_AUTHOR "Hibernatus"
|
||||||
|
|
||||||
|
@ -497,7 +497,6 @@ u32 wbfs_add_disc(wbfs_t *p, read_wiidisc_callback_t read_src_wii_disc, void *ca
|
|||||||
}
|
}
|
||||||
if (ret) break;
|
if (ret) break;
|
||||||
info->wlba_table[i] = wbfs_htons(bl);
|
info->wlba_table[i] = wbfs_htons(bl);
|
||||||
wbfs_sync(p);
|
|
||||||
}
|
}
|
||||||
// write disc info
|
// write disc info
|
||||||
int disc_info_sz_lba = p->disc_info_sz>>p->hd_sec_sz_s;
|
int disc_info_sz_lba = p->disc_info_sz>>p->hd_sec_sz_s;
|
||||||
|
@ -493,7 +493,6 @@ void Asciify2( char *str )
|
|||||||
{
|
{
|
||||||
case '*':
|
case '*':
|
||||||
case '\"':
|
case '\"':
|
||||||
case ':':
|
|
||||||
case '|':
|
case '|':
|
||||||
case '<':
|
case '<':
|
||||||
case '>':
|
case '>':
|
||||||
|
@ -47,6 +47,24 @@ void CachedList<T>::Load(string path, string containing, string m_lastLanguage)
|
|||||||
if(update_lang) gprintf("languages are different!\nOld language string: %s\nNew language string: %s\n", m_lastLanguage.c_str(), m_curLanguage.c_str());
|
if(update_lang) gprintf("languages are different!\nOld language string: %s\nNew language string: %s\n", m_lastLanguage.c_str(), m_curLanguage.c_str());
|
||||||
if(noDB) gprintf("a database was not found!\n");
|
if(noDB) gprintf("a database was not found!\n");
|
||||||
if(mtimes || ditimes) gprintf("the WBFS folder was modified!\n");
|
if(mtimes || ditimes) gprintf("the WBFS folder was modified!\n");
|
||||||
|
|
||||||
|
if(m_extcheck && !m_update)
|
||||||
|
{
|
||||||
|
bool m_chupdate = false;
|
||||||
|
|
||||||
|
DIR *dir = opendir(path.c_str());
|
||||||
|
struct dirent *entry;
|
||||||
|
while((entry = readdir(dir)) != NULL)
|
||||||
|
{
|
||||||
|
m_discinf = sfmt("%s/%s", path.c_str(), entry->d_name);
|
||||||
|
if(stat(m_discinf.c_str(), &discinfo) != -1)
|
||||||
|
m_chupdate = discinfo.st_mtime > cache.st_mtime;
|
||||||
|
|
||||||
|
if(m_chupdate)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
m_update = m_chupdate;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(update_games) force_update[COVERFLOW_USB] = false;
|
if(update_games) force_update[COVERFLOW_USB] = false;
|
||||||
|
@ -20,7 +20,7 @@ template <typename T = dir_discHdr>
|
|||||||
class CachedList : public safe_vector<T>
|
class CachedList : public safe_vector<T>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
void Init(string cachedir, string settingsDir, string curLanguage, string DMLgameDir) /* Initialize Private Variables */
|
void Init(string cachedir, string settingsDir, string curLanguage, string DMLgameDir, bool extcheck) /* Initialize Private Variables */
|
||||||
{
|
{
|
||||||
m_cacheDir = cachedir;
|
m_cacheDir = cachedir;
|
||||||
m_settingsDir = settingsDir;
|
m_settingsDir = settingsDir;
|
||||||
@ -28,6 +28,7 @@ class CachedList : public safe_vector<T>
|
|||||||
m_loaded = false;
|
m_loaded = false;
|
||||||
m_database = "";
|
m_database = "";
|
||||||
m_update = false;
|
m_update = false;
|
||||||
|
m_extcheck = extcheck;
|
||||||
m_DMLgameDir = DMLgameDir;
|
m_DMLgameDir = DMLgameDir;
|
||||||
for(u32 i = 0; i < COVERFLOW_MAX; i++)
|
for(u32 i = 0; i < COVERFLOW_MAX; i++)
|
||||||
force_update[i] = false;
|
force_update[i] = false;
|
||||||
@ -67,6 +68,7 @@ class CachedList : public safe_vector<T>
|
|||||||
bool m_loaded;
|
bool m_loaded;
|
||||||
bool m_update;
|
bool m_update;
|
||||||
bool m_wbfsFS;
|
bool m_wbfsFS;
|
||||||
|
bool m_extcheck;
|
||||||
u8 force_update[COVERFLOW_MAX];
|
u8 force_update[COVERFLOW_MAX];
|
||||||
CList<T> list;
|
CList<T> list;
|
||||||
string m_database;
|
string m_database;
|
||||||
|
@ -54,12 +54,12 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
gprintf("Loading cIOS: %d\n", mainIOS);
|
gprintf("Loading cIOS: %d\n", mainIOS);
|
||||||
|
|
||||||
ISFS_Initialize();
|
|
||||||
|
|
||||||
// Load Custom IOS
|
// Load Custom IOS
|
||||||
bool iosOK = loadIOS(mainIOS, false);
|
bool iosOK = loadIOS(mainIOS, false);
|
||||||
MEM2_init(52);
|
MEM2_init(52);
|
||||||
|
|
||||||
|
ISFS_Initialize();
|
||||||
|
|
||||||
u8 mainIOSBase = 0;
|
u8 mainIOSBase = 0;
|
||||||
iosOK = iosOK && cIOSInfo::D2X(mainIOS, &mainIOSBase);
|
iosOK = iosOK && cIOSInfo::D2X(mainIOS, &mainIOSBase);
|
||||||
gprintf("Loaded cIOS: %u has base %u\n", mainIOS, mainIOSBase);
|
gprintf("Loaded cIOS: %u has base %u\n", mainIOS, mainIOSBase);
|
||||||
|
@ -375,7 +375,9 @@ void CMenu::init(void)
|
|||||||
m_loc.load(sfmt("%s/%s.ini", m_languagesDir.c_str(), m_curLanguage.c_str()).c_str());
|
m_loc.load(sfmt("%s/%s.ini", m_languagesDir.c_str(), m_curLanguage.c_str()).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
m_gameList.Init(m_listCacheDir, m_settingsDir, m_loc.getString(m_curLanguage, "gametdb_code", "EN"), m_DMLgameDir);
|
bool extcheck = m_cfg.getBool("GENERAL", "extended_list_check", true);
|
||||||
|
|
||||||
|
m_gameList.Init(m_listCacheDir, m_settingsDir, m_loc.getString(m_curLanguage, "gametdb_code", "EN"), m_DMLgameDir, extcheck);
|
||||||
|
|
||||||
m_aa = 3;
|
m_aa = 3;
|
||||||
|
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
|
|
||||||
|
//#define ENABLEDUMPER
|
||||||
|
|
||||||
#include "menu.hpp"
|
#include "menu.hpp"
|
||||||
#include "loader/patchcode.h"
|
#include "loader/patchcode.h"
|
||||||
|
|
||||||
@ -1020,13 +1022,52 @@ void CMenu::_launchGame(dir_discHdr *hdr, bool dvd)
|
|||||||
else if (emuSave == 1)
|
else if (emuSave == 1)
|
||||||
emuSave = 0;
|
emuSave = 0;
|
||||||
|
|
||||||
if (!dvd && get_frag_list((u8 *) hdr->hdr.id, (char *) hdr->path, currentPartition == 0 ? 0x200 : sector_size) < 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if(!dvd && emuSave)
|
if(!dvd && emuSave)
|
||||||
{
|
{
|
||||||
|
bool createnand = false;
|
||||||
char basepath[64];
|
char basepath[64];
|
||||||
|
if(emuPath.size() == 0)
|
||||||
|
{
|
||||||
|
Nand::Instance()->CreatePath("%s:/wiiflow", DeviceName[emuPartition]);
|
||||||
|
Nand::Instance()->CreatePath("%s:/wiiflow/nandemu", DeviceName[emuPartition]);
|
||||||
|
m_cfg.setString("GAMES", "savepath", STDEMU_DIR);
|
||||||
|
emuPath = m_cfg.getString("GAMES", "savepath", STDEMU_DIR);
|
||||||
snprintf(basepath, 64, "%s:%s", DeviceName[emuPartition], emuPath.c_str());
|
snprintf(basepath, 64, "%s:%s", DeviceName[emuPartition], emuPath.c_str());
|
||||||
|
if(emuSave == 4)
|
||||||
|
createnand = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
snprintf(basepath, 64, "%s:%s", DeviceName[emuPartition], emuPath.c_str());
|
||||||
|
if(emuSave == 4)
|
||||||
|
{
|
||||||
|
DIR *d;
|
||||||
|
d = opendir(basepath);
|
||||||
|
if(!d)
|
||||||
|
{
|
||||||
|
Nand::Instance()->CreatePath("%s:/wiiflow", DeviceName[emuPartition]);
|
||||||
|
Nand::Instance()->CreatePath("%s:/wiiflow/nandemu", DeviceName[emuPartition]);
|
||||||
|
createnand = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
closedir(d);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(createnand)
|
||||||
|
{
|
||||||
|
#ifdef ENABLEDUMPER
|
||||||
|
bool dumpios = m_cfg.getBool("NAND", "nanddumpios", false);
|
||||||
|
bool dumpgs = m_cfg.getBool("NAND", "nanddumpgamesaves", false);
|
||||||
|
bool dumpsc = m_cfg.getBool("NAND", "nanddumpsyschannels", false);
|
||||||
|
bool dumpwvc = m_cfg.getBool("NAND", "nanddumpwwchannels", true);
|
||||||
|
bool dumpmen = m_cfg.getBool("NAND", "nanddumpsysmenu", false);
|
||||||
|
Nand::Instance()->DoNandDump("/", basepath, dumpios, dumpgs, dumpsc, dumpwvc, dumpmen);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
if(emuSave == 2 || emuSave > 3)
|
if(emuSave == 2 || emuSave > 3)
|
||||||
{
|
{
|
||||||
CreateSavePath(basepath, hdr);
|
CreateSavePath(basepath, hdr);
|
||||||
@ -1038,6 +1079,9 @@ void CMenu::_launchGame(dir_discHdr *hdr, bool dvd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!dvd && get_frag_list((u8 *) hdr->hdr.id, (char *) hdr->path, currentPartition == 0 ? 0x200 : sector_size) < 0)
|
||||||
|
return;
|
||||||
|
|
||||||
int gameIOS = 0;
|
int gameIOS = 0;
|
||||||
int userIOS = 0;
|
int userIOS = 0;
|
||||||
if (m_gcfg2.getInt(id, "ios", &userIOS) && _installed_cios.size() > 0)
|
if (m_gcfg2.getInt(id, "ios", &userIOS) && _installed_cios.size() > 0)
|
||||||
|
@ -31,7 +31,7 @@ void MusicPlayer::Init(Config &cfg, string musicDir, string themeMusicDir)
|
|||||||
SetVolume(0); // Fades in with tick()
|
SetVolume(0); // Fades in with tick()
|
||||||
|
|
||||||
MusicDirectory dir = (MusicDirectory) cfg.getInt("GENERAL", "music_directories", NORMAL_MUSIC | THEME_MUSIC);
|
MusicDirectory dir = (MusicDirectory) cfg.getInt("GENERAL", "music_directories", NORMAL_MUSIC | THEME_MUSIC);
|
||||||
m_music_files.Init(cfg.getString("GENERAL", "dir_list_cache"), std::string(), std::string(), std::string());
|
m_music_files.Init(cfg.getString("GENERAL", "dir_list_cache"), std::string(), std::string(), std::string(), false);
|
||||||
|
|
||||||
if (dir & THEME_MUSIC)
|
if (dir & THEME_MUSIC)
|
||||||
m_music_files.Load(themeMusicDir, ".ogg|.mp3", "EN"); //|.mod|.xm|.s3m|.wav|.aiff");
|
m_music_files.Load(themeMusicDir, ".ogg|.mp3", "EN"); //|.mod|.xm|.s3m|.wav|.aiff");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user