mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-12 03:09:06 +01:00
added USB storage support
This commit is contained in:
parent
3b6375670a
commit
6a9974c865
@ -163,7 +163,7 @@ int UnZipDVD (unsigned char *outbuffer, u64 discoffset, int length)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int UnZipSDCARD (unsigned char *outbuffer, char *filename)
|
int UnZipFAT (unsigned char *outbuffer, char *filename)
|
||||||
{
|
{
|
||||||
unzFile *fd = NULL;
|
unzFile *fd = NULL;
|
||||||
unz_file_info info;
|
unz_file_info info;
|
||||||
|
@ -10,6 +10,6 @@
|
|||||||
|
|
||||||
extern int IsZipFile (char *buffer);
|
extern int IsZipFile (char *buffer);
|
||||||
int UnZipDVD (unsigned char *outbuffer, u64 discoffset, int length);
|
int UnZipDVD (unsigned char *outbuffer, u64 discoffset, int length);
|
||||||
int UnZipSDCARD (unsigned char *outbuffer, char *filename);
|
int UnZipFAT (unsigned char *outbuffer, char *filename);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -28,10 +28,10 @@ static int offset = 0;
|
|||||||
static int selection = 0;
|
static int selection = 0;
|
||||||
static int old_selection = 0;
|
static int old_selection = 0;
|
||||||
static int old_offset = 0;
|
static int old_offset = 0;
|
||||||
static char rootSDdir[256];
|
static char rootFATdir[256];
|
||||||
static u8 haveDVDdir = 0;
|
static u8 haveDVDdir = 0;
|
||||||
static u8 haveSDdir = 0;
|
static u8 haveFATdir = 0;
|
||||||
static u8 UseSDCARD = 0;
|
static u8 UseFAT = 0;
|
||||||
static u8 UseHistory = 0;
|
static u8 UseHistory = 0;
|
||||||
static int LoadFile (unsigned char *buffer);
|
static int LoadFile (unsigned char *buffer);
|
||||||
|
|
||||||
@ -88,11 +88,11 @@ static void ShowFiles (int offset, int selection)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* updateSDdirname
|
* updateFATdirname
|
||||||
*
|
*
|
||||||
* Update ROOT directory while browsing SDCARD
|
* Update ROOT directory while browsing SDCARD
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
static int updateSDdirname()
|
static int updateFATdirname()
|
||||||
{
|
{
|
||||||
int size=0;
|
int size=0;
|
||||||
char *test;
|
char *test;
|
||||||
@ -105,7 +105,7 @@ static int updateSDdirname()
|
|||||||
else if (strcmp(filelist[selection].filename,"..") == 0)
|
else if (strcmp(filelist[selection].filename,"..") == 0)
|
||||||
{
|
{
|
||||||
/* determine last subdirectory namelength */
|
/* determine last subdirectory namelength */
|
||||||
sprintf(temp,"%s",rootSDdir);
|
sprintf(temp,"%s",rootFATdir);
|
||||||
test= strtok(temp,"/");
|
test= strtok(temp,"/");
|
||||||
while (test != NULL)
|
while (test != NULL)
|
||||||
{
|
{
|
||||||
@ -114,33 +114,33 @@ static int updateSDdirname()
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* remove last subdirectory name */
|
/* remove last subdirectory name */
|
||||||
size = strlen(rootSDdir) - size;
|
size = strlen(rootFATdir) - size;
|
||||||
rootSDdir[size-1] = 0;
|
rootFATdir[size-1] = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sprintf(rootSDdir, "%s%s/",rootSDdir, filelist[selection].filename);
|
sprintf(rootFATdir, "%s%s/",rootFATdir, filelist[selection].filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* parseSDdirectory
|
* parseFATdirectory
|
||||||
*
|
*
|
||||||
* List files into one SDCARD directory
|
* List files into one SDCARD directory
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
static int parseSDdirectory()
|
static int parseFATdirectory()
|
||||||
{
|
{
|
||||||
int nbfiles = 0;
|
int nbfiles = 0;
|
||||||
char filename[MAXPATHLEN];
|
char filename[MAXPATHLEN];
|
||||||
struct stat filestat;
|
struct stat filestat;
|
||||||
|
|
||||||
/* open directory */
|
/* open directory */
|
||||||
DIR_ITER *dir = diropen (rootSDdir);
|
DIR_ITER *dir = diropen (rootFATdir);
|
||||||
if (dir == NULL)
|
if (dir == NULL)
|
||||||
{
|
{
|
||||||
sprintf(filename, "Error opening %s", rootSDdir);
|
sprintf(filename, "Error opening %s", rootFATdir);
|
||||||
WaitPrompt (filename);
|
WaitPrompt (filename);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -176,8 +176,8 @@ static int FileSelected()
|
|||||||
if(UseHistory)
|
if(UseHistory)
|
||||||
{
|
{
|
||||||
/* Get the parent folder for the file. */
|
/* Get the parent folder for the file. */
|
||||||
strncpy(rootSDdir, history.entries[selection].filepath, MAXJOLIET-1);
|
strncpy(rootFATdir, history.entries[selection].filepath, MAXJOLIET-1);
|
||||||
rootSDdir[MAXJOLIET-1] = '\0';
|
rootFATdir[MAXJOLIET-1] = '\0';
|
||||||
|
|
||||||
/* Get the length of the file. This has to be done
|
/* Get the length of the file. This has to be done
|
||||||
* before calling LoadFile(). */
|
* before calling LoadFile(). */
|
||||||
@ -192,7 +192,7 @@ static int FileSelected()
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Add/move the file to the top of the history. */
|
/* Add/move the file to the top of the history. */
|
||||||
if (UseSDCARD) history_add_file(rootSDdir, filelist[selection].filename);
|
if (UseFAT) history_add_file(rootFATdir, filelist[selection].filename);
|
||||||
|
|
||||||
rootdir = filelist[selection].offset;
|
rootdir = filelist[selection].offset;
|
||||||
rootdirlength = filelist[selection].length;
|
rootdirlength = filelist[selection].length;
|
||||||
@ -302,7 +302,7 @@ static int FileSelector ()
|
|||||||
if (p & PAD_BUTTON_B)
|
if (p & PAD_BUTTON_B)
|
||||||
{
|
{
|
||||||
filelist[selection].filename_offset = 0;
|
filelist[selection].filename_offset = 0;
|
||||||
if (UseSDCARD)
|
if (UseFAT)
|
||||||
{
|
{
|
||||||
if (strcmp(filelist[0].filename,"..") != 0) return 0;
|
if (strcmp(filelist[0].filename,"..") != 0) return 0;
|
||||||
}
|
}
|
||||||
@ -328,17 +328,17 @@ static int FileSelector ()
|
|||||||
{
|
{
|
||||||
/* select item #1 */
|
/* select item #1 */
|
||||||
go_up = 0;
|
go_up = 0;
|
||||||
selection = UseSDCARD ? 0 : 1;
|
selection = UseFAT ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*** This is directory ***/
|
/*** This is directory ***/
|
||||||
if (filelist[selection].flags)
|
if (filelist[selection].flags)
|
||||||
{
|
{
|
||||||
/* SDCARD directory handler */
|
/* SDCARD directory handler */
|
||||||
if (UseSDCARD)
|
if (UseFAT)
|
||||||
{
|
{
|
||||||
/* update current directory */
|
/* update current directory */
|
||||||
if (updateSDdirname())
|
if (updateFATdirname())
|
||||||
{
|
{
|
||||||
/* reinit selector (previous value is saved for one level) */
|
/* reinit selector (previous value is saved for one level) */
|
||||||
if (selection == 0)
|
if (selection == 0)
|
||||||
@ -358,12 +358,12 @@ static int FileSelector ()
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* set new entry list */
|
/* set new entry list */
|
||||||
maxfiles = parseSDdirectory();
|
maxfiles = parseFATdirectory();
|
||||||
if (!maxfiles)
|
if (!maxfiles)
|
||||||
{
|
{
|
||||||
/* quit */
|
/* quit */
|
||||||
WaitPrompt ("No files found !");
|
WaitPrompt ("No files found !");
|
||||||
haveSDdir = 0;
|
haveFATdir = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -415,9 +415,7 @@ static int FileSelector ()
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
int OpenDVD ()
|
int OpenDVD ()
|
||||||
{
|
{
|
||||||
int ret = 0;
|
UseFAT = 0;
|
||||||
|
|
||||||
UseSDCARD = 0;
|
|
||||||
UseHistory = 0;
|
UseHistory = 0;
|
||||||
|
|
||||||
if (!getpvd())
|
if (!getpvd())
|
||||||
@ -458,36 +456,41 @@ int OpenDVD ()
|
|||||||
if (haveDVDdir == 0)
|
if (haveDVDdir == 0)
|
||||||
{
|
{
|
||||||
/* don't mess with SD entries */
|
/* don't mess with SD entries */
|
||||||
haveSDdir = 0;
|
haveFATdir = 0;
|
||||||
|
|
||||||
/* reinit selector */
|
/* reinit selector */
|
||||||
rootdir = basedir;
|
rootdir = basedir;
|
||||||
old_selection = selection = offset = old_offset = 0;
|
old_selection = selection = offset = old_offset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parse root directory and get entries list */
|
||||||
|
ShowAction("Reading Directory ...");
|
||||||
if ((maxfiles = parseDVDdirectory ()))
|
if ((maxfiles = parseDVDdirectory ()))
|
||||||
{
|
{
|
||||||
ret = FileSelector ();
|
/* Select an entry */
|
||||||
haveDVDdir = 1;
|
haveDVDdir = 1;
|
||||||
|
return FileSelector ();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* no entries found */
|
||||||
|
WaitPrompt ("no files found !");
|
||||||
|
haveDVDdir = 0;
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
else ret = FileSelector ();
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* OpenSD
|
* OpenFAT
|
||||||
*
|
*
|
||||||
* Function to load a SDCARD directory and display to user.
|
* Function to load a FAT directory and display to user.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
int OpenSD ()
|
int OpenFAT (char *name)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
UseFAT = 1;
|
||||||
|
|
||||||
UseSDCARD = 1;
|
|
||||||
UseHistory = 0;
|
UseHistory = 0;
|
||||||
|
|
||||||
if (haveSDdir == 0)
|
if (haveFATdir == 0)
|
||||||
{
|
{
|
||||||
/* don't mess with DVD entries */
|
/* don't mess with DVD entries */
|
||||||
haveDVDdir = 0;
|
haveDVDdir = 0;
|
||||||
@ -496,33 +499,29 @@ int OpenSD ()
|
|||||||
old_selection = selection = offset = old_offset = 0;
|
old_selection = selection = offset = old_offset = 0;
|
||||||
|
|
||||||
/* Reset SDCARD root directory */
|
/* Reset SDCARD root directory */
|
||||||
sprintf (rootSDdir, "/genplus/roms/");
|
sprintf (rootFATdir, "%s/genplus/roms/", name);
|
||||||
|
|
||||||
/* if directory doesn't exist, use root */
|
/* if directory doesn't exist, use root */
|
||||||
DIR_ITER *dir = diropen(rootSDdir);
|
DIR_ITER *dir = diropen(rootFATdir);
|
||||||
if (dir == NULL) sprintf (rootSDdir, "fat:/");
|
if (dir == NULL) sprintf (rootFATdir, "%s/", name);
|
||||||
else dirclose(dir);
|
else dirclose(dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Parse root directory and get entries list */
|
/* Parse root directory and get entries list */
|
||||||
ShowAction("Reading Directory ...");
|
ShowAction("Reading Directory ...");
|
||||||
if ((maxfiles = parseSDdirectory ()))
|
if ((maxfiles = parseFATdirectory ()))
|
||||||
{
|
{
|
||||||
/* Select an entry */
|
/* Select an entry */
|
||||||
ret = FileSelector ();
|
haveFATdir = 1;
|
||||||
|
return FileSelector ();
|
||||||
/* memorize last entries list, actual root directory and selection for next access */
|
|
||||||
haveSDdir = 1;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* no entries found */
|
/* no entries found */
|
||||||
WaitPrompt ("no files found !");
|
WaitPrompt ("no files found !");
|
||||||
haveSDdir = 0;
|
haveFATdir = 0;
|
||||||
return 0;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -534,11 +533,11 @@ int OpenHistory()
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
UseSDCARD = 1;
|
UseFAT = 1;
|
||||||
UseHistory = 1;
|
UseHistory = 1;
|
||||||
|
|
||||||
/* don't mess with other entries */
|
/* don't mess with other entries */
|
||||||
haveSDdir = 0;
|
haveFATdir = 0;
|
||||||
haveDVDdir = 0;
|
haveDVDdir = 0;
|
||||||
|
|
||||||
/* reinit selector */
|
/* reinit selector */
|
||||||
@ -598,23 +597,23 @@ static int LoadFile (unsigned char *buffer)
|
|||||||
if (rootdirlength == 0) return 0;
|
if (rootdirlength == 0) return 0;
|
||||||
|
|
||||||
/* SDCard access */
|
/* SDCard access */
|
||||||
if (UseSDCARD)
|
if (UseFAT)
|
||||||
{
|
{
|
||||||
/* open file */
|
/* open file */
|
||||||
sprintf(fname, "%s%s",rootSDdir,filelist[selection].filename);
|
sprintf(fname, "%s%s",rootFATdir,filelist[selection].filename);
|
||||||
sdfile = fopen(fname, "rb");
|
sdfile = fopen(fname, "rb");
|
||||||
if (sdfile == NULL)
|
if (sdfile == NULL)
|
||||||
{
|
{
|
||||||
WaitPrompt ("Unable to open file!");
|
WaitPrompt ("Unable to open file!");
|
||||||
haveSDdir = 0;
|
haveFATdir = 0;
|
||||||
return 0;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ShowAction ("Loading ... Wait");
|
ShowAction ("Loading ... Wait");
|
||||||
|
|
||||||
/* Read first data chunk */
|
/* Read first data chunk */
|
||||||
if (UseSDCARD)
|
if (UseFAT)
|
||||||
{
|
{
|
||||||
fread(readbuffer, 1, 2048, sdfile);
|
fread(readbuffer, 1, 2048, sdfile);
|
||||||
}
|
}
|
||||||
@ -627,7 +626,7 @@ static int LoadFile (unsigned char *buffer)
|
|||||||
/* determine file type */
|
/* determine file type */
|
||||||
if (!IsZipFile ((char *) readbuffer))
|
if (!IsZipFile ((char *) readbuffer))
|
||||||
{
|
{
|
||||||
if (UseSDCARD)
|
if (UseFAT)
|
||||||
{
|
{
|
||||||
/* go back to file start and read file */
|
/* go back to file start and read file */
|
||||||
fseek(sdfile, 0, SEEK_SET);
|
fseek(sdfile, 0, SEEK_SET);
|
||||||
@ -662,7 +661,7 @@ static int LoadFile (unsigned char *buffer)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* unzip file */
|
/* unzip file */
|
||||||
if (UseSDCARD) return UnZipSDCARD (buffer, fname);
|
if (UseFAT) return UnZipFAT(buffer, fname);
|
||||||
else return UnZipDVD (buffer, discoffset, rootdirlength);
|
else return UnZipDVD (buffer, discoffset, rootdirlength);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -896,13 +896,24 @@ int loadmenu ()
|
|||||||
int prevmenu = menu;
|
int prevmenu = menu;
|
||||||
int ret;
|
int ret;
|
||||||
int quit = 0;
|
int quit = 0;
|
||||||
int count = 3 + dvd_on;
|
#ifdef HW_RVL
|
||||||
char item[4][25] = {
|
int count = 4 + dvd_on;
|
||||||
|
char item[5][25] = {
|
||||||
{"Load Recent"},
|
{"Load Recent"},
|
||||||
{"Load from SDCARD"},
|
{"Load from SD"},
|
||||||
|
{"Load from USB"},
|
||||||
{"Load from DVD"},
|
{"Load from DVD"},
|
||||||
{"Stop DVD Motor"}
|
{"Stop DVD Motor"}
|
||||||
};
|
};
|
||||||
|
#else
|
||||||
|
int count = 3 + dvd_on;
|
||||||
|
char item[4][25] = {
|
||||||
|
{"Load Recent"},
|
||||||
|
{"Load from SD"},
|
||||||
|
{"Load from DVD"},
|
||||||
|
{"Stop DVD Motor"}
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
menu = load_menu;
|
menu = load_menu;
|
||||||
|
|
||||||
@ -912,22 +923,38 @@ int loadmenu ()
|
|||||||
ret = domenu (&item[0], count, 0);
|
ret = domenu (&item[0], count, 0);
|
||||||
switch (ret)
|
switch (ret)
|
||||||
{
|
{
|
||||||
case -1: /*** Button B ***/
|
/*** Button B ***/
|
||||||
|
case -1:
|
||||||
quit = 1;
|
quit = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0: /*** Load Recent ***/
|
/*** Load Recent ***/
|
||||||
|
case 0:
|
||||||
load_menu = menu;
|
load_menu = menu;
|
||||||
if (OpenHistory()) return 1;
|
if (OpenHistory()) return 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1: /*** Load from SCDARD ***/
|
/*** Load from SD ***/
|
||||||
|
case 1:
|
||||||
load_menu = menu;
|
load_menu = menu;
|
||||||
if (OpenSD()) return 1;
|
if (OpenFAT("") > 0) return 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
#ifdef HW_RVL
|
||||||
|
/*** Load from USB ***/
|
||||||
case 2:
|
case 2:
|
||||||
load_menu = menu;
|
load_menu = menu;
|
||||||
|
if (OpenFAT("usb:") > 0) return 1;
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*** Load from DVD ***/
|
||||||
|
#ifdef HW_RVL
|
||||||
|
case 3:
|
||||||
|
#else
|
||||||
|
case 2:
|
||||||
|
#endif
|
||||||
|
load_menu = menu;
|
||||||
if (OpenDVD())
|
if (OpenDVD())
|
||||||
{
|
{
|
||||||
dvd_on = 1;
|
dvd_on = 1;
|
||||||
@ -935,10 +962,19 @@ int loadmenu ()
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 3: /*** Stop DVD Disc ***/
|
/*** Stop DVD Disc ***/
|
||||||
|
#ifdef HW_RVL
|
||||||
|
case 4:
|
||||||
|
#else
|
||||||
|
case 3:
|
||||||
|
#endif
|
||||||
dvd_motor_off();
|
dvd_motor_off();
|
||||||
dvd_on = 0;
|
dvd_on = 0;
|
||||||
|
#ifdef HW_RVL
|
||||||
|
count = 4 + dvd_on;
|
||||||
|
#else
|
||||||
count = 3 + dvd_on;
|
count = 3 + dvd_on;
|
||||||
|
#endif
|
||||||
menu = load_menu;
|
menu = load_menu;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ extern void set_region();
|
|||||||
extern int ManageSRAM(u8 direction, u8 device);
|
extern int ManageSRAM(u8 direction, u8 device);
|
||||||
extern int ManageState(u8 direction, u8 device);
|
extern int ManageState(u8 direction, u8 device);
|
||||||
extern int OpenDVD();
|
extern int OpenDVD();
|
||||||
extern int OpenSD();
|
extern int OpenFAT(char *name);
|
||||||
extern int OpenHistory();
|
extern int OpenHistory();
|
||||||
extern void memfile_autosave();
|
extern void memfile_autosave();
|
||||||
extern void memfile_autoload();
|
extern void memfile_autoload();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user