[submodule "pico/sound/emu2413"]
path = pico/sound/emu2413
url = https://github.com/digital-sound-antiques/emu2413.git
+[submodule "pico/cd/libchdr"]
+ path = pico/cd/libchdr
+ url = https://github.com/rtissera/libchdr
[submodule "platform/common/minimp3"]
path = platform/common/minimp3
url = https://github.com/lieff/minimp3
endif
# default settings
+use_libchdr ?= 1
ifeq "$(ARCH)" "arm"
use_cyclone ?= 1
use_drz80 ?= 1
endif
endif
-ifneq (,$(HAVE_LIBCHDR))
+ifeq (1,$(use_libchdr))
+# yuck, cmake looks like a nightmare to embed in a multi-platform make env :-/
+# Moreover, static library linking isn't working.
+# Reference all source files directly and hope for the best. Tested on linux,
+# might not work on other platforms, and misses autodetected optimizations.
CFLAGS += -DUSE_LIBCHDR
+
+# chdr
+CHDR = pico/cd/libchdr
+CHDR_OBJS += $(CHDR)/src/libchdr_chd.o $(CHDR)/src/libchdr_cdrom.o
+CHDR_OBJS += $(CHDR)/src/libchdr_flac.o
+CHDR_OBJS += $(CHDR)/src/libchdr_bitstream.o $(CHDR)/src/libchdr_huffman.o
+
+# flac
+FLAC = $(CHDR)/deps/flac-1.3.3
+FLAC_OBJS += $(FLAC)/src/format.o $(FLAC)/src/lpc.o $(FLAC)/src/cpu.o
+FLAC_OBJS += $(FLAC)/src/metadata_object.o $(FLAC)/src/metadata_iterators.o
+FLAC_OBJS += $(FLAC)/src/bitmath.o $(FLAC)/src/bitreader.o $(FLAC)/src/md5.o
+FLAC_OBJS += $(FLAC)/src/memory.o $(FLAC)/src/fixed.o $(FLAC)/src/crc.o
+FLAC_OBJS += $(FLAC)/src/window.o $(FLAC)/src/stream_decoder.o
+$(FLAC_OBJS): CFLAGS += -DPACKAGE_VERSION=\"1.3.3\" -DFLAC__HAS_OGG=0
+$(FLAC_OBJS): CFLAGS += -DHAVE_LROUND -DHAVE_STDINT_H -DHAVE_STDLIB_H # ugh...
+
+# lzma
+LZMA = $(CHDR)/deps/lzma-19.00
+LZMA_OBJS += $(LZMA)/src/CpuArch.o $(LZMA)/src/Alloc.o $(LZMA)/src/LzmaEnc.o
+LZMA_OBJS += $(LZMA)/src/Sort.o $(LZMA)/src/LzmaDec.o $(LZMA)/src/LzFind.o
+LZMA_OBJS += $(LZMA)/src/Delta.o
+$(LZMA_OBJS): CFLAGS += -D_7ZIP_ST
+
+OBJS += $(CHDR_OBJS) $(FLAC_OBJS) $(LZMA_OBJS)
+CHDR_I = $(shell find $(CHDR) -name 'include')
+CFLAGS += $(patsubst %, -I%, $(CHDR_I)) # tsk...
endif
ifeq "$(PLATFORM_ZLIB)" "1"
asm_32xmemory = 0
endif
-#HAVE_LIBCHDR = 1
-
CFLAGS += $(fpic)
ifeq ($(findstring Haiku,$(shell uname -a)),)
esac
fi
-if check_libchdr; then
- have_libchdr="yes"
-fi
+#if check_libchdr; then
+# have_libchdr="yes"
+# MAIN_LDLIBS="-lchdr $MAIN_LDLIBS"
+#fi
# find what audio support we can compile
if [ "x$sound_drivers" = "x" ]; then
echo "libraries $MAIN_LDLIBS"
echo "linker flags $LDFLAGS"
echo "libavcodec (mp3) $have_libavcodec"
-echo "libchdr $have_libchdr"
+#echo "libchdr $have_libchdr"
# echo "ARMv7 optimizations $have_armv7"
echo "# Automatically generated by configure" > $config_mak
\r
#include "pico_int.h"\r
#include <cpu/debug.h>\r
-#include <unzip/unzip.h>\r
-#include <zlib.h>\r
\r
#ifdef USE_LIBRETRO_VFS\r
#include "file_stream_transforms.h"\r
#include "libchdr/cdrom.h"\r
#endif\r
\r
+#include <unzip/unzip.h>\r
+#include <zlib.h>\r
+\r
static int rom_alloc_size;\r
static const char *rom_exts[] = { "bin", "gen", "smd", "iso", "sms", "gg", "sg" };\r
\r
--- /dev/null
+Subproject commit cecbe84eb7ee1b0e5e558d15c2882a9d9be37794
mp3_reopen_file();
#if 0 // TODO
- if (!(Pico_mcd->s68k_regs[0x36] & 1)/* && (Pico_mcd->scd.Status_CDC & 1)*/)
+ if (!(Pico_mcd->s68k_regs[0x36] & 1))
cdd_change_track(cdd.index, cdd.lba);
#endif
}
}
-int mp3_get_offset(void) // 0-1023
-{
- unsigned int offs1024 = 0;
- int cdda_on;
-
- cdda_on = (PicoIn.AHW & PAHW_MCD) && (PicoIn.opt & POPT_EN_MCD_CDDA) && !(Pico_mcd->s68k_regs[0x36] & 1) &&
- /* TODO (Pico_mcd->scd.Status_CDC & 1) &&*/ mp3_handle >= 0;
-
- if (cdda_on) {
- offs1024 = mp3_src_pos << 7;
- offs1024 /= mp3_src_size >> 3;
- }
- lprintf("offs1024=%u (%i/%i)\n", offs1024, mp3_src_pos, mp3_src_size);
-
- return offs1024;
-}
-
-
void mp3_reopen_file(void)
{
if (mp3_fname == NULL) return;
sceKernelIcacheInvalidateRange(addr, size);
return 0;
}
+
+/* stubs for libflac (embedded in libchdr) */
+int chown(const char *pathname, uid_t owner, gid_t group) { return -1; }
+int chmod(const char *pathname, mode_t mode) { return -1; }
+int utime(const char *filename, const struct utimbuf *times) { return -1; }
+int fseeko64(FILE *stream, _off64_t offset, int whence)
+ { return fseeko(stream, offset, whence); }
+_off64_t ftello64(FILE *stream)
+ { return ftello(stream); }
+int posix_memalign(void **memptr, size_t alignment, size_t size)
+ { *memptr = memalign(alignment, size); return 0; }