mirror of
https://github.com/vgmstream/vgmstream.git
synced 2025-01-17 23:36:41 +01:00
commit
8ce5de5835
@ -14,8 +14,8 @@ libg7221_decode.a: libg7221_decode.def
|
|||||||
libg719_decode.a: libg719_decode.def
|
libg719_decode.a: libg719_decode.def
|
||||||
$(DLLTOOL) -d libg719_decode.def -l libg719_decode.a
|
$(DLLTOOL) -d libg719_decode.def -l libg719_decode.a
|
||||||
|
|
||||||
at3plusdecoder.a: at3plusdecoder.def
|
libat3plusdecoder.a: at3plusdecoder.def
|
||||||
$(DLLTOOL) -d at3plusdecoder.def -l at3plusdecoder.a
|
$(DLLTOOL) -d at3plusdecoder.def -l libat3plusdecoder.a
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f libvorbis.a libmpg123-0.a libg7221_decode.a libat3plusdecoder.a
|
rm -f libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a libat3plusdecoder.a
|
||||||
|
@ -16,7 +16,7 @@ VGMSTREAM * init_vgmstream_adx(STREAMFILE *streamFile) {
|
|||||||
off_t stream_offset;
|
off_t stream_offset;
|
||||||
uint16_t version_signature;
|
uint16_t version_signature;
|
||||||
int loop_flag=0;
|
int loop_flag=0;
|
||||||
int channel_count;
|
int channel_count, i, j, channel_header_spacing;
|
||||||
int32_t loop_start_sample=0;
|
int32_t loop_start_sample=0;
|
||||||
int32_t loop_end_sample=0;
|
int32_t loop_end_sample=0;
|
||||||
meta_t header_type;
|
meta_t header_type;
|
||||||
@ -25,14 +25,27 @@ VGMSTREAM * init_vgmstream_adx(STREAMFILE *streamFile) {
|
|||||||
char filename[PATH_LIMIT];
|
char filename[PATH_LIMIT];
|
||||||
int coding_type = coding_CRI_ADX;
|
int coding_type = coding_CRI_ADX;
|
||||||
uint16_t xor_start=0,xor_mult=0,xor_add=0;
|
uint16_t xor_start=0,xor_mult=0,xor_add=0;
|
||||||
|
/* Xenoblade Chronicles 3D uses an adx extension as with
|
||||||
|
the Wii version, but it's actually DSP ADPCM. Adding
|
||||||
|
this flag to account for it. */
|
||||||
|
int xb3d_flag = 0;
|
||||||
|
|
||||||
/* check extension, case insensitive */
|
/* check extension, case insensitive */
|
||||||
streamFile->get_name(streamFile,filename,sizeof(filename));
|
streamFile->get_name(streamFile,filename,sizeof(filename));
|
||||||
if (strcasecmp("adx",filename_extension(filename))) goto fail;
|
if (strcasecmp("adx",filename_extension(filename))) goto fail;
|
||||||
|
|
||||||
/* check first 2 bytes */
|
/* check first 2 bytes */
|
||||||
if ((uint16_t)read_16bitBE(0,streamFile)!=0x8000) goto fail;
|
if ((uint16_t)read_16bitBE(0,streamFile)!=0x8000) {
|
||||||
|
if (read_8bit(0,streamFile)!=2)goto fail;
|
||||||
|
else {xb3d_flag = 1; coding_type = coding_NGC_DSP;}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (xb3d_flag) {
|
||||||
|
channel_count = read_32bitLE(0, streamFile);
|
||||||
|
loop_flag = read_16bitLE(0x6e, streamFile);
|
||||||
|
channel_header_spacing = 0x34;
|
||||||
|
}
|
||||||
|
else {
|
||||||
/* get stream offset, check for CRI signature just before */
|
/* get stream offset, check for CRI signature just before */
|
||||||
stream_offset = (uint16_t)read_16bitBE(2,streamFile) + 4;
|
stream_offset = (uint16_t)read_16bitBE(2,streamFile) + 4;
|
||||||
if ((uint16_t)read_16bitBE(stream_offset-6,streamFile)!=0x2863 ||/* "(c" */
|
if ((uint16_t)read_16bitBE(stream_offset-6,streamFile)!=0x2863 ||/* "(c" */
|
||||||
@ -111,10 +124,35 @@ VGMSTREAM * init_vgmstream_adx(STREAMFILE *streamFile) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
channel_count = read_8bit(7,streamFile);
|
channel_count = read_8bit(7,streamFile);
|
||||||
|
}
|
||||||
vgmstream = allocate_vgmstream(channel_count,loop_flag);
|
vgmstream = allocate_vgmstream(channel_count,loop_flag);
|
||||||
if (!vgmstream) goto fail;
|
if (!vgmstream) goto fail;
|
||||||
|
|
||||||
/* fill in the vital statistics */
|
/* fill in the vital statistics */
|
||||||
|
|
||||||
|
if (xb3d_flag) {
|
||||||
|
for (j=0;j<vgmstream->channels;j++) {
|
||||||
|
for (i=0;i<16;i++) {
|
||||||
|
vgmstream->ch[j].adpcm_coef[i]=read_16bitLE(4+j*channel_header_spacing+i*2,streamFile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vgmstream->layout_type = layout_none;
|
||||||
|
vgmstream->coding_type = coding_type;
|
||||||
|
vgmstream->meta_type = meta_XB3D_ADX;
|
||||||
|
vgmstream->sample_rate = read_32bitLE(0x70,streamFile);
|
||||||
|
vgmstream->num_samples = read_32bitLE(0x74, streamFile);
|
||||||
|
vgmstream->loop_start_sample = read_32bitLE(0x78, streamFile);
|
||||||
|
vgmstream->loop_end_sample = read_32bitLE(0x7c, streamFile);
|
||||||
|
|
||||||
|
for (i = 0; i<channel_count; i++) {
|
||||||
|
vgmstream->ch[i].streamfile = streamFile->open(streamFile, filename, 0x1000);
|
||||||
|
vgmstream->ch[i].channel_start_offset = vgmstream->ch[i].offset
|
||||||
|
= read_32bitLE(0x34+i*channel_header_spacing, streamFile);
|
||||||
|
if (!vgmstream->ch[i].streamfile) goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
vgmstream->num_samples = read_32bitBE(0xc,streamFile);
|
vgmstream->num_samples = read_32bitBE(0xc,streamFile);
|
||||||
vgmstream->sample_rate = read_32bitBE(8,streamFile);
|
vgmstream->sample_rate = read_32bitBE(8,streamFile);
|
||||||
/* channels and loop flag are set by allocate_vgmstream */
|
/* channels and loop flag are set by allocate_vgmstream */
|
||||||
@ -129,7 +167,6 @@ VGMSTREAM * init_vgmstream_adx(STREAMFILE *streamFile) {
|
|||||||
vgmstream->meta_type = header_type;
|
vgmstream->meta_type = header_type;
|
||||||
|
|
||||||
vgmstream->interleave_block_size=18;
|
vgmstream->interleave_block_size=18;
|
||||||
|
|
||||||
/* calculate filter coefficients */
|
/* calculate filter coefficients */
|
||||||
{
|
{
|
||||||
double x,y,z,a,b,c;
|
double x,y,z,a,b,c;
|
||||||
@ -178,7 +215,7 @@ VGMSTREAM * init_vgmstream_adx(STREAMFILE *streamFile) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return vgmstream;
|
return vgmstream;
|
||||||
|
|
||||||
/* clean up anything we may have opened */
|
/* clean up anything we may have opened */
|
||||||
|
23
src/util.c
23
src/util.c
@ -127,6 +127,29 @@ void make_wav_header(uint8_t * buf, int32_t sample_count, int32_t sample_rate, i
|
|||||||
put_32bitLE(buf+0x28, (int32_t)bytecount);
|
put_32bitLE(buf+0x28, (int32_t)bytecount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void make_smpl_chunk(uint8_t * buf, int32_t loop_start, int32_t loop_end) {
|
||||||
|
int i;
|
||||||
|
/* RIFF header */
|
||||||
|
memcpy(buf+0, "smpl", 4);
|
||||||
|
/* size of RIFF */
|
||||||
|
put_32bitLE(buf+4, 0x3c);
|
||||||
|
|
||||||
|
for (i = 0; i < 7; i++)
|
||||||
|
put_32bitLE(buf+8 + i * 4, 0);
|
||||||
|
|
||||||
|
put_32bitLE(buf+36, 1);
|
||||||
|
|
||||||
|
for (i = 0; i < 3; i++)
|
||||||
|
put_32bitLE(buf+40 + i * 4, 0);
|
||||||
|
|
||||||
|
put_32bitLE(buf+52, loop_start);
|
||||||
|
put_32bitLE(buf+56, loop_end);
|
||||||
|
put_32bitLE(buf+60, 0);
|
||||||
|
put_32bitLE(buf+64, 0);
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void swap_samples_le(sample *buf, int count) {
|
void swap_samples_le(sample *buf, int count) {
|
||||||
int i;
|
int i;
|
||||||
for (i=0;i<count;i++) {
|
for (i=0;i<count;i++) {
|
||||||
|
@ -63,6 +63,7 @@ static inline int clamp16(int32_t val) {
|
|||||||
/* make a header for PCM .wav */
|
/* make a header for PCM .wav */
|
||||||
/* buffer must be 0x2c bytes */
|
/* buffer must be 0x2c bytes */
|
||||||
void make_wav_header(uint8_t * buf, int32_t sample_count, int32_t sample_rate, int channels);
|
void make_wav_header(uint8_t * buf, int32_t sample_count, int32_t sample_rate, int channels);
|
||||||
|
void make_smpl_chunk(uint8_t * buf, int32_t loop_start, int32_t loop_end);
|
||||||
void swap_samples_le(sample *buf, int count);
|
void swap_samples_le(sample *buf, int count);
|
||||||
|
|
||||||
void concatn(int length, char * dst, const char * src);
|
void concatn(int length, char * dst, const char * src);
|
||||||
|
@ -3148,6 +3148,9 @@ void describe_vgmstream(VGMSTREAM * vgmstream, char * desc, int length) {
|
|||||||
case meta_MCA:
|
case meta_MCA:
|
||||||
snprintf(temp,TEMPSIZE,"Capcom MCA Header");
|
snprintf(temp,TEMPSIZE,"Capcom MCA Header");
|
||||||
break;
|
break;
|
||||||
|
case meta_XB3D_ADX:
|
||||||
|
snprintf(temp, TEMPSIZE,"Xenoblade 3D ADX Header");
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
snprintf(temp,TEMPSIZE,"THEY SHOULD HAVE SENT A POET");
|
snprintf(temp,TEMPSIZE,"THEY SHOULD HAVE SENT A POET");
|
||||||
}
|
}
|
||||||
|
@ -580,6 +580,7 @@ typedef enum {
|
|||||||
meta_3DS_IDSP, // Nintendo 3DS IDSP
|
meta_3DS_IDSP, // Nintendo 3DS IDSP
|
||||||
meta_G1L, // Tecmo Koei G1L
|
meta_G1L, // Tecmo Koei G1L
|
||||||
meta_MCA, // Capcom MCA "MADP"
|
meta_MCA, // Capcom MCA "MADP"
|
||||||
|
meta_XB3D_ADX, // Xenoblade Chronicles 3D ADX
|
||||||
#ifdef VGM_USE_MP4V2
|
#ifdef VGM_USE_MP4V2
|
||||||
meta_MP4,
|
meta_MP4,
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
export SHELL = /bin/sh
|
export SHELL = /bin/sh
|
||||||
export CFLAGS=-Wall -O3 -I../ext_includes
|
export CFLAGS=-Wall -O3 -I../ext_includes -DUSE_ALLOCA -DVGM_USE_MAIATRAC3PLUS
|
||||||
export LDFLAGS=-L../src -L ../ext_libs -lvgmstream -lvorbisfile -lmpg123 -lm
|
# -DVGM_USE_G7221 -DVGM_USE_G719
|
||||||
|
export LDFLAGS=-L../src -L ../ext_libs -lvgmstream -lvorbisfile -lmpg123 -lat3plusdecoder -lpthread -lm
|
||||||
|
#-lg719_decode -lg7221_decode -lsiren_decode
|
||||||
export CC=gcc
|
export CC=gcc
|
||||||
export AR=ar
|
export AR=ar
|
||||||
export STRIP=strip
|
export STRIP=strip
|
||||||
@ -8,8 +10,8 @@ export STRIP=strip
|
|||||||
.PHONY: libvgmstream.a
|
.PHONY: libvgmstream.a
|
||||||
|
|
||||||
test.exe: libvgmstream.a
|
test.exe: libvgmstream.a
|
||||||
$(CC) $(CFLAGS) $(LDFLAGS) "-DVERSION=\"`../version.sh`\"" test.c $(LDFLAGS) -o test
|
$(CC) $(CFLAGS) $(LDFLAGS) "-DVERSION=\"`../version.sh`\"" test.c $(LDFLAGS) -o vgmstream
|
||||||
$(STRIP) test
|
$(STRIP) vgmstream
|
||||||
|
|
||||||
libvgmstream.a:
|
libvgmstream.a:
|
||||||
$(MAKE) -C ../src $@
|
$(MAKE) -C ../src $@
|
||||||
|
@ -8,9 +8,9 @@ export STRIP=i586-mingw32msvc-strip
|
|||||||
#export AR=i686-w64-mingw32-ar
|
#export AR=i686-w64-mingw32-ar
|
||||||
#export STRIP=i686-w64-mingw32-strip
|
#export STRIP=i686-w64-mingw32-strip
|
||||||
|
|
||||||
.PHONY: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a at3plusdecoder.a
|
.PHONY: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a libat3plusdecoder.a
|
||||||
|
|
||||||
test.exe: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a at3plusdecoder.a
|
test.exe: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a libat3plusdecoder.a
|
||||||
$(CC) $(CFLAGS) "-DVERSION=\"`../version.sh`\"" test.c $(LDFLAGS) -o test.exe
|
$(CC) $(CFLAGS) "-DVERSION=\"`../version.sh`\"" test.c $(LDFLAGS) -o test.exe
|
||||||
$(STRIP) test.exe
|
$(STRIP) test.exe
|
||||||
|
|
||||||
@ -29,7 +29,8 @@ libg7221_decode.a:
|
|||||||
libg719_decode.a:
|
libg719_decode.a:
|
||||||
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
||||||
|
|
||||||
at3plusdecoder.a:
|
libat3plusdecoder.a:
|
||||||
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f test.exe
|
rm -f test.exe
|
||||||
|
17
test/test.c
17
test/test.c
@ -29,12 +29,12 @@ void usage(const char * name) {
|
|||||||
" -x: decode and print adxencd command line to encode as ADX\n"
|
" -x: decode and print adxencd command line to encode as ADX\n"
|
||||||
" -g: decode and print oggenc command line to encode as OGG\n"
|
" -g: decode and print oggenc command line to encode as OGG\n"
|
||||||
" -b: decode and print batch variable commands\n"
|
" -b: decode and print batch variable commands\n"
|
||||||
|
" -L: append a smpl chunk and create a looping wav\n"
|
||||||
" -e: force end-to-end looping\n"
|
" -e: force end-to-end looping\n"
|
||||||
" -E: force end-to-end looping even if file has real loop points\n"
|
" -E: force end-to-end looping even if file has real loop points\n"
|
||||||
" -r outfile2.wav: output a second time after resetting\n"
|
" -r outfile2.wav: output a second time after resetting\n"
|
||||||
" -2 N: only output the Nth (first is 0) set of stereo channels\n"
|
" -2 N: only output the Nth (first is 0) set of stereo channels\n"
|
||||||
,name);
|
,name);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char ** argv) {
|
int main(int argc, char ** argv) {
|
||||||
@ -56,13 +56,14 @@ int main(int argc, char ** argv) {
|
|||||||
int metaonly = 0;
|
int metaonly = 0;
|
||||||
int adxencd = 0;
|
int adxencd = 0;
|
||||||
int oggenc = 0;
|
int oggenc = 0;
|
||||||
|
int lwav = 0;
|
||||||
int batchvar = 0;
|
int batchvar = 0;
|
||||||
int only_stereo = -1;
|
int only_stereo = -1;
|
||||||
double loop_count = 2.0;
|
double loop_count = 2.0;
|
||||||
double fade_seconds = 10.0;
|
double fade_seconds = 10.0;
|
||||||
double fade_delay_seconds = 0.0;
|
double fade_delay_seconds = 0.0;
|
||||||
|
|
||||||
while ((opt = getopt(argc, argv, "o:l:f:d:ipPcmxeEr:gb2:")) != -1) {
|
while ((opt = getopt(argc, argv, "o:l:f:d:ipPcmxeLEr:gb2:")) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'o':
|
case 'o':
|
||||||
outfilename = optarg;
|
outfilename = optarg;
|
||||||
@ -107,6 +108,9 @@ int main(int argc, char ** argv) {
|
|||||||
case 'E':
|
case 'E':
|
||||||
really_force_loop = 1;
|
really_force_loop = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'L':
|
||||||
|
lwav = 1;
|
||||||
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
reset_outfilename = optarg;
|
reset_outfilename = optarg;
|
||||||
break;
|
break;
|
||||||
@ -294,6 +298,15 @@ int main(int argc, char ** argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!play && lwav && s->loop_flag) { // Writing smpl chuck
|
||||||
|
make_smpl_chunk((uint8_t*)buf, s->loop_start_sample, s->loop_end_sample);
|
||||||
|
fwrite(buf,1,0x44,outfile);
|
||||||
|
fseek(outfile, 4, SEEK_SET);
|
||||||
|
|
||||||
|
size_t bytecount = len*s->channels*sizeof(sample);
|
||||||
|
put_32bitLE((uint8_t*)buf, (int32_t)(bytecount+0x2c+52));
|
||||||
|
fwrite(buf,1,0x4,outfile);
|
||||||
|
}
|
||||||
fclose(outfile); outfile = NULL;
|
fclose(outfile); outfile = NULL;
|
||||||
|
|
||||||
#ifdef PROFILE_STREAMFILE
|
#ifdef PROFILE_STREAMFILE
|
||||||
|
@ -13,7 +13,7 @@ export WINDRES=i586-mingw32msvc-windres
|
|||||||
|
|
||||||
.PHONY: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a at3plusdecoder.a
|
.PHONY: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a at3plusdecoder.a
|
||||||
|
|
||||||
in_vgmstream.dll: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a in_vgmstream.c resource.o
|
in_vgmstream.dll: libvgmstream.a libvorbis.a libmpg123-0.a libg7221_decode.a libg719_decode.a libat3plusdecoder.a in_vgmstream.c resource.o
|
||||||
$(CC) -shared -static-libgcc $(CFLAGS) "-DVERSION=\"`../version.sh`\"" in_vgmstream.c resource.o $(LDFLAGS) -o in_vgmstream.dll
|
$(CC) -shared -static-libgcc $(CFLAGS) "-DVERSION=\"`../version.sh`\"" in_vgmstream.c resource.o $(LDFLAGS) -o in_vgmstream.dll
|
||||||
$(STRIP) in_vgmstream.dll
|
$(STRIP) in_vgmstream.dll
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ libg7221_decode.a:
|
|||||||
libg719_decode.a:
|
libg719_decode.a:
|
||||||
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
||||||
|
|
||||||
at3plusdecoder.a:
|
libat3plusdecoder.a:
|
||||||
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
$(MAKE) -C ../ext_libs -f Makefile.mingw $@
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user