mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Wii: Take advantage of libogc features: PNG screenshots (libpng/zlib), Ogg Vorbis audio (libtremor), and high-resolution profiling timers.
FLAC and VPX remain out in the cold. git-svn-id: https://svn.eduke32.com/eduke32@3497 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
624841257c
commit
719efefbf0
4 changed files with 68 additions and 35 deletions
|
@ -282,7 +282,6 @@ ifeq (1,$(strip $(shell expr $(GCC_MAJOR) \>= 4)))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(PLATFORM),WII)
|
ifeq ($(PLATFORM),WII)
|
||||||
override USE_LIBPNG = 0
|
|
||||||
override USE_LIBVPX = 0
|
override USE_LIBVPX = 0
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,10 @@
|
||||||
# include <mach/mach_time.h>
|
# include <mach/mach_time.h>
|
||||||
#elif defined HAVE_GTK2
|
#elif defined HAVE_GTK2
|
||||||
# include "gtkbits.h"
|
# include "gtkbits.h"
|
||||||
|
#elif defined GEKKO
|
||||||
|
# define HW_RVL
|
||||||
|
# include <ogc/lwp.h>
|
||||||
|
# include <ogc/lwp_watchdog.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined _WIN32 && !defined HAVE_GTK2 && !defined __APPLE__
|
#if !defined _WIN32 && !defined HAVE_GTK2 && !defined __APPLE__
|
||||||
|
@ -890,7 +894,9 @@ uint64_t gethiticks(void)
|
||||||
ticks = now.tv_sec;
|
ticks = now.tv_sec;
|
||||||
ticks *= 1000000000;
|
ticks *= 1000000000;
|
||||||
ticks += now.tv_nsec;
|
ticks += now.tv_nsec;
|
||||||
return (ticks);
|
return ticks;
|
||||||
|
# elif defined GEKKO
|
||||||
|
return ticks_to_nanosecs(gettime());
|
||||||
# else
|
# else
|
||||||
// Blar. This pragma is unsupported on earlier GCC versions.
|
// Blar. This pragma is unsupported on earlier GCC versions.
|
||||||
// At least we'll get a warning and a reference to this line...
|
// At least we'll get a warning and a reference to this line...
|
||||||
|
@ -914,6 +920,8 @@ uint64_t gethitickspersec(void)
|
||||||
return (1000000000LL*ti.denom)/ti.numer;
|
return (1000000000LL*ti.denom)/ti.numer;
|
||||||
# elif _POSIX_TIMERS>0 && defined _POSIX_MONOTONIC_CLOCK
|
# elif _POSIX_TIMERS>0 && defined _POSIX_MONOTONIC_CLOCK
|
||||||
return 1000000000;
|
return 1000000000;
|
||||||
|
# elif defined GEKKO
|
||||||
|
return TB_NSPERSEC;
|
||||||
# else
|
# else
|
||||||
return 1000;
|
return 1000;
|
||||||
# endif
|
# endif
|
||||||
|
|
|
@ -7,9 +7,9 @@ SRC=src
|
||||||
INC=include
|
INC=include
|
||||||
|
|
||||||
# for BUILD_ECHOFLAGS:
|
# for BUILD_ECHOFLAGS:
|
||||||
OURCOMMONFLAGS=$(BASECOMMONFLAGS) $(BUILDCOMMONFLAGS) -I$(INC) -I$(SRC)
|
OURCOMMONFLAGS=$(BASECOMMONFLAGS) $(BUILDCOMMONFLAGS) -I$(INC) -I$(SRC) -DHAVE_VORBIS
|
||||||
ifneq ($(PLATFORM),WII)
|
ifneq ($(PLATFORM),WII)
|
||||||
OURCOMMONFLAGS+= -DHAVE_VORBIS -DHAVE_FLAC
|
OURCOMMONFLAGS+= -DHAVE_FLAC
|
||||||
endif
|
endif
|
||||||
ifneq ($(RELEASE),0)
|
ifneq ($(RELEASE),0)
|
||||||
# Debugging disabled
|
# Debugging disabled
|
||||||
|
|
|
@ -37,8 +37,11 @@
|
||||||
|
|
||||||
#define OV_EXCLUDE_STATIC_CALLBACKS
|
#define OV_EXCLUDE_STATIC_CALLBACKS
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#if defined __APPLE__
|
||||||
# include <vorbis/vorbisfile.h>
|
# include <vorbis/vorbisfile.h>
|
||||||
|
#elif defined GEKKO
|
||||||
|
# define USING_TREMOR
|
||||||
|
# include <tremor/ivorbisfile.h>
|
||||||
#else
|
#else
|
||||||
# include "vorbis/vorbisfile.h"
|
# include "vorbis/vorbisfile.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -60,18 +63,41 @@ typedef struct {
|
||||||
// designed with multiple calls in mind
|
// designed with multiple calls in mind
|
||||||
static void MV_GetVorbisCommentLoops(VoiceNode *voice, vorbis_comment *vc)
|
static void MV_GetVorbisCommentLoops(VoiceNode *voice, vorbis_comment *vc)
|
||||||
{
|
{
|
||||||
|
int32_t comment;
|
||||||
uint8_t loopTagCount;
|
uint8_t loopTagCount;
|
||||||
|
|
||||||
|
const char *vc_loopstart = NULL;
|
||||||
|
const char *vc_loopend = NULL;
|
||||||
|
const char *vc_looplength = NULL;
|
||||||
|
|
||||||
if (vc == NULL)
|
if (vc == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
for (comment = 0; comment < vc->comments; ++comment)
|
||||||
{
|
{
|
||||||
char *vc_loopstart = NULL;
|
const char *entry = (const char *) vc->user_comments[comment];
|
||||||
|
if (entry != NULL && entry[0] != '\0')
|
||||||
|
{
|
||||||
|
const char *value = strchr(entry,'=');
|
||||||
|
const size_t field = value-entry;
|
||||||
|
value += 1;
|
||||||
|
|
||||||
for (loopTagCount = 0; loopTagCount < loopStartTagCount && vc_loopstart == NULL; ++loopTagCount)
|
for (loopTagCount = 0; loopTagCount < loopStartTagCount && vc_loopstart == NULL; ++loopTagCount)
|
||||||
vc_loopstart = vorbis_comment_query(vc, loopStartTags[loopTagCount], 0);
|
if (strncasecmp(entry, loopStartTags[loopTagCount], field) == 0)
|
||||||
|
vc_loopstart = value;
|
||||||
|
|
||||||
|
for (loopTagCount = 0; loopTagCount < loopEndTagCount && vc_loopend == NULL; ++loopTagCount)
|
||||||
|
if (strncasecmp(entry, loopEndTags[loopTagCount], field) == 0)
|
||||||
|
vc_loopend = value;
|
||||||
|
|
||||||
|
for (loopTagCount = 0; loopTagCount < loopLengthTagCount && vc_looplength == NULL; ++loopTagCount)
|
||||||
|
if (strncasecmp(entry, loopLengthTags[loopTagCount], field) == 0)
|
||||||
|
vc_looplength = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (vc_loopstart != NULL)
|
if (vc_loopstart != NULL)
|
||||||
|
{
|
||||||
{
|
{
|
||||||
const ogg_int64_t ov_loopstart = atol(vc_loopstart);
|
const ogg_int64_t ov_loopstart = atol(vc_loopstart);
|
||||||
if (ov_loopstart >= 0) // a loop starting at 0 is valid
|
if (ov_loopstart >= 0) // a loop starting at 0 is valid
|
||||||
|
@ -81,31 +107,18 @@ static void MV_GetVorbisCommentLoops(VoiceNode *voice, vorbis_comment *vc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (voice->LoopSize > 0)
|
|
||||||
{
|
|
||||||
{
|
|
||||||
char *vc_loopend = NULL;
|
|
||||||
|
|
||||||
for (loopTagCount = 0; loopTagCount < loopEndTagCount && vc_loopend == NULL; ++loopTagCount)
|
|
||||||
vc_loopend = vorbis_comment_query(vc, loopEndTags[loopTagCount], 0);
|
|
||||||
|
|
||||||
if (vc_loopend != NULL)
|
if (vc_loopend != NULL)
|
||||||
|
{
|
||||||
|
if (voice->LoopSize > 0)
|
||||||
{
|
{
|
||||||
const ogg_int64_t ov_loopend = atol(vc_loopend);
|
const ogg_int64_t ov_loopend = atol(vc_loopend);
|
||||||
if (ov_loopend > 0) // a loop ending at 0 is invalid
|
if (ov_loopend > 0) // a loop ending at 0 is invalid
|
||||||
voice->LoopEnd = (const char *) (intptr_t) ov_loopend;
|
voice->LoopEnd = (const char *) (intptr_t) ov_loopend;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (voice->LoopEnd == 0)
|
|
||||||
{
|
|
||||||
char *vc_looplength = NULL;
|
|
||||||
|
|
||||||
for (loopTagCount = 0; loopTagCount < loopLengthTagCount && vc_looplength == NULL; ++loopTagCount)
|
|
||||||
vc_looplength = vorbis_comment_query(vc, loopLengthTags[loopTagCount], 0);
|
|
||||||
|
|
||||||
if (vc_looplength != NULL)
|
if (vc_looplength != NULL)
|
||||||
|
{
|
||||||
|
if (voice->LoopSize > 0 && voice->LoopEnd == 0)
|
||||||
{
|
{
|
||||||
const ogg_int64_t ov_looplength = atol(vc_looplength);
|
const ogg_int64_t ov_looplength = atol(vc_looplength);
|
||||||
if (ov_looplength > 0) // a loop of length 0 is invalid
|
if (ov_looplength > 0) // a loop of length 0 is invalid
|
||||||
|
@ -113,7 +126,6 @@ static void MV_GetVorbisCommentLoops(VoiceNode *voice, vorbis_comment *vc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// callbacks
|
// callbacks
|
||||||
|
|
||||||
|
@ -209,7 +221,11 @@ static playbackstatus MV_GetNextVorbisBlock
|
||||||
|
|
||||||
bytesread = 0;
|
bytesread = 0;
|
||||||
do {
|
do {
|
||||||
|
#ifdef USING_TREMOR
|
||||||
|
bytes = ov_read(&vd->vf, vd->block + bytesread, BLOCKSIZE - bytesread, &bitstream);
|
||||||
|
#else
|
||||||
bytes = ov_read(&vd->vf, vd->block + bytesread, BLOCKSIZE - bytesread, 0, 2, 1, &bitstream);
|
bytes = ov_read(&vd->vf, vd->block + bytesread, BLOCKSIZE - bytesread, 0, 2, 1, &bitstream);
|
||||||
|
#endif
|
||||||
//fprintf(stderr, "ov_read = %d\n", bytes);
|
//fprintf(stderr, "ov_read = %d\n", bytes);
|
||||||
if (bytes > 0) {
|
if (bytes > 0) {
|
||||||
bytesread += bytes;
|
bytesread += bytes;
|
||||||
|
@ -274,6 +290,16 @@ static playbackstatus MV_GetNextVorbisBlock
|
||||||
voice->BlockLength = 0;
|
voice->BlockLength = 0;
|
||||||
voice->length = bytesread << 16; // ???: Should the literal 16 be voice->bits?
|
voice->length = bytesread << 16; // ???: Should the literal 16 be voice->bits?
|
||||||
|
|
||||||
|
#ifdef GEKKO
|
||||||
|
{
|
||||||
|
// If libtremor had the three additional ov_read() parameters that libvorbis has,
|
||||||
|
// this would be better handled using the endianness parameter.
|
||||||
|
int16_t *data = (int16_t*)(voice->sound); // assumes signed 16-bit
|
||||||
|
for (bytesread = 0; bytesread < BLOCKSIZE / 2; ++bytesread)
|
||||||
|
data[bytesread] = (data[bytesread] & 0xff) << 8 | ((data[bytesread] & 0xff00) >> 8);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return KeepPlaying;
|
return KeepPlaying;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue