mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-26 01:51:15 +01:00
[Core/CDD] added compiler define option to disallow opening multiple .ogg files at the same time for platforms with limited RAM (fixes memory crash on Gamecube when using too many .ogg files)
This commit is contained in:
parent
ca143abd26
commit
c4842fb700
@ -27,7 +27,7 @@ INCLUDES := core core/m68k core/z80 core/sound core/tremor core/ntsc core/input_
|
|||||||
# options for code generation
|
# options for code generation
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
|
|
||||||
CFLAGS = -O3 -fomit-frame-pointer --param large-function-growth=800 --param inline-unit-growth=200 -Wall -Winline -Wno-strict-aliasing $(MACHDEP) $(INCLUDE) -DUSE_LIBTREMOR -DUSE_16BPP_RENDERING -DALT_RENDERER
|
CFLAGS = -O3 -fomit-frame-pointer --param large-function-growth=800 --param inline-unit-growth=200 -Wall -Winline -Wno-strict-aliasing $(MACHDEP) $(INCLUDE) -DUSE_LIBTREMOR -DDISABLE_MANY_OGG_OPEN_FILES -DUSE_16BPP_RENDERING -DALT_RENDERER
|
||||||
CXXFLAGS = $(CFLAGS)
|
CXXFLAGS = $(CFLAGS)
|
||||||
|
|
||||||
LDFLAGS = $(MACHDEP) -Wl,-Map,$(notdir $@).map
|
LDFLAGS = $(MACHDEP) -Wl,-Map,$(notdir $@).map
|
||||||
|
181
core/cd_hw/cdd.c
181
core/cd_hw/cdd.c
@ -152,6 +152,26 @@ static const char extensions[SUPPORTED_EXT][16] =
|
|||||||
|
|
||||||
static blip_t* blip[2];
|
static blip_t* blip[2];
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
static void ogg_free(int i)
|
||||||
|
{
|
||||||
|
/* clear OGG file descriptor to prevent file from being closed */
|
||||||
|
cdd.toc.tracks[i].vf.datasource = NULL;
|
||||||
|
|
||||||
|
/* close VORBIS file structure */
|
||||||
|
ov_clear(&cdd.toc.tracks[i].vf);
|
||||||
|
|
||||||
|
/* indicates that the track is a seekable VORBIS file */
|
||||||
|
cdd.toc.tracks[i].vf.seekable = 1;
|
||||||
|
|
||||||
|
/* reset file reading position */
|
||||||
|
fseek(cdd.toc.tracks[i].fd, 0, SEEK_SET);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
void cdd_init(blip_t* left, blip_t* right)
|
void cdd_init(blip_t* left, blip_t* right)
|
||||||
{
|
{
|
||||||
/* CD-DA is running by default at 44100 Hz */
|
/* CD-DA is running by default at 44100 Hz */
|
||||||
@ -206,6 +226,16 @@ int cdd_context_load(uint8 *state)
|
|||||||
int lba;
|
int lba;
|
||||||
int bufferptr = 0;
|
int bufferptr = 0;
|
||||||
|
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
load_param(&cdd.cycles, sizeof(cdd.cycles));
|
load_param(&cdd.cycles, sizeof(cdd.cycles));
|
||||||
load_param(&cdd.latency, sizeof(cdd.latency));
|
load_param(&cdd.latency, sizeof(cdd.latency));
|
||||||
load_param(&cdd.index, sizeof(cdd.index));
|
load_param(&cdd.index, sizeof(cdd.index));
|
||||||
@ -231,14 +261,19 @@ int cdd_context_load(uint8 *state)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
else if (cdd.toc.tracks[cdd.index].vf.datasource)
|
else if (cdd.toc.tracks[cdd.index].vf.seekable)
|
||||||
{
|
{
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* VORBIS file need to be opened first */
|
||||||
|
ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0);
|
||||||
|
#endif
|
||||||
|
/* VORBIS AUDIO track */
|
||||||
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else if (cdd.toc.tracks[cdd.index].fd)
|
else if (cdd.toc.tracks[cdd.index].fd)
|
||||||
{
|
{
|
||||||
/* AUDIO track */
|
/* PCM AUDIO track */
|
||||||
fseek(cdd.toc.tracks[cdd.index].fd, (lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET);
|
fseek(cdd.toc.tracks[cdd.index].fd, (lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -564,7 +599,12 @@ int cdd_load(char *filename, char *header)
|
|||||||
cdd.toc.tracks[cdd.toc.last].offset = 0;
|
cdd.toc.tracks[cdd.toc.last].offset = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close VORBIS file structure to save memory */
|
||||||
|
ogg_free(cdd.toc.last);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
@ -718,6 +758,11 @@ int cdd_load(char *filename, char *header)
|
|||||||
cdd.toc.tracks[cdd.toc.last].end -= 150;
|
cdd.toc.tracks[cdd.toc.last].end -= 150;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close VORBIS file structure to save memory */
|
||||||
|
ogg_free(cdd.toc.last);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* update TOC end */
|
/* update TOC end */
|
||||||
cdd.toc.end = cdd.toc.tracks[cdd.toc.last].end;
|
cdd.toc.end = cdd.toc.tracks[cdd.toc.last].end;
|
||||||
|
|
||||||
@ -854,23 +899,21 @@ void cdd_unload(void)
|
|||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
if (cdd.toc.tracks[i].vf.datasource)
|
if (cdd.toc.tracks[i].vf.datasource)
|
||||||
{
|
{
|
||||||
/* close VORBIS file */
|
/* close VORBIS file (if still opened) */
|
||||||
ov_clear(&cdd.toc.tracks[i].vf);
|
ov_clear(&cdd.toc.tracks[i].vf);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
|
if (cdd.toc.tracks[i].fd)
|
||||||
{
|
{
|
||||||
if (cdd.toc.tracks[i].fd)
|
/* close file */
|
||||||
{
|
fclose(cdd.toc.tracks[i].fd);
|
||||||
/* close file */
|
|
||||||
fclose(cdd.toc.tracks[i].fd);
|
|
||||||
|
|
||||||
/* detect single file images */
|
/* detect single file images */
|
||||||
if (cdd.toc.tracks[i+1].fd == cdd.toc.tracks[i].fd)
|
if (cdd.toc.tracks[i+1].fd == cdd.toc.tracks[i].fd)
|
||||||
{
|
{
|
||||||
/* exit loop */
|
/* exit loop */
|
||||||
i = cdd.toc.last;
|
i = cdd.toc.last;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1130,6 +1173,15 @@ void cdd_update(void)
|
|||||||
/* check end of current track */
|
/* check end of current track */
|
||||||
if (cdd.lba >= cdd.toc.tracks[cdd.index].end)
|
if (cdd.lba >= cdd.toc.tracks[cdd.index].end)
|
||||||
{
|
{
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
/* play next track */
|
/* play next track */
|
||||||
cdd.index++;
|
cdd.index++;
|
||||||
|
|
||||||
@ -1138,8 +1190,12 @@ void cdd_update(void)
|
|||||||
|
|
||||||
/* seek to next audio track start */
|
/* seek to next audio track start */
|
||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
if (cdd.toc.tracks[cdd.index].vf.seekable)
|
||||||
{
|
{
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* VORBIS file need to be opened first */
|
||||||
|
ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0);
|
||||||
|
#endif
|
||||||
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, -cdd.toc.tracks[cdd.index].offset);
|
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, -cdd.toc.tracks[cdd.index].offset);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1160,6 +1216,15 @@ void cdd_update(void)
|
|||||||
/* check current track limits */
|
/* check current track limits */
|
||||||
if (cdd.lba >= cdd.toc.tracks[cdd.index].end)
|
if (cdd.lba >= cdd.toc.tracks[cdd.index].end)
|
||||||
{
|
{
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
/* next track */
|
/* next track */
|
||||||
cdd.index++;
|
cdd.index++;
|
||||||
|
|
||||||
@ -1174,6 +1239,16 @@ void cdd_update(void)
|
|||||||
}
|
}
|
||||||
else if (cdd.lba < cdd.toc.tracks[cdd.index].start)
|
else if (cdd.lba < cdd.toc.tracks[cdd.index].start)
|
||||||
{
|
{
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/* previous track */
|
/* previous track */
|
||||||
cdd.index--;
|
cdd.index--;
|
||||||
|
|
||||||
@ -1209,15 +1284,23 @@ void cdd_update(void)
|
|||||||
fseek(cdd.toc.tracks[0].fd, cdd.lba * cdd.sectorSize, SEEK_SET);
|
fseek(cdd.toc.tracks[0].fd, cdd.lba * cdd.sectorSize, SEEK_SET);
|
||||||
}
|
}
|
||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
else if (cdd.toc.tracks[cdd.index].vf.datasource)
|
else if (cdd.toc.tracks[cdd.index].vf.seekable)
|
||||||
{
|
{
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* check if a new track is being played */
|
||||||
|
if (!cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
/* VORBIS file need to be opened first */
|
||||||
|
ov_open(cdd.toc.tracks[cdd.index].fd,&cdd.toc.tracks[cdd.index].vf,0,0);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
/* VORBIS AUDIO track */
|
/* VORBIS AUDIO track */
|
||||||
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (cdd.lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
ov_pcm_seek(&cdd.toc.tracks[cdd.index].vf, (cdd.lba - cdd.toc.tracks[cdd.index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else if (cdd.toc.tracks[cdd.index].fd)
|
else if (cdd.toc.tracks[cdd.index].fd)
|
||||||
{
|
{
|
||||||
/* AUDIO track */
|
/* PCM AUDIO track */
|
||||||
fseek(cdd.toc.tracks[cdd.index].fd, (cdd.lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET);
|
fseek(cdd.toc.tracks[cdd.index].fd, (cdd.lba * 2352) - cdd.toc.tracks[cdd.index].offset, SEEK_SET);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1389,11 +1472,33 @@ void cdd_process(void)
|
|||||||
/* update current LBA */
|
/* update current LBA */
|
||||||
cdd.lba = lba;
|
cdd.lba = lba;
|
||||||
|
|
||||||
/* update current track index */
|
/* get track index */
|
||||||
while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++;
|
while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++;
|
||||||
|
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* check if track index has changed */
|
||||||
|
if (index != cdd.index)
|
||||||
|
{
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* open current track VORBIS file */
|
||||||
|
if (cdd.toc.tracks[index].vf.seekable)
|
||||||
|
{
|
||||||
|
ov_open(cdd.toc.tracks[index].fd,&cdd.toc.tracks[index].vf,0,0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* update current track index */
|
||||||
cdd.index = index;
|
cdd.index = index;
|
||||||
|
|
||||||
/* stay within track limits */
|
/* stay within track limits when seeking files */
|
||||||
if (lba < cdd.toc.tracks[index].start)
|
if (lba < cdd.toc.tracks[index].start)
|
||||||
{
|
{
|
||||||
lba = cdd.toc.tracks[index].start;
|
lba = cdd.toc.tracks[index].start;
|
||||||
@ -1406,15 +1511,15 @@ void cdd_process(void)
|
|||||||
fseek(cdd.toc.tracks[0].fd, lba * cdd.sectorSize, SEEK_SET);
|
fseek(cdd.toc.tracks[0].fd, lba * cdd.sectorSize, SEEK_SET);
|
||||||
}
|
}
|
||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
else if (cdd.toc.tracks[index].vf.datasource)
|
else if (cdd.toc.tracks[index].vf.seekable)
|
||||||
{
|
{
|
||||||
/* VORBIS AUDIO track */
|
/* VORBIS AUDIO track */
|
||||||
ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[index].offset);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else if (cdd.toc.tracks[index].fd)
|
else if (cdd.toc.tracks[index].fd)
|
||||||
{
|
{
|
||||||
/* AUDIO track */
|
/* PCM AUDIO track */
|
||||||
fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET);
|
fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1459,8 +1564,30 @@ void cdd_process(void)
|
|||||||
/* update current LBA */
|
/* update current LBA */
|
||||||
cdd.lba = lba;
|
cdd.lba = lba;
|
||||||
|
|
||||||
/* update current track index */
|
/* get current track index */
|
||||||
while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++;
|
while ((cdd.toc.tracks[index].end <= lba) && (index < cdd.toc.last)) index++;
|
||||||
|
|
||||||
|
#ifdef USE_LIBTREMOR
|
||||||
|
#ifdef DISABLE_MANY_OGG_OPEN_FILES
|
||||||
|
/* check if track index has changed */
|
||||||
|
if (index != cdd.index)
|
||||||
|
{
|
||||||
|
/* close previous track VORBIS file structure to save memory */
|
||||||
|
if (cdd.toc.tracks[cdd.index].vf.datasource)
|
||||||
|
{
|
||||||
|
ogg_free(cdd.index);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* open current track VORBIS file */
|
||||||
|
if (cdd.toc.tracks[index].vf.seekable)
|
||||||
|
{
|
||||||
|
ov_open(cdd.toc.tracks[index].fd,&cdd.toc.tracks[index].vf,0,0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* update current track index */
|
||||||
cdd.index = index;
|
cdd.index = index;
|
||||||
|
|
||||||
/* stay within track limits */
|
/* stay within track limits */
|
||||||
@ -1476,15 +1603,15 @@ void cdd_process(void)
|
|||||||
fseek(cdd.toc.tracks[0].fd, lba * cdd.sectorSize, SEEK_SET);
|
fseek(cdd.toc.tracks[0].fd, lba * cdd.sectorSize, SEEK_SET);
|
||||||
}
|
}
|
||||||
#ifdef USE_LIBTREMOR
|
#ifdef USE_LIBTREMOR
|
||||||
else if (cdd.toc.tracks[index].vf.datasource)
|
else if (cdd.toc.tracks[index].vf.seekable)
|
||||||
{
|
{
|
||||||
/* VORBIS AUDIO track */
|
/* VORBIS AUDIO track */
|
||||||
ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[cdd.index].offset);
|
ov_pcm_seek(&cdd.toc.tracks[index].vf, (lba - cdd.toc.tracks[index].start) * 588 - cdd.toc.tracks[index].offset);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else if (cdd.toc.tracks[index].fd)
|
else if (cdd.toc.tracks[index].fd)
|
||||||
{
|
{
|
||||||
/* AUDIO track */
|
/* PCM AUDIO track */
|
||||||
fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET);
|
fseek(cdd.toc.tracks[index].fd, (lba * 2352) - cdd.toc.tracks[index].offset, SEEK_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user