[v2] C++ backend stuff, enable ronan w/ asm backend

This commit is contained in:
PoroCYon 2019-07-28 23:08:08 +02:00
parent f41e000eaf
commit 10dd1751b5
11 changed files with 41 additions and 9 deletions

View File

@ -1,6 +1,8 @@
# C++ version is more stable, but might be larger
USE_CXX_VERSION ?= 1
USE_CXX_VERSION ?= 0
# v2m-player submodule instead of fr_public
USE_CXX_CLEANUP_VERSION ?= 0
# you most likely want this
USE_RONAN ?= 1
@ -20,13 +22,17 @@ fr_public/README.md:
@>&2 echo " git submodule update --init --recursive"
@false
CFLAGS := -m32
CFLAGS := -m32 -DNDEBUG -fno-asynchronous-unwind-tables -fno-stack-protector
ASFLAGS := -felf32
ifeq ($(USE_CXX_VERSION),0)
CFLAGS += -I libv2/
else
ifeq ($(USE_CXX_CLEANUP_VERSION),0)
CFLAGS += -I libv2/ -DUSE_CXX_VERSION
else
CFLAGS += -I v2m-player/src/ -DUSE_CXX_VERSION
endif
endif
ifneq ($(USE_RONAN),0)
CFLAGS += -DRONAN
ASFLAGS += -DRONAN
@ -38,11 +44,20 @@ ASFLAGS += -g
obj/lplayer.o: src/lplayer.cpp obj/
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/v2mplayer.o: libv2/v2mplayer.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/synth.o: libv2/synth.asm obj/ fr_public/README.md
$(NASM) $(ASFLAGS) -o "$@" "$<"
obj/v2mconv.o: libv2/v2mconv.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/v2mplayer.o: libv2/v2mplayer.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/ronan.o: libv2/ronan.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/synth_core.o: libv2/synth_core.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/sounddef.o: libv2/sounddef.cpp obj/ fr_public/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/pv2mconv.o: v2m-player/src/v2mconv.cpp obj/ v2m-player/README.md
$(CXX) $(CFLAGS) -o "$@" -c "$<"
obj/pv2mplayer.o: v2m-player/src/v2mplayer.cpp obj/ v2m-player/README.md
@ -64,10 +79,16 @@ obj/v2m-%.o: obj/v2m-%.asm
$(NASM) -g -f elf32 -o "$@" "$<"
ifeq ($(USE_CXX_VERSION),0)
bin/lplayer-%: obj/lplayer.o obj/synth.o obj/v2mplayer.o obj/v2m-%.o bin/
bin/lplayer-%: obj/lplayer.o obj/synth.o obj/ronan.o obj/v2mconv.o \
obj/v2mplayer.o obj/sounddef.o obj/v2m-%.o bin/
else
ifeq ($(USE_CXX_CLEANUP_VERSION),0)
bin/lplayer-%: obj/lplayer.o obj/synth_core.o obj/v2mconv.o obj/v2mplayer.o \
obj/ronan.o obj/sounddef.o obj/v2m-%.o bin/
else
bin/lplayer-%: obj/lplayer.o obj/psynth_core.o obj/pv2mconv.o obj/pv2mplayer.o \
obj/pronan.o obj/psounddef.o obj/v2m-%.o bin/
endif
endif
$(CXX) -Wl,--gc-sections $(CFLAGS) -o "$@" $(filter-out bin/,$^)

@ -1 +1 @@
Subproject commit 280b89ad3668d8e65f5b45518da9244bf1e0a630
Subproject commit 5a9bddc43a01d1c17729dadb79910732dd6db371

1
v2/libv2/phonemtab.h Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/phonemtab.h

1
v2/libv2/ronan.cpp Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/ronan.cpp

1
v2/libv2/sounddef.cpp Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/sounddef.cpp

1
v2/libv2/sounddef.h Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/sounddef.h

1
v2/libv2/synth_core.cpp Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/synth_core.cpp

1
v2/libv2/types.h Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/types.h

1
v2/libv2/v2mconv.cpp Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/v2mconv.cpp

1
v2/libv2/v2mconv.h Symbolic link
View File

@ -0,0 +1 @@
../fr_public/v2/v2mconv.h

View File

@ -4,7 +4,9 @@
#include <stdio.h>
#include <unistd.h>
#define AUTOCONVERT
#ifdef USE_CXX_VERSION
//#define AUTOCONVERT
#endif
#include "v2mplayer.h"
#include "synth.h"
@ -17,7 +19,7 @@
// automatically convert the module to the newest format version
extern "C" const uint8_t theTune[];
extern "C" /*const*/ uint8_t theTune[];
extern "C" const size_t theTune_size;
#define BUFFERLEN (8192) /* arbitrary */
@ -26,12 +28,13 @@ static V2MPlayer player;
static float output_buffer[BUFFERLEN*8];
#ifdef AUTOCONVERT
static uint8_t* check_and_convert(const uint8_t* tune, size_t len) {
static uint8_t* check_and_convert(/*const*/ uint8_t* tune, size_t len) {
if (tune[2] != 0 || tune[3] != 0) {
fprintf(stderr, "Invalid input file\n");
return NULL;
}
int v = CheckV2MVersion(tune, len);
if (!v) return tune; // version is the latest one
if (v < 0) {
fprintf(stderr, "Invalid input file (version not recognised)\n");
return NULL;