[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; }