mirror of
https://github.com/dborth/fceugx.git
synced 2025-01-24 14:31:10 +01:00
finalize 3.2.2
This commit is contained in:
parent
8caf7fd972
commit
a6017afa64
@ -2,8 +2,9 @@
|
|||||||
<app version="1">
|
<app version="1">
|
||||||
<name>FCE Ultra GX</name>
|
<name>FCE Ultra GX</name>
|
||||||
<coder>Tantric</coder>
|
<coder>Tantric</coder>
|
||||||
<version>3.2.1</version>
|
<version>3.2.2</version>
|
||||||
<release_date>20100722</release_date>
|
<release_date>20100814</release_date>
|
||||||
<short_description>Nintendo Emulator</short_description>
|
<short_description>Nintendo Emulator</short_description>
|
||||||
<long_description>A port of FCE Ultra to the Wii.</long_description>
|
<long_description>A port of FCE Ultra to the Wii.</long_description>
|
||||||
|
<no_ios_reload/>
|
||||||
</app>
|
</app>
|
||||||
|
@ -32,6 +32,12 @@ Wii/GameCube.
|
|||||||
|0O×øo· UPDATE HISTORY ·oø×O0|
|
|0O×øo· UPDATE HISTORY ·oø×O0|
|
||||||
`¨•¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨'
|
`¨•¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨ ¨¨¨¨¨¨¨¨¨¨¨¨¨'
|
||||||
|
|
||||||
|
[3.2.2 - August 14, 2010]
|
||||||
|
|
||||||
|
* IOS 202 support removed
|
||||||
|
* USB 2.0 support via IOS 58 added - requires that IOS58 be pre-installed
|
||||||
|
* DVD support via AHBPROT - requires latest HBC
|
||||||
|
|
||||||
[3.2.1 - July 22, 2010]
|
[3.2.1 - July 22, 2010]
|
||||||
|
|
||||||
* Fixed broken auto-update
|
* Fixed broken auto-update
|
||||||
|
@ -191,51 +191,12 @@ static void ipl_set_config(unsigned char c)
|
|||||||
* IOS Check
|
* IOS Check
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#ifdef HW_RVL
|
#ifdef HW_RVL
|
||||||
static bool FindIOS(u32 ios)
|
|
||||||
{
|
|
||||||
s32 ret;
|
|
||||||
u32 n;
|
|
||||||
|
|
||||||
u64 *titles = NULL;
|
|
||||||
u32 num_titles=0;
|
|
||||||
|
|
||||||
ret = ES_GetNumTitles(&num_titles);
|
|
||||||
if (ret < 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if(num_titles < 1)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
titles = (u64 *)memalign(32, num_titles * sizeof(u64) + 32);
|
|
||||||
if (!titles)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
ret = ES_GetTitles(titles, num_titles);
|
|
||||||
if (ret < 0)
|
|
||||||
{
|
|
||||||
free(titles);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(n=0; n < num_titles; n++)
|
|
||||||
{
|
|
||||||
if((titles[n] & 0xFFFFFFFF)==ios)
|
|
||||||
{
|
|
||||||
free(titles);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
free(titles);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool SaneIOS()
|
bool SaneIOS()
|
||||||
{
|
{
|
||||||
bool res = false;
|
bool res = false;
|
||||||
u32 num_titles=0;
|
u32 num_titles=0;
|
||||||
u32 tmd_size;
|
u32 tmd_size;
|
||||||
u32 ios = IOS_GetVersion();
|
u32 ios = IOS_GetVersion();
|
||||||
u32 tmdbuffer[MAX_SIGNED_TMD_SIZE] ATTRIBUTE_ALIGN(32);
|
|
||||||
|
|
||||||
if(ios > 200)
|
if(ios > 200)
|
||||||
return false;
|
return false;
|
||||||
@ -247,12 +208,23 @@ bool SaneIOS()
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
u64 *titles = (u64 *)memalign(32, num_titles * sizeof(u64) + 32);
|
u64 *titles = (u64 *)memalign(32, num_titles * sizeof(u64) + 32);
|
||||||
|
|
||||||
|
if(!titles)
|
||||||
|
return false;
|
||||||
|
|
||||||
if (ES_GetTitles(titles, num_titles) < 0)
|
if (ES_GetTitles(titles, num_titles) < 0)
|
||||||
{
|
{
|
||||||
free(titles);
|
free(titles);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u32 *tmdbuffer = (u32 *)memalign(32, MAX_SIGNED_TMD_SIZE);
|
||||||
|
|
||||||
|
if(!tmdbuffer)
|
||||||
|
{
|
||||||
|
free(titles);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
for(u32 n=0; n < num_titles; n++)
|
for(u32 n=0; n < num_titles; n++)
|
||||||
{
|
{
|
||||||
@ -274,6 +246,7 @@ bool SaneIOS()
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
free(tmdbuffer);
|
||||||
free(titles);
|
free(titles);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
@ -349,14 +322,11 @@ int main(int argc, char *argv[])
|
|||||||
#ifdef HW_RVL
|
#ifdef HW_RVL
|
||||||
// only reload IOS if AHBPROT is not enabled
|
// only reload IOS if AHBPROT is not enabled
|
||||||
u32 version = IOS_GetVersion();
|
u32 version = IOS_GetVersion();
|
||||||
|
s32 preferred = IOS_GetPreferredVersion();
|
||||||
if(version != 58 && __di_check_ahbprot() != 1)
|
|
||||||
{
|
if(version != 58 && preferred > 0 && version != (u32)preferred && __di_check_ahbprot() != 1)
|
||||||
if(FindIOS(58))
|
IOS_ReloadIOS(preferred);
|
||||||
IOS_ReloadIOS(58);
|
|
||||||
else if((version < 61 || version >= 200) && FindIOS(61))
|
|
||||||
IOS_ReloadIOS(61);
|
|
||||||
}
|
|
||||||
DI_Init();
|
DI_Init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
#include "fceultra/driver.h"
|
#include "fceultra/driver.h"
|
||||||
|
|
||||||
#define APPNAME "FCE Ultra GX"
|
#define APPNAME "FCE Ultra GX"
|
||||||
#define APPVERSION "3.2.1"
|
#define APPVERSION "3.2.2"
|
||||||
#define APPFOLDER "fceugx"
|
#define APPFOLDER "fceugx"
|
||||||
#define PREF_FILE_NAME "settings.xml"
|
#define PREF_FILE_NAME "settings.xml"
|
||||||
|
|
||||||
|
@ -471,13 +471,21 @@ SavePrefs (bool silent)
|
|||||||
|
|
||||||
sprintf(filepath, "%s%s", pathPrefix[device], APPFOLDER);
|
sprintf(filepath, "%s%s", pathPrefix[device], APPFOLDER);
|
||||||
|
|
||||||
if (!diropen(filepath))
|
DIR_ITER *dir = diropen(filepath);
|
||||||
|
if (!dir)
|
||||||
{
|
{
|
||||||
mkdir(filepath, 0777);
|
if(mkdir(filepath, 0777) != 0)
|
||||||
|
return false;
|
||||||
sprintf(filepath, "%s%s/roms", pathPrefix[device], APPFOLDER);
|
sprintf(filepath, "%s%s/roms", pathPrefix[device], APPFOLDER);
|
||||||
mkdir(filepath, 0777);
|
if(mkdir(filepath, 0777) != 0)
|
||||||
|
return false;
|
||||||
sprintf(filepath, "%s%s/saves", pathPrefix[device], APPFOLDER);
|
sprintf(filepath, "%s%s/saves", pathPrefix[device], APPFOLDER);
|
||||||
mkdir(filepath, 0777);
|
if(mkdir(filepath, 0777) != 0)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dirclose(dir);
|
||||||
}
|
}
|
||||||
sprintf(filepath, "%s%s/%s", pathPrefix[device], APPFOLDER, PREF_FILE_NAME);
|
sprintf(filepath, "%s%s/%s", pathPrefix[device], APPFOLDER, PREF_FILE_NAME);
|
||||||
sprintf(prefpath, "%s%s", pathPrefix[device], APPFOLDER);
|
sprintf(prefpath, "%s%s", pathPrefix[device], APPFOLDER);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
||||||
<app version="3.2.1">
|
<app version="3.2.2">
|
||||||
<file url="http://fceugc.googlecode.com/files/FCE%20Ultra%20GX%203.2.1.zip"></file>
|
<file url="http://fceugc.googlecode.com/files/FCE%20Ultra%20GX%203.2.2.zip"></file>
|
||||||
</app>
|
</app>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user