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:
hendricks266 2013-02-18 08:50:42 +00:00
parent 624841257c
commit 719efefbf0
4 changed files with 68 additions and 35 deletions

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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;
if (vc_loopstart != NULL) 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)
{
{ {
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,36 +107,22 @@ static void MV_GetVorbisCommentLoops(VoiceNode *voice, vorbis_comment *vc)
} }
} }
} }
if (vc_loopend != NULL)
if (voice->LoopSize > 0)
{ {
if (voice->LoopSize > 0)
{ {
char *vc_loopend = NULL; const ogg_int64_t ov_loopend = atol(vc_loopend);
if (ov_loopend > 0) // a loop ending at 0 is invalid
for (loopTagCount = 0; loopTagCount < loopEndTagCount && vc_loopend == NULL; ++loopTagCount) voice->LoopEnd = (const char *) (intptr_t) ov_loopend;
vc_loopend = vorbis_comment_query(vc, loopEndTags[loopTagCount], 0);
if (vc_loopend != NULL)
{
const ogg_int64_t ov_loopend = atol(vc_loopend);
if (ov_loopend > 0) // a loop ending at 0 is invalid
voice->LoopEnd = (const char *) (intptr_t) ov_loopend;
}
} }
}
if (voice->LoopEnd == 0) if (vc_looplength != NULL)
{
if (voice->LoopSize > 0 && voice->LoopEnd == 0)
{ {
char *vc_looplength = NULL; const ogg_int64_t ov_looplength = atol(vc_looplength);
if (ov_looplength > 0) // a loop of length 0 is invalid
for (loopTagCount = 0; loopTagCount < loopLengthTagCount && vc_looplength == NULL; ++loopTagCount) voice->LoopEnd = (const char *) ((intptr_t) ov_looplength + (intptr_t) voice->LoopStart);
vc_looplength = vorbis_comment_query(vc, loopLengthTags[loopTagCount], 0);
if (vc_looplength != NULL)
{
const ogg_int64_t ov_looplength = atol(vc_looplength);
if (ov_looplength > 0) // a loop of length 0 is invalid
voice->LoopEnd = (const char *) ((intptr_t) ov_looplength + (intptr_t) voice->LoopStart);
}
} }
} }
} }
@ -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;
} }